/* ============================================================
   Fahrschule Keck Osnabrück – shared stylesheet
   Brand palette from the official logo: royal-navy blue + red
   ============================================================ */
:root{
  --ink:#14215c;        /* deep navy – dark sections, headings */
  --ink-2:#1b2c74;
  --brand:#20368f;      /* logo royal blue – wordmark, links, emblem */
  --brand-d:#192a73;
  --accent:#e30613;     /* logo red – primary CTA + highlights */
  --accent-d:#bf0510;
  --star:#f5b301;       /* gold – rating stars only */
  --bg:#ffffff;--bg-soft:#f4f6fc;--bg-card:#ffffff;
  --line:#e1e7f3;--txt:#1a2238;--muted:#5a6478;--ok:#1f9d57;
  --radius:18px;
  --shadow-sm:0 1px 3px rgba(20,33,92,.06),0 1px 2px rgba(20,33,92,.04);
  --shadow:0 10px 30px -12px rgba(20,33,92,.20);
  --shadow-lg:0 24px 60px -20px rgba(20,33,92,.30);
  --maxw:1140px;--space:clamp(64px,9vw,120px);
  --font-d:"Plus Jakarta Sans",system-ui,sans-serif;
  --font-b:"Inter",system-ui,sans-serif;
  --ease-out:cubic-bezier(.23,1,.32,1);
  --ease-out-soft:cubic-bezier(.16,1,.3,1);
  --ease-in-out:cubic-bezier(.77,0,.175,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--txt);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-d);line-height:1.12;color:var(--ink);letter-spacing:-.02em;font-weight:800}
h1{letter-spacing:-.035em}
h2{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-.03em}
h3{font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700;letter-spacing:-.015em}
p{color:var(--muted)}
::selection{background:var(--brand);color:#fff}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:6px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:var(--space) 0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);background:rgba(32,54,143,.09);padding:7px 14px;border-radius:100px;margin-bottom:18px}
.eyebrow.gold{color:#ffd152;background:rgba(245,179,1,.14)}
.sec-head{max-width:680px;margin:0 auto 54px;text-align:center}
.sec-head p{margin-top:14px;font-size:1.08rem}
.center{text-align:center}
.mt-l{margin-top:38px}

/* brand tagline – "Sicher. Kompetent. Vertraut." */
.brand-tagline{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-d);font-weight:700;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
.brand-tagline::before,.brand-tagline::after{content:"";width:22px;height:2px;background:var(--accent);border-radius:2px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-d);font-weight:700;font-size:1rem;line-height:1.2;padding:15px 26px;border-radius:100px;border:0;cursor:pointer;white-space:nowrap;transition:transform .18s var(--ease-out),box-shadow .25s var(--ease-out),background .2s ease,filter .2s ease}
.btn:active{transform:translateY(0) scale(.97);transition-duration:.1s}
.btn-primary{background:linear-gradient(135deg,#f01a26,var(--accent));color:#fff;box-shadow:0 10px 24px -12px rgba(227,6,19,.6)}
.btn-dark{background:var(--ink);color:#fff}
.btn-wa{background:#25d366;color:#063d22}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
@media(hover:hover){
  .btn:hover{transform:translateY(-2px)}
  .btn-primary:hover{box-shadow:0 16px 34px -10px rgba(227,6,19,.75)}
  .btn-dark:hover{background:var(--ink-2)}
  .btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
}
.btn-block{width:100%}

/* header */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line);transition:box-shadow .3s ease,background .3s ease}
header.scrolled{box-shadow:0 8px 28px -18px rgba(20,33,92,.5);background:rgba(255,255,255,.93)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
/* brand / logo lockup */
.brand{display:flex;align-items:center;gap:11px;white-space:nowrap;flex-shrink:0}
.brand .mark{width:54px;height:54px;border-radius:14px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow-sm);flex-shrink:0}
.brand .mark img{width:42px;height:42px}
.brand-name{font-family:var(--font-d);font-weight:800;color:var(--brand);line-height:1.02;letter-spacing:-.02em}
.brand-name .wm{display:block;font-size:1.18rem;font-style:italic}
.brand-name em{color:var(--accent);font-style:italic}
.brand-name small{display:block;font-family:var(--font-b);font-weight:500;font-style:normal;font-size:.7rem;color:var(--muted);letter-spacing:.02em;margin-top:2px}
.nav-links{display:flex;gap:26px;list-style:none}
.nav-links a{position:relative;font-weight:500;font-size:.96rem;color:var(--txt);white-space:nowrap;transition:color .15s ease}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;background:var(--brand);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease-out)}
.nav-links a[aria-current="page"]{color:var(--brand);font-weight:700}
.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
@media(hover:hover){.nav-links a:hover{color:var(--brand)}.nav-links a:hover::after{transform:scaleX(1)}}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-d);font-weight:700;color:var(--ink);white-space:nowrap}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}

/* hero (home) */
/* hero background photo: drop a real driving photo at /assets/images/hero.jpg
   (1920x1080, JPG/WebP, self-hosted for speed + DSGVO). Until then the navy
   gradient shows on its own — no broken image, no external request. */
.hero{position:relative;color:#fff;padding:clamp(56px,8vw,104px) 0 clamp(72px,10vw,128px);overflow:hidden;background:#121d52}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:
  linear-gradient(90deg,rgba(18,29,82,.95) 0%,rgba(20,33,92,.82) 42%,rgba(26,42,114,.58) 100%),
  radial-gradient(120% 120% at 82% -10%,rgba(42,68,184,.35) 0%,rgba(18,29,82,0) 55%),
  url("/assets/images/hero.jpg") center/cover no-repeat;
  background-color:#121d52}
.hero::after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23ffffff' stroke-opacity='.05' stroke-width='1'/%3E%3C/svg%3E");pointer-events:none}
/* decorative wheel background in hero */
.hero-deco{position:absolute;top:50%;right:-5%;transform:translateY(-50%);width:clamp(360px,52vw,680px);height:clamp(360px,52vw,680px);pointer-events:none;z-index:1;flex-shrink:0}
@media(max-width:760px){.hero-deco{display:none}}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{color:#fff;font-size:clamp(2.3rem,5.2vw,3.7rem);line-height:1.05}
.hero h1 .hl{color:#ff5a63}
.hero p.lead{color:#ccd6ef;font-size:1.16rem;margin:22px 0 30px;max-width:540px}
.hero .brand-tagline{color:#9fb4ec;margin-bottom:20px}
.hero .brand-tagline::before,.hero .brand-tagline::after{background:var(--accent)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.rating-pill{display:inline-flex;align-items:center;gap:14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:13px 20px;border-radius:100px;backdrop-filter:blur(6px)}
.rating-pill .num{font-family:var(--font-d);font-weight:800;font-size:1.5rem;color:#fff}
.stars{color:var(--star);letter-spacing:2px;font-size:1.05rem;line-height:1}
.rating-pill small{color:#ccd6ef;font-size:.82rem;display:block}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:26px;list-style:none}
.hero-trust li{display:flex;align-items:center;gap:8px;font-size:.92rem;color:#dae3f5;font-weight:500}
.hero-trust svg{color:#8fb3ff;flex-shrink:0}
.hero-card{background:#fff;border-radius:24px;padding:30px;box-shadow:var(--shadow-lg);color:var(--txt)}
.hero-card h3{font-size:1.25rem;margin-bottom:4px}
.hero-card .sub{font-size:.9rem;color:var(--muted);margin-bottom:18px}

/* page hero (interior pages) */
.page-hero{background:radial-gradient(120% 140% at 85% -20%,#2a44b8 0%,#1a2a72 52%,#121d52 100%);color:#fff;padding:clamp(54px,7vw,86px) 0;text-align:center}
.page-hero h1{color:#fff;font-size:clamp(2rem,4.6vw,3.1rem)}
.page-hero p{color:#ccd6ef;font-size:1.12rem;max-width:620px;margin:16px auto 0}
.crumb{font-size:.85rem;color:#9fb0c6;margin-bottom:16px}
.crumb a:hover{color:#fff}

/* forms */
.frm label{display:block;font-size:.83rem;font-weight:600;color:var(--ink);margin:0 0 6px;line-height:1.2}
.frm input,.frm select,.frm textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--font-b);font-size:.96rem;margin-bottom:13px;background:var(--bg-soft);transition:border-color .15s ease,box-shadow .2s var(--ease-out),background .15s ease}
.frm input::placeholder,.frm textarea::placeholder{color:#9aa6b4}
.frm input:focus,.frm select:focus,.frm textarea:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px rgba(32,54,143,.14)}
.frm textarea{resize:vertical;min-height:90px}
.fineprint{font-size:.74rem;color:var(--muted);margin-top:10px;text-align:center}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.8rem;color:var(--muted);margin:6px 0 16px}
.consent input{width:auto;margin:3px 0 0}
.form-msg{display:none;padding:14px 16px;border-radius:12px;font-size:.92rem;margin-bottom:12px}
.form-msg.ok{display:block;background:rgba(31,157,87,.1);color:#157a42;border:1px solid rgba(31,157,87,.3)}
.form-msg.err{display:block;background:rgba(214,69,69,.08);color:#b53636;border:1px solid rgba(214,69,69,.3)}

/* stat strip */
.strip{background:var(--ink);color:#fff}
.strip .wrap{display:flex;flex-wrap:wrap;justify-content:space-around;gap:22px;padding:26px 22px;text-align:center}
.strip .stat{flex:1;min-width:140px}
.strip .stat b{font-family:var(--font-d);font-size:1.9rem;display:block;color:#ffd152}
.strip .stat span{font-size:.86rem;color:#bcc9da}

/* cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out),border-color .25s ease}
@media(hover:hover){.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#ccd6ef}}
.card .ico{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(32,54,143,.12),rgba(32,54,143,.05));color:var(--brand);display:grid;place-items:center;margin-bottom:18px;transition:transform .25s var(--ease-out)}
@media(hover:hover){.card:hover .ico{transform:scale(1.06) rotate(-3deg)}}
.card h3{margin-bottom:9px}
.card p{font-size:.96rem}

/* about */
.about{background:var(--bg-soft)}
.about .grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center}
.about-photo{position:relative;border-radius:24px;aspect-ratio:4/5;background:linear-gradient(160deg,var(--ink),var(--brand));box-shadow:var(--shadow-lg);display:grid;place-items:center;color:rgba(255,255,255,.85);overflow:hidden}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo .initials{font-family:var(--font-d);font-weight:800;font-size:5rem;letter-spacing:-.03em}
.about-photo .badge{position:absolute;bottom:18px;left:18px;right:18px;background:rgba(255,255,255,.95);color:var(--ink);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}
.about-photo .badge b{font-family:var(--font-d)}
.about-photo .badge small{color:var(--muted);font-size:.78rem}
.about .role{font-family:var(--font-d);font-weight:700;color:var(--brand);margin-bottom:18px}
.about p+p{margin-top:14px}
.sign{font-family:var(--font-d);font-weight:800;color:var(--ink);font-size:1.3rem;margin-top:22px}
.quotebox{margin-top:24px;border-left:3px solid var(--accent);padding-left:18px;font-style:italic;color:var(--ink)}
.quotebox small{font-style:normal;font-size:.85rem;color:var(--muted)}

/* klassen */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.klasse{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative;transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out),border-color .25s ease}
@media(hover:hover){.klasse:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--brand)}}
.klasse .tag{position:absolute;top:18px;right:18px;font-family:var(--font-d);font-weight:800;font-size:1.4rem;color:rgba(32,54,143,.18)}
.klasse.feat{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.klasse.feat::before{content:"Beliebt";position:absolute;top:-12px;left:24px;background:var(--accent);color:#fff;font-family:var(--font-d);font-weight:700;font-size:.74rem;padding:4px 12px;border-radius:100px}
.klasse h3{margin-bottom:8px;font-size:1.18rem}
.klasse p{font-size:.92rem}
.klasse ul{list-style:none;margin-top:14px;font-size:.9rem}
.klasse ul li{padding:5px 0;padding-left:24px;position:relative;color:var(--muted)}
.klasse ul li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:700}

/* reviews */
.reviews{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.reviews .sec-head h2{color:#fff}
.reviews .sec-head p{color:#bcc9da}
.gscore{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:46px;flex-wrap:wrap}
.gscore .g{background:#fff;color:var(--ink);border-radius:14px;padding:14px 22px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.gscore .g .big{font-family:var(--font-d);font-weight:800;font-size:2.1rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:24px;transition:transform .25s var(--ease-out),border-color .25s ease,background .25s ease}
@media(hover:hover){.rev:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.08)}}
.rev .stars{margin-bottom:12px}
.rev p{color:#e3ebf5;font-size:.96rem}
.rev .who{display:flex;align-items:center;gap:11px;margin-top:16px}
.rev .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#4f6fd6);display:grid;place-items:center;font-family:var(--font-d);font-weight:700;color:#fff;flex-shrink:0}
.rev .who b{display:block;font-size:.92rem;color:#fff;font-family:var(--font-d)}
.rev .who small{color:#9fb0c6;font-size:.78rem}
.reviews .more{text-align:center;margin-top:40px}

/* faq */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;background:#fff;overflow:hidden;transition:box-shadow .25s var(--ease-out),border-color .25s ease}
.faq-item[open]{box-shadow:var(--shadow);border-color:var(--brand)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--font-d);font-weight:700;color:var(--ink);font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:background .2s ease}
.faq-item summary::-webkit-details-marker{display:none}
@media(hover:hover){.faq-item summary:hover{background:var(--bg-soft)}}
.faq-item summary .pl{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--brand);font-size:1.3rem;transition:transform .25s var(--ease-out),background .2s ease,color .2s ease}
.faq-item[open] summary .pl{transform:rotate(135deg);background:var(--brand);color:#fff}
.faq-item .ans{padding:0 24px 22px;color:var(--muted);font-size:.98rem}
.faq-item[open] .ans{animation:faqReveal .26s var(--ease-out)}
@keyframes faqReveal{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* contact */
.contact{background:var(--bg-soft)}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.contact-info .ci{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.contact-info .ci .ico{width:46px;height:46px;border-radius:12px;background:var(--ink);color:#fff;display:grid;place-items:center;flex-shrink:0}
.contact-info .ci b{font-family:var(--font-d);color:var(--ink);display:block;font-size:1.02rem}
.contact-info .ci a,.contact-info .ci span{color:var(--muted);font-size:.96rem}
.contact-info .ci a:hover{color:var(--brand)}
.map{margin-top:24px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.map iframe{width:100%;height:260px;border:0;display:block}
.form-card{background:#fff;border-radius:24px;padding:32px;box-shadow:var(--shadow);border:1px solid var(--line)}
.form-card h3{margin-bottom:6px}
.form-card .sub{color:var(--muted);font-size:.92rem;margin-bottom:22px}

/* legal pages */
.prose{max-width:780px;margin:0 auto}
.prose h2{font-size:1.5rem;margin:34px 0 12px}
.prose h3{font-size:1.15rem;margin:24px 0 8px}
.prose p,.prose li{color:var(--txt);font-size:.98rem;margin-bottom:10px}
.prose ul{padding-left:22px;margin-bottom:12px}
.prose a{color:var(--brand);text-decoration:underline}

/* footer */
footer{background:var(--ink);color:#bcc9da;padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
footer h4{color:#fff;font-family:var(--font-d);font-size:1.05rem;margin-bottom:16px}
footer .brand{margin-bottom:14px}
footer .brand-name{color:#fff}
footer .brand-name em{color:#ff5a63}
footer .brand-name small{color:#aebbd6}
footer .brand-tagline{color:#9fb4ec;margin:0 0 14px}
footer ul{list-style:none}
footer ul li{margin-bottom:9px;font-size:.94rem}
footer ul a{transition:color .15s ease}
footer ul a:hover{color:#fff}
.foot-contact li,.foot-contact li a{display:flex;align-items:flex-start;gap:10px}
.foot-contact svg{flex-shrink:0;margin-top:3px;color:#7ea6ff}
footer p{font-size:.92rem;color:#9fb0c6}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;color:#8294ab}
.foot-bottom a{transition:color .15s ease}
.foot-bottom a:hover{color:#fff}

/* sticky mobile + floating wa */
.mobile-bar{position:fixed;bottom:0;left:0;right:0;z-index:70;display:none;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(20,33,92,.12);padding:10px 12px;gap:10px}
.mobile-bar a{flex:1;padding:14px;font-size:.95rem}
.wa-float{position:fixed;right:18px;bottom:18px;z-index:65;width:58px;height:58px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:var(--shadow-lg);transition:transform .2s var(--ease-out),box-shadow .2s ease}
.wa-float:active{transform:scale(.95)}
@media(hover:hover){.wa-float:hover{transform:scale(1.08)}}

/* scroll-reveal (JS adds .reveal then .in) */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease-out-soft),transform .6s var(--ease-out-soft)}
.reveal.in{opacity:1;transform:none}

/* hero + page-hero entrance */
@keyframes riseIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:no-preference){
  .hero-copy>*{animation:riseIn .7s var(--ease-out-soft) backwards}
  .hero-copy>*:nth-child(1){animation-delay:.04s}
  .hero-copy>*:nth-child(2){animation-delay:.10s}
  .hero-copy>*:nth-child(3){animation-delay:.16s}
  .hero-copy>*:nth-child(4){animation-delay:.22s}
  .hero-copy>*:nth-child(5){animation-delay:.28s}
  .hero-copy>*:nth-child(6){animation-delay:.34s}
  .hero-copy>*:nth-child(7){animation-delay:.40s}
  .hero-card{animation:riseIn .7s var(--ease-out-soft) .24s backwards}
  .page-hero .wrap>*{animation:riseIn .6s var(--ease-out-soft) backwards}
  .page-hero .wrap>*:nth-child(1){animation-delay:.04s}
  .page-hero .wrap>*:nth-child(2){animation-delay:.12s}
  .page-hero .wrap>*:nth-child(3){animation-delay:.20s}
}

/* ---------- responsive ---------- */
@media(max-width:1180px){.nav-phone{display:none}}
@media(max-width:1080px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:#fff;padding:20px 22px;gap:18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open a::after{display:none}
}
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .about .grid,.contact .grid{grid-template-columns:1fr;gap:34px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .mobile-bar{display:flex}
  .wa-float{bottom:84px}
  body{padding-bottom:70px}
  .nav-cta .btn{display:none}
  .brand-name small{display:none}
}

/* accessibility: respect reduced motion */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
}
