:root{--color-primary:#1E40AF;--color-secondary:#3B82F6;--color-accent:#22C55E;--color-neutral-dark:#1E3A8A;--color-neutral-light:#EFF6FF;--font-heading:'Poppins',sans-serif;--font-body:'Inter',sans-serif;--ease:cubic-bezier(0.22,1,0.36,1);--radius:16px;--radius-lg:24px;--shadow-sm:0 2px 20px rgba(15,23,42,.06);--shadow-md:0 10px 30px -10px rgba(30,64,175,.25);--shadow-lg:0 30px 60px -25px rgba(30,58,138,.35);--maxw:1200px}

/* === Base === */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);font-size:16px;line-height:1.6;color:#0f172a;background:#fff;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--color-primary);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--color-secondary)}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--color-neutral-dark);margin:0 0 .75em}
h1{font-size:clamp(2.25rem,5vw,4rem);letter-spacing:-.02em;font-weight:700}
h2{font-size:clamp(1.75rem,3.2vw,2.5rem);letter-spacing:-.01em}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:1.25rem}
.narrow{max-width:760px}
.eyebrow{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-secondary);margin:0 0 1rem}

/* === Header === */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid rgba(30,64,175,.08);transition:background .25s var(--ease),box-shadow .25s var(--ease)}
.site-header.scrolled{background:rgba(255,255,255,.92);box-shadow:var(--shadow-sm)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.75rem}
.logo{display:inline-flex;align-items:center}
.logo img{height:72px;width:auto;display:block}
.nav-toggle{background:transparent;border:0;color:var(--color-neutral-dark);padding:.5rem;cursor:pointer;border-radius:8px}
.nav-toggle:hover{background:var(--color-neutral-light)}
.primary-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid rgba(30,64,175,.08);padding:1rem 1.25rem;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-sm)}
.primary-nav.is-open{display:flex}
.primary-nav a{position:relative;color:var(--color-neutral-dark);font-weight:500;padding:.6rem .25rem}
.primary-nav a[aria-current="page"]{color:var(--color-primary)}
.nav-cta{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff!important;padding:.6rem 1rem!important;border-radius:999px;text-align:center;margin-top:.25rem}
.nav-cta:hover{filter:brightness(1.05)}

@media(min-width:900px){
.logo img{height:96px}
.nav-toggle{display:none}
.primary-nav{display:flex;position:static;flex-direction:row;align-items:center;gap:1.75rem;background:transparent;padding:0;border:0;box-shadow:none}
.primary-nav a{padding:.5rem 0}
.primary-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--color-primary);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.primary-nav a:not(.nav-cta):hover::after,.primary-nav a[aria-current="page"]::after{transform:scaleX(1)}
}

/* === Hero === */
.hero{position:relative;overflow:hidden;padding-block:3.5rem 4rem;text-align:center}
.hero__bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(34,197,94,.10),transparent 50%),radial-gradient(circle at 85% 20%,rgba(59,130,246,.18),transparent 55%),linear-gradient(180deg,var(--color-neutral-light),#fff 70%);z-index:-1}
.hero__inner{display:flex;flex-direction:column;align-items:center}
.hero h1{max-width:24ch}
.hero__sub{font-size:1.15rem;color:#334155;max-width:54ch;margin-bottom:2rem}
.hero__ctas{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:3rem}
.hero__image-wrap{width:100%;max-width:960px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.hero__image-wrap::before{content:"";position:absolute;inset:-30px;background:radial-gradient(circle,rgba(59,130,246,.25),transparent 60%);z-index:-1;filter:blur(40px)}
.hero__image{aspect-ratio:16/10;object-fit:cover;width:100%}

@media(min-width:768px){
.hero{padding-block:5rem 6rem}
.hero__sub{font-size:1.25rem}
}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:600;font-size:1rem;padding:.85rem 1.6rem;border-radius:999px;border:0;cursor:pointer;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease),filter .2s var(--ease)}
.btn--primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;box-shadow:0 12px 30px -10px rgba(30,64,175,.5)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(30,64,175,.55);color:#fff}
.btn--accent{background:var(--color-accent);color:#fff;box-shadow:0 12px 30px -10px rgba(34,197,94,.5)}
.btn--accent:hover{transform:translateY(-2px);filter:brightness(1.05);color:#fff}
.btn--ghost{background:rgba(255,255,255,.7);color:var(--color-neutral-dark);border:1px solid rgba(30,64,175,.18);backdrop-filter:blur(8px)}
.btn--ghost:hover{transform:translateY(-2px);background:#fff;color:var(--color-primary)}
.btn:focus-visible{outline:3px solid var(--color-accent);outline-offset:3px}

/* === Sections === */
.section{padding-block:4rem}
.section__title{text-align:center;margin-bottom:2.5rem}
.section__sub{text-align:center;color:#475569;max-width:60ch;margin:-1rem auto 2rem}
@media(min-width:768px){.section{padding-block:5.5rem}}

/* === Intro === */
.intro__grid{display:grid;gap:2.5rem;align-items:center}
.intro__text h2{margin-top:0}
.intro__image img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);aspect-ratio:4/3;object-fit:cover}
@media(min-width:900px){.intro__grid{grid-template-columns:1.1fr 1fr}}
.intro .narrow{text-align:left}
.intro .narrow h2{text-align:center}

/* === Grid & cards === */
.grid{display:grid;gap:1.5rem}
.grid--3{grid-template-columns:1fr}
.grid--4{grid-template-columns:1fr}
@media(min-width:640px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}}

.card{background:#fff;border:1px solid rgba(30,64,175,.10);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);display:flex;flex-direction:column;gap:.5rem}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(59,130,246,.4)}
.card__icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,rgba(30,64,175,.12),rgba(34,197,94,.12));color:var(--color-primary);margin-bottom:.5rem}
.card h3{margin:0}
.card p{margin:0;color:#475569;font-size:.97rem}
.card-link{color:inherit;text-decoration:none}
.card-link:hover h3{color:var(--color-primary)}

/* === Testimonial === */
.testimonial{background:linear-gradient(180deg,#fff,var(--color-neutral-light))}
.testimonial blockquote{max-width:780px;margin:0 auto;text-align:center;position:relative;padding:2rem 1rem 0}
.testimonial blockquote::before{content:"„";position:absolute;top:-1rem;left:50%;transform:translateX(-50%);font-family:var(--font-heading);font-size:6rem;line-height:1;color:var(--color-secondary);opacity:.35}
.testimonial blockquote p{font-size:1.2rem;color:#1e293b;font-style:italic;line-height:1.55}
.testimonial blockquote cite{display:block;margin-top:1.25rem;font-style:normal;font-weight:600;color:var(--color-neutral-dark)}
@media(min-width:768px){.testimonial blockquote p{font-size:1.35rem}}

/* === CTA band === */
.cta-band{padding-block:4rem}
.cta-band__inner{background:linear-gradient(135deg,var(--color-primary),var(--color-neutral-dark));color:#fff;border-radius:var(--radius-lg);padding:3rem 1.75rem;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.cta-band__inner::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(34,197,94,.25),transparent 60%);pointer-events:none}
.cta-band h2{color:#fff;max-width:24ch;margin-inline:auto}
.cta-band p{color:rgba(239,246,255,.85);max-width:54ch;margin:0 auto 1.5rem}
@media(min-width:768px){.cta-band__inner{padding:4rem 3rem}}

/* === Stats === */
.stats__grid{text-align:center}
.stat{padding:1.5rem;background:#fff;border-radius:var(--radius);border:1px solid rgba(30,64,175,.08);box-shadow:var(--shadow-sm)}
.stat__num{font-family:var(--font-heading);font-weight:700;font-size:clamp(2rem,4vw,2.75rem);color:var(--color-accent);margin:0 0 .5rem;line-height:1}
.stat__body{color:#475569;font-size:.97rem;margin:0}

/* === Contact === */
.contact-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:700px){.contact-grid{grid-template-columns:repeat(2,1fr)}}
.contact-card{background:#fff;border:1px solid rgba(30,64,175,.10);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}
.contact-card h3{margin-top:0;color:var(--color-primary);font-size:1rem;text-transform:uppercase;letter-spacing:.05em}
.contact-card address{font-style:normal;line-height:1.6}
.hours{width:100%;border-collapse:collapse}
.hours th,.hours td{text-align:left;padding:.4rem 0;border-bottom:1px solid rgba(30,64,175,.08);font-weight:400}
.hours th{font-weight:500;color:var(--color-neutral-dark)}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}

/* === Form === */
.form{display:flex;flex-direction:column;gap:1.25rem;background:#fff;border:1px solid rgba(30,64,175,.10);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);margin-top:1rem}
.form__row{display:flex;flex-direction:column;gap:.4rem}
.form label{font-weight:500;color:var(--color-neutral-dark)}
.form input,.form textarea{font:inherit;padding:.75rem .9rem;border:1px solid rgba(30,64,175,.20);border-radius:10px;background:var(--color-neutral-light);color:#0f172a;transition:border-color .2s,box-shadow .2s}
.form input:focus,.form textarea:focus{outline:0;border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(59,130,246,.2);background:#fff}
.form button{align-self:flex-start}
.form-success{background:rgba(34,197,94,.12);color:#166534;padding:1rem 1.25rem;border-radius:12px;margin-top:1rem;font-weight:500}

/* === FAQ === */
.faq details{background:#fff;border:1px solid rgba(30,64,175,.10);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease)}
.faq details[open]{box-shadow:var(--shadow-md)}
.faq summary{font-weight:600;color:var(--color-neutral-dark);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;font-weight:300;color:var(--color-primary);transition:transform .2s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:.75rem 0 0;color:#475569}

/* === Footer === */
.site-footer{background:var(--color-neutral-dark);color:rgba(239,246,255,.9);padding-block:3rem 1.5rem;margin-top:2rem}
.site-footer__grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:800px){.site-footer__grid{grid-template-columns:1.2fr 1fr 1.2fr}}
.site-footer h3{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}
.site-footer a{color:rgba(239,246,255,.85)}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.site-footer address{font-style:normal;line-height:1.7;margin-bottom:1rem}
.legal-links{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.12)}
.logo--footer{background:#fff;padding:.5rem .75rem;border-radius:8px;display:inline-flex;margin-bottom:.75rem}
.logo--footer img{height:48px}
.site-footer__base{text-align:center;margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.12);font-size:.9rem;color:rgba(239,246,255,.65)}

/* === Reveal === */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* === Cookie banner === */
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;display:none;z-index:9999;background:var(--color-neutral-dark);color:var(--color-neutral-light);padding:1.25rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:560px}
.cookie-banner.is-visible{display:block}
.cookie-banner p{margin:0 0 1rem;font-size:.92rem;line-height:1.55}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie-banner button{font:inherit;font-weight:600;padding:.55rem 1rem;border-radius:999px;border:0;cursor:pointer;font-size:.88rem;transition:filter .2s,transform .15s}
.cookie-banner button:hover{transform:translateY(-1px);filter:brightness(1.08)}
.cookie-banner [data-cookie-accept]{background:var(--color-accent);color:#fff}
.cookie-banner [data-cookie-reject]{background:rgba(255,255,255,.12);color:#fff}
.cookie-banner [data-cookie-settings]{background:transparent;color:rgba(239,246,255,.85);text-decoration:underline}
.cookie-banner__prefs{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;gap:.5rem}
.cookie-banner__prefs label{display:flex;align-items:center;gap:.5rem;font-size:.9rem}
.cookie-banner [data-cookie-save]{background:var(--color-secondary);color:#fff;align-self:flex-start;margin-top:.5rem}
