/* ============================================================================
   California Safe Driver v2 "Court Docket" -- site-wide visual system.
   Tokens, typography, nav, hero, course docket, audiences, body copy,
   testimonials, footer, language picker, mobile breakpoints.
   ============================================================================ */

:root{
  --csd-navy:#38458E; --csd-dark:#2c3e50; --csd-gold:#E26B15; --csd-green:#3a5a3a;
  --csd-cream:#f2eee8; --csd-page:#faf7f2; --csd-graybar:#e8e6e1; --csd-white:#ffffff;
  --csd-text:#1a2d52; --csd-text-light:#555555;
  /* Legacy token aliases so pre-v2 inline styles still render correctly. */
  --csd-orange:#E26B15; --csd-primary:#38458E; --csd-bg:#faf7f2;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;color:var(--csd-text);background:var(--csd-page);line-height:1.55;font-size:16px}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-style:normal;font-weight:700;margin:0 0 .6em;line-height:1.2;color:var(--csd-text)}
a{color:var(--csd-navy)}
em{font-style:italic}
img{max-width:100%;height:auto}

/* --- NAV ------------------------------------------------------------------ */
.site-nav{display:flex;align-items:center;justify-content:space-between;padding:.8rem 9rem;background:var(--csd-page);border-bottom:1px solid var(--csd-graybar);position:sticky;top:0;z-index:50}
.nav-brand{display:flex;align-items:center;gap:1.3rem;text-decoration:none;color:var(--csd-text);position:relative;z-index:2}
.nav-brand-logo{width:140px;height:140px;min-width:140px;flex:0 0 140px;border-radius:50%;background:var(--csd-page);border:0;box-shadow:none;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:-40px}
/* Belt-and-suspenders: use a high-specificity selector chain
   (.nav-brand + .nav-brand-logo + img = 0,0,3,1) to decisively beat the
   legacy main.css .nav-brand img rule (0,0,1,1). Plus an all-attrs reset
   with !important so no v1 width/height/margin/border leaks through. */
.nav-brand .nav-brand-logo img,
a.nav-brand .nav-brand-logo img{
  display:block;
  width:94% !important;
  height:94% !important;
  max-width:none !important;
  min-width:0 !important;
  border-radius:0 !important;
  margin:0 !important;
  padding:0 !important;
  object-fit:contain;
}
.nav-brand-text{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:2.8rem;color:var(--csd-navy);line-height:1.05}
.nav-brand-tag{display:block;font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:.95rem;letter-spacing:.22em;text-transform:uppercase;color:var(--csd-text-light);margin-top:.35rem;padding-left:.7em}
.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{color:var(--csd-text);text-decoration:none;font-size:.92rem;font-weight:500}
.btn-enroll-nav{background:var(--csd-gold);color:#fff !important;padding:.5rem 1.1rem;border-radius:5px;font-weight:600 !important;white-space:nowrap}
.btn-login{border:1px solid var(--csd-navy);padding:.5rem 1.1rem;border-radius:5px;color:var(--csd-navy) !important;white-space:nowrap}
.btn-login:hover{background:var(--csd-navy);color:#fff !important;border-color:var(--csd-navy)}

/* Hamburger (mobile) */
.hamburger{display:none;background:transparent;border:0;cursor:pointer;padding:.5rem;width:44px;height:44px;flex-direction:column;justify-content:space-around;align-items:center;z-index:60}
.hamburger-line{display:block;width:24px;height:2px;background:var(--csd-navy);border-radius:1px;transition:transform .2s ease,opacity .2s ease}
.hamburger.is-active .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-active .hamburger-line:nth-child(2){opacity:0}
.hamburger.is-active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* --- Language picker ------------------------------------------------------ */
.lang-selector{position:relative}
.btn-lang{display:inline-flex;align-items:center;gap:.35rem;background:transparent;border:1px solid var(--csd-graybar);color:var(--csd-text);padding:.5rem 1.1rem;border-radius:5px;font-size:.85rem;font-weight:500;cursor:pointer;font-family:inherit;white-space:nowrap}
.btn-lang:hover{border-color:var(--csd-navy)}
.btn-lang .lang-caret{transition:transform .15s}
.btn-lang-open .lang-caret{transform:rotate(180deg)}
.lang-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:.3rem;background:#fff;border:1px solid var(--csd-graybar);border-radius:5px;box-shadow:0 4px 14px rgba(0,0,0,.08);list-style:none;padding:.3rem 0;min-width:160px;z-index:60}
.lang-dropdown-open{display:block}
.lang-dropdown li{margin:0}
.lang-option{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.5rem .85rem;border:0;background:transparent;color:var(--csd-text);font-size:.88rem;cursor:pointer;font-family:inherit}
.lang-option:hover{background:var(--csd-cream)}
.lang-option.lang-active{color:var(--csd-navy);font-weight:600}

/* --- HERO ----------------------------------------------------------------- */
.hero{background:var(--csd-navy);color:var(--csd-white);position:relative}
.hero-wrap{display:grid;grid-template-columns:1.05fr 1fr;max-width:1280px;margin:0 auto;align-items:stretch;min-height:440px}
.hero-copy{padding:3rem 2.5rem 2.5rem;display:flex;flex-direction:column;justify-content:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#e8b58a;font-weight:600;margin-bottom:1rem}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--csd-gold);display:inline-block}
.hero-eyebrow .dot:nth-of-type(2){margin-left:1rem}
.hero h1{color:var(--csd-white);font-size:clamp(1.9rem,3.7vw,3rem);margin:0 0 1rem;max-width:560px;letter-spacing:-.01em}
.hero h1 .accent{display:block;color:#eb975b;font-size:.75em;font-weight:600;margin-top:.2em;letter-spacing:.01em;line-height:1.15}
.hero-copy p{color:#dde1ee;max-width:540px;font-size:1.02rem;margin:0 0 1.5rem}
.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;justify-content:space-between;max-width:540px}
.hero-ctas .btn-primary{margin-right:auto}
.hero-ctas .btn-ghost{margin-left:auto}
.btn-primary{background:var(--csd-gold);color:#fff;padding:.8rem 1.6rem;border-radius:6px;text-decoration:none;font-weight:700;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 4px 12px rgba(226,107,21,.25);transition:transform .18s cubic-bezier(.2,.7,.2,1.2),box-shadow .18s ease,background .18s ease;will-change:transform;border:0;cursor:pointer;font-family:inherit;font-size:.95rem}
.btn-primary:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 10px 24px rgba(226,107,21,.45);background:#f07a25}
.btn-primary:active{transform:translateY(-1px) scale(1.01);box-shadow:0 4px 10px rgba(226,107,21,.35);transition-duration:.08s}
.btn-primary span[aria-hidden]{transition:transform .2s ease}
.btn-primary:hover span[aria-hidden]{transform:translateX(4px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.45);color:#fff;padding:.8rem 1.4rem;border-radius:6px;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:.45rem;transition:border-color .18s ease,background .18s ease}
.btn-ghost:hover{border-color:rgba(255,255,255,.8);background:rgba(255,255,255,.08)}
.hero-img-wrap{position:relative;min-height:320px}
.hero-img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:85% center}
.hero-img-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(56,69,142,.35) 0%,rgba(56,69,142,0) 30%)}
.hero-trust{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.2rem;font-size:.82rem;color:#dde1ee}
.hero-trust-item{display:inline-flex;align-items:center;gap:.4rem;font-weight:500}
.hero-trust-item svg{flex-shrink:0;color:var(--csd-gold)}
.hero-shield{position:absolute;top:1.2rem;right:4rem;border-radius:4px;border:2px solid rgba(255,255,255,.2);z-index:2;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.25);line-height:1.25}
.hero-shield .shield-accent{display:block;background:var(--csd-gold);color:#fff;padding:.22rem .85rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-align:center}
.hero-shield .shield-body{display:block;background:var(--csd-navy);color:#fff;padding:.42rem .85rem;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-align:center}

/* --- CREDENTIAL BAR ------------------------------------------------------- */
.cred-bar{background:var(--csd-cream);border-top:3px solid var(--csd-gold)}
.cred-bar-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);padding:1.2rem 2.5rem;gap:1.5rem}
.cred{display:flex;align-items:center;gap:.85rem;font-size:.85rem;color:var(--csd-text);border-right:1px solid rgba(44,62,80,.15);padding-right:1.2rem}
.cred:last-child{border-right:none}
.cred-icon{width:38px;height:38px;flex:0 0 38px;border-radius:50%;background:var(--csd-navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem}
.cred-label{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--csd-text-light);margin-bottom:2px;font-weight:600}
.cred-value{font-weight:600;color:var(--csd-text);font-size:.92rem;line-height:1.25}

/* --- PROGRAM DOCKET ------------------------------------------------------- */
.docket{max-width:1280px;margin:0 auto;padding:2rem 2.5rem 0}
.docket-head{display:flex;align-items:end;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-bottom:2px solid var(--csd-text);padding-bottom:.9rem;margin-bottom:0}
.docket-head h2{font-size:1.9rem;color:var(--csd-text);margin:0}
.docket-head .sub{font-size:.82rem;color:var(--csd-text-light);font-weight:500;letter-spacing:.12em;text-transform:uppercase}
.docket-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.docket-col{padding:1.5rem 1.3rem 1.6rem;border-right:1px solid var(--csd-graybar);display:flex;flex-direction:column;text-decoration:none;color:var(--csd-text);transition:background .15s}
.docket-col:last-child{border-right:none}
.docket-col:hover{background:var(--csd-cream)}
.docket-badge{height:96px;display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.docket-badge img{max-height:96px;width:auto;object-fit:contain}
.docket-col .title{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:1.15rem;color:var(--csd-text);margin:0 0 .75rem;line-height:1.25;text-align:center;min-height:2.85rem}
.docket-col .meta{display:grid;grid-template-columns:auto 1fr;gap:.3rem .75rem;font-size:.82rem;color:var(--csd-text-light);margin-bottom:1rem}
.docket-col .meta dt{font-weight:600;color:var(--csd-dark)}
.docket-col .meta dd{margin:0;color:var(--csd-text-light)}
.docket-col .learn{margin-top:auto;font-weight:600;color:var(--csd-navy);font-size:.88rem;display:inline-flex;align-items:center;gap:.3rem}
.docket-col .learn::after{content:"→";transition:transform .2s}
.docket-col:hover .learn::after{transform:translateX(3px)}
.docket-footnote{font-size:.82rem;color:var(--csd-text-light);padding:1rem 0;font-style:italic;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.docket-footnote a{color:var(--csd-gold);font-weight:600;text-decoration:none}

/* --- AUDIENCE ------------------------------------------------------------- */
.audiences{background:var(--csd-cream);padding:1.5rem 2.5rem}
.aud-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.aud-head{grid-column:1/-1;margin-bottom:.5rem}
.aud-head h2{font-size:1.6rem;margin:0 0 .3rem}
.aud-head p{margin:0;color:var(--csd-text-light);font-size:.95rem}
.aud-card{background:var(--csd-white);padding:1.3rem 1.2rem;border-top:3px solid var(--csd-navy);border-radius:2px}
.aud-card:nth-child(3){border-top-color:var(--csd-gold)}
.aud-card:nth-child(4){border-top-color:var(--csd-green)}
.aud-card:nth-child(5){border-top-color:var(--csd-dark)}
.aud-card h3{font-family:'Playfair Display',serif;font-size:1.05rem;margin:0 0 .4rem;color:var(--csd-text)}
.aud-card p{margin:0;font-size:.88rem;color:var(--csd-text-light);line-height:1.5}

/* --- BODY CONTENT --------------------------------------------------------- */
.body-wrap{max-width:920px;margin:0 auto;padding:3rem 2.5rem}
.body-wrap h2{font-size:1.7rem;color:var(--csd-text);margin-top:2.3rem}
.body-wrap h3{font-size:1.3rem;color:var(--csd-navy);margin-top:2rem;padding-bottom:.4rem;border-bottom:1px solid var(--csd-graybar)}
.body-wrap h4{font-size:1.05rem;margin-top:1.2rem}
.body-wrap p{font-size:1rem;line-height:1.7;margin:0 0 1rem}
.body-wrap ul{padding-left:1.2rem}
.body-wrap ul li{margin-bottom:.4rem}
.program-meta{font-size:.88rem;color:var(--csd-text-light);margin:-.4rem 0 1rem;letter-spacing:.03em}
.pullquote{border-left:3px solid var(--csd-gold);padding:.4rem 0 .4rem 1.2rem;font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--csd-text);margin:1.5rem 0}
.disclaimer-text{font-size:.82rem;color:var(--csd-text-light);font-style:italic;padding-top:1.2rem;border-top:1px solid var(--csd-graybar);margin-top:1.5rem}

/* Generic content page (for extending v2 to non-home pages) */
.content-page{max-width:920px;margin:0 auto;padding:2.5rem 2.5rem 3rem}
.content-page h1{font-size:2.2rem;color:var(--csd-text);margin:0 0 1rem}
.content-page h2{font-size:1.5rem;color:var(--csd-text);margin-top:2rem}
.content-page h3{font-size:1.2rem;color:var(--csd-navy);margin-top:1.6rem}
.content-page p{font-size:1rem;line-height:1.7;margin:0 0 1rem}
.content-page ul,.content-page ol{padding-left:1.2rem;line-height:1.7}
.content-page ul li,.content-page ol li{margin-bottom:.4rem}
.content-page a{color:var(--csd-navy);text-decoration:underline}

/* Messages */
.csd-message{max-width:920px;margin:1rem auto;padding:.85rem 1.2rem;border-radius:4px;font-size:.95rem}
.csd-message-success{background:#e5f5e0;color:#1b5e20;border-left:3px solid #3a5a3a}
.csd-message-error,.csd-message-danger{background:#fcebea;color:#8b1a14;border-left:3px solid #c0392b}
.csd-message-warning{background:#fff6dc;color:#7a5400;border-left:3px solid #e6c97a}
.csd-message-info{background:#e4edf7;color:#1a2d52;border-left:3px solid var(--csd-navy)}

/* Forms (generic) */
form.v2-form{max-width:560px;margin:1.5rem 0}
form.v2-form label{display:block;font-weight:600;font-size:.9rem;margin:1rem 0 .35rem;color:var(--csd-text)}
form.v2-form input[type="text"],form.v2-form input[type="email"],form.v2-form input[type="password"],form.v2-form input[type="tel"],form.v2-form input[type="number"],form.v2-form input[type="date"],form.v2-form select,form.v2-form textarea{width:100%;padding:.6rem .8rem;border:1px solid var(--csd-graybar);border-radius:5px;font-size:1rem;font-family:inherit;background:#fff;color:var(--csd-text)}
form.v2-form input:focus,form.v2-form select:focus,form.v2-form textarea:focus{outline:none;border-color:var(--csd-navy);box-shadow:0 0 0 3px rgba(56,69,142,.12)}
form.v2-form .v2-submit{margin-top:1.2rem}

/* --- TESTIMONIAL STRIP ---------------------------------------------------- */
.testi-strip{background:var(--csd-dark);color:var(--csd-white);padding:3rem 2.5rem}
.testi-strip-inner{max-width:1200px;margin:0 auto}
.testi-strip h2{color:var(--csd-white);font-size:1.7rem;margin:0 0 .3rem}
.testi-strip .tag{color:#bcc4d5;font-style:italic;margin:0 0 1.8rem;font-size:1.1rem}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.testi-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);padding:1.1rem 1.2rem;border-radius:4px}
.testi-text{margin:0 0 .6rem;font-size:.93rem;line-height:1.55;color:#e5e9f2}
.testi-author{margin:0;font-size:.82rem;color:#9aa4bd}

/* --- FOOTER --------------------------------------------------------------- */
.site-footer{background:var(--csd-navy);color:#fff;text-align:center;padding:2rem 1.5rem;font-size:.88rem}
.site-footer p{margin:.35rem 0;color:#d8dce3}
.site-footer a{color:#f4d6bf;text-decoration:none;margin:0 .15rem}
.footer-logos{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:1rem;flex-wrap:wrap}
.footer-logos img{background:#fff;padding:8px;border-radius:6px}

/* --- DASHBOARD overrides -------------------------------------------------- */
/* Dashboards stay data-dense: v2 applies colors + typography here, NOT the
   hero-level whitespace. Tables keep their compact rhythm. */
body.v2-dashboard .site-nav{padding:.6rem 2rem} /* denser nav for authed views */
body.v2-dashboard .nav-brand-logo{width:72px;height:72px;margin-bottom:-14px}
body.v2-dashboard .nav-brand-text{font-size:1.4rem}
body.v2-dashboard .nav-brand-tag{font-size:.6rem;letter-spacing:.14em;margin-top:.2rem}
body.v2-dashboard .nav-links{gap:1.2rem}

/* Dashboard table styling: map v1 admin-table patterns to v2 tokens.
   Header is WHITE bg with navy text + 2px bottom border (was navy bg before
   but hover-state on sort links made text invisible against the dark bg). */
.v2-table,.dash-table{width:100%;border-collapse:collapse;font-size:.92rem;background:#fff;border:1px solid var(--csd-graybar);border-radius:4px;overflow:hidden}
.v2-table thead th,.dash-table thead th{background:#fff;color:var(--csd-text);text-align:left;padding:.65rem .85rem;font-size:.75rem;letter-spacing:.08em;font-weight:700;text-transform:uppercase;border-bottom:2px solid var(--csd-navy)}
.v2-table thead th a,.dash-table thead th a{color:var(--csd-text);text-decoration:none}
.v2-table thead th a:hover,.dash-table thead th a:hover{color:var(--csd-navy);text-decoration:underline}
.v2-table tbody td,.dash-table tbody td{padding:.55rem .85rem;border-top:1px solid var(--csd-graybar);vertical-align:top}
.v2-table tbody tr:hover,.dash-table tbody tr:hover{background:var(--csd-cream)}
.v2-table a,.dash-table a{color:var(--csd-navy);text-decoration:none;font-weight:500}
.v2-table a:hover,.dash-table a:hover{text-decoration:underline}
.dash-table th,.dash-table td{vertical-align:middle}
.dash-table-scroll{border:1px solid var(--csd-graybar);border-radius:4px;overflow:auto}
/* Dashboard pill / status tags (commonly used in admin lists) */
.pill{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:var(--csd-graybar);color:var(--csd-text)}
.pill-navy{background:var(--csd-navy);color:#fff}
.pill-gold{background:var(--csd-gold);color:#fff}
.pill-green{background:var(--csd-green);color:#fff}
.pill-cream{background:var(--csd-cream);color:var(--csd-text)}

/* Dashboard action buttons */
.v2-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .85rem;border-radius:4px;font-size:.85rem;font-weight:600;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:background .15s ease,border-color .15s ease;font-family:inherit}
.v2-btn-primary{background:var(--csd-gold);color:#fff}
.v2-btn-primary:hover{background:#f07a25;color:#fff}
.v2-btn-secondary{background:#fff;color:var(--csd-navy);border-color:var(--csd-navy)}
.v2-btn-secondary:hover{background:var(--csd-navy);color:#fff}
.v2-btn-danger{background:#fff;color:#8b1a14;border-color:#8b1a14}
.v2-btn-danger:hover{background:#8b1a14;color:#fff}

/* Dashboard card / panel */
.v2-card{background:#fff;border:1px solid var(--csd-graybar);border-radius:4px;padding:1rem 1.2rem;margin-bottom:1rem}
.v2-card h2,.v2-card h3{margin-top:0;font-size:1.15rem;color:var(--csd-text)}

/* --- MOBILE BREAKPOINTS --------------------------------------------------- */
@media (max-width:1100px){
  .site-nav{padding:.8rem 3rem}
}
@media (max-width:960px){
  .site-nav{padding:.8rem 2rem}
  .nav-brand-text{font-size:2rem}
  .nav-brand-tag{font-size:.8rem}
  .nav-brand-logo{width:110px;height:110px;min-width:110px;flex:0 0 110px;margin-bottom:-28px}
  .hero-wrap{grid-template-columns:1fr}
  .hero-img-wrap{min-height:260px;order:-1}
  .cred-bar-inner{grid-template-columns:repeat(2,1fr)}
  .cred{border-right:none}
  .docket-grid{grid-template-columns:repeat(2,1fr)}
  .docket-col:nth-child(2){border-right:none}
  .docket-col{border-bottom:1px solid var(--csd-graybar)}
  .aud-inner{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .content-page{padding:2rem 1.5rem 2.5rem}
}
@media (max-width:720px){
  .site-nav{padding:.7rem 1rem}
  .hamburger{display:flex}
  .nav-brand-text{display:none}
  .nav-brand-tag{display:none}
  .nav-brand-logo{width:72px;height:72px;min-width:72px;flex:0 0 72px;margin-bottom:-18px;border-width:3px}
  /* Mobile nav becomes a drop-down drawer triggered by hamburger */
  .nav-links{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:.5rem 0;box-shadow:0 6px 18px rgba(0,0,0,.08);display:none;border-top:1px solid var(--csd-graybar)}
  .nav-links.nav-open{display:flex}
  .nav-links > a,.nav-links > .lang-selector{padding:.8rem 1.2rem;border-bottom:1px solid var(--csd-graybar);text-align:left;font-size:1rem}
  .nav-links > a.btn-enroll-nav{background:var(--csd-gold);color:#fff !important;margin:.4rem 1rem;border-radius:5px;text-align:center;border-bottom:0;padding:.6rem 1.2rem}
  .nav-links > a.btn-login{border:1px solid var(--csd-navy);color:var(--csd-navy) !important;margin:.4rem 1rem;border-radius:5px;text-align:center;border-bottom:0;padding:.55rem 1.2rem}
  .lang-dropdown{position:static;box-shadow:none;border:0;padding:0;margin-top:.5rem}
  /* Hero adjustments */
  .hero-copy{padding:2rem 1.2rem}
  .hero h1{font-size:1.9rem;overflow-wrap:break-word}
  .hero-ctas{max-width:100%;flex-direction:column;align-items:stretch}
  .hero-ctas .btn-primary,.hero-ctas .btn-ghost{margin:0;justify-content:center;text-align:center}
  .hero-trust{flex-direction:column;gap:.5rem}
  .hero-shield{top:.6rem;right:.6rem;transform:scale(.85);transform-origin:top right}
  /* Docket */
  .docket{padding:1.5rem 1rem 0}
  .docket-head h2{font-size:1.4rem}
  .docket-grid{grid-template-columns:1fr}
  .docket-col{border-right:none}
  /* Audiences + body + testi */
  .audiences,.testi-strip{padding:1.5rem 1rem}
  .body-wrap{padding:2rem 1.1rem}
  .content-page{padding:1.5rem 1.1rem 2rem}
  .content-page h1{font-size:1.7rem}
  /* Dashboard mobile: denser nav, responsive tables */
  body.v2-dashboard .site-nav{padding:.5rem .8rem}
  .dash-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .dash-table{font-size:.85rem}
  .dash-table th,.dash-table td{padding:.45rem .55rem}
}
@media (max-width:440px){
  /* Extra-narrow phones: small comfort tweaks only. Empirical mobile
     screenshots at 375/390/430 show the default H1 + shield sizes
     render cleanly; no need to over-shrink. */
  .hero h1{font-size:1.65rem;line-height:1.2;overflow-wrap:break-word}
  .hero-copy{padding:1.5rem 1rem}
  .hero-copy p{font-size:.95rem;line-height:1.55}
  .hero-eyebrow{font-size:.7rem;letter-spacing:.14em}
  .hero-shield{top:.4rem;right:.4rem;transform:scale(.72);transform-origin:top right}
  .docket-head h2{font-size:1.2rem}
  .docket-col .title{font-size:1rem}
  .aud-head h2{font-size:1.3rem}
  .testi-strip h2{font-size:1.35rem}
  .body-wrap h2{font-size:1.35rem}
  .body-wrap h3{font-size:1.1rem}
  .cred-bar-inner{grid-template-columns:1fr}
  .cred{padding-right:0}
}
