:root{
  --ink:#081524; --navy:#0B2340; --navy2:#13365f;
  --accent:#2A62D6; --accent-d:#1e51bd;
  --cta:#EA4D00; --cta-d:#cf4400;
  --gold:#F2A81E; --wa:#25D366; --wa-d:#1da851;
  --teal:#12b5a5;
  --bg:#F5F8FC; --bg2:#EBF1F8; --card:#ffffff; --line:#E4EBF4;
  --text:#152234; --muted:#5b6a7d; --muted2:#7c8a9c;
  --sh-sm:0 4px 14px rgba(11,35,64,.07);
  --sh:0 16px 40px rgba(11,35,64,.10);
  --sh-lg:0 30px 70px rgba(8,21,36,.18);
  --r:14px; --r-lg:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:96px}
body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:var(--text);line-height:1.65;background:#fff;-webkit-font-smoothing:antialiased;font-size:17px}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{font-family:"Sora",sans-serif;line-height:1.15;color:var(--navy);letter-spacing:-.02em;font-weight:700}
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.sec{padding:100px 0}
.sec.tight{padding:66px 0}
.center{text-align:center}
.eyebrow{display:inline-block;font-family:"Sora",sans-serif;font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:rgba(42,98,214,.09);border:1px solid rgba(42,98,214,.18);padding:7px 16px;border-radius:30px;margin-bottom:18px}
.sec h2{font-size:40px}
@media(max-width:820px){.sec{padding:70px 0}.sec h2{font-size:30px}}
.lead-sub{color:var(--muted);font-size:18px;max-width:660px;margin:14px auto 0}
.center .lead-sub{margin-left:auto;margin-right:auto}
.badge-neu{background:var(--gold);color:#5a3d00;font-family:"Sora";font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.06em;vertical-align:middle}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:"Sora",sans-serif;font-weight:700;font-size:16px;padding:15px 26px;border-radius:12px;border:0;cursor:pointer;transition:.18s;line-height:1}
.btn:hover{transform:translateY(-2px)}
.btn-call{background:var(--cta);color:#fff;box-shadow:0 10px 24px rgba(245,99,30,.34)}
.btn-call:hover{background:var(--cta-d);box-shadow:0 14px 30px rgba(245,99,30,.42)}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 10px 24px rgba(37,211,102,.30)}
.btn-wa:hover{background:var(--wa-d)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line);box-shadow:var(--sh-sm)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-light{background:#fff;color:var(--navy)}
.btn-outline-l{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-outline-l:hover{background:rgba(255,255,255,.12)}
.ico{width:20px;height:20px;fill:currentColor;flex:none}
/* topbar */
.topbar{background:linear-gradient(90deg,#0a1a2e,#0f2744);color:#b3c4d8;font-size:13.5px;border-bottom:1px solid rgba(255,255,255,.08)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:44px;gap:16px;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:600;display:inline-flex;align-items:center}
.topbar a:hover{color:var(--gold)}
.topbar span{display:inline-flex;align-items:center;gap:8px}
.topbar svg{width:15px;height:15px;fill:currentColor;opacity:.85;vertical-align:-2px;margin-right:5px}
/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header .wrap{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.logo{font-family:"Sora";font-size:23px;font-weight:800;color:var(--navy);letter-spacing:-.03em}
.logo b{color:var(--cta)}
nav{display:flex;gap:22px;font-family:"Sora";font-weight:600;font-size:14.5px;color:var(--navy);white-space:nowrap}
nav a{position:relative;padding:4px 0}
nav a:hover{color:var(--accent)}
nav a.active{color:var(--accent)}
.hcall .btn-call{padding:12px 20px;font-size:15px;white-space:nowrap}
.navtoggle{display:none;background:none;border:0;cursor:pointer;color:var(--navy);padding:6px;line-height:0}
.navtoggle svg{width:30px;height:30px;fill:currentColor;display:block}
@media(max-width:960px){
  nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-direction:column;gap:0;padding:6px 0;box-shadow:0 16px 30px rgba(11,35,64,.12)}
  .navcb:checked ~ nav{display:flex}
  nav a{padding:14px 22px;font-size:16px;border-bottom:1px solid var(--line)}
  nav a:last-child{border-bottom:0}
  .navtoggle{display:inline-flex;align-items:center;margin-left:auto;order:2}
  .hcall{order:3}
  .hcall .num{display:none}
}
/* hero */
.hero{position:relative;background:radial-gradient(1000px 500px at 80% -10%,rgba(46,107,230,.28),transparent 60%),radial-gradient(700px 400px at 5% 110%,rgba(18,181,165,.18),transparent 55%),linear-gradient(160deg,#0B2340 0%,#081524 100%);color:#eaf1fb;padding:78px 0 84px;overflow:hidden}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:center;z-index:2}
.hero .pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);padding:7px 14px;border-radius:30px;font-size:13.5px;font-weight:600;color:#cfe0f5;margin-bottom:22px}
.hero .pill .stars{color:var(--gold);letter-spacing:1px}
.hero h1{color:#fff;font-size:50px;font-weight:800;line-height:1.06}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero .lead{font-size:19px;color:#b9cae0;margin:20px 0 30px;max-width:540px}
.cta-row{display:flex;gap:13px;flex-wrap:wrap}
.hero .trust{display:flex;gap:26px;flex-wrap:wrap;margin-top:30px;font-size:14.5px;font-weight:600;color:#d6e3f3}
.hero .trust span{display:inline-flex;align-items:center;gap:8px}
.hero .trust svg{width:19px;height:19px;fill:var(--gold)}
/* hero visual cards */
.hstack{display:flex;flex-direction:column;gap:16px}
.gcard{background:#fff;color:var(--text);border-radius:18px;padding:22px 24px;box-shadow:var(--sh-lg)}
.gcard.rate{display:flex;align-items:center;gap:16px}
.gcard.rate .big{font-family:"Sora";font-size:34px;font-weight:800;color:var(--navy);line-height:1}
.gcard.rate .stars{color:var(--gold);letter-spacing:2px;font-size:15px}
.gcard.rate small{color:var(--muted);font-size:13px}
.gcard h4{font-size:16px;margin-bottom:14px;color:var(--navy)}
.pl{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed var(--line);font-size:15px}
.pl:last-of-type{border:0}
.pl b{color:var(--cta);font-family:"Sora";font-weight:700}
.edit-note{font-size:12px;color:var(--muted2);margin-top:10px}
.seal{position:absolute;right:-6px;top:-14px;background:var(--gold);color:#5a3d00;font-family:"Sora";font-weight:800;font-size:12px;padding:10px 14px;border-radius:50%;width:76px;height:76px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.1;box-shadow:var(--sh);transform:rotate(8deg)}
@media(max-width:900px){.hero .wrap{grid-template-columns:1fr}.hero h1{font-size:38px}.seal{display:none}}
/* brand marquee */
.brands{background:var(--ink);color:#8ea3bd;padding:20px 0}
.brands .wrap{display:flex;align-items:center;justify-content:center;gap:34px;flex-wrap:wrap;font-family:"Sora";font-weight:700;font-size:16px;letter-spacing:.02em;opacity:.9}
.brands .lbl{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#66809c}
/* stat band */
.stats{background:radial-gradient(700px 300px at 15% 0,rgba(46,107,230,.25),transparent 60%),linear-gradient(135deg,#0B2340,#12365c)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:56px 22px;text-align:center}
.stat .n{font-family:"Sora";font-size:44px;font-weight:800;color:#fff;line-height:1}
.stat .n em{color:var(--gold);font-style:normal}
.stat p{color:#a9c2da;font-size:15px;margin-top:8px}
@media(max-width:760px){.stats .wrap{grid-template-columns:repeat(2,1fr);gap:28px}}
/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:st}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--sh-sm);position:relative;overflow:hidden;counter-increment:st}
.step::after{content:counter(st,decimal-leading-zero);position:absolute;right:16px;top:2px;font-family:"Sora";font-weight:800;font-size:76px;line-height:1;color:var(--navy);opacity:.05;pointer-events:none}
.step .n{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--accent),var(--navy2));color:#fff;font-family:"Sora";font-weight:800;font-size:19px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.step h3{font-size:19px;margin-bottom:7px}
.step p{color:var(--muted);font-size:15.5px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
/* services */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;perspective:1200px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;transition:.2s;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--cta),var(--gold));transform:scaleX(0);transform-origin:left;transition:.3s}
.svc:hover::before{transform:scaleX(1)}
.svc:hover{transform:translateY(-6px) rotateX(3deg) scale(1.012);box-shadow:0 26px 50px rgba(11,35,64,.17);border-color:transparent}
.svc .si{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--navy2));display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 8px 18px rgba(42,98,214,.28)}
.svc .si svg{width:28px;height:28px;fill:#fff}
.svc h3{font-size:20px;margin-bottom:9px}
.svc p{color:var(--muted);font-size:15.5px;margin-bottom:16px}
.svc a.more{color:var(--accent);font-family:"Sora";font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:6px}
.svc a.more:hover{gap:10px}
@media(max-width:900px){.grid3{grid-template-columns:1fr}}
/* price table */
.ptable{max-width:740px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}
.prow{display:flex;justify-content:space-between;align-items:center;padding:18px 26px;border-bottom:1px solid var(--line)}
.prow:last-child{border:0}
.prow span{font-size:16px;font-weight:600}
.prow small{color:var(--muted);font-weight:400}
.prow b{color:var(--cta);font-family:"Sora";font-size:19px}
/* teaser (verkauf/telekom on homepage) */
.teaser{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.tcard{border-radius:var(--r-lg);padding:40px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--sh)}
.tcard.verkauf{background:radial-gradient(600px 300px at 100% 0,rgba(46,107,230,.5),transparent),linear-gradient(150deg,#0B2340,#13365f)}
.tcard.telekom{background:radial-gradient(600px 300px at 100% 0,rgba(255,255,255,.14),transparent),linear-gradient(150deg,#E20074,#a3005a)}
.tcard .eyebrow{color:rgba(255,255,255,.8)}
.tcard h3{color:#fff;font-size:26px;margin-bottom:12px}
.tcard p{opacity:.92;margin-bottom:20px;font-size:16px}
.tcard ul{list-style:none;margin-bottom:26px}
.tcard li{padding:7px 0 7px 30px;position:relative;font-size:15.5px}
.tcard li:before{content:"";position:absolute;left:0;top:12px;width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E");background-size:14px;background-repeat:no-repeat;background-position:center}
/* reviews */
.gbadge{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:10px 22px;font-family:"Sora";font-weight:700;margin:0 auto 32px;box-shadow:var(--sh-sm)}
.gbadge .stars{color:var(--gold);letter-spacing:2px}
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 26px 26px;box-shadow:var(--sh-sm);position:relative}
.rev::before{content:"\201C";position:absolute;top:2px;right:20px;font-family:Georgia,serif;font-weight:700;font-size:78px;line-height:1;color:var(--cta);opacity:.14;pointer-events:none}
.rev .stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px}
.rev p{font-size:15.5px;color:var(--text)}
.rev .who{margin-top:14px;font-family:"Sora";font-weight:700;font-size:14px;color:var(--navy)}
@media(max-width:900px){.revs{grid-template-columns:1fr}}
/* location + faq */
.locgrid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:stretch}
.infocard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--sh-sm)}
.infocard p{margin-bottom:10px;color:var(--muted)}
.infocard b{color:var(--navy);font-family:"Sora";font-weight:600}
.mapbox{background:linear-gradient(135deg,var(--bg2),#dde8f4);border:1px solid var(--line);border-radius:var(--r-lg);min-height:280px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:600}
.faq{max-width:800px;margin:0 auto}
.q{border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;background:#fff;overflow:hidden;box-shadow:var(--sh-sm)}
.q>button{width:100%;text-align:left;padding:18px 24px;font-family:"Sora";font-weight:600;font-size:16.5px;background:none;border:0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--navy)}
.q>button span{color:var(--accent);font-size:22px}
.q .a{padding:0 24px;max-height:0;overflow:hidden;transition:.28s;color:var(--muted)}
.q.open .a{max-height:240px;padding:0 24px 18px}
@media(max-width:820px){.locgrid{grid-template-columns:1fr}}
/* final cta */
.final{background:radial-gradient(700px 400px at 50% 0,rgba(46,107,230,.32),transparent),linear-gradient(160deg,#0B2340,#081524);color:#fff;text-align:center}
.final h2{color:#fff;font-size:34px}
.final p{color:#b9cae0;margin:12px 0 28px;font-size:18px}
/* footer */
footer{background:var(--ink);color:#93a7bf;font-size:14.5px;padding:52px 0 40px}
footer .cta-band{background:#0f2c4e;border:1px solid #16375e;border-radius:var(--r-lg);padding:30px 36px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:44px}
footer .cta-band h3{color:#fff;font-size:22px}
footer .cta-band p{color:#9fb6cc;font-size:15px}
footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1.4fr;gap:38px;margin-bottom:32px}
footer h4{color:#fff;font-family:"Sora";font-size:15px;margin-bottom:14px}
footer a{display:block;padding:3px 0;color:#93a7bf}
footer a:hover{color:#fff}
.towns{display:flex;flex-wrap:wrap;gap:8px 18px}
.towns a{padding:0}
.fbar{border-top:1px solid #16314f;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#6f889f}
@media(max-width:820px){footer .cols{grid-template-columns:1fr}}
/* sticky mobile bar */
.mbar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;background:#fff;border-top:1px solid var(--line);padding:10px;gap:10px;box-shadow:0 -6px 22px rgba(8,21,36,.12)}
.mbar a{flex:1;justify-content:center;padding:14px}
@media(max-width:960px){.mbar{display:flex}}
/* subpage hero */
.subhero{background:radial-gradient(800px 400px at 85% -20%,rgba(46,107,230,.30),transparent 60%),linear-gradient(160deg,#0B2340,#081524);color:#eaf1fb;padding:64px 0}
.subhero .crumbs{font-size:13.5px;color:#8ea3bd;margin-bottom:16px}
.subhero .crumbs a:hover{color:#fff}
.subhero h1{color:#fff;font-size:42px;max-width:760px}
.subhero p{color:#b9cae0;font-size:19px;max-width:640px;margin:16px 0 26px}
@media(max-width:900px){.subhero h1{font-size:32px}}
/* generic two-col feature block for subpages */
.fblock{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.fblock.rev-order .txt{order:2}
.fblock h2{font-size:30px;margin-bottom:12px}
.fblock p{color:var(--muted);font-size:16.5px;margin-bottom:16px}
.checklist{list-style:none}
.checklist li{padding:9px 0 9px 34px;position:relative;font-size:16px}
.checklist li:before{content:"";position:absolute;left:0;top:11px;width:22px;height:22px;border-radius:7px;background:#eaf1fd;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232E6BE6'%3E%3Cpath d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.4-1.4z'/%3E%3C/svg%3E");background-size:15px;background-repeat:no-repeat;background-position:center}
.visualcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--sh)}
.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1200px}
.mini{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--sh-sm);transition:transform .25s ease,box-shadow .25s ease}
.mini:hover{transform:translateY(-5px) rotateX(3deg);box-shadow:0 22px 44px rgba(11,35,64,.15)}
.mini .si{width:50px;height:50px;border-radius:13px;background:linear-gradient(135deg,#eaf1fd,#dbe8fb);display:flex;align-items:center;justify-content:center;margin-bottom:15px}
.mini .si svg{width:26px;height:26px;fill:var(--accent)}
.mini h3{font-size:18px;margin-bottom:7px}
.mini p{color:var(--muted);font-size:15px}
@media(max-width:820px){.fblock{grid-template-columns:1fr;gap:28px}.fblock.rev-order .txt{order:0}.cards2,.cards3{grid-template-columns:1fr}}
.logo img{width:auto;display:block}
header .logo img{height:30px}
footer .logo img{height:30px;margin-bottom:14px}
.townchips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:880px;margin:36px auto 0}
.townchips a{background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-weight:600;font-size:14.5px;color:var(--navy);box-shadow:var(--sh-sm);transition:.15s}
.townchips a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.trustpill{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-weight:600;font-size:14.5px;color:var(--navy);box-shadow:var(--sh-sm)}
.trustpill svg{width:18px;height:18px;fill:var(--teal)}
.person{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--sh-sm)}
.person .av{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--navy2));color:#fff;font-family:"Sora";font-weight:800;font-size:20px;display:flex;align-items:center;justify-content:center;flex:none}
.person b{font-family:"Sora";color:var(--navy);font-size:16px}
.person small{color:var(--muted);font-size:14px}
.btn-mail{background:#2A62D6;color:#fff;box-shadow:0 10px 24px rgba(42,98,214,.28)}
.btn-mail:hover{background:#1e51bd;color:#fff}
.wafab{position:fixed;right:22px;bottom:22px;z-index:80;display:inline-flex;align-items:center;gap:10px;background:var(--wa);color:#fff;font-family:"Sora",sans-serif;font-weight:700;font-size:15px;padding:14px 22px;border-radius:40px;box-shadow:0 14px 34px rgba(37,211,102,.5);transition:.18s}
.wafab:hover{background:var(--wa-d);transform:translateY(-3px);color:#fff}
.wafab svg{width:24px;height:24px;fill:currentColor}
@media(max-width:960px){.wafab{bottom:84px;right:16px;width:58px;height:58px;padding:0;justify-content:center;border-radius:50%}.wafab .lbl{display:none}}
.cform input,.cform textarea{width:100%;padding:12px 14px;margin-bottom:12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:15px;color:var(--text);background:#fff}
.cform input:focus,.cform textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(42,98,214,.14)}
.cform textarea{resize:vertical;min-height:110px}
.cform .hp{display:none}
.cform .privacy{font-size:12.5px;color:var(--muted);margin:2px 0 12px}
.cform .privacy a{color:var(--accent)}
.cform .captcha-q{display:block;font-size:14px;color:var(--navy);font-weight:600;margin:2px 0 8px}
.cform .captcha-q b{color:var(--cta)}
/* --- Bewegung & Politur --- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.hstack .gcard{animation:floaty 6s ease-in-out infinite}
.hstack .gcard:last-child{animation-duration:7.5s;animation-delay:.6s}
@keyframes heroglow{0%,100%{opacity:.45;transform:scale(1)}50%{opacity:.85;transform:scale(1.18)}}
.hero::after{content:"";position:absolute;top:-160px;right:-120px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(46,107,230,.4),transparent 65%);filter:blur(24px);animation:heroglow 9s ease-in-out infinite;pointer-events:none;z-index:1}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1.35px);background-size:28px 28px;pointer-events:none;z-index:1}
.final{position:relative;overflow:hidden}
.final .wrap{position:relative;z-index:2}
.final::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1.35px);background-size:28px 28px;pointer-events:none}
.tcard{transition:transform .25s ease,box-shadow .25s ease}
.tcard:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(8,21,36,.28)}
.tcard .eyebrow{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);color:#fff}
.subhero .crumbs{margin-bottom:18px}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}.hstack .gcard,.hero::after{animation:none!important}}
@media(max-width:960px){footer{padding-bottom:100px}}
.legal{max-width:840px;margin:0 auto}
.legal h2{font-size:21px;margin:34px 0 10px}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:17px;margin:22px 0 6px;color:var(--navy)}
.legal p{margin-bottom:14px}
.legal ul{margin:0 0 16px 22px}
.legal li{margin-bottom:6px}
.legal a{color:var(--accent)}
