/* Pacific Hyperbarics — Laguna Beach · "Clinical Luxury" (from Designs/design_1.html, extended site-wide) */
:root{
  --navy:#0A2D6C; --navy-900:#06204A; --navy-700:#0B3A7A;
  --teal:#0D96B2; --teal-bright:#19A6C4; --teal-soft:#E6F4F8;
  --ink:#16233A; --muted:#5C6B82; --faint:#8A98AD;
  --line:#E7ECF3; --tint:#F4F8FB; --paper:#FFFFFF; --sand:#FBF9F5;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,.display{font-family:'Fraunces',serif;font-weight:600;line-height:1.08;letter-spacing:-.015em;color:var(--navy)}
a{color:inherit;text-decoration:none}
img{max-width:100%}
::selection{background:var(--teal);color:#fff}
[id]{scroll-margin-top:110px}
a:focus-visible,.btn:focus-visible,summary:focus-visible{outline:2.5px solid var(--teal);outline-offset:3px;border-radius:6px}
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.eyebrow{font-family:'Inter';font-weight:600;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--teal)}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;padding:15px 28px;border-radius:100px;transition:transform .2s,box-shadow .2s,background .2s,border-color .2s,color .2s;cursor:pointer;border:0;font-family:'Inter',sans-serif;white-space:nowrap}
.btn:hover{transform:translateY(-1.5px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,var(--navy-700),var(--navy) 55%,var(--navy-900));color:#fff;box-shadow:0 10px 24px -12px rgba(10,45,108,.55)}
.btn-primary:hover{box-shadow:0 16px 32px -14px rgba(10,45,108,.65)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);box-shadow:0 10px 24px -16px rgba(13,150,178,.45)}
.btn-teal{background:linear-gradient(120deg,var(--teal),var(--teal-bright));color:#fff;box-shadow:0 10px 24px -12px rgba(13,150,178,.6)}
.btn-teal:hover{box-shadow:0 16px 32px -14px rgba(13,150,178,.7);filter:brightness(1.04)}
.pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--navy);background:var(--teal-soft);padding:7px 15px;border-radius:100px}
.check{width:20px;height:20px;border-radius:50%;background:var(--teal-soft);color:var(--teal);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex:none}

/* ---------- top bar + nav ---------- */
.topbar{background:var(--navy-900);color:#cfe0f0;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:8px;flex-wrap:wrap;padding-top:4px;padding-bottom:4px}
.topbar a{color:#fff;font-weight:600}
.topbar .dot{color:var(--teal-bright);margin:0 10px}
nav.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--line),0 14px 34px -26px rgba(10,45,108,.35)}
nav.site .wrap{display:flex;align-items:center;height:84px;gap:28px}
nav.site .brand img{height:44px;display:block}
.navlinks{display:flex;gap:22px;font-size:15px;font-weight:500;color:var(--ink)}
.navlinks a{position:relative;padding:6px 0;white-space:nowrap;transition:color .15s}
.navlinks a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;border-radius:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .22s}
.navlinks a:hover{color:var(--teal)}
.navlinks a:hover::after,.navlinks a.active::after{transform:scaleX(1)}
.navlinks a.active{color:var(--teal)}
.navcta{margin-left:auto;display:flex;align-items:center;gap:18px}
.navphone{font-weight:700;color:var(--navy);font-size:15px;white-space:nowrap}
.navburger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;padding:8px;color:var(--navy)}

/* ---------- hero (home) ---------- */
.hero{position:relative;overflow:hidden;background:
   radial-gradient(900px 600px at 88% -10%, rgba(25,166,196,.16), transparent 60%),
   radial-gradient(700px 500px at 0% 110%, rgba(10,45,108,.07), transparent 55%),
   var(--paper)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding-top:78px;padding-bottom:84px}
.hero h1{font-size:60px;font-weight:600;margin:22px 0}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero p.lede{font-size:19px;color:var(--muted);max-width:520px;margin-bottom:32px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.hero .reassure{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}
.hero .reassure b{color:var(--navy)}
.hero-art{position:relative;height:480px;border-radius:28px;overflow:hidden;
  background:linear-gradient(155deg,#0B3A7A 0%, #0A2D6C 45%, #06204A 100%);
  box-shadow:0 0 0 1px rgba(10,45,108,.08),0 24px 50px -22px rgba(10,45,108,.4),0 60px 110px -40px rgba(10,45,108,.45)}
.hero-art::after{content:"";position:absolute;inset:0;border-radius:28px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);pointer-events:none}
.hero-art .glow{position:absolute;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(25,166,196,.55),transparent 65%);top:-90px;right:-90px;filter:blur(10px)}
.hero-art .chamber{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);width:300px;height:150px;
  border-radius:100px;background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.04));
  border:1.5px solid rgba(255,255,255,.4);box-shadow:inset 0 2px 30px rgba(255,255,255,.25)}
.hero-art .chamber::before{content:"";position:absolute;left:18px;top:24px;width:70px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.35),transparent 70%)}
.hero-art img.photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-art .shade,.feature-art .shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,32,74,0) 50%,rgba(6,32,74,.72) 100%)}
.bubble{position:absolute;border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.9),rgba(25,166,196,.25));border:1px solid rgba(255,255,255,.3)}
.hero-art .b1{width:26px;height:26px;left:60px;bottom:60px}
.hero-art .b2{width:16px;height:16px;left:120px;bottom:130px;opacity:.8}
.hero-art .b3{width:40px;height:40px;right:80px;bottom:90px;opacity:.7}
.hero-art .b4{width:12px;height:12px;right:150px;bottom:160px;opacity:.6}
.hero-art .tag{position:absolute;left:24px;bottom:22px;color:#bfe2ec;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.hero-art .floatcard{position:absolute;right:22px;bottom:22px;background:rgba(255,255,255,.97);border-radius:16px;padding:14px 18px 14px 16px;box-shadow:0 20px 40px rgba(6,32,74,.3);border-left:3px solid var(--teal)}
.floatcard .n{font-family:'Fraunces';font-size:30px;color:var(--navy);font-weight:600;line-height:1}
.floatcard .l{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- inner page hero ---------- */
.page-hero{position:relative;overflow:hidden;background:
   radial-gradient(700px 420px at 95% -20%, rgba(25,166,196,.2), transparent 60%),
   radial-gradient(520px 320px at 8% 120%, rgba(25,166,196,.1), transparent 60%),
   linear-gradient(120deg,var(--navy),var(--navy-900));color:#fff;padding:76px 0 68px}
.page-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--teal),transparent 70%)}
.page-hero .bubble{pointer-events:none}
.page-hero .eyebrow{color:var(--teal-bright)}
.page-hero h1{color:#fff;font-size:50px;margin:16px 0 14px;max-width:780px}
.page-hero p{color:#c6d4e8;font-size:18px;max-width:660px}
.crumbs{font-size:13px;color:#9fb2cd;margin-bottom:6px}
.crumbs a{color:#cfe0f0}
.crumbs a:hover{color:#fff}

/* ---------- trust strip ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--tint),#FBFDFE)}
.trust .wrap{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:26px 40px;flex-wrap:wrap}
.trust .item{display:flex;align-items:center;gap:11px;font-size:14px;font-weight:600;color:var(--navy)}
.trust .ico{width:36px;height:36px;border-radius:10px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--teal);box-shadow:0 6px 14px -8px rgba(10,45,108,.25)}
.trust .ico svg{width:18px;height:18px}
@media (min-width:881px){
  .trust .item+.item{position:relative;padding-left:24px}
  .trust .item+.item::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:26px;background:var(--line)}
}

/* ---------- sections ---------- */
section{padding:96px 0}
section.tight{padding:72px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin:0 auto 56px;text-align:center}
.sec-head.center .eyebrow{display:inline-flex;align-items:center;gap:14px}
.sec-head.center .eyebrow::before,.sec-head.center .eyebrow::after{content:"";width:30px;height:1.5px;background:linear-gradient(90deg,transparent,var(--teal));border-radius:2px}
.sec-head.center .eyebrow::after{background:linear-gradient(90deg,var(--teal),transparent)}
.sec-head h2{font-size:44px;margin:16px 0 18px}
.sec-head p{font-size:18px;color:var(--muted)}

/* positioning band */
.position{background:var(--navy);color:#fff}
.position .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.position h2{color:#fff;font-size:40px}
.position .eyebrow{color:var(--teal-bright)}
.position p{color:#cdd9ea;font-size:17px;margin-top:18px}
.position .vs{display:flex;flex-direction:column;gap:14px}
.vsrow{display:flex;align-items:flex-start;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:16px 18px;transition:background .2s,border-color .2s,transform .2s}
.position .vsrow:hover{background:rgba(255,255,255,.09);border-color:rgba(25,166,196,.45);transform:translateX(4px)}
.vsrow .v{color:var(--teal-bright);flex:none;font-weight:800}
.vsrow b{color:#fff}.vsrow span{color:#b9c8de;font-size:14px}

/* cards grid (conditions / benefits / posts) */
.cond-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cond{position:relative;border:1px solid var(--line);border-radius:20px;padding:30px;transition:transform .25s,box-shadow .25s,border-color .25s;background:#fff;display:block;overflow:hidden}
.cond::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.cond:hover{box-shadow:0 8px 18px -12px rgba(10,45,108,.12),0 28px 56px -24px rgba(10,45,108,.22);transform:translateY(-4px);border-color:#d8e6ef}
.cond:hover::before{transform:scaleX(1)}
.cond .ic{width:52px;height:52px;border-radius:14px;background:var(--teal-soft);color:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:background .25s,color .25s}
.cond:hover .ic{background:linear-gradient(135deg,var(--teal),var(--teal-bright));color:#fff}
.cond h3{font-size:21px;margin-bottom:8px}
.cond p{font-size:14.5px;color:var(--muted)}
.cond .more{display:inline-block;margin-top:14px;font-size:14px;font-weight:600;color:var(--teal)}

/* benefits band */
.benefits{background:var(--sand)}
.ben-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.ben{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 20px;text-align:center;transition:transform .25s,box-shadow .25s}
.ben:hover{box-shadow:0 8px 18px -12px rgba(10,45,108,.1),0 24px 48px -20px rgba(10,45,108,.18);transform:translateY(-4px)}
.ben .ic{width:50px;height:50px;border-radius:50%;background:var(--teal-soft);color:var(--teal);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:inset 0 0 0 1px rgba(13,150,178,.14);transition:background .25s,color .25s}
.ben:hover .ic{background:linear-gradient(135deg,var(--teal),var(--teal-bright));color:#fff}
.ben h3{font-size:16.5px;margin-bottom:6px}
.ben p{font-size:13px;color:var(--muted);line-height:1.5}

/* chamber feature */
.feature{background:var(--sand)}
.feature .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center}
.feature-art{height:440px;border-radius:24px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,#10406f,#0A2D6C);box-shadow:0 0 0 1px rgba(10,45,108,.08),0 18px 40px -18px rgba(10,45,108,.35),0 50px 90px -36px rgba(10,45,108,.45)}
.feature-art::after{content:"";position:absolute;inset:0;border-radius:24px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.16);pointer-events:none}
.feature-art .ring{position:absolute;border:1px solid rgba(255,255,255,.16);border-radius:50%}
.feature-art img.photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature-art .specs{position:absolute;left:0;right:0;bottom:0;padding:26px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.spec{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:13px 15px;backdrop-filter:blur(6px)}
.spec .n{font-family:'Fraunces';font-size:24px;color:#fff;font-weight:600}
.spec .l{font-size:12px;color:#bcd0ea}
.flist{list-style:none;margin-top:24px}
.flist li{display:flex;gap:13px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line);font-size:15.5px}
.flist li:last-child{border:0}

/* insurance + physician split */
.split2{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.panel{border-radius:24px;padding:44px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.panel:hover{transform:translateY(-3px);box-shadow:0 30px 60px -28px rgba(10,45,108,.3)}
.panel.ins{background:linear-gradient(160deg,#E9F5F9,#F4FAFC);border:1px solid #d6ebf1}
.panel.phys{background:linear-gradient(160deg,#0A2D6C,#06204A);color:#fff}
.panel.phys::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;right:-110px;top:-110px;background:radial-gradient(circle,rgba(25,166,196,.32),transparent 65%);pointer-events:none}
.panel h3{font-size:30px;margin:14px 0}
.panel.phys h3{color:#fff}
.panel p{color:var(--muted);font-size:15.5px;margin-bottom:22px}
.panel.phys p{color:#c6d4e8}
.panel .tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.panel.phys .pill{background:rgba(255,255,255,.12);color:#fff}

/* stats */
.stats{background:
   radial-gradient(640px 320px at 12% 0%, rgba(25,166,196,.14), transparent 60%),
   radial-gradient(640px 320px at 88% 100%, rgba(25,166,196,.1), transparent 60%),
   var(--navy-900);color:#fff;text-align:center}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat .n{font-family:'Fraunces';font-size:58px;font-weight:600;color:#fff;line-height:1}
.stat .n em{color:var(--teal-bright);font-style:normal}
.stat .l{color:#aebfd6;font-size:15px;margin-top:8px}
@media (min-width:881px){
  .stat+.stat{position:relative}
  .stat+.stat::before{content:"";position:absolute;left:-15px;top:50%;transform:translateY(-50%);width:1px;height:64px;background:rgba(255,255,255,.14)}
}

/* testimonial */
.quote{max-width:880px;margin:0 auto;text-align:center}
.quote .mark{font-family:'Fraunces';font-size:80px;color:var(--teal);line-height:.6;height:40px}
.quote .stars{color:#F2B01E;font-size:18px;letter-spacing:4px;margin-bottom:14px}
.quote blockquote{font-family:'Fraunces';font-size:30px;font-weight:500;color:var(--navy);line-height:1.4;margin:10px 0 26px}
.quote .by{font-weight:600;color:var(--ink)}.quote .role{color:var(--faint);font-size:14px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px 24px;transition:transform .25s,box-shadow .25s}
.step:hover{transform:translateY(-4px);box-shadow:0 24px 48px -20px rgba(10,45,108,.18)}
.step::before{counter-increment:s;content:counter(s,decimal-leading-zero);display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--teal-soft);box-shadow:inset 0 0 0 1px rgba(13,150,178,.16);font-family:'Fraunces';font-size:17px;color:var(--teal);font-weight:600}
.step h3{font-size:19px;margin:14px 0 7px}
.step p{font-size:14px;color:var(--muted)}
.step .bar{height:3px;width:46px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));border-radius:3px;margin-top:16px}

/* CTA */
.cta{position:relative;overflow:hidden;background:
   radial-gradient(700px 400px at 100% 0%, rgba(25,166,196,.3), transparent 60%),
   radial-gradient(560px 360px at 0% 100%, rgba(25,166,196,.14), transparent 60%),
   linear-gradient(120deg,var(--navy),var(--navy-900));color:#fff;text-align:center}
.cta::before,.cta::after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.08);pointer-events:none}
.cta::before{width:420px;height:420px;left:-160px;top:-160px}
.cta::after{width:300px;height:300px;right:-110px;bottom:-110px}
.cta h2{color:#fff;font-size:48px;margin-bottom:18px}
.cta p{color:#c6d4e8;font-size:18px;max-width:560px;margin:0 auto 32px}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}

/* ---------- prose (blog post, condition detail) ---------- */
.prose{max-width:760px;margin:0 auto;font-size:17px}
.prose h2{font-size:30px;margin:38px 0 14px}
.prose p{margin-bottom:18px;color:var(--ink)}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{margin-bottom:8px}
.prose .meta{color:var(--faint);font-size:14px;margin-bottom:28px}

/* blog cards */
.post-card{position:relative;border:1px solid var(--line);border-radius:20px;padding:32px;background:#fff;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;flex-direction:column;overflow:hidden}
.post-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.post-card:hover{box-shadow:0 8px 18px -12px rgba(10,45,108,.12),0 28px 56px -24px rgba(10,45,108,.22);transform:translateY(-4px);border-color:#d8e6ef}
.post-card:hover::before{transform:scaleX(1)}
.post-card .date{font-size:12.5px;color:var(--teal);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.post-card h3{font-size:22px;margin-bottom:10px}
.post-card p{font-size:14.5px;color:var(--muted);flex:1}
.post-card .more{margin-top:16px;font-weight:600;color:var(--teal);font-size:14px;transition:transform .2s;display:inline-block}
.post-card:hover .more{transform:translateX(4px)}
.post-card .thumb{margin:-32px -32px 22px;height:190px;overflow:hidden;border-bottom:1px solid var(--line)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.post-card:hover .thumb img{transform:scale(1.045)}
.post-hero-img{margin:0 0 30px;border-radius:20px;overflow:hidden;box-shadow:0 0 0 1px var(--line),0 26px 52px -26px rgba(10,45,108,.3)}
.post-hero-img img{width:100%;max-height:420px;object-fit:cover;display:block}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-size:13.5px;font-weight:600;color:var(--navy);margin-bottom:6px}
input[type=text],input[type=email],input[type=tel],select,textarea{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:'Inter',sans-serif;
  font-size:15px;color:var(--ink);background:#fff;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,150,178,.12)}
textarea{min-height:120px;resize:vertical}
.form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:42px;box-shadow:0 6px 16px -10px rgba(10,45,108,.08),0 34px 70px -36px rgba(10,45,108,.3)}
.form-card h3{position:relative;padding-bottom:14px;margin-bottom:8px}
.form-card h3::after{content:"";position:absolute;left:0;bottom:0;width:44px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--teal),var(--teal-bright))}
.alert{border-radius:14px;padding:16px 20px;margin-bottom:24px;font-size:15px;font-weight:500}
.alert.ok{background:#E8F7EE;color:#11643B;border:1px solid #BFE8CF}
.alert.err{background:#FDEDEE;color:#8C1F28;border:1px solid #F5C8CC}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* FAQ accordion */
.faq-cat{margin-bottom:36px}
.faq-cat h2{font-size:26px;margin-bottom:16px}
.faq{border:1px solid var(--line);border-radius:14px;background:#fff;margin-bottom:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq:hover{border-color:#cfe3ec}
.faq[open]{border-color:rgba(13,150,178,.45);box-shadow:0 16px 36px -22px rgba(10,45,108,.25)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;font-weight:600;font-size:16px;color:var(--navy)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Fraunces';font-size:22px;color:var(--teal);transition:.2s;flex:none}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 22px 20px;color:var(--muted);font-size:15px;border-top:1px dashed var(--line);padding-top:14px;margin:0 0}

/* contact layout */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
.info-card{background:var(--tint);border:1px solid var(--line);border-radius:22px;padding:36px}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border:0}
.info-row .ic{width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--line);color:var(--teal);display:flex;align-items:center;justify-content:center;flex:none}
.info-row b{color:var(--navy);display:block;font-size:14px}
.info-row span,.info-row a{color:var(--muted);font-size:14.5px}
.map-embed{border:0;width:100%;height:380px;border-radius:22px;margin-top:26px;box-shadow:0 0 0 1px var(--line),0 24px 48px -24px rgba(10,45,108,.25)}

/* footer */
footer{position:relative;background:
   radial-gradient(700px 360px at 90% 0%, rgba(25,166,196,.08), transparent 60%),
   #061A3C;color:#9fb2cd;font-size:14px;padding:74px 0 40px}
footer::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),rgba(25,166,196,0) 70%)}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.1)}
footer img{height:42px;margin-bottom:16px}
footer .ftag{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-bright);font-weight:600;margin-bottom:14px}
footer h4{color:#fff;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
footer a{display:block;color:#9fb2cd;padding:5px 0;transition:color .15s,transform .15s}
footer a:hover{color:#fff;transform:translateX(3px)}
footer .bottom{display:flex;justify-content:space-between;padding-top:26px;font-size:13px;color:#6f84a3;flex-wrap:wrap;gap:10px}
footer .legal-links{margin-left:14px}
footer .legal-links a{display:inline;padding:0;color:#9fb2cd;text-decoration:underline;text-underline-offset:3px}
footer .legal-links a:hover{color:#fff;transform:none}

/* form consent + fine print */
.consent{display:flex;gap:11px;align-items:flex-start;margin-top:18px;font-size:13px;color:var(--muted);line-height:1.55}
.consent input[type=checkbox]{width:17px;height:17px;margin-top:2px;flex:none;accent-color:var(--teal)}
.consent a{color:var(--teal);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.fineprint{margin-top:14px;font-size:12px;color:var(--faint);line-height:1.5}
.fineprint a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.disclaimer{max-width:520px;color:#7e92b0}

/* generic 2-col layout that collapses on mobile */
.grid2{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center}
.grid2.even{grid-template-columns:1fr 1fr}
.icon-row{display:grid;grid-template-columns:64px 1fr;gap:24px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .wrap{padding:0 28px}
  .hero h1{font-size:48px}
  .cond-grid{grid-template-columns:repeat(2,1fr)}
  .ben-grid{grid-template-columns:repeat(3,1fr)}
  .steps,.stats .grid{grid-template-columns:repeat(2,1fr);row-gap:40px}
  footer .grid{grid-template-columns:1fr 1fr}
}
@media (max-width:1180px){
  .navlinks{gap:16px}
}
@media (max-width:990px){
  .navlinks{display:none;position:absolute;top:84px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;gap:0;padding:10px 28px 18px;box-shadow:0 30px 40px -20px rgba(10,45,108,.15)}
  .navlinks.open{display:flex}
  .navlinks a{padding:12px 0;border-bottom:1px solid var(--line);font-size:16px}
  .navburger{display:block;margin-left:auto}
  .navcta{margin-left:0}
  .navcta .btn{display:none}
}
@media (max-width:880px){
  .hero .wrap,.position .wrap,.feature .wrap,.grid2{grid-template-columns:1fr}
  .hero-art{height:380px}
  .split2,.contact-grid,.form-grid{grid-template-columns:1fr}
  .page-hero h1{font-size:38px}
  .sec-head h2{font-size:34px}
  section{padding:64px 0}
  .topbar .left{display:none}
}
@media (max-width:560px){
  .wrap{padding:0 20px}
  .hero h1{font-size:36px}
  .hero p.lede{font-size:17px}
  .cond-grid,.ben-grid,.steps,.stats .grid{grid-template-columns:1fr}
  .icon-row{grid-template-columns:1fr;gap:12px}
  .quote blockquote{font-size:22px}
  .cta h2{font-size:34px}
  .panel{padding:30px}
  .form-card{padding:28px}
  footer .grid{grid-template-columns:1fr}
}
