/* =========================================================
   Neeraj Tickoo — Personal Brand Site
   Stylesheet: refined editorial aesthetic
   Palette per brief: Deep Navy, Warm Amber, Soft Ivory, Stone, Charcoal
   Typography: Fraunces (serif display) + DM Sans (humanist sans body)
   ========================================================= */

/* ---------- Design Tokens ---------- */
:root {
  /* Brand colours */
  --c-navy:      #0E2A47;
  --c-navy-700:  #163559;
  --c-amber:     #B4540A;
  --c-amber-600: #97430A;
  --c-ivory:     #FAF7F0;
  --c-ivory-2:   #F2EDE2;
  --c-stone:     #E5E2DA;
  --c-stone-2:   #CBC6B9;
  --c-stone-50:  #F3EFE6;
  --c-charcoal:  #303030;
  --c-muted:     #4E5867;

  /* Semantic */
  --bg:          var(--c-ivory);
  --bg-alt:      var(--c-ivory-2);
  --surface:     #FFFFFF;
  --text:        var(--c-charcoal);
  --text-soft:   var(--c-muted);
  --heading:     var(--c-navy);
  --rule:        var(--c-stone);
  --accent:      var(--c-amber);
  --accent-text: #FFFFFF;
  --focus-ring:  #FFB454;

  /* Typography */
  --f-serif: "Fraunces", "Times New Roman", Georgia, serif;
  --f-sans:  "DM Sans", "Helvetica Neue", system-ui, sans-serif;
  --f-mono:  "JetBrains Mono", ui-monospace, Menlo, monospace;

  /* Scale */
  --fs-1: clamp(2.2rem, 4vw + 0.5rem, 3.8rem);
  --fs-2: clamp(1.7rem, 2.6vw + 0.5rem, 2.6rem);
  --fs-3: clamp(1.35rem, 1.4vw + 0.5rem, 1.75rem);
  --fs-4: 1.15rem;
  --fs-body: 1rem;
  --fs-small: 0.875rem;
  --fs-tiny: 0.75rem;

  /* Layout */
  --max-w: 1200px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --section-y: clamp(2.25rem, 4vw, 3rem);
  --radius-card: 14px;
  --shadow-card: 0 4px 14px rgba(14, 42, 71, 0.06);
  --radius: 2px;
  --transition: 220ms cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
[id] { scroll-margin-top: 80px; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
}
body {
  margin: 0;
  font-family: var(--f-sans);
  font-size: var(--fs-body);
  line-height: 1.58;
  color: var(--text);
  background: var(--bg);
  font-feature-settings: "ss01", "kern";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; }
a { color: var(--accent); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--c-amber-600); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 4px; }
:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 3px; border-radius: 2px; }
.skip-link {
  position: absolute; left: -9999px; top: 1rem;
  background: var(--c-navy); color: #fff; padding: .75rem 1rem;
  z-index: 1000; font-weight: 600;
}
.skip-link:focus { left: 1rem; }

::selection { background: var(--c-navy); color: #FAF7F0; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 {
  font-family: var(--f-serif);
  color: var(--heading);
  font-weight: 500;
  font-variation-settings: "opsz" 144, "SOFT" 30;
  letter-spacing: -0.015em;
  line-height: 1.1;
  margin: 0 0 0.6em;
}
h1 { font-size: var(--fs-1); font-weight: 400; letter-spacing: -0.025em; }
h2 { font-size: var(--fs-2); font-weight: 450; }
h3 { font-size: var(--fs-3); font-weight: 500; }
h4 { font-size: var(--fs-4); font-weight: 500; }
p { margin: 0 0 1.1em; max-width: 65ch; }
.lead { font-size: 1.1rem; line-height: 1.55; color: var(--text); max-width: 60ch; }
em, .italic { font-style: italic; }

.eyebrow {
  font-family: var(--f-sans);
  font-size: var(--fs-tiny);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--accent);
  margin: 0 0 1.25rem;
  display: inline-flex; align-items: center; gap: .75rem;
}
.eyebrow::before {
  content: ""; display: inline-block; width: 2rem; height: 1px; background: var(--accent);
}
.section-number {
  font-family: var(--f-mono);
  font-size: var(--fs-tiny);
  color: var(--heading);
  letter-spacing: 0.1em;
}

/* ---------- Layout primitives ---------- */
.container { max-width: var(--max-w); margin: 0 auto; padding-inline: var(--gutter); }
.container-narrow { max-width: 820px; margin: 0 auto; padding-inline: var(--gutter); }
section { padding-block: var(--section-y); }
.section-tight { padding-block: clamp(1.5rem, 3vw, 2.25rem); }

.rule { height: 1px; background: var(--rule); border: 0; margin: 0; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--rule);
}
.nav-bar {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand {
  font-family: var(--f-serif);
  font-size: 1.15rem;
  white-space: nowrap;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--heading);
}
.brand:hover { color: var(--heading); text-decoration: none; }
.brand .dot { color: var(--accent); }

.nav-links {
  display: flex; gap: clamp(0.9rem, 1.4vw, 1.6rem); align-items: center;
  list-style: none; margin: 0; padding: 0;
}
.nav-links a {
  color: var(--text);
  font-size: 0.88rem;
  white-space: nowrap;
  font-weight: 500;
  position: relative;
  padding: .25rem 0;
}
.nav-links a:hover { color: var(--accent); text-decoration: none; }
.nav-links a[aria-current="page"] { color: var(--accent); }
.nav-links a[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 2px; background: var(--accent);
}

.nav-tools {
  display: flex; align-items: center; gap: .5rem;
}
.icon-btn {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid transparent;
  color: var(--text); border-radius: 999px;
  transition: all var(--transition);
}
.icon-btn:hover { background: var(--bg-alt); border-color: var(--rule); }
.icon-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.6; }

.hamburger {
  display: none;
  width: 44px; height: 44px;
  background: transparent; border: 1px solid var(--rule);
  border-radius: 999px;
  position: relative;
}
.hamburger span {
  position: absolute; left: 50%; transform: translateX(-50%);
  width: 18px; height: 1.5px; background: var(--text);
  transition: transform var(--transition), opacity var(--transition), top var(--transition);
}
.hamburger span:nth-child(1) { top: 16px; }
.hamburger span:nth-child(2) { top: 21px; }
.hamburger span:nth-child(3) { top: 26px; }
.hamburger[aria-expanded="true"] span:nth-child(1) { top: 21px; transform: translateX(-50%) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { top: 21px; transform: translateX(-50%) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  position: fixed; inset: 64px 0 0 0; z-index: 90;
  background: var(--bg);
  padding: 2rem var(--gutter);
  transform: translateY(-100%);
  transition: transform var(--transition);
  overflow-y: auto;
  display: flex; flex-direction: column;
}
.mobile-menu.open { transform: translateY(0); }
.mobile-menu .nav-links {
  flex-direction: column;
  gap: 0;
  align-items: flex-start;
}
.mobile-menu .nav-links li { width: 100%; }
.mobile-menu .nav-links a {
  display: block;
  font-family: var(--f-serif);
  font-size: 1.75rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--rule);
  width: 100%;
}
.mobile-menu-cta { margin-top: auto; padding-top: 2rem; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .65rem;
  padding: .7rem 1.3rem;
  border-radius: 999px;
  font-size: 0.93rem;
  font-weight: 500;
  font-family: var(--f-sans);
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: all var(--transition);
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn-primary {
  background: var(--c-navy); color: #fff;
}
.btn-primary:hover { background: var(--c-navy-700); color: #fff; }
.btn-accent { background: var(--accent); color: var(--accent-text); }
.btn-accent:hover { background: var(--c-amber-600); color: #fff; }
.btn-ghost { background: transparent; color: var(--text); border-color: var(--rule); }
.btn-ghost:hover { border-color: var(--text); color: var(--text); }
.btn .arrow { transition: transform var(--transition); }
.btn:hover .arrow { transform: translateX(3px); }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  padding-top: clamp(2rem, 3vw, 3rem);
  padding-bottom: clamp(2.25rem, 4vw, 3.25rem);
  overflow: hidden;
  background:
    radial-gradient(900px 420px at 85% -10%, color-mix(in oklab, var(--c-amber) 9%, transparent) 0%, transparent 65%),
    radial-gradient(700px 380px at -10% 110%, color-mix(in oklab, var(--c-navy) 7%, transparent) 0%, transparent 60%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
@media (min-width: 960px) {
  .hero-grid { grid-template-columns: 1.4fr 1fr; align-items: end; gap: 4rem; }
}
.hero h1 {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.hero h1 .accent {
  font-style: normal;
  color: var(--accent);
}
.hero-meta {
  display: flex; flex-wrap: wrap; gap: 1rem 2rem;
  margin-top: 1.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
}
.hero-meta-item { font-size: var(--fs-small); }
.hero-meta-item .label { display: block; font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-soft); margin-bottom: .25rem; }
.hero-meta-item .value { color: var(--heading); font-weight: 500; }

.hero-cta { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.5rem; }

.hero-aside {
  padding: 2rem 0;
  border-left: 1px solid var(--rule);
  padding-left: 2.5rem;
}
@media (max-width: 959px) { .hero-aside { border-left: 0; padding-left: 0; border-top: 1px solid var(--rule); padding-top: 2rem; } }
.hero-aside p { font-family: var(--f-serif); font-size: 1.15rem; font-style: italic; color: var(--text); line-height: 1.55; }

/* Hero portrait abstraction */
.portrait {
  position: relative;
  aspect-ratio: 4 / 5;
  background: linear-gradient(180deg, var(--c-navy) 0%, var(--c-navy-700) 100%);
  overflow: hidden;
  display: flex; align-items: flex-end; justify-content: center;
}
.portrait::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 50% 30%, rgba(184,92,0,.35) 0%, transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(245,234,210,.08) 0%, transparent 50%);
}
.portrait::after {
  content: ""; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(0,0,0,.04) 3px, rgba(0,0,0,.04) 4px);
  mix-blend-mode: overlay;
}
.portrait-tag {
  position: absolute; top: 1.25rem; left: 1.25rem;
  font-family: var(--f-mono); font-size: var(--fs-tiny);
  letter-spacing: 0.14em; color: rgba(255,255,255,.85);
  text-transform: uppercase;
}
.portrait-caption {
  position: relative; z-index: 2;
  padding: 1.5rem; color: #fff;
  font-family: var(--f-serif); font-style: italic;
  font-size: 1.05rem;
  text-align: center;
  max-width: 80%;
  margin-bottom: 2rem;
}
.portrait-caption strong { font-style: normal; display: block; font-size: var(--fs-tiny); letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,.85); margin-top: .5rem; font-family: var(--f-sans); font-weight: 500; }

/* ---------- Stats band ---------- */
.stats {
  background: linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-700) 100%);
  color: #F4EFE2;
  padding-block: clamp(2.75rem, 4.5vw, 3.75rem);
}
.stats-grid {
  display: grid; gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  align-items: stretch;
}
.stat {
  padding: .25rem 0 .25rem 1.4rem;
  border-left: 2px solid color-mix(in oklab, var(--c-amber) 75%, #fff 10%);
}
.stat .num {
  font-family: var(--f-serif);
  font-size: clamp(2.2rem, 3.6vw, 3rem);
  font-weight: 400;
  color: #FAF7F0;
  line-height: 1;
  font-variation-settings: "opsz" 144;
  display: block;
  letter-spacing: -0.01em;
}
.stat .num .unit { color: #E8A35C; font-style: italic; }
.stat .num .cur {
  color: #E8A35C;
  font-family: var(--f-sans);
  font-style: normal;
  font-weight: 500;
  font-size: .62em;
  vertical-align: .14em;
  margin-right: .08em;
}
.stat .label {
  display: block;
  margin-top: .85rem;
  font-size: var(--fs-small);
  color: rgba(244, 239, 226, .78);
  max-width: 24ch;
  line-height: 1.55;
}

/* ---------- Logos wall ---------- */
.logos-wall {
  background: #0D0D0D;
  padding-block: clamp(2rem, 3.5vw, 3rem);
}
.logos-wall-label {
  display: block;
  text-align: center;
  font-family: var(--f-sans);
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: #E8836A;
  margin-bottom: 1.5rem;
}
.logos-grid {
  display: grid; gap: 1px;
  background: rgba(232, 131, 106, 0.12);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px) { .logos-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 960px) { .logos-grid { grid-template-columns: repeat(5, 1fr); } }
.logo-cell {
  background: #0D0D0D;
  padding: 1.25rem .75rem;
  display: flex; align-items: center; justify-content: center;
  min-height: 72px;
  font-family: var(--f-sans);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #C8C0B8;
  text-align: center;
  transition: color var(--transition), background var(--transition);
}
.logo-cell:hover {
  color: #F5C4B5;
  background: #1A0F0A;
}
.logos-caption {
  display: none;
}

/* ---------- Segmentation cards ---------- */
.segment-grid {
  display: grid; gap: 1px;
  grid-template-columns: 1fr;
  background: var(--rule);
  border: 1px solid var(--rule);
}
@media (min-width: 720px) { .segment-grid { grid-template-columns: 1fr 1fr; } }
.segment-card {
  background: var(--surface);
  padding: 1.6rem;
  display: flex; flex-direction: column;
  text-decoration: none;
  color: var(--text);
  transition: background var(--transition), color var(--transition);
  position: relative;
  min-height: 170px;
}
.segment-card:hover { background: var(--c-navy); color: #F4EFE2; text-decoration: none; }
.segment-card .seg-label { font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.16em; color: var(--accent); margin-bottom: 1rem; }
.segment-card:hover .seg-label { color: #fff; }
.segment-card h3 { font-size: 1.4rem; color: inherit; margin-bottom: .5rem; }
.segment-card:hover h3 { color: inherit; }
.segment-card .seg-cta {
  margin-top: auto;
  font-family: var(--f-sans);
  font-size: var(--fs-small);
  font-weight: 500;
  display: inline-flex; align-items: center; gap: .5rem;
  color: var(--accent);
}
.segment-card:hover .seg-cta { color: #fff; }
/* ---------- Practice areas ---------- */
.practice-grid {
  display: grid; gap: 2.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .practice-grid { grid-template-columns: repeat(2, 1fr); gap: 1.75rem 2.5rem; } }
.practice {
  padding-top: 1.5rem;
  border-top: 1px solid var(--c-navy);
}
.practice .practice-num {
  font-family: var(--f-mono);
  font-size: var(--fs-tiny);
  letter-spacing: 0.14em;
  color: var(--accent);
  margin-bottom: 1rem;
  display: block;
}
.practice h3 { font-size: 1.6rem; margin-bottom: .75rem; }
.practice ul { padding-left: 1.1rem; margin: 1rem 0 0; font-size: var(--fs-small); color: var(--text-soft); }
.practice ul li { margin-bottom: .35rem; }

/* ---------- Outcomes / Case study cards ---------- */
.outcome-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 760px) { .outcome-grid { grid-template-columns: repeat(3, 1fr); } }
.outcome-card {
  padding: 1.5rem;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  transition: border-color var(--transition), transform var(--transition);
}
.outcome-card:hover { border-color: var(--c-navy); transform: translateY(-3px); }
.outcome-card .outcome-tag { font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent); margin-bottom: 1rem; }
.outcome-card h3 { font-size: 1.25rem; }
.outcome-card .outcome-stat {
  font-family: var(--f-serif);
  font-size: 2rem;
  color: var(--heading);
  font-variation-settings: "opsz" 144;
  margin: 1rem 0 .25rem;
}
.outcome-card p { font-size: var(--fs-small); color: var(--text-soft); margin-bottom: 1.5rem; }
.outcome-card a { font-size: var(--fs-small); font-weight: 500; margin-top: auto; }

/* ---------- Testimonials ---------- */
.testimonials {
  background: var(--c-navy);
  color: #F4EFE2;
  padding-block: var(--section-y);
}
.testimonials h2 { color: #F4EFE2; }
.testimonials .eyebrow { color: #F09A43; }
.testimonials .eyebrow::before { background: #F09A43; }
.testimonial-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: 1fr;
  margin-top: 3rem;
}
@media (min-width: 760px) { .testimonial-grid { grid-template-columns: repeat(2, 1fr); } }
.testimonial {
  padding: 0;
  position: relative;
  padding-left: 2rem;
  border-left: 1px solid rgba(255,255,255,0.15);
}
.testimonial::before {
  content: "“";
  position: absolute; top: -1rem; left: 1.25rem;
  font-family: var(--f-serif); font-size: 4rem;
  color: var(--accent);
  line-height: 1;
}
.testimonial blockquote {
  margin: 0;
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 1.2rem;
  line-height: 1.55;
  color: #F4EFE2;
}
.testimonial cite {
  display: block;
  margin-top: 1.5rem;
  font-style: normal;
  font-size: var(--fs-small);
  color: rgba(244,239,226,0.85);
}
.testimonial cite strong { display: block; color: #fff; font-weight: 500; }

/* ---------- Page header (interior pages) ---------- */
.page-header {
  padding-top: clamp(1.5rem, 3vw, 2.25rem);
  padding-bottom: clamp(1.5rem, 3vw, 2.25rem);
  border-bottom: 1px solid var(--rule);
}
.page-header h1 { margin: 1.25rem 0 1rem; max-width: 18ch; }
.page-header p.lead { color: var(--text-soft); }

/* Breadcrumbs */
.breadcrumbs {
  display: flex; flex-wrap: wrap; gap: .5rem;
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-soft);
  font-family: var(--f-sans);
  margin: 0; padding: 0; list-style: none;
}
.breadcrumbs li { display: flex; gap: .5rem; align-items: center; }
.breadcrumbs li + li::before { content: "/"; color: var(--text-soft); opacity: .5; }
.breadcrumbs a { color: var(--text-soft); }
.breadcrumbs a:hover { color: var(--accent); text-decoration: none; }
.breadcrumbs [aria-current="page"] { color: var(--accent); }

/* ---------- Editorial content blocks ---------- */
.prose { max-width: 70ch; }
.prose h2 { margin-top: 2em; }
.prose h2:first-of-type { margin-top: .5rem; }
.prose h3 { margin-top: 2em; font-size: 1.5rem; }
.prose p { color: var(--text); }
.prose ul, .prose ol { padding-left: 1.25rem; margin: 0 0 1.4em; }
.prose ul li, .prose ol li { margin-bottom: .5em; }
.prose blockquote {
  margin: 2em 0;
  padding-left: 1.5rem;
  border-left: 2px solid var(--accent);
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--heading);
}
.pullquote {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  line-height: 1.35;
  color: var(--heading);
  padding: 2rem 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin: 2.5rem 0;
}

/* ---------- Offering / pricing cards ---------- */
.offering {
  padding: 1.75rem;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 720px) {
  .offering { grid-template-columns: 1fr 2fr 1fr; gap: 3rem; align-items: start; }
}
.offering + .offering { margin-top: 1rem; }
.offering-num {
  font-family: var(--f-mono);
  font-size: var(--fs-tiny);
  letter-spacing: 0.14em;
  color: var(--accent);
  display: block;
  margin-bottom: 1rem;
}
.offering h3 { font-size: 1.65rem; margin-bottom: .25rem; }
.offering .who { font-size: var(--fs-small); color: var(--text-soft); margin-bottom: 1rem; }
.offering ul { padding-left: 1.1rem; font-size: var(--fs-small); color: var(--text); margin: 0; }
.offering ul li { margin-bottom: .35rem; }
.offering .meta {
  display: flex; flex-direction: column; gap: .75rem;
  padding-top: 1.5rem; border-top: 1px solid var(--rule);
}
@media (min-width: 720px) { .offering .meta { border-top: 0; padding-top: 0; border-left: 1px solid var(--rule); padding-left: 2rem; } }
.offering .meta .label { font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-soft); }
.offering .meta .value { font-family: var(--f-serif); font-size: 1.3rem; color: var(--heading); }

/* ---------- Speaking talks ---------- */
.talks-grid {
  display: grid; gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .talks-grid { grid-template-columns: repeat(2, 1fr); } }
.talk-card {
  background: var(--surface);
  padding: 1.5rem;
}
.talk-card .talk-num { font-family: var(--f-mono); font-size: var(--fs-tiny); color: var(--text-soft); letter-spacing: .12em; }
.talk-card h3 { margin: .5rem 0 1rem; font-size: 1.4rem; }
.talk-card .abstract { color: var(--text-soft); font-size: var(--fs-small); margin-bottom: 1.25rem; }
.talk-card .talk-meta { font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent); padding-top: 1rem; border-top: 1px solid var(--rule); }
.talk-card .talk-meta span + span::before { content: "·"; margin: 0 .5rem; color: var(--text-soft); }

/* ---------- Case studies list ---------- */
.case-list { list-style: none; padding: 0; margin: 0; }
.case-list li { border-top: 1px solid var(--rule); }
.case-list li:last-child { border-bottom: 1px solid var(--rule); }
.case-link {
  display: grid; gap: 1rem;
  grid-template-columns: 1fr;
  padding: 1.5rem 0;
  color: var(--text);
}
@media (min-width: 760px) {
  .case-link { grid-template-columns: 80px 1fr 220px; gap: 2.5rem; align-items: baseline; }
}
.case-link:hover { color: var(--accent); text-decoration: none; }
.case-link .case-num { font-family: var(--f-mono); font-size: var(--fs-tiny); color: var(--text-soft); letter-spacing: .12em; }
.case-link h3 { margin: 0 0 .25rem; font-size: 1.65rem; color: inherit; transition: color var(--transition); }
.case-link:hover h3 { color: var(--accent); }
.case-link .case-meta { font-size: var(--fs-small); color: var(--text-soft); }
.case-link .case-outcome { font-family: var(--f-serif); font-size: 1.05rem; color: var(--heading); font-style: italic; }
.case-link:hover .case-outcome { color: var(--accent); }

/* ---------- Insights / Blog cards ---------- */
.insight-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .insight-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .insight-grid { grid-template-columns: repeat(3, 1fr); } }
.insight-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 1.5rem;
  display: flex; flex-direction: column;
  transition: transform var(--transition), border-color var(--transition);
}
.insight-card:hover { transform: translateY(-3px); border-color: var(--c-navy); }
.insight-card .pillar { font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent); margin-bottom: 1rem; }
.insight-card h3 { font-size: 1.3rem; }
.insight-card p { color: var(--text-soft); font-size: var(--fs-small); flex-grow: 1; }
.insight-card .read-more { margin-top: 1rem; font-size: var(--fs-small); font-weight: 500; }
.insight-card .date { font-size: var(--fs-tiny); color: var(--text-soft); margin-top: 1rem; }

/* ---------- Forms ---------- */
.form {
  display: grid; gap: 1.5rem;
  max-width: 640px;
}
.field { display: flex; flex-direction: column; gap: .4rem; }
.field label { font-size: var(--fs-small); font-weight: 500; color: var(--heading); }
.field .required { color: var(--accent); }
.field input, .field select, .field textarea {
  padding: .9rem 1rem;
  background: var(--surface);
  border: 1px solid var(--rule);
  font-family: var(--f-sans);
  font-size: var(--fs-body);
  color: var(--text);
  border-radius: 2px;
  width: 100%;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
.field-hint { font-size: var(--fs-tiny); color: var(--text-soft); }
.field-error { font-size: var(--fs-small); color: #B30000; }
.form-row { display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 600px) { .form-row { grid-template-columns: 1fr 1fr; } }

/* ---------- Auth ---------- */
.auth-shell {
  display: grid; min-height: calc(100vh - 64px);
  grid-template-columns: 1fr;
}
@media (min-width: 880px) { .auth-shell { grid-template-columns: 1fr 1fr; } }
.auth-panel { padding: clamp(3rem, 6vw, 6rem) var(--gutter); display: flex; align-items: center; }
.auth-form { width: 100%; max-width: 420px; }
.auth-aside {
  background: var(--c-navy); color: #F4EFE2;
  padding: clamp(3rem, 6vw, 6rem) var(--gutter);
  display: flex; align-items: center;
  position: relative; overflow: hidden;
}
.auth-aside::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 80% 20%, rgba(184,92,0,.3) 0%, transparent 50%);
}
.auth-aside-inner { position: relative; z-index: 1; max-width: 460px; }
.auth-aside h2 { color: #fff; font-style: italic; }
.auth-aside p { color: rgba(244,239,226,0.8); }
.auth-divider {
  display: flex; align-items: center; gap: 1rem;
  margin: 1.5rem 0;
  font-size: var(--fs-tiny);
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--text-soft);
}
.auth-divider::before, .auth-divider::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--c-navy);
  color: #E4DECF;
  padding-top: 2.5rem;
  padding-bottom: 1.5rem;
  margin-top: clamp(2rem, 4vw, 3rem);
}
.site-footer a { color: #E4DECF; }
.site-footer a:hover { color: #F09A43; text-decoration: none; }
.footer-grid {
  display: grid; gap: 3rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 4rem; } }
.footer-brand-tag {
  font-family: var(--f-serif);
  font-size: 1.9rem;
  font-weight: 600;
  font-style: normal;
  letter-spacing: -0.03em;
  color: #fff;
  max-width: 22ch;
  line-height: 1.1;
  margin: 0;
}
.footer-title {
  font-family: var(--f-sans);
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #F09A43;
  margin-bottom: 1rem;
}
.footer-list { list-style: none; padding: 0; margin: 0; }
.footer-list li { margin-bottom: .5rem; font-size: var(--fs-small); }
.footer-legal {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex; flex-wrap: wrap;
  gap: 1rem 2rem;
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-tiny);
  color: rgba(228, 222, 207, 0.78);
}
.footer-legal a { font-size: var(--fs-tiny); color: rgba(228, 222, 207, 0.92); }

/* ---------- Utility ---------- */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.text-center { text-align: center; }
.text-balance { text-wrap: balance; }
.text-soft { color: var(--text-soft); }
.mt-0 { margin-top: 0 !important; }
.mt-2 { margin-top: 1rem; }
.mt-4 { margin-top: 2rem; }
.mt-6 { margin-top: 3rem; }
.flex { display: flex; }
.gap-2 { gap: 1rem; }
.gap-4 { gap: 2rem; }
.wrap { flex-wrap: wrap; }

/* ---------- Cookie banner ---------- */
.cookie-banner {
  position: fixed; bottom: 1.5rem; left: 1.5rem; right: 1.5rem;
  max-width: 480px;
  background: var(--surface);
  border: 1px solid var(--rule);
  padding: 1.5rem;
  z-index: 90;
  display: none;
  box-shadow: 0 10px 40px rgba(0,0,0,0.15);
}
.cookie-banner.show { display: block; }
.cookie-banner p { font-size: var(--fs-small); margin-bottom: 1rem; }
.cookie-actions { display: flex; gap: .75rem; flex-wrap: wrap; }

/* ---------- Responsive nav adjustments ---------- */
@media (max-width: 1080px) {
  .site-header .nav-bar > nav .nav-links { display: none; }
  .hamburger { display: inline-block; }
}

/* ---------- Stagger reveal animation ---------- */
@keyframes rise {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.reveal { opacity: 0; }
.reveal.in { animation: rise 700ms cubic-bezier(.2,.7,.2,1) forwards; }
.reveal-1 { animation-delay: 0ms; }
.reveal-2 { animation-delay: 90ms; }
.reveal-3 { animation-delay: 180ms; }
.reveal-4 { animation-delay: 270ms; }

/* ---------- Print ---------- */
@media print {
  .site-header, .site-footer, .cookie-banner { display: none; }
  body { background: #fff; color: #000; }
  a { color: #000; text-decoration: underline; }
}

/* ---------- Honeypot (spam trap) — hidden from humans, visible to bots ---------- */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px; height: 1px;
  overflow: hidden;
}

/* ---------- Notice panel (pre-launch / informational) ---------- */
.notice {
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
  background: var(--surface);
  border-radius: var(--radius-card);
  padding: 1.25rem 1.5rem;
  font-size: var(--fs-small);
  color: var(--text-soft);
  max-width: 70ch;
}
.notice strong { color: var(--heading); }

/* ---------- Team profiles (who-we-are.html) ---------- */
/* ---------- Who We Are — compact 3-col team grid ---------- */
.team-grid-3 {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  margin-top: 2rem;
}
@media (min-width: 700px) { .team-grid-3 { grid-template-columns: repeat(3, 1fr); } }

.team-card-compact {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.tc-photo-wrap {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--c-ivory-2);
  flex-shrink: 0;
}
.tc-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}
.tc-body {
  padding: 1.1rem 1.1rem 1.25rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.tc-tag {
  font-family: var(--f-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--accent);
  margin: 0 0 .3rem;
}
.tc-tag--mentor {
  color: var(--c-navy);
}
.tc-name {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--heading);
  margin: 0 0 .15rem;
  line-height: 1.2;
}
.tc-role {
  font-size: 0.75rem;
  color: var(--text-soft);
  margin: 0 0 .75rem;
  font-weight: 500;
}
.tc-bio {
  font-size: 0.83rem;
  color: var(--text);
  line-height: 1.55;
  margin: 0 0 .85rem;
}
.tc-quals {
  margin: 0;
  padding-left: 1rem;
  list-style: disc;
  border-top: 1px solid var(--rule);
  padding-top: .75rem;
  margin-top: auto;
}
.tc-quals li {
  font-size: 0.76rem;
  color: var(--text-soft);
  margin-bottom: .25rem;
  line-height: 1.45;
}
.tc-link {
  display: inline-block;
  margin-top: .75rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--accent);
}
.tc-link:hover { color: var(--c-amber-600); }

/* Legacy team grid (keep in case used elsewhere) */
.team-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: 1fr;
  margin-top: 2rem;
}
@media (min-width: 880px) { .team-grid { grid-template-columns: 1fr 1fr; } }
.team-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 1.5rem;
  display: flex; flex-direction: column;
}
.team-card .monogram {
  width: 64px; height: 64px;
  border-radius: 16px;
  background: linear-gradient(160deg, var(--c-navy) 0%, var(--c-navy-700) 100%);
  color: #FAF7F0;
  font-family: var(--f-serif); font-style: italic; font-size: 1.5rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
}
.team-card .monogram.accent { background: linear-gradient(160deg, var(--c-amber) 0%, #8F4108 100%); }
.team-card h3 { font-size: 1.5rem; margin-bottom: .15rem; }
.team-card .role {
  font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: .14em;
  color: var(--accent); margin-bottom: 1rem; font-weight: 500;
}
.team-card p { font-size: var(--fs-small); color: var(--text); }
.team-card .quals {
  margin-top: auto; padding-top: 1.25rem; border-top: 1px solid var(--rule);
}
.team-card .quals .label {
  display: block; font-size: var(--fs-tiny); text-transform: uppercase;
  letter-spacing: .14em; color: var(--text-soft); margin-bottom: .5rem;
}
.team-card .quals ul { margin: 0; padding-left: 1.1rem; font-size: var(--fs-small); color: var(--text-soft); }
.team-card .quals li { margin-bottom: .3rem; }
.team-card .profile-link { margin-top: 1.25rem; font-size: var(--fs-small); font-weight: 500; }

/* ---------- Speaker bios: horizontal layout (speaking.html) ---------- */
.bios-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: 1fr;
  align-items: start;            /* each card keeps its own height */
}
@media (min-width: 760px)  { .bios-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1040px) { .bios-grid { grid-template-columns: 1fr 1.15fr 1.6fr; } }
.bios-grid > article { border-radius: var(--radius-card); box-shadow: var(--shadow-card); height: auto; }
.bios-grid > article p { font-size: .92rem; line-height: 1.55; }

/* ---------- Case studies: horizontal layout (case-studies.html) ---------- */
.case-study {
  display: grid; gap: 1.75rem;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 1000px) {
  .case-study { grid-template-columns: 300px 1fr; gap: 3rem; }
  .case-head { position: sticky; top: 84px; }   /* label column stays put while content scrolls */
}
.case-head h2 {
  font-style: italic;
  font-size: clamp(1.4rem, 1.6vw + 0.5rem, 1.8rem);
  margin-bottom: 1rem;
}
.case-role { padding-top: 1rem; border-top: 1px solid var(--rule); }
.case-role .label {
  display: block;
  font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: .14em;
  color: var(--accent); margin-bottom: .4rem; font-weight: 500;
}
.case-role p { font-size: var(--fs-small); color: var(--text-soft); margin: 0; }

.case-body {
  display: grid; gap: 1.25rem 2.5rem;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 720px) { .case-body { grid-template-columns: 1fr 1fr; } }
.case-block h3 {
  font-family: var(--f-sans);
  font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: .14em;
  color: var(--heading); font-weight: 600;
  margin: 0 0 .5rem;
}
.case-block p { font-size: var(--fs-small); margin-bottom: .75rem; }
.case-block ul { padding-left: 1.05rem; margin: 0; font-size: var(--fs-small); }
.case-block ul li { margin-bottom: .4rem; }
.case-quote {
  grid-column: 1 / -1;
  font-family: var(--f-serif); font-style: italic;
  font-size: 1.1rem; line-height: 1.45;
  color: var(--heading);
  border-left: 2px solid var(--accent);
  padding-left: 1.25rem;
  margin: .25rem 0 0;
  max-width: none;
}

/* ---------- Hero logo card (index.html) ---------- */
.hero-logo-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 2.5rem 2rem 1.75rem;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
}

/* Hero aside — compact segment nav + DPDP timer */
.hero-aside-stack {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  height: 100%;
}

/* Mini segment links */
.hero-seg-block {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 1.1rem 1.25rem;
}
.hero-seg-eyebrow {
  font-family: var(--f-sans);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--text-soft);
  margin: 0 0 .75rem;
}
.hero-seg-links {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hero-seg-link {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .55rem .7rem;
  border-radius: 8px;
  font-size: 0.83rem;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
}
.hero-seg-link:hover {
  background: var(--bg);
  color: var(--heading);
  text-decoration: none;
}
.hero-seg-link--alert {
  color: #C0392B;
  font-weight: 600;
}
.hero-seg-link--alert:hover { background: #FEF2F2; color: #C0392B; }
.hero-seg-icon { font-size: 1rem; flex-shrink: 0; }
.hero-seg-arrow {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--text-soft);
  opacity: 0;
  transition: opacity var(--transition), transform var(--transition);
}
.hero-seg-link:hover .hero-seg-arrow { opacity: 1; transform: translateX(3px); }

/* DPDP deadline mini timer */
.hero-dpdp-timer {
  display: block;
  background: #1A0505;
  border-radius: var(--radius-card);
  padding: 1.1rem 1.25rem 1rem;
  text-decoration: none;
  color: #FFFFFF;
  transition: transform var(--transition), box-shadow var(--transition);
  border: 1.5px solid rgba(231,76,60,0.5);
  box-shadow: 0 0 24px rgba(192,57,43,0.15);
}
.hero-dpdp-timer:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(192,57,43,0.35);
  text-decoration: none;
  color: #FFFFFF;
}
.hero-dpdp-timer-top {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .6rem;
}
.hero-dpdp-dot {
  width: 9px; height: 9px;
  background: #FF6B6B;
  border-radius: 50%;
  flex-shrink: 0;
  animation: hero-pulse 1.6s ease-in-out infinite;
}
@keyframes hero-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,107,107,.7); }
  50%      { box-shadow: 0 0 0 6px rgba(255,107,107,0); }
}
.hero-dpdp-label {
  font-family: var(--f-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: #FF8A80;
}
.hero-dpdp-date {
  font-family: var(--f-serif);
  font-size: 1.4rem;
  font-weight: 700;
  color: #FFFFFF !important;
  margin: 0 0 .7rem;
  line-height: 1;
}
.hero-dpdp-cd {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 5px;
  margin-bottom: .75rem;
}
.hero-cd-unit {
  background: #E74C3C;
  border: none;
  border-radius: 7px;
  padding: .5rem .2rem .4rem;
  text-align: center;
}
.hero-cd-num {
  display: block;
  font-family: var(--f-mono, monospace);
  font-size: 1.15rem;
  font-weight: 700;
  color: #FFFFFF !important;
  line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
.hero-cd-lbl {
  display: block;
  font-size: 0.56rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,0.9) !important;
  margin-top: .25rem;
  font-weight: 600;
}
.hero-dpdp-cta {
  font-size: 0.72rem;
  color: #FFCDD2 !important;
  margin: 0;
  line-height: 1.5;
  text-align: center;
  font-weight: 500;
}
.hero-brand-name {
  font-family: var(--f-serif);
  font-size: clamp(1.6rem, 2.2vw, 2.1rem);
  color: var(--heading);
  letter-spacing: -0.01em;
  margin: 0 0 .35rem;
  line-height: 1.1;
}
.hero-brand-name .amp { color: var(--accent); font-style: italic; }
.hero-strip {
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--accent);
  font-weight: 500;
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--rule);
}
.hero-tagline {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: clamp(1.5rem, 2vw, 1.9rem);
  line-height: 1.35;
  color: var(--heading);
  margin: 0;
}
.hero-logo-caption {
  margin: 1.5rem 0 0;
  font-size: var(--fs-tiny);
  text-transform: uppercase; letter-spacing: .18em;
  color: var(--accent); font-weight: 500;
}

/* ---------- Team photos (who-we-are.html) ---------- */
.team-photo {
  width: 132px; height: 165px;                 /* 4:5 portrait */
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--rule);
  margin-bottom: 1.25rem;
  box-shadow: var(--shadow-card);
}

/* ---------- Hard guards: keep injected chrome clean ---------- */
[hidden] { display: none !important; }
.mobile-menu:not(.open) { visibility: hidden; }
