/* ================================================================
   TOKENS
   ================================================================ */
:root {
  --ink:       #0F1E35;
  --ink-deep:  #0A1525;
  --ink-mid:   #172840;
  --ink-light: #1E3558;
  --gold:      #C9A84C;
  --gold-dim:  rgba(201,168,76,.12);
  --gold-bdr:  rgba(201,168,76,.25);
  --cream:     #F9F7F3;
  --off-white: #FAF9F7;
  --white:     #FFFFFF;
  --border:    #E8E3D9;
  --slate:     #4A6580;
  --slate-lt:  #7B98B2;
  --body-txt:  #374151;

  --green:  #16a34a; --green-bg: #f0fdf4; --green-bdr: #bbf7d0;
  --yellow: #ca8a04; --yellow-bg:#fefce8; --yellow-bdr:#fde68a;
  --red:    #dc2626; --red-bg:   #fff1f2; --red-bdr:   #fecaca;

  --f-head: 'Cormorant Garamond', Georgia, serif;
  --f-body: 'DM Sans', system-ui, sans-serif;

  --mw: 1180px;
  --gx: clamp(1.25rem, 5vw, 2.5rem);
  --sec: clamp(4.5rem, 10vw, 7.5rem);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ================================================================
   RESET
   ================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);font-size:1rem;line-height:1.7;color:var(--body-txt);background:var(--white);overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--f-head);line-height:1.12;text-wrap:balance}
p{text-wrap:pretty}
button{font-family:var(--f-body);cursor:pointer;border:none;background:none}
ul{list-style:none}
.hidden{display:none!important}

/* ================================================================
   LAYOUT
   ================================================================ */
.wrap{max-width:var(--mw);margin-inline:auto;padding-inline:var(--gx)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.9rem;border-radius:4px;font-size:.9375rem;font-weight:500;
  letter-spacing:.01em;border:1.5px solid transparent;
  transition:all .22s var(--ease);cursor:pointer;white-space:nowrap;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:var(--ink-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,30,53,.22)}
.btn-gold{background:var(--gold);color:var(--ink-deep);border-color:var(--gold);font-weight:600}
.btn-gold:hover{background:#b8962e;border-color:#b8962e;transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.35)}
.btn-gold:disabled{background:#9CA3AF;border-color:#9CA3AF;color:#E5E7EB;transform:none;box-shadow:none;cursor:not-allowed}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline-w:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.link-btn{font-size:.875rem;color:var(--slate);text-decoration:underline;background:none;border:none;cursor:pointer}
.link-btn:hover{color:var(--ink)}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s;
}
.site-header.scrolled{border-color:var(--border);box-shadow:0 2px 20px rgba(15,30,53,.06)}

.header-inner{
  max-width:var(--mw);margin-inline:auto;
  padding:.875rem var(--gx);
  display:flex;align-items:center;gap:1.5rem;
}

.wordmark{
  font-family:var(--f-head);font-size:1.4rem;font-weight:600;
  color:var(--ink);letter-spacing:.01em;white-space:nowrap;margin-right:auto;
  transition:color .2s;
}
.wordmark:hover{color:var(--gold)}

.primary-nav{display:flex;align-items:center;gap:1.75rem}
.primary-nav a{
  font-size:.8rem;font-weight:500;text-transform:uppercase;
  letter-spacing:.09em;color:var(--slate);transition:color .2s;
}
.primary-nav a:hover{color:var(--gold)}

.header-right{display:flex;align-items:center;gap:.75rem}
.nav-consult{
  font-size:.8rem;font-weight:500;color:var(--slate);
  padding:.45rem .9rem;border-radius:4px;border:1.5px solid var(--border);
  transition:all .2s;
}
.nav-consult:hover{border-color:var(--ink);color:var(--ink)}

.nav-cta{
  font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;
  padding:.55rem 1.1rem;background:var(--ink);color:#fff;border-radius:4px;
  transition:all .2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--gold);color:var(--ink-deep);transform:translateY(-1px)}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;justify-content:space-between;width:24px;height:16px;margin-left:.5rem}
.nav-toggle span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.mobile-drawer{
  position:fixed;inset:0;top:60px;background:var(--white);z-index:199;
  display:flex;flex-direction:column;padding:1.5rem var(--gx) 2rem;gap:0;
  transform:translateX(100%);transition:transform .35s var(--ease);overflow-y:auto;
  border-top:1px solid var(--border);
}
.mobile-drawer[aria-hidden="false"]{transform:translateX(0)}
.mob-link{display:block;padding:.9rem 0;font-size:1.05rem;font-weight:500;color:var(--ink);border-bottom:1px solid var(--border);transition:color .2s}
.mob-link:hover{color:var(--gold)}
.mob-link:last-child{border-bottom:none}
.mob-cta{margin-top:1.5rem;padding:1rem 1.5rem;background:var(--ink);color:#fff!important;border-radius:4px;text-align:center;border-bottom:none!important}
.mob-cta:hover{background:var(--gold);color:var(--ink-deep)!important}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  background:var(--ink-deep);
  padding-block:clamp(4rem,10vw,7rem);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 75% 40%, rgba(201,168,76,.07), transparent 70%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(30,53,88,.5), transparent 70%);
}

.hero-inner{
  max-width:var(--mw);margin-inline:auto;padding-inline:var(--gx);
  display:grid;grid-template-columns:54% 1fr;gap:clamp(2rem,5vw,4rem);
  align-items:center;position:relative;z-index:1;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.5rem;
  padding:.35rem .9rem .35rem .6rem;
  background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.2);border-radius:100px;
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero-copy h1{font-size:clamp(2.8rem,5.5vw,4.5rem);color:#fff;font-weight:600;margin-bottom:1.5rem}
.hero-copy h1 em{color:var(--gold);font-style:italic}

.hero-sub{font-size:1.0625rem;color:rgba(255,255,255,.6);max-width:46ch;margin-bottom:2.25rem;line-height:1.75}
.hero-sub strong{color:#fff;font-weight:500}

.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3rem}

/* Credentials strip */
.hero-creds{
  display:flex;flex-wrap:wrap;align-items:center;gap:1.5rem 2rem;
  border-top:1px solid rgba(255,255,255,.08);padding-top:1.75rem;
}
.hcred{display:flex;align-items:center;gap:.65rem}
.hcred-num{font-family:var(--f-head);font-size:1.5rem;font-weight:600;color:#fff;line-height:1}
.hcred-txt{font-size:.7rem;color:var(--slate-lt);text-transform:uppercase;letter-spacing:.06em;line-height:1.4}
.hcred-div{width:1px;height:2rem;background:rgba(255,255,255,.1);flex-shrink:0}

/* Hero figure — integrated profile card */
.hero-fig { display:flex; justify-content:flex-end; }

.hero-profile-card {
  width:100%;max-width:360px;
  background:var(--ink-mid);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.05);
}

.hero-photo-wrap {
  width:100%;
  aspect-ratio:4/5;
  overflow:hidden;
  position:relative;
}
.hero-photo-wrap::after {
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:30%;
  background:linear-gradient(to top, var(--ink-mid), transparent);
  pointer-events:none;
}
.hero-img { width:100%;height:100%;object-fit:cover;object-position:top center;display:block; }

.hero-profile-footer {
  padding:1.25rem 1.5rem 1.5rem;
  background:var(--ink-mid);
}
.hpf-info { margin-bottom:1.1rem; }
.hpf-name {
  font-family:var(--f-head);font-size:1.15rem;font-weight:600;
  color:#fff;margin-bottom:.25rem;
}
.hpf-title {
  font-size:.72rem;color:var(--gold);text-transform:uppercase;
  letter-spacing:.08em;line-height:1.4;
}

.hpf-stats {
  display:flex;align-items:center;gap:0;
  border-top:1px solid rgba(255,255,255,.08);padding-top:1.1rem;
}
.hpf-stat {
  flex:1;display:flex;flex-direction:column;
  align-items:center;gap:.2rem;text-align:center;
}
.hpf-stat-num {
  font-family:var(--f-head);font-size:1.2rem;font-weight:700;
  color:#fff;line-height:1;
}
.hpf-stat-lbl {
  font-size:.62rem;color:var(--slate-lt);
  text-transform:uppercase;letter-spacing:.07em;
}
.hpf-stat-div { width:1px;height:2rem;background:rgba(255,255,255,.1);flex-shrink:0; }

/* Hero tag pills (replace the cred-strip) */
.hero-tags { display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem; }
.htag {
  font-size:.72rem;font-weight:500;padding:.35rem .9rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:100px;color:rgba(255,255,255,.55);
  letter-spacing:.03em;
}

/* ================================================================
   SECTIONS SHARED
   ================================================================ */
.section{padding-block:var(--sec)}
.section-ink{background:var(--ink);color:#fff}
.section-light{background:var(--cream)}
.section-white{background:var(--white)}

.eyebrow{
  font-family:var(--f-body);font-size:.72rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:block;
}
.eyebrow-gold{color:var(--gold)}

.section h2,.wrap h2{font-size:clamp(2rem,3.5vw,3rem);color:var(--ink);margin-bottom:1rem}
.section-ink h2{color:#fff}

.sec-lead{font-size:1.0625rem;color:var(--slate);max-width:54ch;margin-bottom:3rem;line-height:1.75}

.body-p{font-size:1.0625rem;color:var(--slate);line-height:1.8;margin-bottom:1.1rem}
.body-p strong{color:var(--ink);font-weight:600}

/* ================================================================
   THE GAP
   ================================================================ */
.section-ink .two-col h2{color:#fff}
.section-ink .sec-lead{color:rgba(255,255,255,.55)}

.symp-list{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem}
.symp-list li{
  padding:1rem 1.25rem;font-size:.9375rem;color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-left:3px solid var(--gold);border-radius:4px;
  transition:color .2s,border-color .2s;
}
.symp-list li:hover{color:#fff}

.insight-card{
  background:var(--ink-mid);border:1px solid rgba(255,255,255,.07);
  border-radius:10px;padding:clamp(1.75rem,4vw,2.75rem);
  box-shadow:0 20px 50px rgba(0,0,0,.25);
}
.ic-label{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.ic-body{font-size:1rem;color:rgba(255,255,255,.65);line-height:1.75;margin-bottom:2rem}
.ic-body strong{color:#fff}

.transforms{display:flex;flex-direction:column;gap:0}
.t-row{display:flex;align-items:center;gap:1rem;padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.t-row:last-child{border-bottom:none}
.t-from{font-size:.875rem;color:var(--slate-lt);flex:1}
.t-arr{color:var(--gold)}
.t-to{font-size:1rem;color:#fff;flex:2;font-family:var(--f-head)}

/* ================================================================
   FRAMEWORK
   ================================================================ */
.align-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem;margin-top:3rem}
.align-card{
  background:#fff;border:1px solid var(--border);border-radius:8px;
  padding:1.75rem 1.25rem;text-align:center;
  transition:transform .25s var(--ease),box-shadow .25s;
}
.align-card:hover{transform:translateY(-6px);box-shadow:0 14px 35px rgba(15,30,53,.09)}
.align-letter{
  width:50px;height:50px;margin:0 auto 1.1rem;background:var(--ink);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-size:1.5rem;font-weight:700;
}
.align-card h3{font-size:1rem;color:var(--ink);margin-bottom:.45rem}
.align-card p{font-size:.8125rem;color:var(--slate);line-height:1.5}
/* ================================================================
   SERVICES
   ================================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.svc-card{
  background:var(--cream);border:1px solid var(--border);border-radius:8px;
  padding:2rem 1.75rem;transition:transform .25s var(--ease),box-shadow .25s;
}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 14px 35px rgba(15,30,53,.08)}
.svc-icon{font-size:1.75rem;margin-bottom:1.1rem}
.svc-card h3{font-size:1.05rem;color:var(--ink);margin-bottom:.65rem}
.svc-card p{font-size:.875rem;color:var(--slate);line-height:1.65}
.svc-cta-row{text-align:center;margin-top:3rem}

/* ================================================================
   ABOUT
   ================================================================ */
.about-col{align-items:start}
.creds-stack{display:flex;flex-direction:column;gap:.875rem}
.cred-row{
  display:flex;align-items:center;gap:1.25rem;
  padding:1.1rem 1.35rem;background:#fff;border:1px solid var(--border);border-radius:6px;
  transition:box-shadow .2s;
}
.cred-row:hover{box-shadow:0 4px 16px rgba(15,30,53,.07)}
.cred-badge{
  width:48px;height:48px;flex-shrink:0;background:var(--ink);color:#fff;
  border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-size:1.1rem;font-weight:700;
}
.cred-row div{display:flex;flex-direction:column;gap:.2rem}
.cred-row strong{font-size:.9375rem;color:var(--ink)}
.cred-row span{font-size:.8rem;color:var(--slate)}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.testi-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:8px;padding:2rem 1.75rem;
}
.testi-stars{color:var(--gold);font-size:1rem;letter-spacing:.1em;margin-bottom:1rem}
.testi-card p{font-size:.9375rem;color:rgba(255,255,255,.7);font-style:italic;line-height:1.75;margin-bottom:1.5rem}
.testi-card footer{display:flex;align-items:center;gap:.9rem}
.testi-avatar{
  width:40px;height:40px;border-radius:50%;background:var(--gold);color:var(--ink-deep);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;
}
.testi-card footer div{display:flex;flex-direction:column;gap:.2rem}
.testi-card footer strong{font-size:.875rem;color:#fff;font-style:normal}
.testi-card footer span{font-size:.75rem;color:var(--slate-lt)}
.testi-cta{text-align:center;margin-top:3rem}

/* ================================================================
   DIAGNOSTIC — QUIZ
   ================================================================ */
#assessment-app{margin-top:2.5rem}

/* Intro */
.quiz-intro{
  background:var(--cream);border:1px solid var(--border);border-radius:10px;
  padding:clamp(2rem,4vw,2.75rem);display:flex;justify-content:space-between;
  align-items:center;gap:2rem;flex-wrap:wrap;
}
.qi-left{flex:1;min-width:260px}
.qi-left h3{font-family:var(--f-head);font-size:1.6rem;color:var(--ink);margin-bottom:.75rem}
.qi-left p{font-size:.9375rem;color:var(--slate);margin-bottom:1.5rem;max-width:48ch;line-height:1.7}
.qi-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.qi-pill{
  padding:.3rem .875rem;background:#fff;border:1px solid var(--border);
  border-radius:100px;font-size:.75rem;font-weight:500;color:var(--slate);
}

/* Progress */
.q-progress-row{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem}
.q-prog-wrap{flex:1;height:4px;background:#E8E3D9;border-radius:2px;overflow:hidden}
.q-prog-fill{height:100%;width:0%;background:var(--gold);border-radius:2px;transition:width .4s var(--ease)}
.q-prog-txt{font-size:.8125rem;font-weight:600;color:var(--slate);white-space:nowrap}

/* Section title */
.q-sec-title{
  padding:.875rem 1.25rem;border-radius:6px 6px 0 0;
  font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;display:flex;align-items:center;gap:.5rem;margin-top:2rem;
}
.q-sec-title:first-child{margin-top:0}
.q-sec-title.leadership{background:var(--ink)}
.q-sec-title.execution {background:#7C4A10}
.q-sec-title.engagement{background:#1A5E38}

/* Question block */
.q-block{
  background:#fff;border:1px solid var(--border);border-top:none;
  padding:1.75rem 1.5rem;
}
.q-block:last-of-type{border-radius:0 0 6px 6px;margin-bottom:2rem}
.q-text{font-size:.9375rem;font-weight:500;color:var(--ink);margin-bottom:1.25rem}

.q-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.q-opt{
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
  padding:1rem .75rem;background:var(--cream);border:1.5px solid var(--border);
  border-radius:5px;cursor:pointer;text-align:center;transition:all .2s;
  font-family:var(--f-body);color:var(--ink);
}
.q-opt:hover{background:#EDE9E0;border-color:#C5BEB1}
.q-opt.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.q-opt-num{font-size:1.25rem;font-weight:700}
.q-opt-lbl{font-size:.78rem;font-weight:600}
.q-opt-sub{font-size:.7rem;opacity:.65}

/* Submit row */
.q-submit-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;padding-top:2rem;border-top:1px solid var(--border)}
.q-hint{font-size:.875rem;color:var(--slate)}

/* ================================================================
   DIAGNOSTIC — RESULTS  (matches Claude's design)
   ================================================================ */
.res-header{margin-bottom:2rem}
.res-header h2{color:var(--ink)}

/* Overall score card */
.res-overall{
  background:var(--ink);border-radius:10px;padding:clamp(1.75rem,4vw,2.5rem);
  margin-bottom:2rem;
}
.res-score-block{display:flex;align-items:center;gap:2rem;margin-bottom:1.75rem;flex-wrap:wrap}
.res-score-num{
  font-family:var(--f-head);font-size:4.5rem;font-weight:700;color:#fff;line-height:1;
  display:flex;align-items:baseline;gap:.25rem;
}
.res-score-num::after{content:'/36';font-size:1.5rem;color:var(--slate-lt);font-family:var(--f-body);font-weight:400}
.res-status-line{font-size:1.25rem;font-weight:600;color:#fff;margin-bottom:.35rem}
.res-status-sub{font-size:.8125rem;color:var(--slate-lt)}

/* Score bar */
.res-bar-wrap{margin-top:0}
.res-scale-bar{height:8px;background:rgba(255,255,255,.12);border-radius:4px;overflow:hidden;margin-bottom:.65rem}
.res-scale-fill{height:100%;border-radius:4px;transition:width 1s var(--ease)}
.res-scale-labels{display:flex;justify-content:space-between;gap:.5rem}
.res-scale-lbl{font-size:.7rem;font-weight:600;padding:.25rem .65rem;border-radius:100px}
.lbl-red   {background:rgba(220,38,38,.2);color:#fca5a5}
.lbl-yellow{background:rgba(202,138,4,.2);color:#fde68a}
.lbl-green {background:rgba(22,163,74,.2);color:#86efac}

/* Category cards */
.res-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}
.res-cat{
  background:#fff;border:1px solid var(--border);border-radius:8px;padding:1.5rem;
}
.res-cat-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.res-cat-icon{font-size:1rem}
.res-cat-name{font-size:.8rem;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.07em}
.res-cat-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .75rem;border-radius:100px;font-size:.75rem;font-weight:600;margin-bottom:.875rem}
.badge-strong  {background:var(--green-bg);color:var(--green);border:1px solid var(--green-bdr)}
.badge-moderate{background:var(--yellow-bg);color:var(--yellow);border:1px solid var(--yellow-bdr)}
.badge-critical{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bdr)}
.res-cat-score{display:flex;align-items:baseline;gap:.2rem;margin-bottom:.75rem}
.cat-num{font-family:var(--f-head);font-size:2.25rem;font-weight:700;color:var(--ink);line-height:1}
.cat-denom{font-size:1rem;color:var(--slate)}
.cat-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.cat-bar-fill{height:100%;border-radius:2px;transition:width 1s var(--ease)}

/* Primary gap */
.res-primary{
  background:var(--ink);border-radius:8px;padding:clamp(1.5rem,3vw,2rem);
  margin-bottom:1.25rem;border-left:4px solid var(--gold);
}
.res-primary-label{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.res-primary-title{font-family:var(--f-head);font-size:1.5rem;color:#fff;margin-bottom:.75rem}
.res-primary-desc{font-size:.9375rem;color:rgba(255,255,255,.65);line-height:1.75}

/* Secondary observation */
.res-secondary{
  background:var(--yellow-bg);border:1px solid var(--yellow-bdr);
  border-radius:8px;padding:1.5rem;margin-bottom:2rem;
}
.res-secondary-label{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);margin-bottom:.65rem}
.res-secondary-desc{font-size:.9375rem;color:var(--body-txt);line-height:1.7}
.res-secondary-desc strong{color:var(--ink)}

/* Results CTA */
.res-cta-box{
  background:var(--cream);border:1px solid var(--border);
  border-radius:8px;padding:clamp(1.75rem,3vw,2.25rem);
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  margin-bottom:1.25rem;
}
.res-cta-txt h3{font-family:var(--f-head);font-size:1.35rem;color:var(--ink);margin-bottom:.5rem}
.res-cta-txt p{font-size:.9rem;color:var(--slate);max-width:46ch}
.res-retake{text-align:center;padding-top:.75rem}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{background:var(--ink-deep)}

.footer-top{padding-block:clamp(3rem,6vw,5rem)}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:3rem;
  align-items:start;
}
.ft-wordmark{font-family:var(--f-head);font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:.35rem}
.ft-tagline{font-size:.78rem;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.ft-bio{font-size:.875rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:30ch}

.ft-col{display:flex;flex-direction:column;gap:.7rem}
.ft-col-title{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.35rem}
.ft-col a{font-size:.875rem;color:rgba(255,255,255,.55);transition:color .2s}
.ft-col a:hover{color:var(--gold)}
.ft-location{font-size:.8rem;color:rgba(255,255,255,.3);margin-top:.35rem}

.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-block:1.25rem}
.footer-bot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-bot-inner p{font-size:.78rem;color:rgba(255,255,255,.25)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1080px){
  .align-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .ft-brand{grid-column:1/-1}
}

@media (max-width:860px){
  .primary-nav,.header-right{display:none}
  .nav-toggle{display:flex}

  .hero-inner{grid-template-columns:1fr}
  .hero-fig{order:-1;justify-content:center}
  .hero-profile-card{max-width:300px}

  .two-col{grid-template-columns:1fr}

  .align-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .res-cats{grid-template-columns:1fr}
  .q-opts{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width:600px){
  .align-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:1fr}
  .quiz-intro{flex-direction:column;align-items:flex-start}
  .q-opts{grid-template-columns:1fr}
  .q-submit-row{flex-direction:column;align-items:flex-start}
  .res-score-block{gap:1rem}
  .res-score-num{font-size:3.5rem}
  .res-cta-box{flex-direction:column}
  .res-scale-labels{font-size:.6rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bot-inner{flex-direction:column;text-align:center}
}

@media (max-width:440px){
  .hero-copy h1{font-size:2.5rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-tags{gap:.4rem}
  .wordmark{font-size:1.2rem}
  .align-grid{grid-template-columns:1fr}
  .hero-profile-card{max-width:100%}
}

.form-notice {
  text-align: center;
  font-size: .85rem;
  color: var(--slate);
  margin-top: 1rem;
}

/* Success Message */
.form-success {
  text-align: center;
  padding: 4rem 2rem;
  animation: fadeIn 0.5s ease;
}
.form-success h3 {
  color: var(--ink);
  margin-bottom: 1rem;
}
.form-success p {
  color: var(--slate);
  margin-bottom: 0.5rem;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
