/* Corvell — Full Site Stylesheet (v2 brochureware overhaul)
   Used by all pages in ui_kits/site-v2/.
   Requires ../../colors_and_type.css loaded first. */

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#fff;color:var(--corvell-navy);font-family:var(--font-sans);overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.container-wide{max-width:1340px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}

/* ---------- TOP ANNOUNCEMENT ---------- */
.announce{background:var(--corvell-navy);color:#fff;font:500 12px/1 var(--font-sans);letter-spacing:0.06em;padding:10px 0;text-align:center}
.announce .dot{display:inline-block;width:6px;height:6px;border-radius:999px;background:var(--corvell-blue-300);vertical-align:middle;margin-right:10px;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,0.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--ink-100)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{height:28px}
.nav-links{display:flex;gap:32px}
.nav-links a{font:500 14px/1 var(--font-sans);color:var(--corvell-navy);transition:color 140ms var(--ease-out);position:relative;padding:6px 0}
/* The drawer's "Book a diagnostic" CTA is for mobile only — the desktop
   nav already has a .nav-cta button. Default to hidden; the mobile media
   query below sets display:inline-flex. */
.nav-links .nav-mobile-cta{display:none}
.nav-links a:hover{color:var(--corvell-blue)}
.nav-links a.active{color:var(--corvell-blue)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--corvell-blue)}
.nav-cta{font:500 13px/1 var(--font-sans);background:var(--corvell-blue);color:#fff;padding:11px 18px;border-radius:8px;box-shadow:var(--shadow-brand);transition:all 140ms var(--ease-out)}
.nav-cta:hover{background:var(--corvell-blue-700);transform:translateY(-1px)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font:500 15px/1 var(--font-sans);padding:14px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:all 140ms var(--ease-out);white-space:nowrap}
.btn-primary{background:var(--corvell-blue);color:#fff;box-shadow:var(--shadow-brand)}
.btn-primary:hover{background:var(--corvell-blue-700);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--corvell-navy);border-color:var(--ink-200)}
.btn-secondary:hover{border-color:var(--corvell-blue);color:var(--corvell-blue)}
.btn-white{background:#fff;color:var(--corvell-navy)}
.btn-white:hover{transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(0,0,0,0.3)}
.btn-ghost-white{background:transparent;color:#fff;border-color:rgba(255,255,255,0.3)}
.btn-ghost-white:hover{background:rgba(255,255,255,0.08);border-color:#fff}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{padding:clamp(60px,7vw,96px) 0 clamp(40px,5vw,64px);position:relative;border-bottom:1px solid var(--ink-100)}
.page-hero .rule{width:56px;height:3px;background:var(--corvell-blue);border-radius:999px;margin-bottom:26px}
.page-hero .c-eyebrow{margin-bottom:18px;display:block}
.page-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-0.025em;margin:0 0 22px;max-width:920px;text-wrap:balance;color:var(--corvell-navy)}
.page-hero h1 .accent{color:var(--corvell-blue)}
.page-hero p.lead{font-size:var(--fs-body-lg);color:var(--ink-500);line-height:1.55;margin:0;max-width:680px}
.page-hero .row{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}

/* ---------- SECTION BASE ---------- */
.section{padding:clamp(64px,9vw,112px) 0}
.section-head{max-width:860px;margin-bottom:48px}
.section-head .c-eyebrow{margin-bottom:14px;display:block}
.section-head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-0.02em;margin:0 0 18px;text-wrap:balance;color:var(--corvell-navy)}
.section-head h2 .accent{color:var(--corvell-blue)}
.section-head p.lead{font-size:var(--fs-body-lg);color:var(--ink-500);line-height:1.55;margin:0;max-width:680px}

.section-subtle{background:var(--ink-50)}

/* ---------- FOOTER ---------- */
.footer{background:var(--corvell-navy);color:rgba(255,255,255,0.72);padding:72px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer-logo{height:26px;margin-bottom:20px}
.footer-tag{font:400 13px/1.6 var(--font-sans);max-width:280px}
.footer-col h4{font:600 12px/1 var(--font-sans);letter-spacing:0.12em;text-transform:uppercase;color:#fff;margin:0 0 18px}
.footer-col a{display:block;font:400 14px/1 var(--font-sans);color:rgba(255,255,255,0.65);padding:7px 0;transition:color 140ms var(--ease-out)}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);font:400 12px/1 var(--font-sans);color:rgba(255,255,255,0.5);flex-wrap:wrap;gap:12px}

/* ---------- GENERIC CARD ---------- */
.card{background:#fff;border:1px solid var(--ink-200);border-radius:12px;padding:28px 26px;transition:all 220ms var(--ease-out)}
.card:hover{border-color:var(--corvell-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}

/* ---------- HERO (home) ---------- */
.home-hero{padding:clamp(56px,7vw,88px) 0 clamp(48px,7vw,88px);position:relative}
.home-hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:72px;align-items:end}
.home-hero .rule{width:56px;height:3px;background:var(--corvell-blue);border-radius:999px;margin-bottom:28px}
.home-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(44px,6vw,82px);line-height:1.02;letter-spacing:-0.025em;margin:0;text-wrap:balance;color:var(--corvell-navy)}
.home-hero h1 .accent{color:var(--corvell-blue)}
.home-hero p.lead{font-size:var(--fs-body-lg);color:var(--ink-500);line-height:1.55;margin:26px 0 32px;max-width:520px}
.home-hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}
.home-hero .facts{display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;padding:28px 0 0;margin-top:36px;border-top:1px solid var(--ink-200)}
.fact .n{font:700 clamp(28px,3vw,38px)/1 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.02em}
.fact .n .blue{color:var(--corvell-blue)}
.fact .l{font:400 13px/1.5 var(--font-sans);color:var(--ink-500);margin-top:8px;max-width:220px}

.hero-visual{position:relative;aspect-ratio:4/5;background:var(--corvell-navy);border-radius:var(--r-xl);overflow:hidden;padding:32px;display:flex;flex-direction:column;justify-content:space-between}
.hero-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(0,61,255,0.32),transparent 55%);pointer-events:none}
.hero-visual-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}
.hero-visual-top .mark{width:44px;height:44px}
.hero-visual-top .tag{font:500 11px/1 var(--font-mono);letter-spacing:0.12em;color:rgba(255,255,255,0.6);text-transform:uppercase}
.hero-ticker{position:relative;z-index:1;color:#fff}
.hero-ticker .label{font:600 11px/1 var(--font-sans);letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-bottom:14px}
.hero-ticker .r{display:flex;align-items:center;gap:10px;padding:11px 0;border-top:1px solid rgba(255,255,255,0.1)}
.hero-ticker .r:first-of-type{border-top:0}
.hero-ticker .r .dot{width:8px;height:8px;border-radius:999px;background:var(--success);box-shadow:0 0 10px rgba(0,168,107,0.7);flex-shrink:0}
.hero-ticker .r .dot.warn{background:var(--warning)}
.hero-ticker .r .name{font:500 13px/1.3 var(--font-sans);flex:1}
.hero-ticker .r .meta{font:400 12px/1 var(--font-mono);color:rgba(255,255,255,0.55)}

/* ---------- TRUST STRIP ---------- */
.trust{padding:32px 0 24px;border-top:1px solid var(--ink-100)}
.trust-lbl{font:600 11px/1 var(--font-sans);letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-400);text-align:center;margin-bottom:20px}
.trust-row{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;opacity:.82}
.trust-row span{font:700 15px/1 var(--font-display);letter-spacing:-0.01em;color:var(--ink-500);text-transform:uppercase}
.trust-row .compliance{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--ink-200);border-radius:999px;font:600 11px/1 var(--font-sans);letter-spacing:0.08em;color:var(--ink-500);text-transform:uppercase}

/* ---------- SERVICES GRID ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc{background:#fff;border:1px solid var(--ink-200);border-radius:12px;padding:32px 28px 28px;transition:all 220ms var(--ease-out);cursor:default;display:flex;flex-direction:column;gap:14px;min-height:280px}
.svc:hover{border-color:var(--corvell-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.svc-ic{width:52px;height:52px;border-radius:10px;overflow:hidden;background:var(--corvell-navy)}
.svc-ic img{width:100%;height:100%;object-fit:cover}
.svc-t{font:700 20px/1.15 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.svc-d{font:400 14px/1.6 var(--font-sans);color:var(--ink-500);flex:1}
.svc-link{font:500 13px/1 var(--font-sans);color:var(--corvell-blue);display:inline-flex;align-items:center;gap:6px}

/* ---------- DEEP SERVICE BLOCK (services page) ---------- */
.svc-deep{padding:clamp(64px,8vw,96px) 0;border-bottom:1px solid var(--ink-100)}
.svc-deep-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:72px;align-items:flex-start}
.svc-deep .ic-big{width:72px;height:72px;border-radius:14px;overflow:hidden;background:var(--corvell-navy);margin-bottom:24px}
.svc-deep .ic-big img{width:100%;height:100%;object-fit:cover}
.svc-deep .c-eyebrow{margin-bottom:12px;display:block}
.svc-deep h2{font:700 clamp(30px,3.6vw,44px)/1.07 var(--font-display);letter-spacing:-0.02em;margin:0 0 16px;color:var(--corvell-navy);text-wrap:balance}
.svc-deep .summary{font-size:var(--fs-body-lg);color:var(--ink-500);line-height:1.55;margin:0}
.svc-deep-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.svc-deep-list li{display:flex;gap:10px;font:400 14px/1.5 var(--font-sans);color:var(--corvell-navy);padding:6px 0;border-top:1px solid var(--ink-100)}
.svc-deep-list li:first-child,.svc-deep-list li:nth-child(2){border-top:0}
.svc-deep-list .check{flex-shrink:0;width:16px;height:16px;border-radius:4px;background:var(--corvell-blue-50);color:var(--corvell-blue);display:inline-flex;align-items:center;justify-content:center;font:700 10px/1 var(--font-sans);margin-top:3px}

/* ---------- ENGAGEMENT MODELS (plans) ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.plan{background:#fff;border:1px solid var(--ink-200);border-radius:14px;padding:32px 30px;display:flex;flex-direction:column;gap:20px;transition:all 220ms var(--ease-out);position:relative}
.plan:hover{border-color:var(--corvell-blue);box-shadow:var(--shadow-md)}
.plan.featured{border:1.5px solid var(--corvell-blue);background:linear-gradient(180deg,rgba(0,61,255,0.03),#fff 40%)}
.plan.featured::before{content:"MOST ENGAGED";position:absolute;top:-11px;left:30px;background:var(--corvell-blue);color:#fff;font:700 10px/1 var(--font-sans);letter-spacing:0.12em;padding:6px 10px;border-radius:6px}
.plan .name{font:700 22px/1.2 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.plan .dur{font:500 13px/1 var(--font-mono);color:var(--corvell-blue);letter-spacing:0.06em}
.plan .desc{font:400 14px/1.55 var(--font-sans);color:var(--ink-500)}
.plan ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;flex:1}
.plan ul li{font:400 13.5px/1.4 var(--font-sans);color:var(--corvell-navy);display:flex;gap:10px;padding-top:10px;border-top:1px solid var(--ink-100)}
.plan ul li:first-child{border-top:0;padding-top:0}
.plan ul li::before{content:"";flex-shrink:0;width:14px;height:14px;border-radius:4px;background:var(--corvell-blue-50);background-image:radial-gradient(circle at center,var(--corvell-blue) 3px,transparent 3.5px);margin-top:3px}
.plan .foot-cta{font:500 13px/1 var(--font-sans);color:var(--corvell-blue);display:inline-flex;align-items:center;gap:6px;margin-top:6px}

/* ---------- WHY / VALUES GRID ---------- */
.why{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--ink-200);border-left:1px solid var(--ink-200)}
.why-cell{padding:40px 36px;border-right:1px solid var(--ink-200);border-bottom:1px solid var(--ink-200);display:flex;flex-direction:column;gap:12px}
.why-cell .num{font:700 12px/1 var(--font-mono);color:var(--corvell-blue);letter-spacing:0.08em}
.why-cell .t{font:700 22px/1.2 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.why-cell .d{font:400 14px/1.6 var(--font-sans);color:var(--ink-500)}

/* ---------- PANEL BLUE (CTA band variant) ---------- */
.panel-blue{background:var(--corvell-blue);color:#fff;padding:clamp(64px,8vw,112px) 0;position:relative;overflow:hidden}
.panel-blue::before{content:"";position:absolute;right:-100px;top:-100px;width:500px;height:500px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,0.1),transparent 70%)}
.panel-blue-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:64px;align-items:center;position:relative}
.panel-blue .c-eyebrow{color:rgba(255,255,255,0.72);margin-bottom:18px;display:block}
.panel-blue h2{font:700 clamp(34px,4.6vw,56px)/1.05 var(--font-display);letter-spacing:-0.02em;margin:0 0 22px;text-wrap:balance}
.panel-blue p{font-size:var(--fs-body-lg);line-height:1.55;color:rgba(255,255,255,0.88);margin:0 0 28px;max-width:520px}
.panel-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.panel-stat{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.16);border-radius:12px;padding:22px 20px}
.panel-stat .n{font:700 clamp(30px,3vw,38px)/1 var(--font-display);color:#fff;letter-spacing:-0.02em}
.panel-stat .l{font:400 13px/1.45 var(--font-sans);color:rgba(255,255,255,0.7);margin-top:10px}

/* ---------- NAVY CTA BAND ---------- */
.cta-navy{padding:clamp(64px,8vw,112px) 0;background:var(--corvell-navy);color:#fff;text-align:center}
.cta-navy h2{font:700 clamp(34px,5vw,60px)/1.05 var(--font-display);letter-spacing:-0.02em;margin:0 auto 20px;max-width:860px;text-wrap:balance}
.cta-navy h2 .accent{color:var(--corvell-blue-300)}
.cta-navy p{font-size:var(--fs-body-lg);color:rgba(255,255,255,0.75);margin:0 auto 32px;max-width:600px}
.cta-navy .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- INDUSTRIES ---------- */
.industries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ind-tile{background:#fff;border:1px solid var(--ink-200);border-radius:12px;padding:28px 26px;display:flex;flex-direction:column;gap:16px;transition:all 220ms var(--ease-out);min-height:260px}
.ind-tile:hover{border-color:var(--corvell-blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.ind-tile .ic{width:48px;height:48px;border-radius:10px;overflow:hidden;background:var(--corvell-navy)}
.ind-tile .ic img{width:100%;height:100%;object-fit:cover}
.ind-tile .t{font:700 20px/1.15 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.ind-tile .d{font:400 14px/1.55 var(--font-sans);color:var(--ink-500);flex:1}
.ind-tile .link{font:500 13px/1 var(--font-sans);color:var(--corvell-blue);display:inline-flex;align-items:center;gap:6px}

/* ---------- ENGAGEMENT FLOW (4-step) ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.flow-step{display:flex;flex-direction:column;gap:14px}
.flow-step .rule{height:2px;background:var(--ink-200);border-radius:999px}
.flow-step.active .rule{background:var(--corvell-blue);height:3px}
.flow-step .num{font:600 13px/1 var(--font-mono);color:var(--corvell-blue);letter-spacing:0.06em}
.flow-step .t{font:700 20px/1.2 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.flow-step .d{font:400 13.5px/1.6 var(--font-sans);color:var(--ink-500)}

/* ---------- FOUNDER CARDS ---------- */
.founders{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.founder{background:#fff;border:1px solid var(--ink-200);border-radius:14px;padding:36px 34px;display:flex;flex-direction:column;gap:20px;transition:all 220ms var(--ease-out)}
.founder:hover{border-color:var(--corvell-blue);box-shadow:var(--shadow-md)}
.founder .top{display:flex;gap:20px;align-items:center}
.founder .av{width:72px;height:72px;border-radius:999px;background:var(--corvell-blue-50);color:var(--corvell-blue);display:flex;align-items:center;justify-content:center;font:700 24px/1 var(--font-display);letter-spacing:-0.01em;flex-shrink:0}
.founder .meta .name{font:700 22px/1.2 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.015em}
.founder .meta .role{font:500 13px/1.4 var(--font-sans);color:var(--corvell-blue);margin-top:4px}
.founder .desc{font:400 14.5px/1.6 var(--font-sans);color:var(--ink-500)}
.founder ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}
.founder ul li{font:400 13px/1.4 var(--font-sans);color:var(--corvell-navy);display:flex;gap:8px;padding-top:10px;border-top:1px solid var(--ink-100)}
.founder ul li::before{content:"";flex-shrink:0;width:4px;height:4px;border-radius:999px;background:var(--corvell-blue);margin-top:8px}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:4px}
.faq-item{border-top:1px solid var(--ink-200);padding:20px 0}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;list-style:none;padding:6px 0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .q{font:700 18px/1.3 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.01em}
.faq-item .sign{width:28px;height:28px;border-radius:999px;border:1px solid var(--ink-200);color:var(--corvell-blue);display:flex;align-items:center;justify-content:center;font:500 18px/1 var(--font-mono);flex-shrink:0;transition:all 140ms var(--ease-out)}
.faq-item[open] .sign{background:var(--corvell-blue);color:#fff;border-color:var(--corvell-blue);transform:rotate(45deg)}
.faq-item .a{font:400 15px/1.7 var(--font-sans);color:var(--ink-500);max-width:780px;padding:14px 0 4px}

/* ---------- CONTACT FORM ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px}
.contact-info .item{padding:24px 0;border-top:1px solid var(--ink-200);display:flex;gap:18px}
.contact-info .item:first-of-type{border-top:0;padding-top:0}
.contact-info .item .ic{width:36px;height:36px;border-radius:8px;background:var(--corvell-blue-50);color:var(--corvell-blue);display:flex;align-items:center;justify-content:center;font:700 14px/1 var(--font-sans);flex-shrink:0}
.contact-info .item h4{font:700 15px/1.2 var(--font-display);color:var(--corvell-navy);margin:0 0 4px;letter-spacing:-0.01em}
.contact-info .item p{font:400 14px/1.55 var(--font-sans);color:var(--ink-500);margin:0}
.contact-info .item a{color:var(--corvell-blue)}
.contact-form{background:#fff;border:1px solid var(--ink-200);border-radius:14px;padding:36px 32px}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form .f{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.contact-form .lbl{font:500 13px/1 var(--font-sans);color:var(--ink-700)}
.contact-form .inp,.contact-form select,.contact-form textarea{font:400 15px/1.4 var(--font-sans);padding:12px 14px;border:1px solid var(--ink-200);border-radius:8px;background:#fff;width:100%;color:var(--corvell-navy);transition:all 140ms var(--ease-out)}
.contact-form .inp:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--corvell-blue);box-shadow:0 0 0 3px rgba(0,61,255,0.22)}
.contact-form textarea{resize:vertical;min-height:110px}
.contact-form .privacy{font:400 12px/1.5 var(--font-sans);color:var(--ink-400);margin-top:4px}
.contact-form .privacy a{color:var(--corvell-blue)}
.form-success{background:#effaf1;border:1px solid #b8e5c4;border-radius:10px;padding:16px 18px;margin-bottom:22px;display:flex;flex-direction:column;gap:4px}
.form-success strong{font:600 15px/1.3 var(--font-sans);color:#14532d}
.form-success span{font:400 13px/1.55 var(--font-sans);color:#1e3a2a}
.form-success a{color:var(--corvell-blue)}
.thanks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:40px}
.thanks-card{display:flex;flex-direction:column;gap:10px;padding:28px 26px;background:#fff;border:1px solid var(--ink-200);border-radius:14px;text-decoration:none;transition:border-color .15s,transform .15s,box-shadow .15s}
.thanks-card:hover{border-color:var(--corvell-blue);transform:translateY(-2px);box-shadow:0 10px 30px -16px rgba(0,20,60,.15)}
.thanks-num{font:600 12px/1 var(--font-sans);letter-spacing:0.12em;color:var(--corvell-blue);text-transform:uppercase}
.thanks-t{font:700 18px/1.25 var(--font-display);color:var(--corvell-navy);letter-spacing:-0.01em}
.thanks-d{font:400 14px/1.55 var(--font-sans);color:var(--ink-500);flex:1}
.thanks-cta{font:600 13px/1 var(--font-sans);color:var(--corvell-blue);margin-top:6px}
.thanks-note{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;padding:28px 30px;background:var(--ink-50);border:1px solid var(--ink-200);border-radius:14px}
.thanks-note .c-eyebrow{display:block;margin-bottom:6px}
.thanks-note p{font:400 14px/1.6 var(--font-sans);color:var(--ink-600);margin:0;max-width:620px}
@media(max-width:860px){.thanks-grid{grid-template-columns:1fr}.thanks-note{grid-template-columns:1fr;gap:18px}}

/* ---------- BADGE ---------- */
.badge-blue{display:inline-flex;align-items:center;gap:6px;background:var(--corvell-blue-50);color:var(--corvell-blue-700);border-radius:999px;padding:6px 12px;font:600 11px/1 var(--font-sans);letter-spacing:0.08em;text-transform:uppercase}

/* ---------- UTILITIES ---------- */
.center-text{text-align:center}
.center-text .c-eyebrow,.center-text h2,.center-text .lead{margin-left:auto;margin-right:auto}

/* ---------- MOBILE NAV (hamburger) ---------- */
.nav-toggle{display:none;width:40px;height:40px;border:1px solid var(--ink-200);border-radius:8px;background:#fff;cursor:pointer;align-items:center;justify-content:center;padding:0}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--corvell-navy);position:relative;transition:all 180ms var(--ease-out)}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--corvell-navy);transition:all 180ms var(--ease-out)}
.nav-toggle span::before{top:-6px}
.nav-toggle span::after{top:6px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
body.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ---------- RESPONSIVE BREAKPOINTS ---------- */
@media(max-width:1024px){
  .home-hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-visual{aspect-ratio:16/10;max-width:560px}
  .svc-grid,.industries-grid{grid-template-columns:repeat(2,1fr)}
  .plans{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .flow{grid-template-columns:repeat(2,1fr);gap:24px}
  .svc-deep-grid{grid-template-columns:1fr;gap:32px}
  .panel-blue-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .founders{grid-template-columns:1fr}
}

/* ============================================================
   MOBILE REDESIGN (≤820px) — treated as its own layout language,
   not a squeeze of desktop. More air, larger type, generous cards,
   single focused column, mobile-native patterns.
   ============================================================ */
@media(max-width:820px){

  /* Global container: comfortable side gutters */
  .container,.container-wide{padding:0 22px;max-width:100%}

  /* Announce bar: compact, single line, no wrap */
  .announce{font-size:11px;padding:9px 16px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:0.04em}
  .announce .dot{margin-right:8px}

  /* NAV — taller-feeling chrome on mobile */
  /* IMPORTANT: drop backdrop-filter on mobile. backdrop-filter creates a
     containing block for position:fixed descendants, which would scope the
     drawer to the 60px-tall header and collapse its height to 0. */
  .nav{background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-inner{height:60px}
  .nav-logo{height:22px}
  .nav-links{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;width:100vw;height:calc(100vh - 60px);flex-direction:column;gap:0;background:#fff;padding:8px 22px 40px;border-top:1px solid var(--ink-100);overflow-y:auto;z-index:49}
  body.nav-open .nav-links{display:flex !important}
  body.nav-open{overflow:hidden}
  .nav-links a{font:600 22px/1.1 var(--font-display);padding:22px 0;border-bottom:1px solid var(--ink-100);color:var(--corvell-navy);letter-spacing:-0.01em;display:flex;align-items:center;justify-content:space-between}
  .nav-links a::after{content:"→";font:400 18px/1 var(--font-sans);color:var(--ink-300);opacity:.6}
  .nav-links a.active{color:var(--corvell-blue)}
  .nav-links a.active::before{display:none}
  /* Override the desktop active-link underline (.nav-links a.active::after
     positions a 2px blue bar at bottom:-26px). On mobile we want the active
     link to look like the others — same → arrow, no stray blue line. */
  .nav-links a.active::after{content:"→";font:400 18px/1 var(--font-sans);color:var(--ink-300);opacity:.6;position:static;background:transparent;left:auto;right:auto;bottom:auto;height:auto;width:auto}
  .nav-cta{display:none}
  .nav-toggle{display:inline-flex}

  /* Mobile nav drawer "footer" CTA injected via a helper class if the page wants it */
  .nav-links .nav-mobile-cta{margin-top:24px;display:inline-flex;align-items:center;justify-content:center;background:var(--corvell-blue);color:#fff;padding:18px 20px;border-radius:10px;font:600 16px/1 var(--font-sans);border-bottom:0}
  .nav-links .nav-mobile-cta::after{content:"→";color:#fff;opacity:1}

  /* ---- BUTTONS: bigger tap, better hierarchy ---- */
  .btn{padding:16px 22px;font:600 16px/1 var(--font-sans);border-radius:10px;min-height:52px}
  .btn-primary{box-shadow:0 6px 18px -6px rgba(0,61,255,0.35)}

  /* ---- HOME HERO: no side-visual; big expressive title ---- */
  .home-hero{padding:28px 0 44px}
  .home-hero-grid{grid-template-columns:1fr;gap:32px}
  .home-hero .rule{width:40px;height:3px;margin-bottom:20px}
  .home-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(38px,10vw,52px);line-height:1.02;letter-spacing:-0.03em}
  .home-hero p.lead{font-size:17px;line-height:1.55;margin:18px 0 28px;max-width:100%;color:var(--ink-500)}
  .home-hero .cta-row{flex-direction:column;gap:10px;align-items:stretch}
  .home-hero .cta-row .btn{flex:1;justify-content:center;width:100%}
  /* Hero visual becomes a compact "trust card" at the bottom of the stack */
  .hero-visual{aspect-ratio:auto;max-width:100%;padding:22px 22px 20px;border-radius:16px}
  .hero-visual-top .mark{width:36px;height:36px}
  .hero-ticker .label{font-size:10px;margin-bottom:10px}
  .hero-ticker .r{padding:10px 0}
  .hero-ticker .r .name{font-size:14px}
  .home-hero .facts{grid-template-columns:1fr 1fr;gap:22px 20px;padding-top:28px;margin-top:32px}
  .fact .n{font-size:30px}
  .fact .l{font-size:13px;max-width:none}

  /* ---- SECTION RHYTHM: more vertical air, not less ---- */
  .section{padding:64px 0}
  .section-subtle{padding:64px 0}
  .section-head{margin-bottom:36px;max-width:100%}
  .section-head .c-eyebrow{margin-bottom:12px;font-size:11px}
  .section-head h2{font-size:clamp(30px,7.5vw,40px);line-height:1.06;letter-spacing:-0.025em;margin-bottom:14px}
  .section-head p.lead{font-size:16px;line-height:1.6}

  /* Page hero */
  .page-hero{padding:40px 0 48px}
  .page-hero .rule{width:40px;height:3px;margin-bottom:20px}
  .page-hero h1{font-size:clamp(34px,9vw,44px);line-height:1.05;letter-spacing:-0.025em;margin-bottom:18px}
  .page-hero p.lead{font-size:16.5px;line-height:1.55}
  .page-hero .row{flex-direction:column;gap:10px;margin-top:26px}
  .page-hero .row .btn{flex:1;justify-content:center;width:100%;min-width:0}

  /* ---- SERVICES: generous, card-style, one column ---- */
  .svc-grid{grid-template-columns:1fr;gap:14px}
  .svc{min-height:0;padding:28px 26px 26px;gap:14px;border-radius:14px}
  .svc-ic{width:48px;height:48px;border-radius:11px}
  .svc-t{font-size:21px;line-height:1.2}
  .svc-d{font-size:15px;line-height:1.6}
  .svc-link{font-size:14px;padding-top:4px}

  /* ---- INDUSTRIES ---- */
  .industries-grid{grid-template-columns:1fr;gap:14px}
  .ind-tile{min-height:0;padding:28px 26px;gap:16px;border-radius:14px}
  .ind-tile .ic{width:46px;height:46px}
  .ind-tile .t{font-size:21px}
  .ind-tile .d{font-size:15px;line-height:1.6}
  .ind-tile .link{font-size:14px}

  /* ---- WHY GRID: stack cleanly, use solid cards (not shared borders) ---- */
  .why{grid-template-columns:1fr;border:0;display:flex;flex-direction:column;gap:12px}
  .why-cell{padding:26px 24px;border:1px solid var(--ink-200);border-radius:14px;background:#fff}
  .why-cell .num{font-size:11px}
  .why-cell .t{font-size:20px}
  .why-cell .d{font-size:15px;line-height:1.6}

  /* ---- ENGAGEMENT PLANS ---- */
  .plans{grid-template-columns:1fr;gap:14px;max-width:100%;margin:0}
  .plan{padding:30px 26px;border-radius:16px;gap:18px}
  .plan.featured::before{left:26px;font-size:9px;padding:6px 9px}
  .plan .name{font-size:23px}
  .plan .desc{font-size:15px}
  .plan ul li{font-size:15px;line-height:1.5;padding-top:12px}

  /* ---- FLOW STEPS ---- */
  .flow{grid-template-columns:1fr;gap:28px}
  .flow-step{gap:12px}
  .flow-step .t{font-size:20px}
  .flow-step .d{font-size:15px;line-height:1.6}

  /* ---- DEEP SERVICE BLOCKS ---- */
  .svc-deep{padding:56px 0}
  .svc-deep-grid{grid-template-columns:1fr;gap:28px}
  .svc-deep .ic-big{width:60px;height:60px;margin-bottom:20px}
  .svc-deep h2{font-size:clamp(28px,7vw,36px);line-height:1.08}
  .svc-deep .summary{font-size:16px;line-height:1.6}
  .svc-deep-list{grid-template-columns:1fr;gap:0}
  .svc-deep-list li{font-size:15px;line-height:1.55;padding:12px 0;gap:12px}
  .svc-deep-list li:nth-child(2){border-top:1px solid var(--ink-100)}

  /* ---- PANEL (BLUE) ---- */
  .panel-blue{padding:64px 0}
  .panel-blue-grid{grid-template-columns:1fr;gap:32px}
  .panel-blue h2{font-size:clamp(30px,8vw,40px);line-height:1.06;letter-spacing:-0.025em;margin-bottom:16px}
  .panel-blue p{font-size:16px;line-height:1.6;margin-bottom:24px}
  .panel-stats{grid-template-columns:1fr 1fr;gap:10px}
  .panel-stat{padding:22px 18px;border-radius:12px}
  .panel-stat .n{font-size:28px}
  .panel-stat .l{font-size:13px;line-height:1.45;margin-top:8px}

  /* ---- NAVY CTA ---- */
  .cta-navy{padding:64px 0}
  .cta-navy h2{font-size:clamp(30px,8vw,42px);line-height:1.06;letter-spacing:-0.025em;margin-bottom:16px}
  .cta-navy p{font-size:16px;line-height:1.6;margin-bottom:26px}
  .cta-navy .row{flex-direction:column;gap:10px;align-items:stretch}
  .cta-navy .row .btn{flex:1;justify-content:center;width:100%}

  /* ---- FOUNDERS: single col, open layout ---- */
  .founders{gap:14px}
  .founder{padding:30px 26px;gap:22px;border-radius:16px}
  .founder .top{gap:18px}
  .founder .av{width:60px;height:60px;font-size:20px}
  .founder .meta .name{font-size:21px}
  .founder .meta .role{font-size:13px;margin-top:4px}
  .founder .desc{font-size:15px;line-height:1.65}
  .founder ul{grid-template-columns:1fr;gap:0}
  .founder ul li{padding:10px 0;border-top:1px solid var(--ink-100);font-size:14px}
  .founder ul li:first-child{border-top:0}

  /* ---- FAQ ---- */
  .faq-item{padding:22px 0}
  .faq-item .q{font-size:17px;line-height:1.35}
  .faq-item .sign{width:32px;height:32px}
  .faq-item .a{font-size:15px;line-height:1.65;padding:16px 0 4px;padding-right:28px}

  /* ---- CONTACT ---- */
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-info .item{padding:22px 0;gap:16px}
  .contact-info .item h4{font-size:15px}
  .contact-info .item p{font-size:14px;line-height:1.6}
  .contact-form{padding:28px 22px;border-radius:16px}
  .contact-form .row{grid-template-columns:1fr;gap:0}
  .contact-form .f{margin-bottom:18px}
  .contact-form .lbl{font-size:13px}
  /* 16px prevents iOS from zooming on focus */
  .contact-form .inp,.contact-form select,.contact-form textarea{font-size:16px;padding:14px 14px;border-radius:10px}
  .contact-form textarea{min-height:130px}
  .contact-form .btn{width:100%;justify-content:center}

  /* ---- TRUST STRIP ---- */
  .trust{padding:28px 0 20px}
  .trust-lbl{font-size:10px;margin-bottom:18px}
  .trust-row{gap:14px 22px;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .trust-row::-webkit-scrollbar{display:none}
  .trust-row span{font-size:13px;flex-shrink:0}
  .trust-row .compliance{font-size:10px;padding:7px 11px;flex-shrink:0}

  /* ---- FOOTER: stacked, generous ---- */
  .footer{padding:56px 0 28px}
  .footer-grid{grid-template-columns:1fr;gap:36px;margin-bottom:36px}
  .footer-logo{height:24px;margin-bottom:16px}
  .footer-tag{font-size:14px;line-height:1.6;max-width:100%}
  .footer-col h4{font-size:11px;margin-bottom:14px}
  .footer-col a{font-size:15px;padding:9px 0}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px;text-align:left;font-size:12px}

  /* Utilities: cards give a tad more padding */
  .card{padding:26px 24px;border-radius:14px}
  .badge-blue{font-size:11px;padding:7px 13px}

  /* Thanks grid (contact success page) */
  .thanks-grid{grid-template-columns:1fr;gap:14px;margin-bottom:32px}
  .thanks-card{padding:26px 24px;border-radius:14px}
  .thanks-t{font-size:18px}
  .thanks-d{font-size:15px;line-height:1.6}
}

/* Very narrow phones — focus on comfort, not compression */
@media(max-width:420px){
  .container,.container-wide{padding:0 20px}
  .home-hero h1{font-size:36px}
  .home-hero .facts{grid-template-columns:1fr;gap:20px;padding-top:26px;margin-top:28px}
  .page-hero h1{font-size:32px}
  .section-head h2{font-size:28px}
  .panel-blue h2{font-size:28px}
  .cta-navy h2{font-size:28px}
  .panel-stats{grid-template-columns:1fr}
  .svc,.ind-tile,.plan,.founder,.contact-form,.hero-visual{padding-left:22px;padding-right:22px}
  .fact .n{font-size:28px}
}
