/* ============================================================
   Phone Service Beverburg – shared styles (light, Apple-clean)
   ============================================================ */
:root{
  --bg:#FBFBFD;            /* apple off-white */
  --bg-2:#F5F5F7;          /* light grey section */
  --surface:#FFFFFF;
  --ink:#1D1D1F;           /* apple near-black */
  --ink-soft:#6E6E73;      /* apple secondary grey */
  --ink-faint:#86868B;
  --line:#E5E5EA;
  --line-soft:#F0F0F2;
  --accent:#2B2B2E;        /* anthracite – buttons (white text readable) */
  --accent-deep:#1D1D1F;   /* hover (near-black) */
  --accent-soft:#EAF3F8;   /* very light wash of the logo blue */
  --accent-bright:#C6DFEC; /* exact logo blue – fills & highlights */
  --accent-text:#3E6E8A;   /* readable steel-blue from logo family – for accent TEXT, links, eyebrows */
  --steel:#86868B;         /* logo grey family */
  --ok:#34C759;
  --shadow:0 18px 50px -22px rgba(0,0,0,.20);
  --shadow-sm:0 6px 20px -10px rgba(0,0,0,.16);
  --r:22px;
  --r-sm:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.5;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-weight:600;line-height:1.07;letter-spacing:-.025em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.02em;color:var(--accent-text);text-transform:none}

/* ===== NAV ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,251,253,.72);backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;transition:border-color .3s;
}
header.scrolled{border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-weight:600;font-size:1.02rem;letter-spacing:-.01em}
.brand img{width:34px;height:34px;border-radius:50%}
.brand .bt small{display:block;font-size:.7rem;font-weight:400;color:var(--ink-soft);letter-spacing:0}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.9rem;color:var(--ink-soft);font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-21px;height:2px;background:var(--ink)}
.nav-cta{
  background:var(--accent);color:#fff !important;padding:9px 18px;border-radius:100px;
  font-size:.86rem;font-weight:500;transition:background .2s,transform .2s;
}
.nav-cta:hover{background:var(--accent-deep);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:52px;padding:0 28px;min-width:200px;border-radius:100px;
  font-weight:500;font-size:1rem;cursor:pointer;border:none;text-align:center;white-space:nowrap;
  transition:transform .2s,box-shadow .2s,background .2s,border-color .2s,color .2s;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 12px 30px -14px rgba(29,29,31,.45)}
.btn-primary:hover{background:var(--accent-deep);transform:translateY(-2px)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink-faint);transform:translateY(-2px)}
.btn-wa{background:#25D366;color:#0a3d1f}
.btn-wa:hover{background:#1eb858;transform:translateY(-2px)}
.btn-text{color:var(--accent-text);font-weight:500;display:inline-flex;align-items:center;gap:5px;font-size:.98rem}
.btn-text:hover{color:#2E5468}
.btn-text .arr{transition:transform .2s}
.btn-text:hover .arr{transform:translateX(3px)}

/* ===== SECTIONS ===== */
section{padding:100px 0}
.sec-head{max-width:680px;margin:0 auto 60px;text-align:center}
.sec-head.left{margin-left:0;text-align:left}
.sec-head h2{font-size:clamp(2rem,4vw,3.1rem);margin:14px 0 16px}
.sec-head p{font-size:1.16rem;color:var(--ink-soft);font-weight:400}

/* ===== PAGE HERO (sub-pages) ===== */
.page-hero{padding:88px 0 56px;text-align:center}
.page-hero .eyebrow{display:block;margin-bottom:14px}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:20px}
.page-hero p{font-size:1.2rem;color:var(--ink-soft);max-width:48ch;margin:0 auto;font-weight:400}

/* ===== CARDS GRID ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;
  transition:transform .3s,box-shadow .3s;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ic{
  width:52px;height:52px;border-radius:14px;background:var(--accent-soft);
  display:grid;place-items:center;font-size:1.45rem;margin-bottom:20px;
}
.card h3{font-size:1.3rem;margin-bottom:9px}
.card p{color:var(--ink-soft);font-size:.98rem;font-weight:400}
.card .price{margin-top:16px;font-size:.92rem;color:var(--ink-faint);font-weight:500}

/* ===== TRUST ROW ===== */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.trust-item b{font-size:2.6rem;font-weight:600;display:block;letter-spacing:-.03em}
.trust-item span{color:var(--ink-soft);font-size:1rem}

/* ===== STEPS ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{padding-top:20px;border-top:2px solid var(--line)}
.step::before{counter-increment:s;content:"0" counter(s);font-size:1rem;color:var(--accent);font-weight:600;display:block;margin-bottom:12px}
.step h3{font-size:1.18rem;margin-bottom:8px}
.step p{color:var(--ink-soft);font-size:.95rem;font-weight:400}

/* ===== PANELS / SPLIT ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:42px 40px}
.panel h3{font-size:1.4rem;margin-bottom:26px;display:flex;align-items:center;gap:10px}
.hours-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line-soft);font-size:1rem}
.hours-row:last-child{border-bottom:none}
.hours-row.today{background:var(--accent-soft);margin:0 -16px;padding:13px 16px;border-radius:10px;border-bottom:none;font-weight:600}
.hours-row span:last-child{color:var(--ink-soft)}
.hours-row.today span:first-child{color:var(--accent-text)}
.hours-row.closed span:last-child{color:#C0392B}
.contact-item{display:flex;align-items:center;gap:16px;padding:17px 0;border-bottom:1px solid var(--line-soft)}
.contact-item:last-child{border-bottom:none}
.contact-item .ic{width:48px;height:48px;border-radius:13px;background:var(--accent-soft);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.contact-item small{display:block;font-size:.76rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.05em}
.contact-item b{font-weight:600;font-size:1.04rem}
.contact-item a:hover{color:var(--accent-text)}

/* ===== PRICE TABLE ===== */
.ptable{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ptable-row{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-bottom:1px solid var(--line-soft);transition:background .2s}
.ptable-row:last-child{border-bottom:none}
.ptable-row:hover{background:var(--bg-2)}
.ptable-row .l b{font-weight:600;font-size:1.04rem}
.ptable-row .l small{display:block;color:var(--ink-soft);font-size:.88rem;margin-top:2px}
.ptable-row .r{font-weight:600;color:var(--ink);white-space:nowrap;font-size:1.02rem}
.ptable-row .r em{font-style:normal;color:var(--ink-faint);font-weight:400}

/* ===== FAQ ===== */
.faq{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:24px 0;font-family:inherit;font-size:1.12rem;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;letter-spacing:-.01em}
.faq-q .plus{flex-shrink:0;width:24px;height:24px;position:relative;transition:transform .3s}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--ink-soft);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-q .plus::before{width:13px;height:1.5px}
.faq-q .plus::after{width:1.5px;height:13px;transition:transform .3s,opacity .3s}
.faq-item.open .plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft)}
.faq-a p{padding:0 0 24px;max-width:66ch;font-weight:400}

/* ===== CTA BAND ===== */
.cta-band{background:var(--ink);color:#fff;border-radius:28px;padding:70px 56px;text-align:center}
.cta-band h2{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:16px}
.cta-band p{color:rgba(255,255,255,.7);font-size:1.16rem;max-width:48ch;margin:0 auto 32px;font-weight:400}
.cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== FOOTER ===== */
footer{background:var(--bg-2);border-top:1px solid var(--line);padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.foot-brand .brand{margin-bottom:15px}
.foot-brand p{color:var(--ink-soft);font-size:.92rem;max-width:32ch;font-weight:400}
.foot-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:14px;font-weight:600}
.foot-col a{display:block;color:var(--ink-soft);font-size:.94rem;padding:5px 0;transition:color .2s;font-weight:400}
.foot-col a:hover{color:var(--accent-text)}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.84rem;color:var(--ink-faint)}
.foot-social{display:flex;gap:10px}
.foot-social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;transition:.2s;font-size:1.05rem;color:var(--ink-soft)}
.foot-social a:hover{border-color:var(--accent);color:var(--accent)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== MOBILE BAR ===== */
.mobile-bar{display:none}

@media(max-width:900px){
  .grid-3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:80px 0}
}
@media(max-width:640px){
  .nav-links{
    position:fixed;top:64px;left:0;right:0;background:var(--bg);flex-direction:column;
    gap:0;padding:8px 24px 24px;border-bottom:1px solid var(--line);
    transform:translateY(-135%);transition:transform .35s;box-shadow:var(--shadow)
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a:not(.nav-cta){padding:15px 0;width:100%;border-bottom:1px solid var(--line-soft)}
  .nav-links a.active::after{display:none}
  .nav-links .nav-cta{margin-top:14px;text-align:center}
  .burger{display:flex}
  .grid-3,.grid-2,.steps,.foot-grid{grid-template-columns:1fr}
  .trust{grid-template-columns:1fr;gap:30px}
  .cta-band{padding:50px 28px}
  .panel{padding:32px 26px}
  .page-hero{padding:56px 0 40px}
  section{padding:64px 0}
  .ptable-row{padding:18px 20px}
  .btn{width:100%;min-width:0}
  .home-hero .row,.cta-band .row,.hero-cta,.panel .row{flex-direction:column;width:100%}
  .mobile-bar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;
    background:rgba(255,255,255,.92);backdrop-filter:blur(12px);
    border-top:1px solid var(--line);padding:10px 14px;gap:10px;
  }
  .mobile-bar a{flex:1;text-align:center;padding:13px;border-radius:12px;font-weight:600;font-size:.95rem}
  .mobile-bar .m-call{background:var(--accent);color:#fff}
  .mobile-bar .m-wa{background:#25D366;color:#0a3d1f}
  body{padding-bottom:66px}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none !important}
}

/* ============================================================
   ADDITIONS: hero image, reviews, booking, feature media
   ============================================================ */
.home-hero-img{
  position:relative;width:min(100%,340px);margin:0 auto 4px;
}
.home-hero-img .frame{
  border-radius:30px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.4);background:#fff;
}
.home-hero-img img{width:100%;display:block}
.hero-badge{
  position:absolute;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:14px;padding:11px 15px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:.85rem;font-weight:600;
}
.hero-badge .ic{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);display:grid;place-items:center;font-size:1rem}
.hero-badge small{display:block;font-weight:400;color:var(--ink-soft);font-size:.74rem}

/* feature media rows */
.media-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.media-row.rev{direction:rtl}
.media-row.rev > *{direction:ltr}
.media-row .media{border-radius:24px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff}
.media-row .media img{width:100%;display:block}
.media-row .txt h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:16px}
.media-row .txt p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:22px;font-weight:400}
.media-row .txt ul{list-style:none;margin-bottom:26px}
.media-row .txt li{padding:9px 0 9px 30px;position:relative;color:var(--ink);font-size:1rem}
.media-row .txt li::before{content:"✓";position:absolute;left:0;top:9px;color:var(--accent-text);font-weight:700}

/* reviews */
.reviews-head{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:14px}
.stars{color:#F5A623;font-size:1.5rem;letter-spacing:3px}
.google-line{display:inline-flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:.96rem}
.google-line .g{font-weight:700}
.google-line .g b:nth-child(1){color:#4285F4}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.review-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;display:flex;flex-direction:column;gap:14px}
.review-card .rstars{color:#F5A623;font-size:1rem;letter-spacing:2px}
.review-card p{color:var(--ink);font-size:.98rem;font-weight:400;line-height:1.6;flex:1}
.review-card .who{display:flex;align-items:center;gap:11px}
.review-card .av{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);display:grid;place-items:center;font-weight:600;color:var(--accent-text)}
.review-card .who b{font-size:.94rem}
.review-card .who small{display:block;color:var(--ink-faint);font-size:.8rem}

@media(max-width:900px){
  .media-row{grid-template-columns:1fr;gap:32px}
  .media-row.rev{direction:ltr}
  .media-row .media{max-width:360px;margin:0 auto}
  .review-grid{grid-template-columns:1fr}
}

/* ============================================================
   ADDITIONS v3: motion, cookie consent, maps gate
   ============================================================ */
/* subtle card lift already exists; add icon pop + image zoom */
.card .ic,.svc .ic{transition:transform .3s,background .3s}
.card:hover .ic{transform:scale(1.08) rotate(-3deg);background:var(--accent-bright)}
.media{overflow:hidden}
.media img{transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.media:hover img{transform:scale(1.04)}
.trust-item b{transition:transform .3s}
.trust-item:hover b{transform:translateY(-3px)}

/* hero badges float */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-badge{animation:floaty 5s ease-in-out infinite}
.home-hero-img .hero-badge:nth-of-type(2){animation-delay:.9s}

/* animated gradient wash behind hero */
.home-hero::after{
  content:"";position:absolute;top:-140px;right:-80px;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(216,216,220,.6),transparent 62%);
  filter:blur(20px);z-index:-1;pointer-events:none;animation:breathe 9s ease-in-out infinite;
}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.12);opacity:1}}

/* link underline grow on text buttons */
.btn-text .arr{transition:transform .25s}
.btn-text:hover .arr{transform:translateX(5px)}

/* reveal: add subtle scale */
.reveal{opacity:0;transform:translateY(26px) scale(.99);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== MAPS GATE ===== */
.map-gate{
  position:relative;min-height:380px;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);background:
    linear-gradient(rgba(53,97,122,.04),rgba(53,97,122,.04)),
    repeating-linear-gradient(45deg,var(--bg-2),var(--bg-2) 18px,#EEF0F2 18px,#EEF0F2 36px);
  display:grid;place-items:center;text-align:center;padding:40px 24px;
}
.map-gate .inner{max-width:420px}
.map-gate .pin{font-size:2.2rem;margin-bottom:12px}
.map-gate h4{font-size:1.2rem;margin-bottom:10px}
.map-gate p{color:var(--ink-soft);font-size:.95rem;margin-bottom:20px;font-weight:400}
.map-gate small{display:block;margin-top:14px;color:var(--ink-faint);font-size:.82rem}
.map-gate a{color:var(--accent-text);text-decoration:underline}

/* ===== COOKIE CONSENT ===== */
.cookie{
  position:fixed;left:0;right:0;bottom:0;z-index:200;
  background:rgba(255,255,255,.97);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -10px 40px -20px rgba(0,0,0,.3);
  padding:20px 24px;transform:translateY(110%);transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.cookie.show{transform:translateY(0)}
.cookie-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.cookie-txt{flex:1;min-width:260px}
.cookie-txt b{display:block;margin-bottom:4px;font-size:1rem}
.cookie-txt p{color:var(--ink-soft);font-size:.9rem;font-weight:400}
.cookie-txt a{color:var(--accent-text);text-decoration:underline}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.cookie-actions .btn{height:46px;min-width:150px;font-size:.95rem}
.btn-soft{background:var(--bg-2);color:var(--ink);border:1px solid var(--line)}
.btn-soft:hover{border-color:var(--ink-faint);transform:translateY(-2px)}
@media(max-width:640px){
  .cookie-inner{flex-direction:column;align-items:stretch}
  .cookie-actions{width:100%}
  .cookie-actions .btn{flex:1;min-width:0}
  body.has-mobilebar .cookie{padding-bottom:20px}
}

.accent{color:var(--accent-text)}

/* ============================================================
   ICONS (clean line icons replacing emoji)
   ============================================================ */
.card .ic,.svc .ic,.contact-item .ic,.panel h3 svg{color:var(--accent-text)}
.ic svg{width:24px;height:24px;display:block}
.contact-item .ic svg{width:22px;height:22px}
.card:hover .ic{background:var(--accent-bright)}
.card:hover .ic svg{color:#1D1D1F}
.map-gate .pin{color:var(--accent-text);display:flex;justify-content:center;margin-bottom:12px}
/* keep icon boxes calm */
.card .ic,.svc .ic{background:var(--accent-soft)}
.contact-item .ic{background:var(--accent-soft)}

/* ============================================================
   LEGAL PAGES (Impressum / Datenschutz)
   ============================================================ */
.legal{font-size:1rem;color:var(--ink-soft)}
.legal h3{color:var(--ink);font-size:1.16rem;margin:30px 0 8px;letter-spacing:-.01em}
.legal h3:first-of-type{margin-top:10px}
.legal p{margin-bottom:6px;line-height:1.7}
.legal .note{background:var(--accent-soft);border:1px solid var(--line);border-radius:12px;padding:14px 18px;font-size:.92rem;margin-bottom:24px;color:var(--ink)}
.legal .todo{color:#B0560C;font-weight:500}
