/* ============================================================
   Carolina CDL Training Center — shared design system
   "Working Yard": navy #282D68 + signal red #B51C2A, real photography,
   wide mechanical display type. Hand-coded, no builder. Ports to WP theme.
   ============================================================ */
:root{
  --navy:#1c2150; --navy-2:#282d68; --ink:#11132b; --red:#b51c2a; --red-hi:#d8242f;
  --paper:#f5f2ea; --concrete:#e6e1d4; --steel:#6c7194; --steel-d:#3a3f63;
  --green:#0d8a44;
  --line:rgba(255,255,255,.12); --line-d:rgba(17,19,43,.12);
  --fx:cubic-bezier(.2,.7,.2,1);
  --pad:clamp(20px,5vw,90px);
  --f-disp:"Archivo Expanded",sans-serif; --f-head:"Archivo",sans-serif;
  --f-body:"Hanken Grotesk",sans-serif; --f-mono:"JetBrains Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--paper);color:var(--ink);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3{font-family:var(--f-disp);line-height:.96;letter-spacing:-.02em;font-weight:900;text-transform:uppercase}
.wrap{max-width:1500px;margin-inline:auto;padding-inline:var(--pad)}
.wrap-narrow{max-width:920px;margin-inline:auto;padding-inline:var(--pad)}
.kicker{font-family:var(--f-mono);font-size:.72rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.55em}
.kicker::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.center{text-align:center}

/* buttons */
.btn{font-family:var(--f-head);font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:.86rem;display:inline-flex;align-items:center;gap:.6em;padding:1.05em 1.7em;
  border:2px solid transparent;cursor:pointer;transition:.25s var(--fx);white-space:nowrap}
.btn iconify-icon{font-size:1.2em}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-hi);transform:translateY(-2px)}
.btn-ghost{border-color:currentColor;background:transparent}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--navy-2)}
.btn-lg{font-size:1rem;padding:1.2em 2em}
.brand-logo{height:34px;width:auto}
.brand-logo .st0{fill:var(--red)} .brand-logo .st1{fill:#fff}

.hazard{height:8px;background:repeating-linear-gradient(135deg,var(--red) 0 18px,var(--ink) 18px 36px)}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--ink);color:#cdd0e6;font-size:.78rem;font-family:var(--f-head);font-weight:500}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;height:40px}
.topbar a{display:inline-flex;align-items:center;gap:.45em;transition:.2s}
.topbar a:hover{color:#fff}
.topbar .tb-l{display:flex;gap:22px}
.topbar .tb-r{display:flex;gap:18px;align-items:center}
.topbar .pill{color:#fff;font-weight:700;letter-spacing:.02em}
.topbar .pill iconify-icon{color:var(--red)}
.langsw{display:inline-flex;gap:7px;align-items:center;font-family:var(--f-head);font-weight:700;letter-spacing:.04em}
.langsw a,.langsw strong{font-size:.74rem;padding:2px 6px;border:1px solid var(--line);color:#cdd0e6}
.langsw strong{background:var(--red);border-color:var(--red);color:#fff}
.langsw a:hover{color:#fff;border-color:#fff}
@media(max-width:820px){.topbar .tb-l span:last-child{display:none}}
@media(max-width:560px){.topbar .tb-r .socials{display:none}.topbar .tb-r a span{display:none}}

/* ---------- HEADER ---------- */
.hdr{position:sticky;top:0;z-index:60;background:rgba(17,19,43,0);transition:.3s var(--fx)}
.hdr.solid{background:rgba(17,19,43,.97);box-shadow:0 10px 40px rgba(0,0,0,.35);backdrop-filter:blur(8px)}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px}
.nav{display:flex;align-items:center;gap:28px}
.nav>a,.nav .has-drop>span:not(.drop){font-family:var(--f-head);font-weight:600;font-size:.92rem;color:#fff;letter-spacing:.01em;
  position:relative;padding:6px 0;cursor:pointer;display:inline-flex;align-items:center;gap:.3em}
.nav>a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--red);transition:.25s var(--fx)}
.nav>a:hover::after{width:100%}
.has-drop{position:relative}
.has-drop .drop{position:absolute;top:100%;left:-16px;background:#fff;min-width:230px;padding:10px;
  box-shadow:0 24px 50px rgba(0,0,0,.25);opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.22s var(--fx);border-top:3px solid var(--red)}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:none}
.has-drop .drop a{display:flex;align-items:center;gap:.6em;padding:11px 14px;color:var(--ink);
  font-family:var(--f-head);font-weight:600;font-size:.9rem;transition:.18s}
.has-drop .drop a iconify-icon{color:var(--red);font-size:1.2em}
.has-drop .drop a:hover{background:var(--paper);color:var(--red)}
.hdr-cta{display:flex;align-items:center;gap:18px}
.hdr-phone{font-family:var(--f-head);font-weight:700;color:#fff;font-size:1rem;display:flex;align-items:center;gap:.5em}
.hdr-phone iconify-icon{color:var(--red);font-size:1.2em}
.burger{display:none;background:none;border:0;color:#fff;font-size:1.8rem;cursor:pointer}
@media(max-width:1180px){.nav,.hdr-phone{display:none}.burger{display:block}}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:95;background:var(--ink);transform:translateX(100%);visibility:hidden;
  transition:transform .4s var(--fx),visibility .4s;display:flex;flex-direction:column;padding:26px var(--pad);overflow-y:auto}
.drawer.open{transform:none;visibility:visible}
.drawer .x{align-self:flex-end;background:none;border:0;color:#fff;font-size:2rem;cursor:pointer}
.drawer a{color:#fff;font-family:var(--f-disp);font-weight:800;text-transform:uppercase;
  font-size:1.3rem;padding:13px 0;border-bottom:1px solid var(--line)}
.drawer a.sub{font-family:var(--f-head);font-size:1rem;text-transform:none;padding-left:14px;opacity:.85}
.drawer .btn{margin-top:24px;justify-content:center}

/* ---------- HERO (home) ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;
  margin-top:-78px;padding-top:78px}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(17,19,43,.94) 0%,rgba(17,19,43,.7) 38%,rgba(17,19,43,.15) 75%),
  linear-gradient(0deg,rgba(17,19,43,.85),transparent 45%)}
.hero .wrap{width:100%;padding-bottom:clamp(40px,6vw,86px);padding-top:60px}
.plate{display:inline-flex;align-items:center;gap:.6em;background:var(--red);color:#fff;
  font-family:var(--f-mono);font-weight:700;font-size:.72rem;letter-spacing:.18em;padding:.5em 1em;margin-bottom:26px}
.hero h1{font-size:clamp(2.7rem,7.2vw,6.4rem);max-width:16ch;margin-bottom:22px;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero h1 em{font-style:normal;color:var(--red)}
.hero .sub{font-size:clamp(1.05rem,1.7vw,1.3rem);max-width:46ch;color:#d8dbf0;margin-bottom:34px;font-weight:500}
.hero .acts{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px}
.trust{display:flex;gap:8px 30px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.trust div{display:flex;align-items:center;gap:.5em;font-family:var(--f-head);font-weight:600;font-size:.95rem;color:#eef0fb}
.trust iconify-icon{color:var(--red);font-size:1.35em}

/* ---------- SUBPAGE HERO (banner) ---------- */
.subhero{position:relative;color:#fff;overflow:hidden;background:var(--navy);margin-top:-78px;padding-top:78px}
.subhero-bg{position:absolute;inset:0;z-index:0}
.subhero-bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.subhero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,19,43,.78),rgba(28,33,80,.92))}
.subhero .wrap{position:relative;z-index:1;padding-block:clamp(46px,7vw,96px)}
.subhero h1{font-size:clamp(2.2rem,5.4vw,4.4rem);max-width:20ch;margin:14px 0 16px}
.subhero p{color:#d2d5ee;font-size:clamp(1.02rem,1.5vw,1.2rem);max-width:54ch}
.crumb{display:flex;gap:.5em;align-items:center;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:#9ea3cb;margin-bottom:8px;flex-wrap:wrap}
.crumb a:hover{color:#fff}.crumb iconify-icon{font-size:1em}
.subhero .acts{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

/* ---------- STAT RIBBON ---------- */
.ribbon{background:var(--red);color:#fff}
.ribbon .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.ribbon .s{padding:26px 10px;text-align:center;border-right:1px solid rgba(255,255,255,.18)}
.ribbon .s:last-child{border:0}
.ribbon b{font-family:var(--f-disp);font-weight:900;font-size:clamp(1.5rem,3vw,2.3rem);display:block;line-height:1}
.ribbon span{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;opacity:.9}
@media(max-width:640px){.ribbon .wrap{grid-template-columns:repeat(2,1fr)}.ribbon .s:nth-child(2){border:0}
  .ribbon .s:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.18)}}

/* ---------- SECTIONS ---------- */
section{position:relative}
.sec{padding:clamp(64px,8vw,120px) 0}
.sec-sm{padding:clamp(46px,5vw,76px) 0}
.sec.concrete{background:var(--concrete)}
.sec.navy{background:var(--navy);color:#fff}
.sec.ink{background:var(--ink);color:#fff}
.sec.navy h2,.sec.ink h2{color:#fff}
.sec-head{margin-bottom:54px;max-width:780px}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.6rem);margin:16px 0 0}
.sec-head .kicker{color:var(--red)}
.sec-head p{margin-top:18px;color:var(--steel-d);font-size:1.05rem}
.sec.navy .sec-head p,.sec.ink .sec-head p{color:#c7cbe8}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .kicker{justify-content:center}

/* ---------- PROSE (articles, legal, rich text) ---------- */
.prose{font-size:1.05rem;color:#2a2d44;max-width:74ch}
.prose>*+*{margin-top:1.1em}
.prose h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-top:1.8em;margin-bottom:.2em}
.prose h3{font-family:var(--f-head);font-weight:800;text-transform:none;letter-spacing:0;font-size:1.3rem;margin-top:1.4em}
.prose p,.prose li{line-height:1.75}
.prose ul,.prose ol{padding-left:1.3em}.prose li{margin-top:.5em}
.prose ul li::marker{color:var(--red)}
.prose a{color:var(--red);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink)}
.prose blockquote{border-left:4px solid var(--red);padding:.3em 0 .3em 1.2em;font-size:1.2rem;
  font-family:var(--f-head);font-weight:600;color:var(--navy-2);font-style:italic}
.prose table{width:100%;border-collapse:collapse;font-size:.95rem}
.prose th,.prose td{border:1px solid var(--line-d);padding:12px 14px;text-align:left}
.prose th{background:var(--navy);color:#fff;font-family:var(--f-head);text-transform:uppercase;font-size:.78rem;letter-spacing:.08em}
.prose tr:nth-child(even) td{background:rgba(17,19,43,.03)}

/* ---------- GENERIC GRIDS ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.grid-2{grid-template-columns:1fr;gap:36px}.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid-3,.grid-4{grid-template-columns:1fr}}
.media-img{overflow:hidden;border:1px solid var(--line-d)}
.media-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ---------- PRICING CARDS ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line-d);position:relative;display:flex;flex-direction:column;transition:.3s var(--fx)}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(17,19,43,.14)}
.card-top{padding:30px 30px 22px;border-bottom:1px solid var(--line-d)}
.card .tag{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;color:var(--red);font-weight:700;text-transform:uppercase}
.card h3{font-size:1.7rem;margin:14px 0 4px;font-family:var(--f-disp);font-weight:800}
.card .hrs{font-family:var(--f-head);color:var(--steel);font-weight:600;font-size:.9rem}
.card-body{padding:24px 30px 30px;display:flex;flex-direction:column;gap:14px;flex:1}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:13px;border-bottom:1px dashed var(--line-d)}
.price-row .l{font-weight:600;display:flex;align-items:center;gap:.5em}
.price-row .l iconify-icon{color:var(--navy-2)}
.price-row .p{font-family:var(--f-disp);font-weight:900;font-size:1.45rem;color:var(--ink)}
.card .ftr{margin-top:auto;padding-top:8px}
.card .btn{width:100%;justify-content:center}
.card.feat{background:var(--navy);color:#fff;border-color:var(--navy)}
.card.feat .card-top,.card.feat .price-row{border-color:var(--line)}
.card.feat .hrs{color:#b9bdde}.card.feat .price-row .p,.card.feat .price-row .l iconify-icon{color:#fff}
.card.feat .badge{position:absolute;top:0;right:30px;background:var(--red);color:#fff;font-family:var(--f-mono);
  font-size:.62rem;letter-spacing:.14em;padding:.5em .9em;text-transform:uppercase}
@media(max-width:880px){.cards{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}

/* ---------- BENEFIT / ICON CELLS ---------- */
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d)}
.bcell{background:var(--paper);padding:34px 30px;transition:.3s var(--fx)}
.sec.concrete .bcell{background:var(--concrete)}
.bcell:hover{background:#fff}
.bcell .ic{width:52px;height:52px;display:grid;place-items:center;background:var(--navy);color:#fff;margin-bottom:18px;transition:.3s}
.bcell:hover .ic{background:var(--red)}
.bcell iconify-icon{font-size:1.6rem}
.bcell h3{font-family:var(--f-head);font-weight:700;font-size:1.15rem;text-transform:none;letter-spacing:0;margin-bottom:8px}
.bcell p{color:var(--steel-d);font-size:.95rem}
@media(max-width:880px){.bgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.bgrid{grid-template-columns:1fr}}

/* ---------- STEPS (how to enroll) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{background:#fff;border:1px solid var(--line-d);padding:30px 26px;position:relative;transition:.3s var(--fx)}
.step:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(17,19,43,.12)}
.step .n{font-family:var(--f-disp);font-weight:900;font-size:2.6rem;color:var(--red);line-height:1;margin-bottom:14px}
.step h3{font-family:var(--f-head);font-weight:800;text-transform:none;letter-spacing:0;font-size:1.2rem;margin-bottom:8px}
.step p{color:var(--steel-d);font-size:.95rem}
@media(max-width:980px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.steps{grid-template-columns:1fr}}

/* ---------- COURSE BARS ---------- */
.bars{display:flex;flex-direction:column;gap:18px}
.bar .top{display:flex;justify-content:space-between;font-family:var(--f-head);font-weight:600;margin-bottom:8px}
.bar .top b{font-family:var(--f-disp);font-weight:900;font-size:1.3rem}
.bar .track{height:12px;background:rgba(255,255,255,.1)}
.sec:not(.navy):not(.ink) .bar .track{background:rgba(17,19,43,.08)}
.bar .fill{height:100%;background:var(--red);width:0;transition:width 1.1s var(--fx)}
.bar.r2 .fill{background:#e0e3f5}.bar.r3 .fill{background:#8489b8}.bar.r4 .fill{background:#4a4f7e}
.sched{display:flex;gap:18px;flex-wrap:wrap;margin-top:6px}
.sched .chip{border:1px solid var(--line-d);padding:14px 18px;font-family:var(--f-head);font-weight:600;display:flex;align-items:center;gap:.6em}
.sec.navy .sched .chip,.sec.ink .sched .chip{border-color:var(--line)}
.sched .chip iconify-icon{color:var(--red);font-size:1.3em}

/* ---------- COMPARISON TABLE ---------- */
.cmp{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line-d);font-size:.98rem}
.cmp th,.cmp td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line-d)}
.cmp thead th{background:var(--navy);color:#fff;font-family:var(--f-head);text-transform:uppercase;font-size:.8rem;letter-spacing:.06em}
.cmp tbody th{font-family:var(--f-head);font-weight:700;color:var(--ink)}
.cmp td iconify-icon{color:var(--green);font-size:1.3em}
.cmp tr:hover td,.cmp tr:hover th{background:var(--paper)}

/* ---------- FAQ ACCORDION ---------- */
.faq{max-width:880px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.faq details{background:#fff;border:1px solid var(--line-d);transition:.2s}
.faq details[open]{box-shadow:0 14px 36px rgba(17,19,43,.1)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--f-head);font-weight:700;
  font-size:1.06rem;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq .a{color:var(--steel-d)}
.faq summary::-webkit-details-marker{display:none}
.faq summary iconify-icon{color:var(--red);font-size:1.4em;transition:.3s;flex:none}
.faq details[open] summary iconify-icon{transform:rotate(45deg)}
.faq .a{padding:0 24px 22px;color:var(--steel-d);font-size:1rem}

/* ---------- TESTIMONIAL / QUOTE ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:#fff;border:1px solid var(--line-d);padding:30px;display:flex;flex-direction:column;gap:16px}
.quote .stars{color:#f5a623;font-size:1.1em;display:flex;gap:2px}
.quote p{font-size:1.02rem;color:#2a2d44}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.quote .av{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--f-disp);font-weight:900}
.quote .who b{font-family:var(--f-head);display:block}
.quote .who span{font-size:.82rem;color:var(--steel)}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}

/* ---------- REVIEWS ---------- */
.reviews-agg{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:46px;text-align:center}
.reviews-agg .stars{color:#f5a623;font-size:2.2rem;letter-spacing:4px;line-height:1}
.reviews-agg p{font-size:1.1rem;color:var(--steel-d)}
.reviews-agg b{color:var(--ink);font-family:var(--f-disp);font-weight:900}
#gReviews:empty{display:none}

/* ---------- CTA BAND ---------- */
.cta-band{background:var(--red);color:#fff;text-align:center;padding:clamp(54px,7vw,96px) 0;position:relative;overflow:hidden}
.cta-band::before,.cta-band::after{content:"";position:absolute;top:0;bottom:0;width:34%;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.07) 0 14px,transparent 14px 28px)}
.cta-band::before{left:0}.cta-band::after{right:0}
.cta-band .wrap{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(2rem,4.6vw,3.6rem);max-width:18ch;margin:0 auto 16px}
.cta-band p{color:#ffe0e2;max-width:46ch;margin:0 auto 30px;font-size:1.08rem}
.cta-band .acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .btn-ghost{color:#fff}

/* ---------- FINANCING + CALC ---------- */
.fin-box{background:var(--red);color:#fff;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;
  padding:clamp(36px,5vw,68px);position:relative;overflow:hidden}
.fin-box::before{content:"%";position:absolute;right:-20px;top:-60px;font-family:var(--f-disp);font-weight:900;font-size:20rem;opacity:.08;line-height:1}
.fin-box h2{color:#fff;font-size:clamp(1.8rem,3.6vw,3rem)}
.fin-box .kicker{color:#fff}.fin-box .kicker::before{background:#fff}
.fin-box p{color:#ffe3e5;margin:16px 0 0;max-width:42ch}
.pts{display:flex;flex-direction:column;gap:14px}
.pt{display:flex;gap:14px;align-items:flex-start;font-weight:600}
.pt iconify-icon{font-size:1.5em;flex:none;margin-top:.05em}
.fin-box .cta{grid-column:1/-1;margin-top:8px}
@media(max-width:780px){.fin-box{grid-template-columns:1fr;gap:26px}}
.calc{background:#fff;border:1px solid var(--line-d);padding:clamp(26px,3vw,38px)}
.calc h3{font-family:var(--f-head);font-weight:800;text-transform:none;letter-spacing:0;font-size:1.4rem;margin-bottom:6px}
.calc .muted{color:var(--steel);font-size:.92rem;margin-bottom:22px}
.calc label{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--steel-d);display:block;margin:16px 0 8px}
.calc select,.calc input[type=range]{width:100%}
.calc select{padding:12px 14px;border:1.5px solid var(--line-d);background:var(--paper);font-family:var(--f-body);font-size:1rem}
.calc input[type=range]{accent-color:var(--red);margin-top:6px}
.calc .out{margin-top:24px;background:var(--navy);color:#fff;padding:22px 24px;display:flex;justify-content:space-between;align-items:center}
.calc .out .big{font-family:var(--f-disp);font-weight:900;font-size:2.2rem;line-height:1}
.calc .out small{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.8}
.calc .disclaim{font-size:.74rem;color:var(--steel);margin-top:14px}

/* ---------- PARTNER ---------- */
.partner-li{display:flex;gap:12px;align-items:center;font-weight:600;margin-bottom:10px}
.partner-li iconify-icon{color:var(--red);font-size:1.3em}

/* ---------- GALLERY MARQUEE ---------- */
.gallery{padding:0;background:var(--ink)}
.marq{display:flex;gap:14px;padding:14px;overflow:hidden;mask:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.marq-track{display:flex;gap:14px;animation:slide 38s linear infinite}
.marq img{height:230px;width:340px;object-fit:cover;flex:none;filter:saturate(.95)}
.gallery:hover .marq-track{animation-play-state:paused}
@keyframes slide{to{transform:translateX(calc(-50% - 7px))}}
@media(max-width:640px){.marq img{height:170px;width:250px}}

/* ---------- LOCATIONS ---------- */
.loc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.loc{background:#fff;border:1px solid var(--line-d);padding:26px;transition:.3s var(--fx);display:flex;flex-direction:column;gap:8px}
.loc:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(17,19,43,.12);border-color:var(--red)}
.loc .pin{color:var(--red);font-size:1.7em}
.loc h3{font-family:var(--f-head);font-weight:800;text-transform:none;letter-spacing:0;font-size:1.25rem}
.loc p{color:var(--steel-d);font-size:.94rem}
.loc .go{margin-top:auto;color:var(--red);font-family:var(--f-head);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:.4em}
@media(max-width:900px){.loc-cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.loc-cards{grid-template-columns:1fr}}
.map{width:100%;height:420px;border:0;filter:grayscale(.2) contrast(1.05)}

/* ---------- LEAD FORM ---------- */
.apply{position:relative;color:#fff;background:var(--ink)}
.apply .bg{position:absolute;inset:0;z-index:0}
.apply .bg img{width:100%;height:100%;object-fit:cover;opacity:.18}
.apply .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--ink),rgba(17,19,43,.86))}
.apply .wrap{position:relative;z-index:1;display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
.apply h2{color:#fff;font-size:clamp(2rem,4.4vw,3.4rem);margin:16px 0 18px}
.apply .lead{color:#c7cbe8;font-size:1.08rem;max-width:40ch;margin-bottom:30px}
.contact-card{border:1px solid var(--line);padding:24px}
.contact-card .r{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.contact-card .r:last-child{border:0}
.contact-card iconify-icon{color:var(--red);font-size:1.4em;margin-top:.1em}
.contact-card .t{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.14em;color:#9ea3cb;text-transform:uppercase}
.contact-card .v{font-family:var(--f-head);font-weight:700;font-size:1.02rem}
form.lead-form{background:#fff;color:var(--ink);padding:clamp(26px,3.5vw,40px)}
.field{margin-bottom:18px}
.field label{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--steel-d);display:block;margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;font-family:var(--f-body);font-size:1rem;padding:13px 15px;
  border:1.5px solid var(--line-d);background:var(--paper);color:var(--ink);transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--red);background:#fff}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip-r{position:relative}
.chip-r input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip-r span{display:block;border:1.5px solid var(--line-d);padding:9px 15px;font-size:.86rem;font-weight:600;font-family:var(--f-head);transition:.2s;cursor:pointer}
.chip-r input:checked+span{background:var(--navy);color:#fff;border-color:var(--navy)}
.chip-r input:focus-visible+span{outline:2px solid var(--red);outline-offset:2px}
form .btn{width:100%;justify-content:center;margin-top:8px;font-size:1rem;padding:1.15em}
.consent{font-size:.74rem;color:var(--steel);margin-top:14px;line-height:1.5}
.consent a{color:var(--navy-2);text-decoration:underline}
.form-ok{display:none;background:var(--green);color:#fff;padding:16px;font-weight:600;margin-bottom:16px;align-items:center;gap:.6em}
.form-ok.show{display:flex}
.form-err{display:none;background:#b5302b;color:#fff;padding:14px;font-weight:600;margin-bottom:14px}
.form-err.show{display:block}
@media(max-width:880px){.apply .wrap{grid-template-columns:1fr;gap:36px}}

/* ---------- FOOTER ---------- */
footer{background:#0b0d20;color:#9ea3cb;padding:64px 0 30px}
.fcols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px;margin-bottom:46px}
footer .brand-logo{height:40px;margin-bottom:18px}
footer p.ab{font-size:.92rem;max-width:36ch}
footer h4{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:18px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer a:hover{color:#fff}
footer .nap{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px;font-size:.92rem}
footer .nap iconify-icon{color:var(--red);font-size:1.2em;margin-top:.15em;flex:none}
.fsoc{display:flex;gap:12px;margin-top:6px}
.fsoc a{width:40px;height:40px;border:1px solid var(--line);display:grid;place-items:center;color:#fff;transition:.2s}
.fsoc a:hover{background:var(--red);border-color:var(--red)}
.fbot{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem}
.fbot a{text-decoration:underline}
@media(max-width:880px){.fcols{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fcols{grid-template-columns:1fr}}

/* ---------- STICKY MOBILE CALL/APPLY BAR ---------- */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;grid-template-columns:1fr 1fr;
  background:var(--ink);box-shadow:0 -8px 24px rgba(0,0,0,.3)}
.mbar a{padding:15px;text-align:center;font-family:var(--f-head);font-weight:700;text-transform:uppercase;
  font-size:.84rem;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:.5em;color:#fff}
.mbar a.call{background:var(--navy-2)}.mbar a.apply{background:var(--red)}
@media(max-width:760px){.mbar{display:grid}body{padding-bottom:54px}}

/* ---------- BACK TO TOP ---------- */
.totop{position:fixed;right:20px;bottom:20px;z-index:70;width:48px;height:48px;background:var(--navy);color:#fff;
  display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(14px);pointer-events:none;transition:.3s var(--fx);font-size:1.4rem}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{background:var(--red)}
@media(max-width:760px){.totop{bottom:64px}}

/* ---------- AI CHAT WIDGET ---------- */
.chat-fab{position:fixed;left:20px;bottom:20px;z-index:85;width:60px;height:60px;border-radius:50%;
  background:var(--red);color:#fff;display:grid;place-items:center;cursor:pointer;font-size:1.7rem;
  box-shadow:0 14px 34px rgba(181,28,42,.5);transition:.25s var(--fx);border:0}
.chat-fab:hover{transform:scale(1.07)}
.chat-fab .dot{position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;background:var(--green);border:2px solid #fff}
@media(max-width:760px){.chat-fab{bottom:66px}}
.chat-panel{position:fixed;left:20px;bottom:90px;z-index:86;width:min(380px,calc(100vw - 32px));height:min(560px,70vh);
  background:#fff;display:none;flex-direction:column;box-shadow:0 30px 70px rgba(0,0,0,.4);overflow:hidden;
  border-top:4px solid var(--red)}
.chat-panel.open{display:flex;animation:chatin .3s var(--fx)}
@keyframes chatin{from{opacity:0;transform:translateY(20px)}}
.chat-head{background:var(--navy);color:#fff;padding:16px 18px;display:flex;align-items:center;gap:12px}
.chat-head .ava{width:40px;height:40px;border-radius:50%;background:var(--red);display:grid;place-items:center;font-size:1.3rem;flex:none}
.chat-head b{font-family:var(--f-head);font-size:1rem;display:block}
.chat-head span{font-size:.74rem;color:#b9bdde;display:flex;align-items:center;gap:.4em}
.chat-head span::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green)}
.chat-head .x{margin-left:auto;background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:var(--paper)}
.msg{max-width:84%;padding:11px 15px;font-size:.94rem;line-height:1.5}
.msg.bot{background:#fff;border:1px solid var(--line-d);align-self:flex-start}
.msg.me{background:var(--navy);color:#fff;align-self:flex-end}
.msg.typing{align-self:flex-start;color:var(--steel);font-style:italic}
.chat-sugg{display:flex;flex-wrap:wrap;gap:7px;padding:0 18px 10px;background:var(--paper)}
.chat-sugg button{background:#fff;border:1.5px solid var(--line-d);color:var(--navy-2);font-family:var(--f-head);
  font-weight:600;font-size:.8rem;padding:7px 12px;cursor:pointer;transition:.2s}
.chat-sugg button:hover{border-color:var(--red);color:var(--red)}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line-d);background:#fff}
.chat-input input{flex:1;border:1.5px solid var(--line-d);padding:11px 13px;font-family:var(--f-body);font-size:.95rem}
.chat-input input:focus{outline:0;border-color:var(--red)}
.chat-input button{background:var(--red);color:#fff;border:0;width:44px;display:grid;place-items:center;cursor:pointer;font-size:1.2rem}
.chat-disclaim{font-size:.66rem;color:var(--steel);text-align:center;padding:6px}

/* ---------- REVEAL ANIMATIONS ---------- */
.rv{opacity:0;transform:translateY(26px);transition:.7s var(--fx)}
.rv.in{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-30px);transition:.7s var(--fx)}.rv-l.in{opacity:1;transform:none}
.rv-r{opacity:0;transform:translateX(30px);transition:.7s var(--fx)}.rv-r.in{opacity:1;transform:none}
.rv-sc{opacity:0;transform:scale(.94);transition:.7s var(--fx)}.rv-sc.in{opacity:1;transform:none}
[data-stagger]>*{opacity:0;transform:translateY(22px);transition:.6s var(--fx)}
[data-stagger].in>*{opacity:1;transform:none}
[data-stagger].in>*:nth-child(2){transition-delay:.08s}
[data-stagger].in>*:nth-child(3){transition-delay:.16s}
[data-stagger].in>*:nth-child(4){transition-delay:.24s}
[data-stagger].in>*:nth-child(5){transition-delay:.32s}
[data-stagger].in>*:nth-child(6){transition-delay:.40s}
@media(prefers-reduced-motion:reduce){
  .rv,.rv-l,.rv-r,.rv-sc,[data-stagger]>*{opacity:1!important;transform:none!important}
  .marq-track{animation:none}html{scroll-behavior:auto}
}
/* JS-off safety: if .js not set, never hide content */
html:not(.js) .rv,html:not(.js) .rv-l,html:not(.js) .rv-r,html:not(.js) .rv-sc,
html:not(.js) [data-stagger]>*{opacity:1;transform:none}
