/* ════════════════════════════════════════════════════════
   THE FERNIST — Design System v2.0
   Fonts: Fraunces (display) + Plus Jakarta Sans (body)
   Palette: Navy #002040 · Green #1D4D32 · Lime #A3C43A
════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,300;1,9..144,400;1,9..144,600;1,9..144,700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: #F9F8F5;
  color: #1A1917;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
ul, ol { list-style: none; }
button, input, select, textarea { font-family: inherit; font-size: inherit; }

/* ── TOKENS ── */
:root {
  --navy:       #002040;
  --navy-l:     #0a3060;
  --green-d:    #0D2B1A;
  --green:      #1D4D32;
  --green-h:    #276642;
  --lime:       #A3C43A;
  --lime-d:     #8aaa28;
  --light:      #F9F8F5;
  --light-2:    #EDF0F5;
  --dark:       #080E1A;
  --border-l:   rgba(26, 25, 23, 0.10);
  --border-d:   rgba(249, 248, 245, 0.10);
  --ff-display: 'Fraunces', serif;
  --ff-body:    'Plus Jakarta Sans', sans-serif;
  --ease:       cubic-bezier(0.23, 1, 0.32, 1);
  --ease2:      cubic-bezier(0.77, 0, 0.175, 1);
  --pad:        clamp(1.5rem, 5vw, 5rem);
  --container:  1320px;
}

/* ── SECTION PALETTE ── */
.s-light  { background: var(--light);   color: #1A1917; }
.s-light2 { background: #EDF0F5;        color: #1A1917; }
.s-navy   { background: var(--navy);    color: var(--light); }
.s-green  { background: var(--green-d); color: var(--light); }
.s-dark   { background: var(--dark);    color: var(--light); }

/* ── CONTAINER ── */
.wrap { max-width: var(--container); margin-inline: auto; padding-inline: var(--pad); }

/* ════════════════════════════════════════════════════════
   NAVIGATION
════════════════════════════════════════════════════════ */
#site-nav {
  position: fixed; inset-block-start: 0; inset-inline: 0;
  height: 72px; z-index: 500;
  display: flex; align-items: center;
  padding-inline: var(--pad);
  transition: background 400ms var(--ease), border-color 400ms, box-shadow 400ms, backdrop-filter 400ms;
  border-bottom: 1px solid transparent;
}
/* ── Transparent on hero pages ── */
#site-nav.nav-hero {
  background: transparent;
  backdrop-filter: none;
}
#site-nav.nav-hero.nav-scrolled {
  background: rgba(0, 8, 20, 0.88);
  backdrop-filter: blur(14px);
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: 0 1px 24px rgba(0, 0, 0, 0.3);
}
/* ── Solid on inner pages ── */
#site-nav.nav-solid {
  background: rgba(249, 248, 245, 0.96);
  backdrop-filter: blur(12px);
  border-color: var(--border-l);
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.05);
}
#site-nav.nav-solid.nav-scrolled {
  box-shadow: 0 2px 24px rgba(0, 0, 0, 0.08);
}

.nav-inner {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: 2rem;
}

/* ── LOGO — Customizer controls this via body class ── */
.nav-logo-wrap { display: flex; align-items: center; text-decoration: none; }
.nav-logo-wrap img {
  height: 44px; width: auto; display: block;
  transition: filter 350ms var(--ease), opacity 200ms;
}

/* Default: show logo in original colors */
body.logo-original .nav-logo-wrap img { filter: none; }

/* Option: white logo for dark nav */
body.logo-white .nav-logo-wrap img { filter: brightness(0) invert(1); }

/* Option: auto — white on hero/dark, original on solid */
body.logo-auto #site-nav.nav-hero .nav-logo-wrap img     { filter: brightness(0) invert(1); }
body.logo-auto #site-nav.nav-solid .nav-logo-wrap img    { filter: none; }

/* Subtle shadow behind logo on transparent hero so it reads on bright photos */
#site-nav.nav-hero:not(.nav-scrolled) .nav-logo-wrap {
  filter: drop-shadow(0 1px 6px rgba(0,0,0,0.5));
}

/* Nav links — white on hero, dark on solid */
.nav-menu { display: flex; gap: 2rem; list-style: none; }
.nav-menu a { font-size: 1rem; font-weight: 500; letter-spacing: 0.02em; transition: color 150ms; text-decoration: none; }
#site-nav.nav-hero .nav-menu a           { color: rgba(255, 255, 255, 0.72); }
#site-nav.nav-hero .nav-menu a:hover     { color: #fff; }
#site-nav.nav-solid .nav-menu a          { color: #4A5568; }
#site-nav.nav-solid .nav-menu a:hover    { color: var(--green); }

/* Dropdown for sub-menu */
.nav-menu li { position: relative; }
.nav-menu .sub-menu {
  position: absolute; top: 100%; left: 0;
  background: #fff; min-width: 220px;
  border: 1px solid var(--border-l);
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
  padding: 0.5rem 0;
  opacity: 0; visibility: hidden;
  transform: translateY(8px);
  transition: opacity 200ms, transform 200ms, visibility 200ms;
  list-style: none; z-index: 10;
}
.nav-menu li:hover .sub-menu { opacity: 1; visibility: visible; transform: none; }
.nav-menu .sub-menu a { display: block; padding: 0.7rem 1.25rem; font-size: 0.88rem; }
.nav-menu .sub-menu a:hover { background: var(--light); color: var(--green); }
/* Sub-menus are always dark regardless of nav state (hero or solid) */
#site-nav .nav-menu .sub-menu { background: #fff; }
#site-nav .nav-menu .sub-menu a { color: #1A1917; }
#site-nav.nav-hero .nav-menu .sub-menu a { color: #1A1917; }
#site-nav.nav-hero.nav-scrolled .nav-menu .sub-menu a { color: #1A1917; }
#site-nav .nav-menu .sub-menu a:hover { color: var(--green); background: var(--light); }

/* CTA */
.nav-cta {
  font-family: var(--ff-body); font-weight: 700;
  font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.62rem 1.4rem; text-decoration: none;
  transition: background 150ms, color 150ms, border-color 150ms, transform 100ms;
  border: 1.5px solid transparent;
}
.nav-cta:active { transform: scale(0.97); }
#site-nav.nav-hero .nav-cta {
  background: rgba(255,255,255,0.14);
  color: #fff; border-color: rgba(255,255,255,0.35);
}
#site-nav.nav-hero .nav-cta:hover { background: rgba(255,255,255,0.25); }
#site-nav.nav-solid .nav-cta { background: var(--green); color: #fff; border-color: transparent; }
#site-nav.nav-solid .nav-cta:hover { background: var(--green-h); }

/* Hamburger */
.nav-toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.nav-toggle span {
  display: block; width: 24px; height: 1.5px;
  transition: transform 250ms var(--ease), opacity 200ms;
}
#site-nav.nav-hero .nav-toggle span  { background: rgba(255,255,255,0.85); }
#site-nav.nav-solid .nav-toggle span { background: #1A1917; }
.nav-toggle.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile nav open */
.nav-menu.nav-open {
  display: flex; flex-direction: column;
  position: fixed; inset-block-start: 72px; inset-inline: 0;
  background: rgba(249,248,245,0.98); backdrop-filter: blur(12px);
  padding: 2rem var(--pad); gap: 1.25rem; z-index: 400;
  border-bottom: 1px solid var(--border-l);
}
.nav-menu.nav-open a { font-size: 1rem; color: #1A1917 !important; }
.nav-menu.nav-open .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: transparent; border: none; padding: 0.5rem 0 0 1rem; }

/* ════════════════════════════════════════════════════════
   TYPOGRAPHY
════════════════════════════════════════════════════════ */
.eyebrow {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.22em;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 0.75rem;
}
.eyebrow::before { content: ''; width: 2rem; height: 1px; flex-shrink: 0; }
.s-light .eyebrow, .s-light2 .eyebrow { color: var(--green); }
.s-light .eyebrow::before, .s-light2 .eyebrow::before { background: var(--green); }
.s-navy .eyebrow, .s-green .eyebrow, .s-dark .eyebrow { color: var(--lime); }
.s-navy .eyebrow::before, .s-green .eyebrow::before, .s-dark .eyebrow::before { background: var(--lime); }

.disp-xl { font-family: var(--ff-display); font-weight: 700; font-size: clamp(3rem, 6vw, 5.5rem); line-height: 1.05; letter-spacing: -0.03em; }
.disp-lg { font-family: var(--ff-display); font-weight: 700; font-size: clamp(2.2rem, 4vw, 3.8rem); line-height: 1.1;  letter-spacing: -0.025em; }
.disp-md { font-family: var(--ff-display); font-weight: 700; font-size: clamp(1.5rem, 2.5vw, 2.2rem); line-height: 1.2; letter-spacing: -0.02em; }

.body-lg { font-size: 1.05rem; line-height: 1.75; }
.body-sm { font-size: 0.9rem;  line-height: 1.7; }
.s-light .body-lg, .s-light .body-sm,
.s-light2 .body-lg, .s-light2 .body-sm { color: #4A5568; }
.s-navy .body-lg, .s-navy .body-sm,
.s-green .body-lg, .s-green .body-sm { color: rgba(249,248,245,0.65); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--ff-body); font-weight: 700;
  font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.9rem 2rem; cursor: pointer; border: none; text-decoration: none;
  transition: background 150ms, color 150ms, border-color 150ms, transform 100ms;
}
.btn:active { transform: scale(0.97); }
.btn-green  { background: var(--green);  color: #fff; } .btn-green:hover  { background: var(--green-h); }
.btn-lime   { background: var(--lime);   color: #111; } .btn-lime:hover   { background: var(--lime-d); }
.btn-white  { background: #fff; color: var(--navy); }   .btn-white:hover  { background: #e8edf5; }
.btn-navy   { background: var(--navy); color: #fff; }    .btn-navy:hover   { background: var(--navy-l); }
.btn-outline-l { border: 1.5px solid #1A1917; color: #1A1917; background: transparent; } .btn-outline-l:hover { background: #1A1917; color: #fff; }
.btn-outline-w { border: 1.5px solid rgba(255,255,255,0.4); color: #fff; background: transparent; } .btn-outline-w:hover { border-color: #fff; background: rgba(255,255,255,0.1); }

.link-arrow {
  font-weight: 700; font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 0.5rem;
  border-bottom: 1.5px solid currentColor; padding-bottom: 0.2rem;
  text-decoration: none;
  transition: gap 200ms var(--ease), color 150ms;
}
.link-arrow:hover { gap: 0.9rem; }
.s-light .link-arrow, .s-light2 .link-arrow { color: var(--green); }
.s-navy .link-arrow, .s-green .link-arrow   { color: var(--lime); }

/* ── SCROLL REVEAL ── */
[data-sr] { opacity: 0; transform: translateY(30px); transition: opacity 700ms var(--ease), transform 700ms var(--ease); }
[data-sr].sr-in { opacity: 1; transform: none; }
[data-d="1"] { transition-delay: 80ms;  }
[data-d="2"] { transition-delay: 160ms; }
[data-d="3"] { transition-delay: 240ms; }
[data-d="4"] { transition-delay: 320ms; }
[data-d="5"] { transition-delay: 400ms; }

/* ════════════════════════════════════════════════════════
   HERO — Full-screen slideshow (linmanuel style)
════════════════════════════════════════════════════════ */
.hero-fs {
  position: relative; width: 100%; height: 100svh; min-height: 600px;
  overflow: hidden; background: #080E1A;
  margin-top: 0; /* nav is fixed, hero fills viewport */
}
.hero-slides { position: absolute; inset: 0; z-index: 0; }
.h-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1400ms var(--ease); }
.h-slide.active { opacity: 1; }
.h-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; animation: kenBurns 8s ease-out forwards; }
.h-slide:nth-child(2) img { animation-name: kenBurns2; }
.h-slide:nth-child(3) img { animation-name: kenBurns3; }
@keyframes kenBurns  { from { transform: scale(1.08); } to { transform: scale(1); } }
@keyframes kenBurns2 { from { transform: scale(1.07) translate(-1%,0); } to { transform: scale(1); } }
@keyframes kenBurns3 { from { transform: scale(1.06) translate(1%,0.5%); } to { transform: scale(1); } }

.hero-grad {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to top, rgba(4,10,24,0.95) 0%, rgba(4,10,24,0.7) 35%, rgba(4,10,24,0.2) 65%, transparent 100%),
    linear-gradient(to bottom, rgba(4,10,24,0.55) 0%, transparent 28%);
}
.hero-content {
  position: absolute; inset-inline: 0; inset-block-end: 0; z-index: 2;
  padding: 0 var(--pad) clamp(3.5rem, 8vh, 7rem);
  max-width: 1000px;
}
.h-kicker {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--lime); margin-bottom: 1.5rem;
  opacity: 0; animation: fadeUp 0.6s var(--ease) 0.4s forwards;
}
.h-headline {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(5rem, 10vw, 11rem);
  line-height: 0.88; letter-spacing: -0.04em; color: #fff; margin-bottom: 1.75rem;
}
.h-word { display: block; overflow: hidden; }
.h-word span { display: block; opacity: 0; transform: translateY(105%); }
.h-word:nth-child(1) span { animation: slideUp 0.85s var(--ease) 0.5s forwards; }
.h-word:nth-child(2) span { animation: slideUp 0.85s var(--ease) 0.65s forwards; }
.h-word:nth-child(3) span { font-style: italic; color: var(--lime); animation: slideUp 0.85s var(--ease) 0.8s forwards; }
.h-sub { font-size: 1rem; color: rgba(255,255,255,0.65); line-height: 1.65; max-width: 50ch; margin-bottom: 2.25rem; opacity: 0; animation: fadeUp 0.6s var(--ease) 1s forwards; }
.h-btns { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; opacity: 0; animation: fadeUp 0.6s var(--ease) 1.15s forwards; }
.h-dots { position: absolute; inset-block-end: 2.5rem; inset-inline-end: var(--pad); z-index: 2; display: flex; gap: 0.5rem; opacity: 0; animation: fadeUp 0.5s var(--ease) 1.5s forwards; }
.h-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.3); border: none; cursor: pointer; padding: 0; transition: background 250ms, transform 250ms; }
.h-dot.active { background: var(--lime); transform: scale(1.35); }

@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(105%); } to { opacity: 1; transform: none; } }

/* ── TICKER ── */
.ticker-bar { overflow: hidden; padding: 0.9rem 0; white-space: nowrap; }
.tick-track { display: inline-flex; animation: tickAnim 38s linear infinite; }
.tick-item { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; padding-inline: 2rem; color: rgba(249,248,245,0.72); }
.tick-sep { color: rgba(249,248,245,0.3); }
@keyframes tickAnim { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── STATS ── */
.stats-band { display: grid; grid-template-columns: repeat(3,1fr); }
.stat-cell { padding: 3rem var(--pad); border-right: 1px solid var(--border-d); }
.stat-cell:last-child { border-right: none; }
.stat-num { font-family: var(--ff-display); font-weight: 700; font-size: clamp(2.8rem,4vw,4.2rem); letter-spacing: -0.04em; line-height: 1; color: var(--lime); margin-bottom: 0.4rem; }
.stat-lbl { font-size: 0.7rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(249,248,245,0.5); }

/* ── PULL QUOTE ── */
.quote-sec { padding: 9rem var(--pad); text-align: center; position: relative; overflow: hidden; }
.quote-sec::before { content: '\201C'; position: absolute; top: -3rem; left: 50%; transform: translateX(-50%); font-family: var(--ff-display); font-size: 22rem; line-height: 1; color: rgba(29,77,50,0.08); pointer-events: none; user-select: none; }
.quote-inner { max-width: 840px; margin-inline: auto; position: relative; z-index: 1; }
.quote-text { font-family: var(--ff-display); font-style: italic; font-weight: 400; font-size: clamp(1.4rem,2.5vw,2.1rem); line-height: 1.55; margin-bottom: 2rem; }
.quote-attr { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--green); }

/* ── ABOUT SNAP ── */
.about-snap { display: grid; grid-template-columns: 45fr 55fr; min-height: 85vh; }
.about-snap-img { position: relative; overflow: hidden; }
.about-snap-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transition: transform 700ms var(--ease); }
.about-snap:hover .about-snap-img img { transform: scale(1.03); }
.about-snap-copy { padding: 7rem 5rem; display: flex; flex-direction: column; justify-content: center; gap: 2rem; }
.chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chip { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.38rem 0.85rem; border: 1px solid; transition: background 150ms, color 150ms, border-color 150ms; cursor: default; }
.s-navy .chip { border-color: rgba(249,248,245,0.2); color: rgba(249,248,245,0.65); }
.s-navy .chip:hover { background: var(--lime); color: #111; border-color: var(--lime); }
.s-light .chip { border-color: var(--border-l); color: #4A5568; }
.s-light .chip:hover { background: var(--green); color: #fff; border-color: var(--green); }

/* ── BOOKS ── */
.books-sec { padding: 8rem var(--pad); }
.sec-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4rem; gap: 2rem; flex-wrap: wrap; }
.books-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; }
.book-card { padding: 4rem; position: relative; overflow: hidden; transition: background 250ms; cursor: default; }
.s-light .book-card { background: #fff; } .s-light .book-card:hover { background: #F5F7FA; }
.s-navy .book-card  { background: rgba(255,255,255,0.04); } .s-navy .book-card:hover { background: rgba(255,255,255,0.07); }
.book-bar { position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: var(--lime); transform: scaleX(0); transform-origin: left; transition: transform 400ms var(--ease); }
.book-card:hover .book-bar { transform: scaleX(1); }
.book-num { position: absolute; bottom: 2.5rem; right: 2.5rem; font-family: var(--ff-display); font-weight: 700; font-size: 5rem; line-height: 1; pointer-events: none; }
.s-light .book-num { color: rgba(0,32,64,0.05); }
.s-navy .book-num  { color: rgba(163,196,58,0.07); }
.book-status { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 1.5rem; }
.bst-pub  { color: var(--lime); } .s-light .bst-pub  { color: var(--green); }
.bst-forth { color: rgba(249,248,245,0.35); } .s-light .bst-forth { color: #9CA3AF; }
.book-title { font-family: var(--ff-display); font-style: italic; font-weight: 400; font-size: 1.4rem; line-height: 1.45; margin-bottom: 1.25rem; }
.book-desc  { font-size: 0.88rem; line-height: 1.72; margin-bottom: 2.5rem; }
.s-light .book-desc { color: #4A5568; } .s-navy .book-desc { color: rgba(249,248,245,0.55); }
.book-with-img { display: grid; grid-template-columns: auto 1fr; gap: 3rem; align-items: start; }
.book-cover-img { width: 200px; flex-shrink: 0; box-shadow: 0 20px 60px rgba(0,0,0,0.2); transition: transform 400ms var(--ease); }
.book-cover-img:hover { transform: scale(1.04) rotate(-1deg); }
.book-buy-row { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.buy-btn { font-family: var(--ff-body); font-weight: 700; font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.6rem 1.3rem; display: inline-flex; align-items: center; gap: 0.4rem; cursor: pointer; text-decoration: none; transition: background 150ms, color 150ms, border-color 150ms, transform 100ms; border: none; }
.buy-btn:active { transform: scale(0.97); }
.buy-btn.primary   { background: var(--green); color: #fff; } .buy-btn.primary:hover { background: var(--green-h); }
.buy-btn.secondary { background: transparent; border: 1px solid var(--border-l); color: #1A1917; } .buy-btn.secondary:hover { border-color: var(--green); color: var(--green); }
.s-navy .buy-btn.secondary { border-color: rgba(249,248,245,0.2); color: rgba(249,248,245,0.7); }
.s-navy .buy-btn.secondary:hover { border-color: var(--lime); color: var(--lime); }

/* ── SPEAKING ── */
.speaking-wrap { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; }
.speaking-photo { position: relative; overflow: hidden; }
.speaking-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; transition: transform 700ms var(--ease); }
.speaking-wrap:hover .speaking-photo img { transform: scale(1.03); }
.speaking-copy { padding: 7rem 5rem; display: flex; flex-direction: column; justify-content: center; gap: 1.75rem; }
.eng-list { margin-top: 0.5rem; }
.eng-item { display: grid; grid-template-columns: 4rem 1fr; gap: 1.25rem; padding: 1rem 0; border-top: 1px solid var(--border-d); }
.eng-item:last-child { border-bottom: 1px solid var(--border-d); }
.eng-year { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; color: var(--lime); padding-top: 0.2rem; white-space: nowrap; }
.eng-title { font-size: 0.9rem; font-weight: 500; line-height: 1.45; margin-bottom: 0.2rem; color: var(--light); }
.eng-venue { font-size: 0.78rem; color: rgba(249,248,245,0.45); }

/* ── ARTICLES GRID ── */
.articles-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 3px; margin-top: 3.5rem; }
.art-card { padding: 2.5rem; position: relative; overflow: hidden; transition: background 200ms; display: block; color: inherit; text-decoration: none; }
.s-light .art-card  { background: #fff; } .s-light .art-card:hover { background: #F5F7FA; }
.s-navy .art-card   { background: rgba(255,255,255,0.03); } .s-navy .art-card:hover { background: rgba(255,255,255,0.06); }
.art-arrow { position: absolute; top: 2rem; right: 2rem; color: var(--lime); font-size: 1rem; opacity: 0; transform: translate(-3px,3px); transition: opacity 200ms var(--ease), transform 200ms var(--ease); }
.s-light .art-arrow { color: var(--green); }
.art-card:hover .art-arrow { opacity: 1; transform: none; }
.art-tag  { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 1.25rem; }
.s-light .art-tag { color: var(--green); } .s-navy .art-tag { color: var(--lime); }
.art-title { font-family: var(--ff-display); font-size: 1.05rem; line-height: 1.45; margin-bottom: 1.25rem; }
.art-meta  { font-size: 0.72rem; letter-spacing: 0.06em; }
.s-light .art-meta { color: #9CA3AF; } .s-navy .art-meta { color: rgba(249,248,245,0.35); }

/* ── GALLERY ── */
.gallery-grid { columns: 3; gap: 10px; }
.gallery-item { break-inside: avoid; margin-bottom: 10px; overflow: hidden; position: relative; cursor: pointer; }
.gallery-item img { width: 100%; display: block; transition: transform 500ms var(--ease); }
.gallery-item:hover img { transform: scale(1.04); }
.gallery-overlay { position: absolute; inset: 0; background: rgba(0,32,64,0.45); opacity: 0; transition: opacity 300ms; display: flex; align-items: center; justify-content: center; }
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-overlay span { color: #fff; font-size: 1.5rem; }

/* Lightbox */
.lightbox { display: none; position: fixed; inset: 0; background: rgba(0,8,20,0.95); z-index: 2000; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 90vw; max-height: 90vh; object-fit: contain; }
.lightbox-close { position: absolute; top: 1.5rem; right: 1.5rem; color: #fff; background: none; border: none; font-size: 2rem; cursor: pointer; opacity: 0.7; transition: opacity 150ms; }
.lightbox-close:hover { opacity: 1; }

/* ── PROFILE / DOWNLOAD ── */
.profile-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }
.profile-circle { width: 300px; height: 300px; border-radius: 50%; object-fit: cover; border: 4px solid var(--lime); }
.dl-cards { display: flex; flex-direction: column; gap: 1rem; margin-top: 1.5rem; }
.dl-card { display: flex; align-items: center; gap: 1.5rem; padding: 1.25rem 1.5rem; border: 1px solid; cursor: pointer; transition: background 150ms, border-color 150ms; text-decoration: none; }
.s-light .dl-card { border-color: var(--border-l); background: #fff; }
.s-light .dl-card:hover { border-color: var(--green); background: #F5F7FA; }
.s-navy .dl-card { border-color: var(--border-d); background: rgba(255,255,255,0.04); }
.s-navy .dl-card:hover { border-color: var(--lime); background: rgba(255,255,255,0.08); }
.dl-icon { width: 2.5rem; height: 2.5rem; background: var(--lime); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1rem; color: #111; }
.dl-label { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.2rem; }
.s-light .dl-label { color: #1A1917; } .s-navy .dl-label { color: var(--light); }
.dl-desc { font-size: 0.72rem; } .s-light .dl-desc { color: #9CA3AF; } .s-navy .dl-desc { color: rgba(249,248,245,0.4); }
.dl-arrow { margin-left: auto; transition: transform 200ms var(--ease); }
.s-light .dl-arrow { color: var(--green); } .s-navy .dl-arrow { color: var(--lime); }
.dl-card:hover .dl-arrow { transform: translateX(4px); }

/* ── NEWSLETTER ── */
.nl-sec { padding: 7rem var(--pad); position: relative; overflow: hidden; }
.nl-sec::after { content: 'Newsletter'; position: absolute; inset-inline-end: -1rem; inset-block-end: -2rem; font-family: var(--ff-display); font-weight: 700; font-size: clamp(5rem,12vw,12rem); color: rgba(255,255,255,0.04); letter-spacing: -0.05em; pointer-events: none; user-select: none; white-space: nowrap; line-height: 1; }
.nl-inner { max-width: 560px; position: relative; z-index: 1; }
.nl-form { display: flex; }
.nl-input { flex: 1; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.18); border-right: none; color: #fff; font-family: var(--ff-body); font-size: 0.9rem; padding: 1rem 1.5rem; outline: none; transition: background 150ms; }
.nl-input:focus { background: rgba(255,255,255,0.16); }
.nl-input::placeholder { color: rgba(255,255,255,0.38); }
.nl-btn { background: var(--lime); color: #111; font-family: var(--ff-body); font-weight: 700; font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; border: none; padding: 1rem 2rem; cursor: pointer; transition: background 150ms, transform 100ms; }
.nl-btn:hover { background: var(--lime-d); } .nl-btn:active { transform: scale(0.97); }
.nl-note { font-size: 0.72rem; color: rgba(255,255,255,0.4); margin-top: 1rem; }

/* ── CONTACT ── */
.contact-wrap { display: grid; grid-template-columns: 1fr 1fr; min-height: 70vh; }
.contact-info { padding: 7rem var(--pad); }
.contact-form-wrap { padding: 7rem 5rem; }
.c-detail { margin-bottom: 1.75rem; }
.c-lbl { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.3rem; }
.s-light .c-lbl { color: var(--green); } .s-navy .c-lbl { color: var(--lime); }
.c-val { font-size: 0.95rem; } .s-light .c-val { color: #1A1917; } .s-navy .c-val { color: rgba(249,248,245,0.85); }
.qr-wrap { margin-top: 2.5rem; }
.qr-wrap img { width: 148px; border: 3px solid; padding: 6px; }
.s-light .qr-wrap img { border-color: var(--border-l); background: var(--light); }
.s-navy .qr-wrap img  { border-color: rgba(255,255,255,0.15); background: var(--light); }
.qr-caption { font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 0.75rem; }
.s-light .qr-caption { color: #9CA3AF; } .s-navy .qr-caption { color: rgba(249,248,245,0.4); }
.form-group { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.25rem; }
.form-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; }
.s-light .form-label { color: #4A5568; } .s-navy .form-label { color: rgba(249,248,245,0.55); }
.form-input, .form-select, .form-textarea { font-family: var(--ff-body); font-size: 0.92rem; padding: 0.85rem 1.1rem; outline: none; width: 100%; transition: border-color 150ms; }
.s-light .form-input, .s-light .form-select, .s-light .form-textarea { background: #fff; border: 1px solid rgba(26,25,23,0.12); color: #1A1917; }
.s-navy  .form-input, .s-navy  .form-select, .s-navy  .form-textarea  { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: #fff; }
.s-light .form-input:focus, .s-light .form-select:focus, .s-light .form-textarea:focus { border-color: var(--green); }
.s-navy  .form-input:focus, .s-navy  .form-select:focus, .s-navy  .form-textarea:focus  { border-color: var(--lime); }
.form-textarea { resize: vertical; min-height: 130px; }
.form-success { background: rgba(29,77,50,0.1); border: 1px solid rgba(29,77,50,0.25); color: var(--green); padding: 1rem 1.25rem; font-size: 0.88rem; font-weight: 500; display: none; margin-bottom: 1.25rem; }
.form-success.show { display: block; }

/* ── PAGE HERO ── */
.pg-hero { padding: calc(72px + 4rem) var(--pad) 5rem; }
.pg-hero .eyebrow { margin-bottom: 1.5rem; }

/* ── ABOUT PAGE ── */
.about-layout { display: grid; grid-template-columns: 2fr 1fr; gap: 5rem; padding: 7rem var(--pad); max-width: var(--container); margin-inline: auto; align-items: start; }
.about-sidebar { position: sticky; top: 100px; }
.about-portrait { width: 100%; object-fit: cover; object-position: center top; border-left: 4px solid var(--lime); }
.bio-p { font-size: 1.05rem; line-height: 1.8; color: #4A5568; margin-bottom: 1.5rem; }
.cred-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 3px; margin-top: 2.5rem; }
.cred-card { padding: 2.25rem; }
.s-navy .cred-card  { background: rgba(255,255,255,0.04); }
.s-light .cred-card { background: #fff; }
.cred-lbl { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.5rem; }
.s-navy  .cred-lbl { color: var(--lime); } .s-light .cred-lbl { color: var(--green); }
.cred-val { font-size: 0.9rem; line-height: 1.45; }
.pos-list { margin-top: 2.5rem; }
.pos-item { display: grid; grid-template-columns: 6rem 1fr; gap: 1.25rem; padding: 1.25rem 0; border-top: 1px solid; }
.s-light .pos-item { border-color: rgba(26,25,23,0.08); }
.s-navy  .pos-item { border-color: rgba(249,248,245,0.08); }
.pos-item:last-child { border-bottom: 1px solid; }
.pos-yr { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; padding-top: 0.2rem; white-space: nowrap; }
.s-light .pos-yr { color: var(--green); } .s-navy .pos-yr { color: var(--lime); }
.pos-title { font-size: 0.9rem; font-weight: 500; line-height: 1.45; margin-bottom: 0.2rem; }
.pos-org { font-size: 0.78rem; color: #9CA3AF; }
.s-navy .pos-org { color: rgba(249,248,245,0.4); }
.award-list { margin-top: 2.5rem; }
.award-item { display: grid; grid-template-columns: 4rem 1fr; gap: 1.25rem; padding: 1rem 0; border-top: 1px solid; }
.s-light .award-item { border-color: rgba(26,25,23,0.08); }
.s-navy  .award-item { border-color: rgba(249,248,245,0.08); }
.award-item:last-child { border-bottom: 1px solid; }
.aw-yr { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; padding-top: 0.2rem; }
.s-light .aw-yr { color: var(--green); } .s-navy .aw-yr { color: var(--lime); }
.aw-name { font-size: 0.9rem; line-height: 1.45; margin-bottom: 0.2rem; }

/* ── SIDEBAR TOPIC BOX ── */
.topic-box { padding: 2.5rem; }
.s-light  .topic-box { background: #fff; border: 1px solid var(--border-l); }
.s-navy   .topic-box { background: rgba(255,255,255,0.04); }
.s-green  .topic-box { background: rgba(255,255,255,0.04); }
.topic-box ul { margin-top: 1.5rem; }
.topic-box li { font-size: 0.88rem; padding: 0.7rem 0; border-top: 1px solid; display: flex; align-items: center; gap: 0.75rem; }
.s-light .topic-box li { border-color: rgba(26,25,23,0.08); color: #4A5568; }
.s-light .topic-box li::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.s-green .topic-box li, .s-navy .topic-box li { border-color: rgba(249,248,245,0.08); color: rgba(249,248,245,0.75); }
.s-green .topic-box li::before, .s-navy .topic-box li::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--lime); flex-shrink: 0; }

/* ── BLOG CARDS ── */
.blog-grid {
  columns: 2;
  column-gap: 18px;
}
.blog-card { overflow: hidden; text-decoration: none; color: inherit; display: block; transition: background 200ms; }
.s-light .blog-card {
  background: #fff;
  border: 1px solid rgba(26,25,23,0.07);
  display: inline-block; /* required for CSS columns masonry */
  width: 100%;
  margin-bottom: 18px;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  transition: transform 250ms var(--ease), box-shadow 250ms var(--ease);
}
.s-light .blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.1);
}
.blog-card-img-wrap { overflow: hidden; }
.blog-card-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 400ms var(--ease);
}
.blog-card-img-wrap {
  overflow: hidden;
  display: block;
}
div.blog-card-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog-card:hover .blog-card-img { transform: scale(1.04); }
.blog-card-body { padding: 1.75rem 2rem 2rem; }
.blog-card-cat  { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 0.75rem; color: var(--green); }
.blog-card-title { font-family: var(--ff-display); font-size: 1.15rem; line-height: 1.4; color: #1A1917; margin-bottom: 0.75rem; }
.blog-card-excerpt { font-size: 0.85rem; color: #4A5568; line-height: 1.65; margin-bottom: 1.25rem; }
.blog-card-meta { font-size: 0.7rem; color: #9CA3AF; letter-spacing: 0.06em; }

/* ── SINGLE POST ── */
.single-post { padding: 0; width: 100%; }
.single-post-hero { height: 55vh; overflow: hidden; }
.single-post-hero img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.single-post-inner { max-width: 820px; margin-inline: auto; padding: 5rem var(--pad); }
.post-title   { font-family: var(--ff-display); font-weight: 700; font-size: clamp(2rem,4vw,3.5rem); line-height: 1.1; letter-spacing: -0.025em; color: #1A1917; margin-bottom: 1.5rem; }
.post-meta    { font-size: 0.72rem; letter-spacing: 0.1em; color: #9CA3AF; margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--border-l); }
.post-content { font-size: 1.05rem; line-height: 1.85; color: #4A5568; }
.post-content h2 { font-family: var(--ff-display); color: #1A1917; font-size: 1.6rem; margin: 2rem 0 1rem; }
.post-content h3 { font-family: var(--ff-display); color: #1A1917; font-size: 1.3rem; margin: 1.75rem 0 0.75rem; }
.post-content p  { margin-bottom: 1.5rem; }
.post-content a  { color: var(--green); text-decoration: underline; text-underline-offset: 3px; }
.post-content blockquote { border-left: 3px solid var(--green); padding-left: 2rem; margin: 2.5rem 0; font-family: var(--ff-display); font-style: italic; font-size: 1.25rem; color: #1A1917; }

/* ── FOOTER ── */
#site-footer { padding: 3.5rem var(--pad); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1.5rem; border-top: 1px solid rgba(255,255,255,0.07); }

/* Footer logo — show in original colors by default; Customizer can change */
.footer-logo img { height: 44px; width: auto; display: block; }
body.logo-footer-white    .footer-logo img { filter: brightness(0) invert(1); }
body.logo-footer-original .footer-logo img { filter: none; }

.footer-links { display: flex; gap: 1.75rem; }
.footer-links a { font-size: 0.72rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; color: rgba(255,255,255,0.32); transition: color 150ms; }
.footer-links a:hover { color: rgba(255,255,255,0.75); }
.footer-social { display: flex; gap: 0.75rem; }
.footer-social a { width: 2.2rem; height: 2.2rem; border: 1px solid rgba(255,255,255,0.14); display: flex; align-items: center; justify-content: center; font-size: 0.75rem; text-decoration: none; color: rgba(255,255,255,0.5); transition: background 150ms, border-color 150ms, color 150ms; }
.footer-social a:hover { background: var(--lime); border-color: var(--lime); color: #111; }
.footer-copy { font-size: 0.68rem; color: rgba(255,255,255,0.2); letter-spacing: 0.06em; }

/* ── PAGINATION ── */
.pagination { display: flex; gap: 0.5rem; justify-content: center; margin-top: 4rem; }
.pagination a, .pagination span { font-size: 0.82rem; font-weight: 600; padding: 0.5rem 0.9rem; text-decoration: none; color: #4A5568; border: 1px solid var(--border-l); transition: background 150ms, color 150ms; }
.pagination a:hover, .pagination .current { background: var(--green); color: #fff; border-color: var(--green); }

/* ── ELEMENTOR COMPAT ── */
.elementor-location-header #site-nav { position: relative; }
body.elementor-page #site-nav { position: fixed; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .about-snap { grid-template-columns: 1fr; }
  .about-snap-img { min-height: 400px; }
  .about-snap-copy { padding: 4rem 2.5rem; }
  .speaking-wrap { grid-template-columns: 1fr; }
  .speaking-photo { min-height: 350px; }
  .speaking-copy { padding: 4rem 2.5rem; }
  .books-grid { grid-template-columns: 1fr; }
  .about-layout { grid-template-columns: 1fr; gap: 3rem; }
  .about-sidebar { position: static; }
  .contact-wrap { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: 4rem 2.5rem; }
  .profile-inner { grid-template-columns: 1fr; text-align: center; align-items: center; }
  .profile-circle { width: 220px; height: 220px; }
  .dl-cards { align-items: stretch; }
}
@media (max-width: 768px) {
  .articles-grid { grid-template-columns: 1fr; }
  .cred-grid { grid-template-columns: 1fr; }
  .stats-band { grid-template-columns: 1fr 1fr; }
  .stat-cell:last-child { grid-column: 1/-1; }
  .gallery-grid { columns: 2; }
  .blog-grid { columns: 1; }
  .book-with-img { grid-template-columns: 1fr; }
  .book-cover-img { width: 150px; }
  .pos-item, .award-item { grid-template-columns: 1fr; gap: 0.25rem; }
  .nav-menu { display: none; }
  .nav-toggle { display: flex; }
  .footer-links { display: none; }
}
@media (max-width: 480px) {
  .gallery-grid { columns: 1; }
  .h-headline { font-size: clamp(4rem, 16vw, 6rem); }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition-duration: 0.01ms !important; }
  [data-sr] { opacity: 1; transform: none; }
}
