/* ============================================================
   HQ for AI — 2026 Design System
   Shared stylesheet. Palette/type/components from the approved
   homepage. Load with: <link rel="stylesheet" href="hq-2026.css">
   Fonts (add to <head>):
   <link href="https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap" rel="stylesheet">
   ============================================================ */

:root{
  --deep:#102A41;        /* hero / darkest */
  --mid:#163651;         /* main dark sections */
  --tint:#0F3231;        /* teal-tinted dark section */
  --panel:#1B3E5B;       /* cards on dark */
  --panel2:#21496A;
  --light:#FFFFFF;       /* logo band / white cards */
  --light-soft:#F4F8F9;  /* light bands / footer */
  --teal:#1FC9B7;
  --teal-bright:#2EE6CF;
  --teal-ink:#0B7F73;    /* teal text on light (AA) */
  --indigo:#8A9BFF;
  --t-light:#EAF3F6;     /* text on dark */
  --m-light:#9DB2C0;     /* muted on dark */
  --t-dark:#102A41;      /* text on light */
  --m-dark:#54646F;      /* muted on light */
  --ld:rgba(255,255,255,.10);
  --ld2:rgba(255,255,255,.18);
  --ll:#E4ECEF;
  --rad:16px;
  --maxw:1180px;
  --shadow:0 22px 50px -28px rgba(16,42,65,.45);
  --shadow-dark:0 30px 70px -40px rgba(0,0,0,.6);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--deep);color:var(--t-light);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5,.ff{font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.95rem;padding:14px 24px;border-radius:12px;transition:.2s;cursor:pointer;border:1.5px solid transparent}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--teal);color:#06222b}
.btn-primary:hover{background:var(--teal-bright);transform:translateY(-2px);box-shadow:0 14px 36px -16px rgba(31,201,183,.6)}
.btn-ghost{background:transparent;color:var(--t-light);border-color:var(--ld2)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
/* ghost on light backgrounds */
.band-light .btn-ghost,.on-light .btn-ghost{color:var(--t-dark);border-color:var(--ll)}
.band-light .btn-ghost:hover,.on-light .btn-ghost:hover{border-color:var(--teal);color:var(--teal-ink)}

/* ---------- Logo mark ---------- */
.hqmark{height:30px;width:auto;color:var(--teal);display:block}
.lockup{display:flex;align-items:center;gap:13px;font-family:'Plus Jakarta Sans';font-weight:600;font-size:1.18rem;letter-spacing:0;color:var(--t-light)}
.lockup-div{width:1px;height:24px;background:var(--ld2);flex:none}
footer.site .lockup-div{background:rgba(16,42,65,.20)}
.lockup-text{font-family:'Plus Jakarta Sans';font-weight:600}

/* ---------- Header / Nav ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(16,42,65,.78);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--ld)}
header.site nav{display:flex;align-items:center;justify-content:space-between;height:76px;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:.93rem;font-weight:500;color:var(--m-light);transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--t-light)}
.login-link{display:none}
.nav-cta{display:flex;align-items:center;gap:14px}
.hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--t-light)}
.hamburger svg{width:26px;height:26px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--ld)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(640px 460px at 86% -6%, rgba(46,230,207,.20), transparent 60%),
  radial-gradient(620px 520px at 4% 86%, rgba(138,155,255,.16), transparent 60%),
  radial-gradient(900px 700px at 60% 120%, rgba(31,201,183,.10), transparent 60%),
  linear-gradient(160deg,#16395a 0%, #102A41 42%, #0E2942 100%);
  background-color:#102A41;}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.ring.rA{width:420px;height:420px;top:-120px;right:-80px}
.ring.rB{width:230px;height:230px;top:60px;right:240px;border-color:rgba(46,230,207,.12)}
.hero .wrap{position:relative;z-index:2;padding-top:88px;padding-bottom:88px}
.hero.split .wrap{display:grid;grid-template-columns:1.3fr .7fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.6rem);font-weight:800;margin:20px 0 0}
.hero h1 .accent{color:var(--teal)}
.hero .sub{font-size:1.16rem;color:var(--m-light);max-width:560px;margin:26px 0 36px;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-note{font-size:.88rem;color:var(--m-light)}

/* compact interior page hero */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--ld);min-height:470px;display:flex;flex-direction:column;justify-content:center;align-items:center}
.page-hero .wrap{position:relative;z-index:2;padding:84px 28px 72px;max-width:var(--maxw);width:100%;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,4.4vw,3.5rem);font-weight:800;margin:18px auto 0;max-width:20ch}
.page-hero .sub{font-size:1.12rem;color:var(--m-light);max-width:660px;margin:22px auto 0;line-height:1.7}

/* flow card (engagement steps) */
.flow-card{background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--ld2);border-radius:18px;padding:28px 26px;box-shadow:var(--shadow-dark)}
.flow-card .k{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--m-light)}
.hflow{display:flex;align-items:center;gap:15px;padding:16px 0;border-bottom:1px dashed var(--ld2)}
.hflow:last-child{border-bottom:none}
.hflow .n{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--teal);color:var(--teal);display:grid;place-items:center;font-family:'Plus Jakarta Sans';font-weight:700;font-size:.85rem;flex:none}
.hflow .t{font-family:'Plus Jakarta Sans';font-size:1.16rem;font-weight:700}
.hflow .d{font-size:.84rem;color:var(--m-light)}

/* ---------- Logo marquee ---------- */
.logoband{background:var(--light);padding:40px 0 44px;overflow:hidden}
.logoband .trust{text-align:center;font-size:.84rem;color:var(--m-dark);font-weight:500;margin-bottom:26px}
.logoband .trust b{color:var(--teal-ink);font-weight:700}
.marquee{position:relative;width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.track{display:flex;align-items:center;gap:56px;width:max-content;animation:hq-scroll 48s linear infinite}
@keyframes hq-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.track img{height:auto;width:auto;max-height:46px;max-width:118px;object-fit:contain;filter:grayscale(100%);opacity:.62;transition:.25s}
.track img:hover{filter:grayscale(0);opacity:1}

/* ---------- Section bands ---------- */
.sec{padding:100px 0;position:relative}
.band-deep{background:var(--deep)}
.band-mid{background:var(--mid)}
.band-tint{background:var(--tint)}
.band-light{background:var(--light-soft);color:var(--t-dark)}
.band-white{background:var(--light);color:var(--t-dark)}
.sec-head{max-width:820px;margin:0 auto 54px;text-align:center}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem);font-weight:800;margin:16px 0 0}
.sec-head p{font-size:1.08rem;margin-top:18px;line-height:1.7;color:var(--m-light)}
.band-light .sec-head p,.band-white .sec-head p{color:var(--m-dark)}
.band-light .eyebrow,.band-white .eyebrow{color:var(--teal-ink)}

/* ---------- Editorial numbered rows (Dream/Plan/Build) ---------- */
.dpb-row{display:grid;grid-template-columns:70px 1fr 1.5fr;gap:30px;align-items:start;padding:38px 0;border-top:1px solid var(--ld)}
.dpb-row:last-child{border-bottom:1px solid var(--ld)}
.dpb-row .idx{font-family:'Plus Jakarta Sans';font-size:2.4rem;font-weight:800;color:var(--teal);line-height:1;opacity:.85}
.dpb-row .k{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--m-light)}
.dpb-row h3{font-size:1.7rem;font-weight:700;margin-top:6px}
.dpb-row .role{color:var(--teal);font-weight:600;margin-bottom:6px;font-size:.96rem}
.dpb-row p{color:var(--m-light);font-size:1.02rem;line-height:1.75}
.band-light .dpb-row{border-color:var(--ll)}
.band-light .dpb-row p{color:var(--m-dark)}
.band-light .dpb-row .k{color:var(--m-dark)}
.band-light .dpb-row .idx,.band-light .dpb-row .role{color:var(--teal-ink)}

/* ---------- Are / Not panels ---------- */
.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--ld2);border-radius:14px;overflow:hidden}
.panel{padding:38px 36px}
.panel.are{background:rgba(46,230,207,.07)}
.panel.not{background:rgba(255,255,255,.02);border-left:1px solid var(--ld2)}
.panel h4{font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
.panel.are h4{color:var(--teal)}
.panel.not h4{color:var(--m-light)}
.panel ul{list-style:none}
.panel li{display:flex;align-items:center;gap:13px;padding:12px 0;font-size:1.01rem;font-weight:500;border-bottom:1px solid var(--ld)}
.panel li:last-child{border-bottom:none}
.panel.not li{color:var(--m-light);font-weight:400}
.ic{width:22px;height:22px;flex:none}
.ic.check{color:var(--teal)}
.ic.cross{color:rgba(255,255,255,.32)}

/* ---------- Offering / generic cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card-grid.two{grid-template-columns:repeat(2,1fr)}
.card-grid.four{grid-template-columns:repeat(4,1fr)}
.off-card{border:1px solid var(--ll);border-radius:var(--rad);padding:34px 30px;background:#fff;color:var(--t-dark);transition:.25s;display:flex;flex-direction:column}
.off-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.off-ic{width:52px;height:52px;border-radius:13px;background:rgba(31,201,183,.12);color:var(--teal-ink);display:grid;place-items:center;margin-bottom:22px}
.off-ic svg{width:26px;height:26px}
.off-card .tag{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--m-dark);margin-bottom:8px}
.off-card h3{font-size:1.4rem;font-weight:700;margin-bottom:6px}
.off-card .lead{color:var(--teal-ink);font-weight:600;margin-bottom:12px}
.off-card p{color:var(--m-dark);font-size:.96rem;line-height:1.7;flex:1}
.off-card .more{margin-top:20px;font-weight:600;color:var(--t-dark);display:inline-flex;align-items:center;gap:7px;font-size:.92rem}
.off-card .more svg{width:16px;height:16px;transition:.2s}
.off-card:hover .more{color:var(--teal-ink)}
.off-card:hover .more svg{transform:translateX(4px)}
/* dark variant of card */
.off-card.dark{background:var(--panel);color:var(--t-light);border-color:var(--ld)}
.off-card.dark p{color:var(--m-light)}
.off-card.dark h3{color:var(--t-light)}
.off-card.dark .tag{color:var(--m-light)}
.off-card.dark .more{color:var(--t-light)}

/* ---------- Case / work cards ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.case{background:linear-gradient(160deg,var(--panel),var(--mid));border:1px solid var(--ld);border-radius:var(--rad);padding:30px 28px;transition:.25s;display:block}
.case:hover{transform:translateY(-4px);border-color:rgba(138,155,255,.4)}
.case .cat{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--indigo);margin-bottom:16px}
.case h3{font-size:1.32rem;font-weight:700;margin-bottom:12px;color:var(--t-light)}
.case p{color:var(--m-light);font-size:.95rem;line-height:1.7}
.case .metric{margin-top:18px;padding-top:18px;border-top:1px solid var(--ld);font-family:'Plus Jakarta Sans';font-weight:700;color:var(--teal);font-size:1.02rem}

/* ---------- Quote rotator ---------- */
.quote-box{position:relative;overflow:hidden;border-radius:24px;border:1px solid var(--ld2);background:linear-gradient(160deg,var(--panel2),var(--tint));padding:64px 52px;text-align:center;min-height:300px;display:flex;flex-direction:column;justify-content:center}
.quote-box .glow{position:absolute;inset:0;background:radial-gradient(520px 300px at 50% -10%,rgba(46,230,207,.16),transparent 60%)}
.quote-box>*{position:relative;z-index:2}
.qslide{display:none;animation:qfade .6s ease}
.qslide.on{display:block}
@keyframes qfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.qslide blockquote{font-family:'Plus Jakarta Sans';font-weight:600;font-size:clamp(1.4rem,2.7vw,2.1rem);line-height:1.4;letter-spacing:-.01em;color:var(--t-light);max-width:840px;margin:0 auto}
.qslide cite{display:block;margin-top:26px;font-style:normal;font-size:.96rem;color:var(--m-light)}
.qslide cite b{color:var(--t-light);font-weight:700;display:block;font-family:'Plus Jakarta Sans'}
.qdots{display:flex;gap:9px;justify-content:center;margin-top:34px}
.qdot{width:8px;height:8px;border-radius:50%;background:var(--ld2);border:none;cursor:pointer;transition:.2s;padding:0}
.qdot.on{background:var(--teal);width:24px;border-radius:5px}

/* ---------- CTA box ---------- */
.cta-box{position:relative;overflow:hidden;border-radius:28px;border:1px solid var(--ld2);background:linear-gradient(150deg,#16415f,#0f2c3f);padding:80px 52px;text-align:center}
.cta-box .glow{position:absolute;inset:0;background:
  radial-gradient(520px 360px at 16% 4%, rgba(46,230,207,.24), transparent 60%),
  radial-gradient(540px 420px at 90% 100%, rgba(138,155,255,.22), transparent 60%)}
.cta-box>*{position:relative;z-index:2}
.cta-box h2{font-size:clamp(2.1rem,4vw,3.2rem);font-weight:800;margin-bottom:18px}
.cta-box p{color:var(--m-light);font-size:1.12rem;max-width:580px;margin:0 auto 34px;line-height:1.65}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Forms ---------- */
.form-card{background:#fff;color:var(--t-dark);border:1px solid var(--ll);border-radius:20px;padding:40px 38px;box-shadow:var(--shadow);max-width:680px;margin:0 auto}
.form-group{margin-bottom:22px;position:relative}
.form-group label{display:block;font-weight:600;font-size:.92rem;margin-bottom:8px;color:var(--t-dark)}
.form-group label span{font-weight:400;color:var(--m-dark)}
.form-group input[type=text],.form-group input[type=email],.form-group textarea{
  width:100%;font-family:'Inter',sans-serif;font-size:1rem;color:var(--t-dark);
  background:var(--light-soft);border:1.5px solid var(--ll);border-radius:11px;padding:13px 15px;transition:.2s}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(31,201,183,.15)}
.form-group textarea{resize:vertical;min-height:130px}
.char-counter{text-align:right;font-size:.82rem;color:var(--m-dark);margin-top:6px}
/* custom select */
.custom-select{position:relative;font-size:1rem}
.select-selected{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--light-soft);border:1.5px solid var(--ll);border-radius:11px;padding:13px 15px;cursor:pointer;transition:.2s;color:var(--t-dark)}
.select-selected:hover{border-color:var(--teal)}
.select-selected.select-arrow-active{border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(31,201,183,.15)}
.select-arrow{width:20px;height:20px;color:var(--m-dark);transition:transform .2s;flex:none}
.select-arrow-active .select-arrow{transform:rotate(180deg)}
.select-items{position:absolute;left:0;right:0;z-index:20;background:#fff;border:1.5px solid var(--ll);border-radius:11px;margin-top:6px;box-shadow:0 18px 40px -20px rgba(16,42,65,.4);overflow:hidden}
.select-items div{padding:12px 15px;cursor:pointer;color:var(--t-dark);transition:.15s}
.select-items div:hover{background:rgba(31,201,183,.10);color:var(--teal-ink)}
.select-hide{display:none}
.form-submit{display:inline-flex;align-items:center;gap:9px;background:var(--teal);color:#06222b;border:none;font-family:'Plus Jakarta Sans';font-weight:700;font-size:1rem;padding:15px 28px;border-radius:12px;cursor:pointer;transition:.2s}
.form-submit svg{width:17px;height:17px}
.form-submit:disabled{opacity:.7;cursor:default}
.form-submit:hover{background:var(--teal-bright);transform:translateY(-2px)}
.thankyou{display:none;text-align:center;background:#fff;border:1px solid var(--ll);border-radius:20px;padding:40px;max-width:680px;margin:0 auto;box-shadow:var(--shadow)}
.thankyou h3{color:var(--t-dark);font-size:1.6rem;margin-bottom:8px}
.thankyou p{color:var(--m-dark)}

/* ---------- Team cards ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.team-card{background:var(--panel);border:1px solid var(--ld);border-radius:var(--rad);padding:30px 28px;transition:.25s}
.team-card:hover{transform:translateY(-4px);border-color:rgba(46,230,207,.35)}
.team-card .avatar{width:74px;height:74px;border-radius:50%;object-fit:cover;margin-bottom:18px;border:2px solid var(--teal)}
.team-card h3{font-size:1.25rem;font-weight:700}
.team-card .role{color:var(--teal);font-weight:600;font-size:.9rem;margin:4px 0 14px}
.team-card p{color:var(--m-light);font-size:.93rem;line-height:1.7}

/* ---------- Article (case study / governance / pulse) ---------- */
.article{max-width:760px;margin:0 auto;padding:0 28px}
.article h2{font-size:1.7rem;font-weight:700;margin:48px 0 14px}
.article h3{font-size:1.25rem;font-weight:700;margin:32px 0 10px;color:var(--teal)}
.article p{color:var(--m-light);font-size:1.05rem;line-height:1.8;margin-bottom:18px}
.article .lead{font-size:1.25rem;color:var(--t-light);line-height:1.6}
.article ul{margin:0 0 18px 20px;color:var(--m-light);line-height:1.8}
.metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:32px 0}
.metric-big{background:var(--panel);border:1px solid var(--ld);border-radius:var(--rad);padding:26px 20px;text-align:center}
.metric-big .n{font-family:'Plus Jakarta Sans';font-weight:800;font-size:2rem;color:var(--teal)}
.metric-big .l{font-size:.85rem;color:var(--m-light);margin-top:6px}

/* ---------- Footer ---------- */
footer.site{background:var(--light-soft);color:var(--t-dark);border-top:1px solid var(--ll);padding:68px 0 30px}
footer.site .lockup{color:var(--t-dark)}
footer.site .hqmark{color:var(--teal)}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px}
.foot-brand p{color:var(--m-dark);font-size:.95rem;max-width:300px;line-height:1.65;margin-top:16px}
.socials{display:flex;gap:10px;margin-top:22px}
.socials a{width:40px;height:40px;border-radius:11px;border:1px solid var(--ll);display:grid;place-items:center;background:#fff;transition:.2s}
.socials a:hover{border-color:var(--teal);background:rgba(31,201,183,.08);transform:translateY(-2px)}
.socials img{width:18px;height:18px;object-fit:contain;opacity:.66;transition:.2s}
.socials a:hover img{opacity:1}
.socials .mail svg{width:19px;height:19px;color:var(--t-dark);opacity:.66}
.socials a:hover svg{opacity:1}
.foot-col h5{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--m-dark);margin-bottom:18px}
.foot-col a{display:block;color:var(--t-dark);font-size:.95rem;padding:7px 0;transition:.2s}
.foot-col a:hover{color:var(--teal-ink)}
.foot-bottom{margin-top:54px;padding-top:26px;border-top:1px solid var(--ll);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.88rem;color:var(--m-dark)}
.foot-bottom .tag{color:var(--t-dark);font-weight:600}
.foot-bottom .tag .tw{color:var(--teal-ink);font-weight:700}

/* ---------- Utilities ---------- */
.center{text-align:center}
.mt-48{margin-top:48px}
.lead-quote-mark{font-family:'Plus Jakarta Sans';font-size:3rem;color:var(--teal);line-height:.5}

/* ---------- Responsive ---------- */
/* Nav buttons start shrinking before the hamburger kicks in */
@media(max-width:1280px){
  .nav-links{gap:22px}
  .nav-cta .btn{padding:11px 16px;font-size:.86rem;gap:6px}
  .nav-cta .btn svg{width:15px;height:15px}
}
/* Collapse the top nav into the hamburger at 1100px (we always have a login button) */
@media(max-width:1100px){
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:76px;left:0;right:0;flex-direction:column;background:var(--mid);padding:18px 28px 26px;gap:6px;border-bottom:1px solid var(--ld)}
  .nav-links.open > a{padding:11px 0;border-bottom:1px solid var(--ld)}
  .hamburger{display:block}
  .nav-cta .btn-ghost{display:none}
  .nav-links.open .login-link{display:block;color:var(--teal);font-weight:600}
}
@media(max-width:920px){
  .hero.split .wrap{grid-template-columns:1fr;gap:38px}
  .dpb-row{grid-template-columns:1fr;gap:8px;padding:30px 0}
  .dpb-row .idx{font-size:2rem}
  .diff-grid,.card-grid,.card-grid.two,.card-grid.four,.work-grid,.team-grid,.metrics-row{grid-template-columns:1fr}
  .panel.not{border-left:none;border-top:1px solid var(--ld2)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .cta-box,.quote-box{padding:54px 26px}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  header.site nav{padding:0 20px}
  .sec{padding:68px 0}
  .foot-grid{grid-template-columns:1fr}
  .form-card{padding:28px 22px}
}

/* ===== Granular fixes: logos label, chips, mobile menu socials, mobile scaling ===== */
.logoband .trust{font-size:.95rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--m-dark)}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;justify-content:center}
.chip{font-size:.78rem;font-weight:600;letter-spacing:.03em;color:var(--teal);background:rgba(46,230,207,.10);border:1px solid rgba(46,230,207,.25);padding:7px 14px;border-radius:999px}
.band-light .chip,.band-white .chip{color:var(--teal-ink);background:rgba(31,201,183,.10);border-color:rgba(31,201,183,.30)}

.nav-social{display:none}
.nav-social a{display:inline-grid;place-items:center}
.nav-social img{width:20px;height:20px;object-fit:contain;filter:brightness(0) invert(1);opacity:.8;transition:.2s}
.nav-social a:hover img{opacity:1}
.nav-social .mail svg{width:21px;height:21px;color:#fff;opacity:.8}

@media(max-width:920px){
  .nav-links.open .nav-social{display:flex;gap:10px;align-items:center;padding-top:18px;margin-top:8px}
  .nav-links.open .nav-social a{width:40px;height:40px;border-radius:11px;border:1px solid var(--ld2);background:rgba(255,255,255,.06);transition:.2s}
  .nav-links.open .nav-social a:hover{border-color:var(--teal);background:rgba(46,230,207,.10)}
  .nav-links.open .nav-social img{width:18px;height:18px}
  .nav-links.open .nav-social .mail svg{width:18px;height:18px}
}
@media(max-width:560px){
  .nav-cta{gap:8px}
  .nav-cta .btn-primary{padding:10px 14px;font-size:.82rem}
  .nav-cta .btn-primary svg{display:none}
  .lockup{font-size:1rem;gap:8px}
  header.site .lockup-text{display:none}
  header.site .hqmark{height:28px}
  .foot-bottom{justify-content:center;gap:4px 16px;font-size:.74rem;text-align:center}
  .foot-bottom .tag{display:none}
}

/* ===== Team cards: larger grayscale-to-color photos, LinkedIn link, "Could be you" placeholder ===== */
.team-card{display:flex;flex-direction:column}
.team-card .avatar{width:104px;height:104px;filter:grayscale(100%);transition:filter .35s ease}
.team-card:hover .avatar{filter:grayscale(0)}
.team-card p{flex:1}
.tcard-li{display:inline-flex;align-items:center;gap:7px;margin-top:16px;color:var(--teal);font-size:.85rem;font-weight:600;transition:.2s}
.tcard-li svg{width:17px;height:17px}
.tcard-li:hover{color:var(--teal-bright)}
.team-card.placeholder{border-style:dashed;border-color:rgba(46,230,207,.4);background:rgba(46,230,207,.04)}
.team-card.placeholder:hover{border-color:var(--teal);background:rgba(46,230,207,.08);transform:translateY(-4px)}
.avatar-ph{width:104px;height:104px;border-radius:50%;border:2px dashed var(--teal);display:grid;place-items:center;color:var(--teal);margin-bottom:18px}
.avatar-ph svg{width:44px;height:44px}
@media(max-width:560px){
  .team-card .avatar,.avatar-ph{width:88px;height:88px}
  .avatar-ph svg{width:38px;height:38px}
  header.site .lockup-div{display:none}
}
/* Team LinkedIn chip: glyph turns white on hover */
.team-card .socials a:hover{background:var(--teal);border-color:var(--teal)}
.team-card .socials a:hover img{filter:brightness(0) invert(1);opacity:1}

/* Footer tagline hides below 850px */
@media(max-width:850px){ .foot-bottom .tag{display:none} }

/* Card keyline (sub-line under a divider). Shared so every article's keylines
   reserve the same height and dividers line up across a row. Keep keyline text
   to <= 2 lines. */
.keyline{margin-top:14px;padding-top:12px;border-top:1px solid var(--ll);font-size:.82rem;font-weight:600;color:var(--teal-ink);min-height:56px}
.off-card.dark .keyline{border-color:var(--ld);color:var(--teal)}
.used-for{min-height:56px}
