/* ===================================================
   TOKENS - Light, Elegant, Aviation
=================================================== */
:root {
  --s0: #FAFAF7;
  --s1: #F4F2ED;
  --s2: #EDE9E2;
  --s3: #E2DDD5;
  --ink:     #1A1A1A;
  --ink-mid: #2C2C2C;
  --ink-soft:#4A4A4A;
  --slate:    #1C2B3A;
  --slate-mid:#243447;
  --slate-lt: #2E4057;
  --accent:   #2B6CB0;
  --accent-lt:#3B82C4;
  --accent-pale:#E8F0FA;
  --accent-wash:#F0F5FB;
  --gold:     #B07D3A;
  --gold-lt:  #C8953A;
  --gold-pale:#F5ECD8;
  --gold-wash:#FAF5EC;
  --t-primary:   #1A1A1A;
  --t-secondary: #4A4A4A;
  --t-muted:     #6B6B6B;
  --t-light:     rgba(255,255,255,0.90);
  --t-dim:       rgba(255,255,255,0.50);
  --t-faint:     rgba(255,255,255,0.28);
  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Mulish', system-ui, sans-serif;
  --mono:  'JetBrains Mono', monospace;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ===================================================
   RESET
=================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--sans);
  background:var(--s0);
  color:var(--t-primary);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none}
img{display:block;max-width:100%}

/* ===================================================
   NAV
=================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(250,250,247,0.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--s2);
  transition:box-shadow 0.3s var(--ease);
}
.nav.scrolled{box-shadow:0 1px 20px rgba(0,0,0,0.06)}
.nav-inner{
  max-width:1160px;margin:0 auto;padding:0 2.5rem;
  height:66px;display:flex;align-items:center;justify-content:space-between;
}
.nav-brand{display:flex;flex-direction:column;gap:1px}
.nav-brand a{display:flex;flex-direction:column;gap:1px}
.nav-brand-name{
  font-family:var(--serif);font-size:1.05rem;font-weight:400;
  color:var(--ink);letter-spacing:0.02em;line-height:1.2;
}
.nav-brand-sub{
  font-family:var(--mono);font-size:0.55rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--accent);
}
.nav-links{display:flex;align-items:center;gap:2.25rem;list-style:none}
.nav-links a{
  font-size:0.75rem;font-weight:500;letter-spacing:0.09em;
  text-transform:uppercase;color:var(--t-muted);
  transition:color 0.18s;
}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-cta{
  background:var(--slate);color:#fff;
  font-family:var(--mono);font-size:0.68rem;letter-spacing:0.1em;
  text-transform:uppercase;padding:9px 20px;border-radius:2px;
  transition:background 0.2s var(--ease);
  display:inline-block;
}
.nav-cta:hover{background:var(--slate-mid)}

/* Hamburger */
.nav-hamburger{
  display:none;
  flex-direction:column;gap:5px;
  background:none;border:none;padding:4px;cursor:pointer;
  z-index:101;
}
.nav-hamburger span{
  display:block;width:24px;height:2px;background:var(--ink);
  transition:transform 0.4s var(--ease), opacity 0.25s var(--ease), background 0.3s var(--ease);
  transform-origin:center center;
}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===================================================
   SHARED ATOMS
=================================================== */
.wrap{max-width:1160px;margin:0 auto;padding:0 2.5rem}
.wrap-narrow{max-width:780px;margin:0 auto;padding:0 2.5rem}

.eyebrow{
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--accent);
  display:flex;align-items:center;gap:0.6rem;margin-bottom:0.9rem;
}
.eyebrow::before{content:'';display:block;width:22px;height:1px;background:var(--accent);flex-shrink:0}
.eyebrow.gold-e{color:var(--gold-lt)}
.eyebrow.gold-e::before{background:var(--gold-lt)}
.eyebrow.white-e{color:rgba(255,255,255,0.5)}
.eyebrow.white-e::before{background:rgba(255,255,255,0.3)}

.serif-h{
  font-family:var(--serif);font-weight:400;
  line-height:1.15;letter-spacing:0.01em;
}
.serif-h em{font-style:italic;color:var(--accent)}
.serif-h.on-dark em{color:#A8C5E8}
.serif-h.on-dark{color:#fff}

.rule-gold{width:40px;height:1px;background:var(--gold);margin:1.25rem 0}

.btn-dark{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:var(--slate);color:#fff;
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;
  text-transform:uppercase;padding:13px 26px;border-radius:2px;
  transition:background 0.18s var(--ease);
}
.btn-dark:hover{background:var(--slate-mid)}
.btn-outline-dark{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:transparent;color:var(--slate);
  border:1px solid var(--slate);
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;
  text-transform:uppercase;padding:12px 25px;border-radius:2px;
  transition:all 0.18s var(--ease);
}
.btn-outline-dark:hover{background:var(--slate);color:#fff}
.btn-light{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.85);
  border:1px solid rgba(255,255,255,0.2);
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.1em;
  text-transform:uppercase;padding:12px 25px;border-radius:2px;
  transition:all 0.18s var(--ease);
}
.btn-light:hover{background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.4)}

.tag-sm{
  display:inline-block;font-family:var(--mono);font-size:0.6rem;
  letter-spacing:0.08em;text-transform:uppercase;
  padding:3px 9px;border-radius:2px;border:1px solid;
}
.tag-slate{background:rgba(28,43,58,0.07);border-color:rgba(28,43,58,0.15);color:var(--slate)}
.tag-accent{background:var(--accent-pale);border-color:rgba(43,108,176,0.2);color:var(--accent)}
.tag-gold{background:var(--gold-pale);border-color:rgba(176,125,58,0.25);color:var(--gold)}
.tag-ghost{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.15);color:rgba(255,255,255,0.55)}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.65s var(--ease),transform 0.65s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:0.08s}
.reveal-delay-2{transition-delay:0.16s}
.reveal-delay-3{transition-delay:0.24s}

/* hero entrance */
@keyframes fade-up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.ani{animation:fade-up 0.75s var(--ease) both}
.d1{animation-delay:0.05s}.d2{animation-delay:0.15s}
.d3{animation-delay:0.25s}.d4{animation-delay:0.38s}
.d5{animation-delay:0.52s}

/* ===================================================
   HOME - HERO
=================================================== */
.hero{
  background:var(--slate);
  min-height:100vh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:100px 0 80px;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(ellipse 80% 60% at 70% 50%, rgba(43,108,176,0.08) 0%, transparent 70%),
    repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.018) 59px,rgba(255,255,255,0.018) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.018) 59px,rgba(255,255,255,0.018) 60px);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;
  max-width:1160px;margin:0 auto;padding:0 2.5rem;
  display:grid;grid-template-columns:1.05fr 0.95fr;gap:6rem;align-items:center;
}
.hero-available{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12);
  border-radius:100px;padding:5px 14px 5px 10px;margin-bottom:2rem;
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.55);
}
.pulse{
  width:6px;height:6px;border-radius:50%;background:#52C97A;flex-shrink:0;
  animation:pulse-anim 2.2s ease-in-out infinite;
}
@keyframes pulse-anim{
  0%,100%{box-shadow:0 0 0 0 rgba(82,201,122,0.5)}
  50%{box-shadow:0 0 0 5px rgba(82,201,122,0)}
}
.hero-h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2.6rem,4.5vw,4.2rem);
  line-height:1.1;letter-spacing:0.005em;
  color:#fff;margin-bottom:1.5rem;
}
.hero-h1 em{font-style:italic;color:#A8C5E8}
.hero-rule{
  width:44px;height:1px;background:rgba(176,125,58,0.7);
  margin-bottom:1.5rem;
}
.hero-lead{
  font-size:1.02rem;font-weight:300;line-height:1.8;
  color:rgba(255,255,255,0.58);max-width:480px;margin-bottom:2.25rem;
}
.hero-lead strong{color:rgba(255,255,255,0.82);font-weight:400}
.hero-actions{display:flex;gap:0.9rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-proof{
  display:flex;gap:2.5rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,0.07);
}
.hp-num{
  font-family:var(--serif);font-size:2rem;font-weight:400;
  color:#A8C5E8;line-height:1;margin-bottom:4px;
}
.hp-label{
  font-family:var(--mono);font-size:0.57rem;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.3);line-height:1.4;
}

/* Hero right: headshot */
.hero-right{display:flex;flex-direction:column;gap:1px}
.hero-headshot{
  position:relative;border-radius:3px;overflow:hidden;
  aspect-ratio:1/1.08;box-shadow:0 24px 60px rgba(0,0,0,0.35);
}
.hero-headshot img{width:100%;height:100%;object-fit:cover}
.hero-headshot-overlay{
  position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;
}
.hero-headshot-name{
  font-family:var(--serif);font-size:1.25rem;font-weight:400;
  color:#fff;letter-spacing:0.02em;line-height:1.2;margin-bottom:4px;
}
.hero-headshot-title{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.15em;
  text-transform:uppercase;color:rgba(168,197,232,0.75);
}

/* ===================================================
   MARQUEE BAND
=================================================== */
.marquee-band{
  background:var(--s1);
  border-top:1px solid var(--s2);border-bottom:1px solid var(--s2);
  padding:1.1rem 0;overflow:hidden;
}
.marquee-track{
  display:flex;gap:3rem;animation:scroll-l 28s linear infinite;white-space:nowrap;
}
@keyframes scroll-l{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  display:flex;align-items:center;gap:0.6rem;
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--t-muted);
}
.marquee-dot{width:3px;height:3px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ===================================================
   CLIENT LOGOS BAND
=================================================== */
.logos-band{
  background:var(--slate);padding:3.5rem 0 3rem;
  border-top:1px solid rgba(255,255,255,0.06);
  overflow:hidden;
}
.logos-band .eyebrow::before{background:rgba(255,255,255,0.2)}
.logos-scroll{overflow:hidden;position:relative}
.logos-scroll::before,.logos-scroll::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.logos-scroll::before{left:0;background:linear-gradient(90deg,var(--slate),transparent)}
.logos-scroll::after{right:0;background:linear-gradient(270deg,var(--slate),transparent)}
.logos-track{
  display:flex;align-items:center;gap:4rem;
  animation:logos-scroll 30s linear infinite;
  white-space:nowrap;
}
@keyframes logos-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logos-track img{
  height:36px;width:auto;
  filter:brightness(0) invert(1);
  opacity:0.55;
  transition:opacity 0.25s var(--ease);
  flex-shrink:0;
}
.logos-track img:hover{opacity:0.85}

/* ===================================================
   POSITIONING
=================================================== */
.pos-section{padding:7rem 0;background:var(--s0)}
.pos-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.pos-text p{
  font-size:0.93rem;font-weight:300;color:var(--t-secondary);
  line-height:1.85;margin-bottom:1rem;
}
.pos-text p strong{color:var(--t-primary);font-weight:500}
.pos-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat-tile{
  background:var(--s1);border:1px solid var(--s2);
  padding:1.65rem 1.5rem;position:relative;overflow:hidden;
}
.stat-tile::after{
  content:'';position:absolute;top:0;left:0;
  width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold) 0%,transparent 80%);
}
.st-num{
  font-family:var(--serif);font-size:2.6rem;font-weight:400;
  color:var(--slate);line-height:1;margin-bottom:6px;
}
.st-label{font-size:0.78rem;font-weight:300;color:var(--t-muted);line-height:1.5}

/* ===================================================
   ENGAGEMENT AREAS
=================================================== */
.engage-section{padding:7rem 0;background:var(--slate);position:relative}
.engage-section::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,0.015) 59px,rgba(255,255,255,0.015) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,0.015) 59px,rgba(255,255,255,0.015) 60px);
  pointer-events:none;
}
.engage-header{
  display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3.5rem;
}
.engage-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5px;background:rgba(255,255,255,0.04)}
.ea-card{
  background:var(--slate);padding:2.5rem;
  border:1px solid rgba(255,255,255,0.04);
  transition:background 0.25s var(--ease);
}
.ea-card:hover{background:rgba(43,108,176,0.06);border-color:rgba(43,108,176,0.12)}
.ea-num{
  font-family:var(--serif);font-size:2.8rem;font-weight:400;
  color:rgba(168,197,232,0.25);line-height:1;margin-bottom:1.25rem;
}
.ea-title{
  font-family:var(--serif);font-size:1.25rem;font-weight:400;
  color:rgba(255,255,255,0.88);margin-bottom:0.75rem;letter-spacing:0.01em;
}
.ea-desc{
  font-size:0.85rem;font-weight:300;color:rgba(255,255,255,0.45);
  line-height:1.75;margin-bottom:1.5rem;
}
.ea-tags{display:flex;flex-wrap:wrap;gap:0.4rem}

/* ===================================================
   THINKING / PRINCIPLES
=================================================== */
.think-section{padding:7rem 0;background:var(--s1)}
.think-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;background:var(--s2);margin-top:3.5rem;
}
.think-card{background:var(--s1);padding:2.5rem;transition:background 0.25s var(--ease)}
.think-card:hover{background:var(--gold-wash)}
.think-icon{
  font-family:var(--serif);font-style:italic;
  font-size:0.8rem;color:var(--gold);margin-bottom:1.25rem;
  letter-spacing:0.05em;
}
.think-title{
  font-family:var(--serif);font-size:1.15rem;font-weight:400;
  color:var(--ink);margin-bottom:0.65rem;letter-spacing:0.01em;
}
.think-body{font-size:0.84rem;font-weight:300;color:var(--t-secondary);line-height:1.75}

/* ===================================================
   SELECTED ENGAGEMENTS
=================================================== */
.eng-section{padding:7rem 0;background:var(--s0)}
.eng-list{margin-top:3.5rem;border-top:1px solid var(--s2)}
.eng-row{
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;
  padding:1.75rem 0;border-bottom:1px solid var(--s2);
  transition:padding-left 0.2s var(--ease);cursor:default;
}
.eng-row:hover{padding-left:0.5rem}
.eng-type{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:0.35rem;
}
.eng-name{
  font-family:var(--serif);font-size:1.15rem;font-weight:400;
  color:var(--ink);margin-bottom:0.3rem;letter-spacing:0.01em;
}
.eng-desc{font-size:0.82rem;font-weight:300;color:var(--t-muted)}
.eng-tags{display:flex;gap:0.4rem;flex-wrap:wrap;justify-content:flex-end}

/* ===================================================
   CONTACT CTA
=================================================== */
.cta-band{
  background:var(--slate);padding:5rem 0;
  border-top:1px solid rgba(255,255,255,0.06);
}
.cta-inner{
  max-width:1160px;margin:0 auto;padding:0 2.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:4rem;
}
.cta-text h2{
  font-family:var(--serif);font-size:2rem;font-weight:400;
  color:#fff;margin-bottom:0.6rem;line-height:1.2;
}
.cta-text p{font-size:0.88rem;font-weight:300;color:rgba(255,255,255,0.45);max-width:420px}

/* ===================================================
   PAGE HERO (sub-pages)
=================================================== */
.pg-hero{
  background:var(--slate);padding:130px 2.5rem 65px;
  position:relative;overflow:hidden;
}
.pg-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 60% 40%,rgba(43,108,176,0.07) 0%,transparent 70%);
  pointer-events:none;
}
.pg-inner{max-width:1160px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:1.25rem;
}
.breadcrumb a{color:rgba(168,197,232,0.7);transition:color 0.18s}
.breadcrumb a:hover{color:#A8C5E8}

/* ===================================================
   CONTACT PAGE
=================================================== */
.contact-pg{padding:5rem 0 7rem;background:var(--s0)}
.contact-pg-grid{
  display:grid;grid-template-columns:1fr 1.15fr;gap:5.5rem;
  align-items:start;margin-top:3.5rem;
}
.ci-block p{
  font-size:0.9rem;font-weight:300;color:var(--t-secondary);
  line-height:1.85;margin-bottom:1.75rem;
}
.cm-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}
.cm-row{display:flex;gap:1rem;align-items:flex-start}
.cm-icon{
  width:40px;height:40px;background:var(--s1);border:1px solid var(--s2);
  border-radius:2px;display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.cm-lbl{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--t-muted);margin-bottom:2px;
}
.cm-val{font-size:0.9rem;color:var(--t-primary);font-weight:400}
.avail-box{
  background:var(--accent-wash);border:1px solid rgba(43,108,176,0.15);
  border-left:3px solid var(--accent);padding:1.25rem 1.25rem;margin-top:1.75rem;
}
.avail-lbl{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--accent);margin-bottom:0.4rem;
}
.avail-txt{font-size:0.83rem;font-weight:300;color:var(--t-secondary);line-height:1.6}

/* Form */
.form-box{background:var(--s1);border:1px solid var(--s2);padding:2.5rem}
.form-box-title{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;
  color:var(--ink);margin-bottom:1.75rem;letter-spacing:0.01em;
}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem}
.f-field{margin-bottom:0.85rem}
.f-lbl{
  font-family:var(--mono);font-size:0.57rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--t-muted);display:block;margin-bottom:0.35rem;
}
.f-input{
  width:100%;background:var(--s0);border:1px solid var(--s2);border-radius:2px;
  padding:10px 13px;font-size:0.87rem;color:var(--t-primary);
  font-family:var(--sans);font-weight:300;
  transition:border-color 0.18s;outline:none;
}
.f-input::placeholder{color:var(--t-muted)}
.f-input:focus{border-color:var(--accent)}
.f-textarea{min-height:110px;resize:vertical}
.f-submit{
  width:100%;background:var(--slate);color:#fff;
  font-family:var(--mono);font-size:0.72rem;letter-spacing:0.12em;
  text-transform:uppercase;padding:13px;border-radius:2px;
  transition:background 0.18s var(--ease);margin-top:0.25rem;
}
.f-submit:hover{background:var(--slate-mid)}
.f-note{
  font-family:var(--mono);font-size:0.57rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--t-muted);text-align:center;margin-top:0.9rem;
}

/* ===================================================
   CAREER PAGE
=================================================== */
.career-pg{padding:5rem 0 7rem;background:var(--s0)}
.tl{position:relative;margin-top:3.5rem}
.tl::before{
  content:'';position:absolute;left:130px;top:0;bottom:0;
  width:1px;background:var(--s2);
}
.tl-entry{
  display:grid;grid-template-columns:130px 1fr;
  gap:2.75rem;margin-bottom:3.5rem;position:relative;
}
.tl-entry:last-child{margin-bottom:0}
.tl-entry::after{
  content:'';position:absolute;left:125px;top:9px;
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);border:2px solid var(--s0);
  box-shadow:0 0 0 3px rgba(43,108,176,0.15);
}
.tl-date{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.09em;
  color:var(--accent);text-align:right;padding-right:2.5rem;
  padding-top:0.2rem;text-transform:uppercase;line-height:1.5;
}
.tl-title{
  font-family:var(--serif);font-size:1.3rem;font-weight:400;
  color:var(--ink);margin-bottom:3px;letter-spacing:0.01em;
}
.tl-co{
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--t-muted);margin-bottom:0.9rem;
}
.tl-body p{
  font-size:0.87rem;font-weight:300;color:var(--t-secondary);
  line-height:1.78;margin-bottom:0.85rem;max-width:560px;
}
.tl-ach{list-style:none;margin-top:0.5rem}
.tl-ach li{
  font-size:0.83rem;font-weight:300;color:var(--t-secondary);
  padding:0.45rem 0;border-bottom:1px solid var(--s2);
  display:flex;gap:0.65rem;align-items:flex-start;max-width:560px;
}
.tl-ach li:last-child{border-bottom:none}
.tl-ach li::before{
  content:'\2013';color:var(--accent);font-size:0.75rem;
  flex-shrink:0;margin-top:0.15rem;
}

/* Education */
.edu-section{padding:5rem 0 7rem;background:var(--s1)}
.cred-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:3rem}
.cred-card{
  background:var(--s0);border:1px solid var(--s2);padding:1.75rem;
  position:relative;overflow:hidden;
}
.cred-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold) 0%,transparent 100%);
}
.cred-deg{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--gold);margin-bottom:5px;
}
.cred-inst{
  font-family:var(--serif);font-size:1.08rem;font-weight:400;
  color:var(--ink);margin-bottom:0.5rem;
}
.cred-det{font-size:0.82rem;font-weight:300;color:var(--t-muted);line-height:1.6}

/* ===================================================
   SERVICES PAGE
=================================================== */
.svc-pg{padding:5rem 0 7rem;background:var(--s0)}
.svc-intro{max-width:640px;margin-bottom:4rem}
.svc-intro p{
  font-size:0.95rem;font-weight:300;color:var(--t-secondary);
  line-height:1.85;margin-top:1rem;
}
.svc-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1.5px;background:var(--s2);
}
.svc-card{
  background:var(--s0);padding:2.5rem;
  transition:background 0.22s var(--ease);
}
.svc-card:hover{background:var(--s1)}
.svc-n{
  font-family:var(--serif);font-size:2.8rem;font-weight:400;
  color:var(--s2);line-height:1;margin-bottom:1rem;
}
.svc-title{
  font-family:var(--serif);font-size:1.2rem;font-weight:400;
  color:var(--ink);margin-bottom:0.65rem;letter-spacing:0.01em;
}
.svc-desc{
  font-size:0.87rem;font-weight:300;color:var(--t-secondary);
  line-height:1.75;margin-bottom:1.25rem;
}
.svc-items{list-style:none;display:flex;flex-direction:column;gap:0.35rem}
.svc-items li{
  font-size:0.8rem;color:var(--t-secondary);font-weight:300;
  padding-left:0.9rem;position:relative;
}
.svc-items li::before{
  content:'\2013';position:absolute;left:0;color:var(--accent);font-size:0.72rem;
}
.svc-cta-box{
  margin-top:3.5rem;padding:2.5rem 3rem;
  background:var(--s1);border:1px solid var(--s2);
  display:flex;align-items:center;justify-content:space-between;gap:3rem;
}
.svc-cta-box h3{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;
  color:var(--ink);margin-bottom:0.4rem;
}
.svc-cta-box p{font-size:0.85rem;font-weight:300;color:var(--t-muted)}

/* ===================================================
   INSIGHTS SECTION
=================================================== */
.insights-section{
  padding:7rem 0;background:var(--s1);
  border-top:1px solid var(--s2);
}
.insights-header{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  align-items:end;margin-bottom:3.5rem;
}
.insights-sub{
  font-size:0.92rem;font-weight:300;color:var(--t-muted);
  line-height:1.85;max-width:440px;justify-self:end;align-self:end;
}
.insights-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1.5px;background:var(--s2);margin-bottom:3.5rem;
}
.insight-card--wide{border-top:3px solid #6B4F9E}
.insight-card--wide .ic-body{display:none}
.insight-card--wide.open .ic-body{display:block}
.insight-card{
  background:var(--s0);padding:2.25rem;cursor:pointer;
  transition:background 0.22s var(--ease);position:relative;overflow:hidden;
}
.insight-card:hover{background:var(--gold-wash)}
.insight-card--coming{background:var(--s1);opacity:0.7}
.insight-card--coming:hover{background:var(--s1)}
.ic-meta{display:flex;align-items:center;gap:0.75rem;margin-bottom:1rem}
.ic-format{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--accent);background:var(--accent-pale);
  border:1px solid rgba(43,108,176,0.15);padding:3px 9px;border-radius:2px;
}
.insight-card[data-format="field-note"] .ic-format{
  color:var(--gold);background:var(--gold-pale);border-color:rgba(176,125,58,0.2);
}
.insight-card[data-format="q-and-a"] .ic-format{
  color:#2D7A4A;background:#EAF5EE;border-color:rgba(45,122,74,0.2);
}
.insight-card[data-format="coming-soon"] .ic-format{
  color:var(--t-muted);background:var(--s2);border-color:transparent;
}
.ic-read{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--t-muted);
}
.ic-title{
  font-family:var(--serif);font-size:1.12rem;font-weight:400;
  color:var(--ink);line-height:1.35;margin-bottom:0.75rem;letter-spacing:0.01em;
}
.ic-hook{
  font-size:0.87rem;font-weight:300;color:var(--t-secondary);
  line-height:1.7;margin-bottom:0;font-style:italic;
}
.ic-body{
  display:none;margin-top:1.25rem;padding-top:1.25rem;
  border-top:1px solid var(--s2);
}
.ic-body p{
  font-size:0.87rem;font-weight:300;color:var(--t-secondary);
  line-height:1.8;margin-bottom:0.85rem;
}
.ic-body p:last-child{margin-bottom:0}
.ic-body strong{color:var(--t-primary);font-weight:500}
.insight-card.open .ic-body{display:block}
.ic-expand-btn{
  display:inline-flex;align-items:center;gap:0.35rem;margin-top:1.1rem;
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--accent);transition:gap 0.2s;
}
.insight-card:hover .ic-expand-btn{gap:0.55rem}
.insight-card.open .ic-arrow{display:inline-block;transform:rotate(180deg)}
.ic-arrow{display:inline-block;transition:transform 0.25s var(--ease)}
.insight-card.open .ic-expand-btn{color:var(--t-muted)}
.insight-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:transparent;transition:background 0.2s;
}
.insight-card[data-format="sharp-take"]::before{background:var(--accent)}
.insight-card[data-format="field-note"]::before{background:var(--gold)}
.insight-card[data-format="q-and-a"]::before{background:#2D7A4A}
.insights-follow{
  display:flex;align-items:center;justify-content:space-between;gap:3rem;
  padding:2rem 2.5rem;background:var(--s0);border:1px solid var(--s2);
}
.if-text .eyebrow{margin-bottom:0.4rem}
.if-text p{font-size:0.87rem;font-weight:300;color:var(--t-muted);max-width:420px}

/* THINKING PAGE */
.thinking-pg{padding:4rem 0 7rem;background:var(--s0)}
.thinking-legend{
  display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap;
  padding:1.1rem 1.5rem;background:var(--s1);
  border:1px solid var(--s2);margin-bottom:0;
}

/* HOMEPAGE PREVIEW STRIP */
.preview-strip{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;background:var(--s2);
}
.preview-card{
  background:var(--s0);padding:1.75rem;cursor:pointer;
  transition:background 0.2s var(--ease);
  display:flex;flex-direction:column;gap:0.65rem;
}
.preview-card:hover{background:var(--gold-wash)}
.preview-title{
  font-family:var(--serif);font-size:1.05rem;font-weight:400;
  color:var(--ink);line-height:1.35;letter-spacing:0.01em;
}
.preview-hook{
  font-size:0.83rem;font-weight:300;color:var(--t-muted);
  line-height:1.65;flex:1;
}
.preview-read{
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--accent);margin-top:0.25rem;
}

/* ===================================================
   FOOTER
=================================================== */
.footer{
  background:var(--ink-mid);
  border-top:1px solid rgba(255,255,255,0.06);
  padding:2.25rem 2.5rem;
}
.footer-inner{
  max-width:1160px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
}
.footer-brand{
  font-family:var(--serif);font-size:0.95rem;font-weight:400;
  color:rgba(255,255,255,0.4);
}
.footer-brand em{color:rgba(168,197,232,0.65);font-style:normal}
.footer-links{display:flex;gap:1.75rem;list-style:none}
.footer-links a{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.28);
  transition:color 0.18s;
}
.footer-links a:hover{color:rgba(168,197,232,0.7)}
.footer-copy{
  font-family:var(--mono);font-size:0.58rem;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.18);
}

/* ===================================================
   RESPONSIVE - TABLET (max-width: 1024px)
=================================================== */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:3rem;text-align:left}
  .hero-right{max-width:400px}
  .hero{min-height:auto;padding:120px 0 60px}
  .pos-grid{grid-template-columns:1fr;gap:3rem}
  .engage-grid{grid-template-columns:1fr 1fr}
  .think-grid{grid-template-columns:1fr 1fr}
  .contact-pg-grid{grid-template-columns:1fr;gap:3rem}
  .insights-header{grid-template-columns:1fr;gap:1.5rem}
  .insights-sub{justify-self:start}
  .insight-card--wide > div[style*="grid-template-columns"]{
    display:block !important;
  }
  .insight-card--wide > div > div:last-child{margin-top:1.5rem}
  .insight-card--wide .ic-body > div[style*="grid-template-columns"]{
    display:block !important;
  }
  .insight-card--wide .ic-body > div > div:last-child{margin-top:2rem}
  .svc-cta-box{flex-direction:column;text-align:center;gap:1.5rem}
  .cta-inner{flex-direction:column;text-align:center;gap:2rem}
  .engage-header{flex-direction:column;align-items:flex-start;gap:1.5rem}
}

/* ===================================================
   RESPONSIVE - MOBILE (max-width: 768px)
=================================================== */
@media (max-width:768px){
  .wrap{padding:0 1.25rem}
  .wrap-narrow{padding:0 1.25rem}
  .nav-inner{padding:0 1.25rem}

  /* Nav mobile */
  .nav-hamburger{display:flex}
  .nav-links{
    display:none;flex-direction:column;
    align-items:center;justify-content:center;
    position:fixed;top:66px;left:0;right:0;bottom:0;
    height:calc(100vh - 66px);width:100vw;
    background:rgba(28,43,58,1);
    padding:0 1.5rem;gap:0;
    z-index:99;
    overflow-y:auto;
    opacity:0;
    transform:translateY(-20px);
  }
  .nav-links.open{
    display:flex;
    animation:menuSlideIn 0.35s var(--ease) forwards;
  }
  @keyframes menuSlideIn{
    from{opacity:0;transform:translateY(-20px)}
    to{opacity:1;transform:translateY(0)}
  }
  .nav.menu-open{
    background:rgba(28,43,58,1);
    border-bottom-color:rgba(255,255,255,0.1);
    transition:background 0.3s var(--ease);
  }
  .nav.menu-open .nav-brand-name,
  .nav.menu-open .nav-brand-sub{
    color:rgba(255,255,255,0.85);
    transition:color 0.3s var(--ease);
  }
  .nav.menu-open .nav-hamburger span{
    background:rgba(255,255,255,0.85);
  }
  .nav-links li{
    border-bottom:1px solid rgba(255,255,255,0.08);
    width:100%;
    text-align:center;
  }
  .nav-links li:last-child{border-bottom:none}
  .nav-links a{
    display:block;padding:1.6rem 0;
    font-size:1.35rem;
    letter-spacing:0.12em;
    color:rgba(255,255,255,0.85);
  }
  .nav-links a:hover,.nav-links a.active{
    color:var(--accent-lt);
  }
  .nav-cta{display:none}

  /* Hero */
  .hero{padding:100px 0 50px}
  .hero-inner{padding:0 1.25rem;gap:2.5rem}
  .hero-h1{font-size:clamp(2rem,6vw,2.6rem)}
  .hero-proof{gap:1.25rem;flex-wrap:wrap}
  .hp-num{font-size:1.5rem}
  .hero-right{max-width:100%}
  .hero-headshot{aspect-ratio:1/1}

  /* Marquee */
  .marquee-item{font-size:0.55rem}

  /* Client logos */
  .logos-band{padding:2.5rem 0 2rem}
  .logos-track{gap:2.5rem}
  .logos-track img{height:28px}

  /* Positioning */
  .pos-section{padding:4rem 0}
  .pos-stats{grid-template-columns:1fr 1fr;gap:0.75rem}
  .st-num{font-size:2rem}

  /* Engagement */
  .engage-section{padding:4rem 0}
  .engage-grid{grid-template-columns:1fr}
  .ea-card{padding:1.75rem}

  /* Thinking */
  .think-section{padding:4rem 0}
  .think-grid{grid-template-columns:1fr}
  .think-card{padding:1.75rem}

  /* Engagements list */
  .eng-section{padding:4rem 0}
  .eng-row{grid-template-columns:1fr;gap:0.75rem}
  .eng-tags{justify-content:flex-start}

  /* Insights */
  .insights-section{padding:4rem 0}
  .insights-grid{grid-template-columns:1fr}
  .preview-strip{grid-template-columns:1fr}
  .insights-follow{flex-direction:column;text-align:center;gap:1.5rem;padding:1.5rem}

  /* Page hero */
  .pg-hero{padding:100px 1.25rem 40px}
  .pg-hero h1{font-size:clamp(1.8rem,5vw,2.4rem) !important}

  /* Contact */
  .contact-pg{padding:3rem 0 4rem}
  .form-box{padding:1.5rem}
  .f-row{grid-template-columns:1fr}

  /* Career */
  .career-pg{padding:3rem 0 4rem}
  .tl::before{left:0}
  .tl-entry{grid-template-columns:1fr;gap:0.5rem;padding-left:1.75rem}
  .tl-entry::after{left:-5px;top:5px}
  .tl-date{text-align:left;padding-right:0;margin-bottom:0.25rem}

  /* Education */
  .edu-section{padding:3rem 0 4rem}
  .cred-grid{grid-template-columns:1fr}

  /* Services */
  .svc-pg{padding:3rem 0 4rem}
  .svc-grid{grid-template-columns:1fr}
  .svc-card{padding:1.75rem}
  .svc-cta-box{padding:1.5rem;flex-direction:column;text-align:center}

  /* CTA */
  .cta-band{padding:3rem 0}

  /* Footer */
  .footer{padding:1.5rem 1.25rem}
  .footer-inner{flex-direction:column;text-align:center;gap:1rem}
  .footer-links{flex-wrap:wrap;justify-content:center;gap:1rem}
}

/* ===================================================
   RESPONSIVE - SMALL MOBILE (max-width: 480px)
=================================================== */
@media (max-width:480px){
  .hero-proof{gap:1rem}
  .hp-num{font-size:1.25rem}
  .hp-label{font-size:0.5rem}
  .pos-stats{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .btn-dark,
  .hero-actions .btn-light{width:100%;justify-content:center}
  .tag-sm{font-size:0.52rem;padding:2px 6px}
  .ea-tags{gap:0.3rem}
  .eng-tags{gap:0.3rem}
}
