/* ===================================================================
   Gloria's Estate — Hector's River, Portland · Jamaica
   An editorial travel-zine, sun-bleached and slow.
   =================================================================== */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

:root {
  /* ---- Sun-warmed paper palette ---- */
  --cream:        #F4EDDF;
  --cream-deep:   #EBE0C8;
  --paper:        #FBF6EC;
  --shell:        #E9DDC2;

  --ink:          #2A2520;
  --ink-soft:     #5A5048;
  --ink-faint:    #8C8275;
  --ink-ghost:    #B8AE9E;

  --jade:         #2C6B5C;
  --jade-deep:    #1C4A3F;
  --jade-soft:    #6F9A90;

  --clay:         #BD5E3C;
  --clay-deep:    #9B4A33;
  --clay-soft:    #D9967A;

  --sand:         #DDBE92;
  --sun:          #E8B968;

  /* ---- Type ---- */
  --display: 'Fraunces', 'Times New Roman', Georgia, serif;
  --body:    'Mulish', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* ---- Layout ---- */
  --max:   1320px;
  --gutter: clamp(1.25rem, 3.5vw, 3rem);

  /* ---- Motion ---- */
  --ease: cubic-bezier(.2,.7,.2,1);
}

html { scroll-behavior: smooth; }

body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.62;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
em { font-style: italic; }
ul, ol { list-style: none; }

::selection { background: var(--clay); color: var(--paper); }

.container { max-width: var(--max); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }

/* ---- Grain overlay ---- */
.grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 200;
  opacity: 0.45; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.16 0 0 0 0 0.13 0 0 0 0 0.10 0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ===================================================================
   HEADER
   =================================================================== */

.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--cream) 88%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}

.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1rem; padding-bottom: 1rem;
}

.brand {
  display: inline-flex; align-items: center; gap: 0.85rem;
  color: var(--ink);
}
.brand-mark { width: 42px; height: 42px; flex-shrink: 0; color: var(--ink); }
.brand-mark.sm { width: 36px; height: 36px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-name {
  font-family: var(--display); font-style: italic;
  font-size: 1.35rem; font-weight: 500;
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
  letter-spacing: -0.01em;
}
.brand-locale {
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft); margin-top: 0.18rem;
}

.primary-nav { display: flex; align-items: center; gap: 1.75rem; }
.primary-nav a {
  font-family: var(--mono); font-size: 0.74rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft); position: relative; padding: 0.4rem 0;
  transition: color 200ms var(--ease);
}
.primary-nav a:hover { color: var(--ink); }
.primary-nav a:not(.nav-cta)::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: var(--ink); transform: scaleX(0); transform-origin: left;
  transition: transform 280ms var(--ease);
}
.primary-nav a:not(.nav-cta):hover::after { transform: scaleX(1); }
.nav-cta {
  background: var(--ink); color: var(--paper) !important;
  padding: 0.6rem 1rem !important; border-radius: 999px;
  letter-spacing: 0.16em !important;
}
.nav-cta:hover { background: var(--clay-deep); }

@media (max-width: 720px) {
  .primary-nav { gap: 0.9rem; }
  .primary-nav a:not(.nav-cta) { display: none; }
  .brand-locale { display: none; }
}

/* ===================================================================
   SHARED — eyebrow, section heads
   =================================================================== */

.eyebrow {
  font-family: var(--mono); font-size: 0.72rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 0.7rem;
  margin-bottom: 1.6rem;
}
.eyebrow .rule {
  width: 28px; height: 1px; background: var(--ink-soft);
  display: inline-block;
}
.eyebrow.centered { justify-content: center; }

.section-title {
  font-family: var(--display);
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  line-height: 0.98; letter-spacing: -0.025em;
  font-weight: 400;
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
  color: var(--ink);
}
.section-title em {
  font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  color: var(--clay-deep);
}
.section-sub {
  font-family: var(--display); font-style: italic;
  font-size: 1.15rem; color: var(--ink-soft);
  max-width: 38ch; margin-top: 1.25rem;
}
.section-head { margin-bottom: 4rem; }

/* ===================================================================
   HERO
   =================================================================== */

.hero {
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 0;
  min-height: clamp(620px, 90vh, 940px);
  align-items: stretch;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  overflow: hidden;
}

.hero-text {
  padding: clamp(2.5rem, 6vw, 6rem) clamp(1.5rem, 5vw, 5rem) 6rem;
  display: flex; flex-direction: column; justify-content: center;
  position: relative;
}

.hero-title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.85rem, 7.4vw, 6.4rem);
  line-height: 0.94;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.hero-title .hl {
  display: block; opacity: 0;
  transform: translateY(18px);
  animation: rise 1100ms var(--ease) forwards;
}
.hero-title .hl:nth-child(1) { animation-delay: 120ms; }
.hero-title .hl:nth-child(2) { animation-delay: 240ms; }
.hero-title .hl:nth-child(3) { animation-delay: 360ms; }
.hero-title .hl:nth-child(4) { animation-delay: 480ms; }
.hero-title em {
  font-style: italic; color: var(--clay-deep);
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
@keyframes rise {
  to { opacity: 1; transform: translateY(0); }
}

.hero-lede {
  margin-top: 2rem; max-width: 44ch;
  font-size: 1.075rem; color: var(--ink-soft); line-height: 1.62;
  opacity: 0; animation: rise 1100ms var(--ease) 700ms forwards;
}
.hero-lede em { font-family: var(--display); color: var(--ink); }

.hero-actions {
  margin-top: 2.4rem;
  display: flex; flex-wrap: wrap; gap: 0.9rem;
  opacity: 0; animation: rise 1100ms var(--ease) 850ms forwards;
}

.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.95rem 1.4rem;
  font-family: var(--mono); font-size: 0.74rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  border-radius: 999px; cursor: pointer;
  transition: transform 240ms var(--ease), background 240ms var(--ease), color 240ms var(--ease), box-shadow 240ms var(--ease);
  border: 1px solid transparent;
}
.btn.primary {
  background: var(--ink); color: var(--paper);
  box-shadow: 0 1px 0 rgba(0,0,0,0.06), 0 12px 30px -16px rgba(42,37,32,0.5);
}
.btn.primary:hover { background: var(--clay-deep); transform: translateY(-2px); }
.btn.primary svg { transition: transform 240ms var(--ease); }
.btn.primary:hover svg { transform: translateX(3px); }
.btn.ghost {
  border-color: var(--ink); color: var(--ink); background: transparent;
}
.btn.ghost:hover { background: var(--ink); color: var(--paper); }
.btn.big { padding: 1.15rem 1.8rem; font-size: 0.8rem; }

.hero-meta {
  margin-top: 3rem;
  display: grid; grid-template-columns: repeat(4, auto);
  gap: 0 2.6rem;
  border-top: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  padding-top: 1.4rem;
  opacity: 0; animation: rise 1100ms var(--ease) 1000ms forwards;
}
.hero-meta dt {
  font-family: var(--mono); font-size: 0.62rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-faint);
}
.hero-meta dd {
  font-family: var(--display); font-size: 1.45rem; font-weight: 400;
  font-variation-settings: 'opsz' 36; color: var(--ink); margin-top: 0.2rem;
}

.hero-figure {
  position: relative;
  background: var(--shell);
  overflow: hidden;
}
.hero-figure img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(1.02) contrast(1.02);
  transform: scale(1.05);
  animation: settle 2400ms var(--ease) 200ms forwards;
}
@keyframes settle { to { transform: scale(1); } }

.hero-figure figcaption {
  position: absolute; left: 1.5rem; bottom: 1.5rem;
  display: flex; flex-direction: column; gap: 0.2rem;
  background: color-mix(in oklab, var(--cream) 90%, transparent);
  padding: 0.7rem 0.95rem; border-radius: 4px;
  backdrop-filter: blur(6px);
}
.cap-mono {
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink);
}
.cap-italic {
  font-family: var(--display); font-style: italic;
  font-size: 0.85rem; color: var(--ink-soft);
}

.hero-marquee {
  position: absolute; left: 0; right: 0; bottom: 0;
  background: var(--ink); color: var(--paper);
  padding: 0.9rem 0;
  overflow: hidden; white-space: nowrap;
  border-top: 1px solid var(--ink);
  z-index: 5;
}
.marquee-track {
  display: inline-flex; align-items: center; gap: 1.5rem;
  font-family: var(--mono); font-size: 0.72rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  animation: marquee 28s linear infinite;
  padding-left: 0;
}
.marquee-track .dot { color: var(--clay-soft); }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-text { padding: 5rem 1.5rem 4rem; }
  .hero-figure { height: 70vh; min-height: 480px; position: relative; }
  .hero-meta { grid-template-columns: repeat(2, 1fr); gap: 1.2rem 2rem; }
}

/* ===================================================================
   STORY
   =================================================================== */

.story {
  padding: clamp(5rem, 11vw, 9rem) 0 clamp(4rem, 8vw, 7rem);
  background:
    radial-gradient(1100px 540px at 110% -10%, color-mix(in oklab, var(--sand) 30%, transparent), transparent 60%),
    var(--cream);
}

.story-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  grid-template-areas:
    "head fig"
    "body fig";
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.story-head { grid-area: head; }
.story-body { grid-area: body; max-width: 56ch; }
.story-figure { grid-area: fig; position: relative; }

.lead-p {
  font-family: var(--display);
  font-size: clamp(1.3rem, 1.9vw, 1.6rem);
  line-height: 1.45;
  font-weight: 400;
  font-variation-settings: 'opsz' 80, 'SOFT' 50;
  color: var(--ink);
  margin-bottom: 1.5rem;
}
.lead-p em { font-style: italic; color: var(--clay-deep); }
.story-body p + p { margin-top: 1.1rem; color: var(--ink-soft); }

.signature {
  margin-top: 2rem; font-family: var(--display);
  color: var(--ink); font-size: 1rem;
}
.signature em { font-size: 1.5rem; display: inline-block; margin-top: 0.3rem; color: var(--clay-deep); }

.story-figure { aspect-ratio: 4 / 5; overflow: hidden; border-radius: 4px; }
.story-figure img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1200ms var(--ease);
}
.story-figure:hover img { transform: scale(1.04); }
.story-figure figcaption {
  position: absolute; left: 1.1rem; bottom: 1.1rem;
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--paper);
  background: color-mix(in oklab, var(--ink) 85%, transparent);
  padding: 0.55rem 0.8rem; border-radius: 3px;
  display: inline-flex; align-items: center; gap: 0.55rem;
}
.story-figure figcaption .cap-mono { color: var(--clay-soft); }

@media (max-width: 880px) {
  .story-grid { grid-template-columns: 1fr; grid-template-areas: "head" "fig" "body"; }
  .story-figure { aspect-ratio: 3 / 4; }
}

/* ===================================================================
   STAY
   =================================================================== */

.stay {
  padding: clamp(5rem, 11vw, 9rem) 0;
  background: var(--cream-deep);
  position: relative;
}
.stay::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 90px;
  background: linear-gradient(to bottom, var(--cream), transparent);
  pointer-events: none;
}

.unit {
  display: grid;
  grid-template-columns: 90px 1fr;
  grid-template-areas:
    "num content"
    ".   gallery";
  column-gap: clamp(1.5rem, 3.5vw, 3.5rem);
  row-gap: clamp(2rem, 4vw, 3rem);
  margin-bottom: 5rem;
  position: relative;
}
.unit + .unit {
  border-top: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
  padding-top: 5rem;
}

.unit-num {
  grid-area: num;
  font-family: var(--display); font-style: italic;
  font-size: clamp(3rem, 5vw, 4.5rem); line-height: 1;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  color: var(--clay-deep);
}
.unit-num span {
  display: block;
  font-size: 0.55em; font-style: normal;
  font-family: var(--mono); letter-spacing: 0.1em;
  color: var(--ink-faint);
  margin-bottom: 0.2rem; text-transform: none;
}

.unit-content { grid-area: content; max-width: 56ch; }
.unit-tag {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--jade); margin-bottom: 0.9rem;
}
.unit-title {
  font-family: var(--display);
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1; letter-spacing: -0.02em;
  font-weight: 400; color: var(--ink);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  margin-bottom: 1.2rem;
}
.unit-title em {
  font-style: italic; color: var(--clay-deep);
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.unit-copy { color: var(--ink-soft); margin-bottom: 1.5rem; }

.unit-specs {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid color-mix(in oklab, var(--ink) 16%, transparent);
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 16%, transparent);
  padding: 1.1rem 0;
}
.unit-specs li {
  display: flex; flex-direction: column; gap: 0.15rem;
  border-right: 1px dashed color-mix(in oklab, var(--ink) 16%, transparent);
  padding-left: 0;
}
.unit-specs li:last-child { border-right: none; }
.unit-specs .num {
  font-family: var(--display); font-size: 1.9rem;
  font-variation-settings: 'opsz' 80, 'SOFT' 30;
  color: var(--ink); line-height: 1;
}
.unit-specs .lbl {
  font-family: var(--mono); font-size: 0.62rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint);
}

.unit-gallery {
  grid-area: gallery;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-template-areas:
    "main side1 side2"
    "main side3 side2";
  gap: 0.75rem;
  height: clamp(380px, 48vw, 560px);
}
.g-main   { grid-area: main; }
.g-side-1 { grid-area: side1; }
.g-side-2 { grid-area: side2; }
.g-side-3 { grid-area: side3; }
.unit-gallery figure {
  position: relative; overflow: hidden; border-radius: 4px;
  background: var(--shell);
}
.unit-gallery img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1400ms var(--ease), filter 600ms var(--ease);
}
.unit-gallery figure:hover img { transform: scale(1.05); }

/* Alternate the second unit so it doesn't feel repetitive */
.unit-b {
  grid-template-columns: 1fr 90px;
  grid-template-areas:
    "content num"
    "gallery .";
  column-gap: clamp(1.5rem, 3.5vw, 3.5rem);
}
.unit-b .unit-content { justify-self: end; text-align: right; margin-left: auto; }
.unit-b .unit-num { text-align: right; }
.unit-b .unit-num span { text-align: right; }
.unit-b .unit-tag { color: var(--jade-deep); }
.unit-b .unit-gallery {
  grid-template-columns: 1fr 1fr 1.6fr;
  grid-template-areas:
    "side1 side2 main"
    "side3 side2 main";
}

@media (max-width: 880px) {
  .unit, .unit-b {
    grid-template-columns: 1fr;
    grid-template-areas: "num" "content" "gallery";
    text-align: left !important;
  }
  .unit-b .unit-content { text-align: left; justify-self: start; }
  .unit-b .unit-num { text-align: left; }
  .unit-num { font-size: 3rem; }
  .unit-gallery { height: 360px; gap: 0.5rem; }
  .unit-specs { grid-template-columns: repeat(2, 1fr); }
  .unit-specs li { border-right: none; padding: 0.4rem 0; }
}

.amenities {
  display: flex; flex-wrap: wrap; gap: 0.55rem;
  margin-top: 2rem;
  padding-top: 3rem;
  border-top: 1px dashed color-mix(in oklab, var(--ink) 18%, transparent);
}
.amenities li {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.55rem 0.95rem;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  border-radius: 999px;
  color: var(--ink-soft);
  background: color-mix(in oklab, var(--paper) 60%, transparent);
}

/* ===================================================================
   COAST / ITINERARY
   =================================================================== */

.coast {
  padding: clamp(5rem, 11vw, 9rem) 0 clamp(5rem, 10vw, 8rem);
  background: var(--paper);
  position: relative;
}

.itinerary { display: flex; flex-direction: column; }

.stop {
  display: grid;
  grid-template-columns: 130px 1fr 1.1fr;
  grid-template-areas: "meta body fig";
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: center;
  padding: clamp(2rem, 4vw, 3rem) 0;
  border-top: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  position: relative;
}
.stop:last-child { border-bottom: 1px solid color-mix(in oklab, var(--ink) 14%, transparent); }

.stop-meta {
  grid-area: meta;
  display: flex; flex-direction: column; gap: 0.4rem;
}
.stop-dist {
  font-family: var(--mono); font-size: 0.74rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--clay-deep);
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.stop-dist::before {
  content: ""; width: 22px; height: 1px; background: var(--clay-deep);
  display: inline-block;
}
.stop-num {
  font-family: var(--display); font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  font-size: 3.4rem; line-height: 1; color: var(--jade);
}

.stop-body { grid-area: body; max-width: 46ch; }
.stop-body h3 {
  font-family: var(--display);
  font-size: clamp(1.6rem, 2.6vw, 2.4rem); line-height: 1.05;
  font-weight: 400; letter-spacing: -0.015em;
  font-variation-settings: 'opsz' 80, 'SOFT' 50;
  color: var(--ink); margin-bottom: 0.7rem;
}
.stop-body p { color: var(--ink-soft); }

.stop-fig {
  grid-area: fig;
  aspect-ratio: 16 / 10;
  overflow: hidden; border-radius: 4px;
  background: var(--shell);
  position: relative;
}
.stop-fig img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1400ms var(--ease);
}
.stop:hover .stop-fig img { transform: scale(1.06); }

/* alternate alignment for visual rhythm */
.stop:nth-child(even) {
  grid-template-columns: 1.1fr 1fr 130px;
  grid-template-areas: "fig body meta";
}
.stop:nth-child(even) .stop-meta { align-items: flex-end; text-align: right; }
.stop:nth-child(even) .stop-dist { flex-direction: row-reverse; }
.stop:nth-child(even) .stop-dist::before { /* keep dash on inner side */ }

@media (max-width: 880px) {
  .stop, .stop:nth-child(even) {
    grid-template-columns: 1fr;
    grid-template-areas: "meta" "fig" "body";
    align-items: start;
  }
  .stop:nth-child(even) .stop-meta { align-items: flex-start; text-align: left; }
  .stop:nth-child(even) .stop-dist { flex-direction: row; }
  .stop-num { font-size: 2.4rem; }
  .stop-fig { aspect-ratio: 16 / 11; }
}

/* ===================================================================
   EXPLORE — typographic index of nearby attractions
   =================================================================== */

.explore {
  padding: clamp(5rem, 11vw, 9rem) 0;
  background:
    linear-gradient(180deg, var(--paper) 0%, var(--cream) 60%),
    var(--cream);
  position: relative;
}

.explore-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid color-mix(in oklab, var(--ink) 16%, transparent);
}

.explore-card {
  position: relative;
  padding: 2.4rem 1.8rem 2rem;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  border-right: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  display: flex; flex-direction: column;
  background: color-mix(in oklab, var(--paper) 50%, transparent);
  transition: background 320ms var(--ease);
}
.explore-card:nth-child(3n) { border-right: none; }
.explore-card:hover { background: var(--paper); }

.ec-thumb {
  margin: -2.4rem -1.8rem 1.6rem;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--shell);
  position: relative;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
}
.ec-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1400ms var(--ease);
}
.explore-card:hover .ec-thumb img { transform: scale(1.04); }

.ec-cat {
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--jade);
  display: inline-flex; align-items: center; gap: 0.55rem;
  margin-bottom: 1rem;
}
.ec-cat::before {
  content: ""; width: 18px; height: 1px; background: var(--jade);
  display: inline-block;
}

.ec-name {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2vw, 1.7rem);
  line-height: 1.1; letter-spacing: -0.015em;
  font-weight: 400; color: var(--ink);
  font-variation-settings: 'opsz' 80, 'SOFT' 30;
  margin-bottom: 0.7rem;
}
.ec-name em {
  font-style: italic; color: var(--clay-deep);
  font-variation-settings: 'opsz' 80, 'SOFT' 100;
}

.ec-desc {
  color: var(--ink-soft);
  font-size: 0.95rem; line-height: 1.55;
  flex-grow: 1; margin-bottom: 1.4rem;
}

.ec-link {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 0.45rem;
  align-self: flex-start;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 30%, transparent);
  padding-bottom: 4px;
  transition: color 240ms var(--ease), border-color 240ms var(--ease), gap 240ms var(--ease);
}
.ec-link svg { transition: transform 240ms var(--ease); }
.ec-link:hover {
  color: var(--clay-deep);
  border-color: var(--clay-deep);
  gap: 0.6rem;
}
.ec-link:hover svg { transform: translate(2px, -2px); }

.explore-foot {
  margin-top: 3rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  flex-wrap: wrap;
}
.ef-note {
  font-family: var(--display); font-style: italic;
  color: var(--ink-faint); font-size: 0.95rem;
  max-width: 48ch;
}
.explore-foot .btn.ghost svg { transition: transform 240ms var(--ease); }
.explore-foot .btn.ghost:hover svg { transform: translate(2px, -2px); }

@media (max-width: 980px) {
  .explore-grid { grid-template-columns: repeat(2, 1fr); }
  .explore-card:nth-child(3n) { border-right: 1px solid color-mix(in oklab, var(--ink) 14%, transparent); }
  .explore-card:nth-child(2n) { border-right: none; }
}
@media (max-width: 620px) {
  .explore-grid { grid-template-columns: 1fr; }
  .explore-card { border-right: none; }
  .explore-card:nth-child(3n) { border-right: none; }
  .explore-foot { flex-direction: column; align-items: flex-start; }
}

/* ===================================================================
   BOOK
   =================================================================== */

.book {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(5rem, 12vw, 10rem) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.book::before, .book::after {
  content: ""; position: absolute; pointer-events: none;
  width: 60vw; height: 60vw; max-width: 800px; max-height: 800px;
  border-radius: 50%; filter: blur(80px); opacity: 0.18;
}
.book::before { top: -10%; left: -15%; background: var(--clay); }
.book::after  { bottom: -20%; right: -10%; background: var(--jade-soft); }

.book-inner { position: relative; z-index: 1; }
.book .eyebrow { color: var(--ink-ghost); }
.book .eyebrow .rule { background: var(--ink-ghost); }

.book-title {
  font-family: var(--display);
  font-size: clamp(2.8rem, 7vw, 5.6rem);
  line-height: 1; letter-spacing: -0.025em;
  font-weight: 400; color: var(--paper);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  margin-top: 0.5rem;
}
.book-title em {
  font-style: italic; color: var(--clay-soft);
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.book-sub {
  margin-top: 1.5rem; max-width: 44ch; margin-inline: auto;
  color: color-mix(in oklab, var(--paper) 75%, transparent);
  font-family: var(--display); font-style: italic; font-size: 1.15rem;
}
.book-actions {
  margin-top: 2.6rem;
  display: inline-flex; flex-wrap: wrap; gap: 0.8rem; justify-content: center;
}
.book .btn.primary {
  background: var(--paper); color: var(--ink);
}
.book .btn.primary:hover { background: var(--clay-soft); color: var(--ink); }
.btn.ghost.light {
  border-color: color-mix(in oklab, var(--paper) 60%, transparent);
  color: var(--paper);
}
.btn.ghost.light:hover {
  background: var(--paper); color: var(--ink);
  border-color: var(--paper);
}

.book-phone {
  margin-top: 1.4rem;
  font-family: var(--mono); font-size: 0.78rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: color-mix(in oklab, var(--paper) 70%, transparent);
}
.book-phone a {
  border-bottom: 1px solid color-mix(in oklab, var(--paper) 35%, transparent);
  padding-bottom: 2px;
  transition: color 200ms var(--ease), border-color 200ms var(--ease);
}
.book-phone a:hover { color: var(--clay-soft); border-color: var(--clay-soft); }

.book-sig {
  margin-top: 2rem;
  font-family: var(--display); font-size: 1.1rem;
  color: color-mix(in oklab, var(--paper) 65%, transparent);
}
.book-sig em { color: var(--clay-soft); }

/* ===================================================================
   FOOTER
   =================================================================== */

.site-footer {
  background: var(--cream-deep);
  padding: clamp(3.5rem, 7vw, 6rem) 0 1.6rem;
  color: var(--ink);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.foot-brand .brand-mark { color: var(--ink); margin-bottom: 0.9rem; }
.foot-name {
  font-family: var(--display); font-style: italic;
  font-size: 1.5rem;
  font-variation-settings: 'opsz' 36, 'SOFT' 100;
}
.foot-tag {
  font-family: var(--display); font-style: italic;
  color: var(--ink-soft); margin-top: 0.3rem;
}
.foot-label {
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 0.7rem;
}
.foot-col p { line-height: 1.7; color: var(--ink-soft); }
.foot-col a {
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 25%, transparent);
  transition: color 200ms var(--ease), border-color 200ms var(--ease);
}
.foot-col a:hover { color: var(--clay-deep); border-color: var(--clay-deep); }

.foot-rule {
  height: 1px; background: color-mix(in oklab, var(--ink) 14%, transparent);
  margin: 3rem 0 1.4rem;
}
.foot-bottom {
  display: flex; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
}
.foot-mono {
  font-family: var(--mono); font-size: 0.66rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint);
}
.foot-mono .sep { color: var(--clay); margin: 0 0.4rem; }

@media (max-width: 880px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .foot-brand { grid-column: 1 / -1; }
}

/* ===================================================================
   REVEAL ANIMATIONS (set by IntersectionObserver)
   =================================================================== */

.reveal {
  opacity: 0; transform: translateY(20px);
  transition: opacity 900ms var(--ease), transform 900ms var(--ease);
  will-change: opacity, transform;
}
.reveal.in { opacity: 1; transform: translateY(0); }

/* The hero text reveals via its own keyframe stagger. */
.hero .hero-text { opacity: 1; transform: none; }
.hero .hero-figure { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
  .marquee-track { animation: none; }
}
