/* ==========================================================================
   Choc'atelier — Editorial Atelier Design System
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:ital,wght@0,100..900;1,100..900&display=swap');

:root {
  /* Palette */
  --cocoa-deep:    #1f140e;
  --cocoa:         #2a1810;
  --cocoa-soft:    #3e2418;
  --bark:          #5a3a26;
  --praline:       #c9a57e;
  --gold:          #b8893e;
  --gold-deep:     #8e6326;
  --sage:          #7a8559;
  --burgundy:      #7c2a1f;

  --cream:         #f4ece0;
  --cream-soft:    #faf6ee;
  --ivory:         #fbf7ef;
  --paper:         #f1e7d6;
  --line:          rgba(42, 24, 16, 0.14);
  --line-soft:     rgba(42, 24, 16, 0.08);

  /* Type */
  --display: 'Hanken Grotesk', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --body:    'Hanken Grotesk', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --script:  'Hanken Grotesk', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

  /* Motion */
  --ease:    cubic-bezier(0.32, 0.72, 0, 1);
  --slow:    900ms;
  --med:     500ms;
  --fast:    240ms;

  /* Space */
  --pad-x:   clamp(1.25rem, 4vw, 4rem);
  --maxw:    1340px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.55;
  color: var(--cocoa);
  background: var(--cream);
  font-feature-settings: 'ss01' on, 'ss02' on;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; }
::selection { background: var(--cocoa); color: var(--cream); }

/* Subtle paper grain over everything */
body::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.06;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.16 0 0 0 0 0.09 0 0 0 0 0.06 0 0 0 0.85 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5 {
  font-family: var(--display);
  font-weight: 300;
  letter-spacing: -0.025em;
  line-height: 1.02;
  color: var(--cocoa-deep);
}
h1 { font-size: clamp(2.25rem, 5.6vw, 5.25rem); }
h2 { font-size: clamp(1.75rem, 3.8vw, 3.5rem); }
h3 { font-size: clamp(1.35rem, 2.2vw, 2rem); line-height: 1.1; }
h4 { font-size: 1.25rem; line-height: 1.2; }

.script {
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.025em;
  color: var(--gold-deep);
}

.italic { font-style: italic; font-weight: 300; }

.eyebrow {
  font-family: var(--body);
  font-weight: 500;
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bark);
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}
.eyebrow::before {
  content: '';
  width: 28px; height: 1px;
  background: var(--gold);
}
.eyebrow.no-rule::before { display: none; }

p { font-size: 1rem; line-height: 1.7; color: var(--cocoa-soft); }
.lead { font-size: clamp(1.05rem, 1.4vw, 1.3rem); line-height: 1.55; color: var(--cocoa-soft); }
.body-serif { font-family: var(--body); font-weight: 400; font-size: 1.4rem; line-height: 1.45; color: var(--cocoa); }

.num {
  font-family: var(--display);
  font-style: italic;
  font-weight: 300;
  color: var(--gold-deep);
  font-feature-settings: 'lnum';
}

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad-x); }
.full      { width: 100%; padding-inline: var(--pad-x); }
.section   { padding-block: clamp(5rem, 10vw, 9rem); position: relative; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.divider   { height: 1px; background: var(--line); width: 100%; }
.rule      { display: block; width: 56px; height: 1px; background: var(--gold); border: 0; margin: 1.5rem 0; }

/* ---------- Header ---------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 1.4rem var(--pad-x);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
  transition: background var(--med) var(--ease), backdrop-filter var(--med) var(--ease), padding var(--med) var(--ease), border-color var(--med) var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled,
.site-header.is-solid {
  background: rgba(244, 236, 224, 0.78);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  padding-block: 1rem;
  border-bottom-color: var(--line-soft);
}
.brand {
  font-family: var(--display);
  font-weight: 380;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
  color: var(--cocoa-deep);
  display: inline-flex;
  align-items: baseline;
  gap: 0.05em;
}
.brand .apos {
  font-family: var(--script);
  font-size: 1.9rem;
  color: var(--gold-deep);
  line-height: 0;
  margin: 0 0.02em;
  transform: translateY(0.06em);
}
.brand img {
  height: 46px;
  width: auto;
  display: block;
  transition: filter var(--med) var(--ease), height var(--med) var(--ease);
}
.site-header.is-scrolled .brand img { height: 38px; }
.brand-mark {
  font-family: var(--script);
  font-size: 2.2rem;
  color: var(--gold-deep);
  line-height: 1;
  display: none;
}
.nav {
  display: flex;
  gap: 2.2rem;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.nav a {
  position: relative;
  padding: 0.4rem 0;
  color: var(--cocoa);
  transition: color var(--fast) var(--ease);
}
.nav a::after {
  content: '';
  position: absolute; left: 0; right: 100%; bottom: -2px;
  height: 1px; background: var(--gold);
  transition: right var(--med) var(--ease);
}
.nav a:hover { color: var(--gold-deep); }
.nav a:hover::after,
.nav a[aria-current="page"]::after { right: 0; }
.nav a[aria-current="page"] { color: var(--gold-deep); }

.header-end {
  display: flex; justify-content: flex-end; align-items: center; gap: 1rem;
  font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cocoa-soft);
}
.header-end .pin {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 4px rgba(184,137,62,0.16);
}
.menu-toggle { display: none; }

@media (max-width: 960px) {
  .site-header { grid-template-columns: 1fr auto; }
  .nav { display: none; }
  .header-end { display: none; }
  .menu-toggle {
    display: inline-flex; align-items: center; gap: 0.6rem;
    font-size: 0.75rem; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--cocoa);
  }
  .menu-toggle .bars { width: 22px; height: 10px; position: relative; }
  .menu-toggle .bars::before, .menu-toggle .bars::after {
    content: ''; position: absolute; left: 0; right: 0; height: 1px; background: currentColor;
  }
  .menu-toggle .bars::before { top: 2px; }
  .menu-toggle .bars::after  { bottom: 2px; }
}

/* Mobile drawer */
.drawer {
  position: fixed; inset: 0; z-index: 99;
  background: var(--cocoa-deep);
  color: var(--cream);
  padding: 6rem var(--pad-x) 3rem;
  display: flex; flex-direction: column; justify-content: space-between;
  transform: translateY(-100%);
  visibility: hidden;
  transition: transform var(--slow) var(--ease), visibility 0s linear var(--slow);
}
.drawer.open { transform: translateY(0); visibility: visible; transition: transform var(--slow) var(--ease), visibility 0s linear 0s; }
.drawer .nav-mobile { display: flex; flex-direction: column; gap: 1.4rem; }
.drawer .nav-mobile a { font-family: var(--display); font-size: 2.2rem; font-weight: 300; letter-spacing: -0.02em; }
.drawer .nav-mobile a .num { font-size: 0.95rem; margin-right: 1rem; color: var(--gold); }
.drawer-foot { font-size: 0.85rem; color: var(--praline); display: grid; gap: 0.4rem; }
.drawer-foot a:hover { color: var(--gold); }

/* ---------- Hero (home) ---------- */
.hero {
  position: relative;
  min-height: 100vh;
  padding: 7rem var(--pad-x) 3rem;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 2rem 4rem;
  align-items: center;
  background: linear-gradient(180deg, var(--cream-soft) 0%, var(--cream) 60%);
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 90% 10%, rgba(184,137,62,0.08), transparent 50%),
              radial-gradient(60% 40% at 10% 100%, rgba(122,133,89,0.07), transparent 60%);
  pointer-events: none;
}
.hero-content { position: relative; z-index: 2; max-width: 38ch; }
.hero h1 {
  font-weight: 250;
  letter-spacing: -0.04em;
}
.hero h1 .script {
  display: block;
  font-style: italic;
  font-weight: 250;
  font-size: 0.95em;
  color: var(--gold-deep);
}
.hero-lead { margin-top: 2rem; max-width: 38ch; }
.hero-cta { margin-top: 2.5rem; display: flex; gap: 1.5rem; align-items: center; flex-wrap: wrap; }

.hero-visual {
  position: relative; z-index: 2;
  height: clamp(360px, 70vh, 720px);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 1rem;
}
.hero-visual .v1 { grid-row: 1 / 3; border-radius: 4px; overflow: hidden; }
.hero-visual .v2 { border-radius: 4px; overflow: hidden; align-self: end; transform: translateY(-2rem); }
.hero-visual .v3 { border-radius: 4px; overflow: hidden; transform: translateY(2rem); }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.6s var(--ease); }
.hero-visual figure { position: relative; height: 100%; overflow: hidden; }
.hero-visual figure:hover img { transform: scale(1.05); }
.hero-visual .badge {
  position: absolute; bottom: 1.2rem; left: 1.2rem; right: 1.2rem;
  font-family: var(--body); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cream);
  display: flex; justify-content: space-between;
  text-shadow: 0 1px 8px rgba(0,0,0,0.4);
}

.hero-meta {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  align-items: end;
  border-top: 1px solid var(--line);
  padding-top: 1.5rem;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cocoa-soft);
  z-index: 2;
}
.hero-meta div { display: flex; flex-direction: column; gap: 0.4rem; }
.hero-meta b { font-weight: 500; color: var(--cocoa-deep); letter-spacing: 0.18em; }
.hero-meta .marquee-trigger { font-family: var(--display); font-style: italic; font-size: 1.4rem; letter-spacing: -0.01em; text-transform: none; color: var(--cocoa-deep); }

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; gap: 3rem; padding-top: 7rem; }
  .hero-visual { height: 60vh; }
  .hero-meta { flex-direction: column; align-items: flex-start; gap: 1rem; }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1rem 1.6rem;
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid var(--cocoa);
  color: var(--cocoa-deep);
  background: transparent;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  transition: color var(--med) var(--ease);
}
.btn::before {
  content: '';
  position: absolute; inset: 0;
  background: var(--cocoa);
  transform: translateY(101%);
  transition: transform var(--med) var(--ease);
  z-index: -1;
}
.btn:hover { color: var(--cream); }
.btn:hover::before { transform: translateY(0); }
.btn .arrow { transition: transform var(--med) var(--ease); }
.btn:hover .arrow { transform: translate(3px, -3px); }
.btn--filled { background: var(--cocoa); color: var(--cream); }
.btn--filled::before { background: var(--gold-deep); }
.btn--filled:hover { color: var(--cream); }

.link-arrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500;
  color: var(--cocoa-deep);
  border-bottom: 1px solid var(--cocoa);
  padding-bottom: 0.25rem;
}
.link-arrow:hover { color: var(--gold-deep); border-color: var(--gold); }

/* ---------- Marquee ---------- */
.marquee {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 1.6rem 0;
  overflow: hidden;
  white-space: nowrap;
  background: var(--cream-soft);
}
.marquee-track {
  display: inline-flex;
  gap: 3rem;
  animation: scroll 38s linear infinite;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(1.6rem, 3.4vw, 2.6rem);
  letter-spacing: -0.025em;
  color: var(--cocoa);
}
.marquee-track span { display: inline-flex; align-items: center; gap: 3rem; }
.marquee-track .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
  display: inline-block;
}
@keyframes scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Editorial sections ---------- */
.split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
}
.split.reverse { direction: rtl; }
.split.reverse > * { direction: ltr; }
.split-stack { display: flex; flex-direction: column; gap: 1.5rem; }
@media (max-width: 900px) { .split { grid-template-columns: 1fr; } .split.reverse { direction: ltr; } }

.frame {
  position: relative;
  overflow: hidden;
  background: var(--paper);
}
.frame img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--ease); }
.frame:hover img { transform: scale(1.04); }
.frame--portrait { aspect-ratio: 4/5; }
.frame--landscape { aspect-ratio: 5/4; }
.frame--wide { aspect-ratio: 16/9; }

.section-head {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 2rem 4rem;
  align-items: end;
  margin-bottom: 4rem;
}
.section-head .title-block { display: flex; flex-direction: column; gap: 1.1rem; }
.section-head h2 { max-width: 18ch; }
.section-head .meta { font-size: 0.95rem; color: var(--cocoa-soft); max-width: 36ch; }
@media (max-width: 800px) {
  .section-head { grid-template-columns: 1fr; gap: 1.25rem; margin-bottom: 2.5rem; }
}

/* ---------- Cards / grid ---------- */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1rem, 2vw, 2rem);
}
.card {
  position: relative;
  overflow: hidden;
  background: var(--ivory);
  display: flex; flex-direction: column;
}
.card .frame { aspect-ratio: 5/6; }
.card .body { padding: 1.4rem 1.4rem 1.6rem; display: flex; flex-direction: column; gap: 0.6rem; }
.card h3 { font-size: 1.5rem; }
.card .body > .num { display: none; }
.card .num { font-size: 0.9rem; }
.card p { font-size: 0.92rem; }
.card .more {
  margin-top: 0.6rem;
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500;
  display: inline-flex; align-items: center; gap: 0.4rem; color: var(--cocoa-deep);
}
.card:hover .more { color: var(--gold-deep); }

/* Story tile (mosaic) */
.mosaic {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 100px;
  gap: 1rem;
}
.mosaic > * { grid-column: span 4; grid-row: span 3; overflow: hidden; }
.mosaic > .x6 { grid-column: span 6; }
.mosaic > .x8 { grid-column: span 8; }
.mosaic > .r4 { grid-row: span 4; }
.mosaic > .r5 { grid-row: span 5; }
@media (max-width: 700px) {
  .mosaic { grid-auto-rows: 70px; }
  .mosaic > * { grid-column: span 6; }
  .mosaic > .x8 { grid-column: span 12; }
}

/* Pill / tag */
.tag {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.9rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--cocoa-soft);
  background: var(--cream-soft);
  cursor: pointer;
  transition: all var(--fast) var(--ease);
}
.tag:hover, .tag.active {
  background: var(--cocoa);
  color: var(--cream);
  border-color: var(--cocoa);
}

/* ---------- Flavor list ---------- */
.flavors {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
@media (min-width: 900px) { .flavors { grid-template-columns: repeat(3, 1fr); } }
.flavor {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 1.2rem 1rem;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  transition: background var(--fast) var(--ease);
}
.flavor:nth-child(2n) { border-right: none; }
@media (min-width: 900px) {
  .flavor:nth-child(2n) { border-right: 1px solid var(--line); }
  .flavor:nth-child(3n) { border-right: none; }
}
.flavor:hover { background: var(--cream-soft); }
.flavor .num { font-size: 0.9rem; min-width: 2ch; }
.flavor .name { font-family: var(--display); font-size: 1.15rem; font-weight: 400; letter-spacing: -0.01em; }
.flavor .type {
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--cocoa-soft);
  display: inline-flex; align-items: center; gap: 0.4rem;
}
.flavor .type::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: var(--cocoa);
}
.flavor.wit .type::before    { background: #f3e3c7; border: 1px solid var(--praline); }
.flavor.bruin .type::before  { background: var(--praline); }
.flavor.zwart .type::before  { background: var(--cocoa-deep); }

@media (max-width: 600px) {
  .flavors { grid-template-columns: 1fr; }
  .flavors .flavor { border-right: none; padding: 1rem 0.5rem; gap: 0.75rem; }
  .flavor .name { font-size: 1.1rem; }
}

/* ---------- Quote ---------- */
.quote {
  font-family: var(--display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.6rem, 3.2vw, 2.6rem);
  letter-spacing: -0.025em;
  line-height: 1.25;
  color: var(--cocoa-deep);
  max-width: 30ch;
}
.quote::before { content: '\201C'; font-size: 1.4em; color: var(--gold); line-height: 0; vertical-align: -0.2em; margin-right: 0.05em; }
.quote::after  { content: '\201D'; font-size: 1.4em; color: var(--gold); line-height: 0; vertical-align: -0.2em; margin-left: 0.05em; }
.quote-cite {
  margin-top: 1.5rem; font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--cocoa-soft);
}

/* ---------- Footer ---------- */
.site-footer {
  background: var(--cocoa-deep);
  color: var(--paper);
  padding: clamp(4rem, 8vw, 7rem) var(--pad-x) 2rem;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: 'choc’atelier';
  position: absolute; bottom: -0.18em; left: 50%; transform: translateX(-50%);
  font-family: var(--display);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(7rem, 20vw, 18rem);
  letter-spacing: -0.04em;
  color: var(--cocoa-soft);
  opacity: 0.22;
  white-space: nowrap;
  pointer-events: none;
  line-height: 1;
}
.footer-grid {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 6rem;
  border-bottom: 1px solid rgba(244, 236, 224, 0.18);
}
.footer-grid h4 {
  font-family: var(--body);
  font-size: 0.72rem; letter-spacing: 0.28em; text-transform: uppercase;
  font-weight: 500;
  color: var(--praline);
  margin-bottom: 1.2rem;
}
.footer-grid .lede {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--cream);
  max-width: 16ch;
}
.footer-grid ul li { padding: 0.35rem 0; }
.footer-grid a { color: var(--paper); }
.footer-grid a:hover { color: var(--gold); }
.footer-bottom {
  position: relative; z-index: 2;
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 2rem;
  font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--praline);
}
@media (max-width: 800px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; gap: 1rem; align-items: flex-start; }
}

/* ---------- Sub page header ---------- */
.page-head {
  padding: 9rem var(--pad-x) 3.5rem;
  background: linear-gradient(180deg, var(--cream-soft) 0%, var(--cream) 100%);
  position: relative;
  overflow: hidden;
}
.page-head::after {
  content: '';
  position: absolute; right: -10%; bottom: -40%;
  width: 60%; height: 120%;
  background: radial-gradient(circle, rgba(184,137,62,0.10), transparent 60%);
  pointer-events: none;
}
.page-head .grid {
  position: relative; z-index: 2;
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: end;
}
.page-head h1 {
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 250;
  letter-spacing: -0.04em;
}
.page-head p { max-width: 38ch; }
.crumb { font-size: 0.72rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--cocoa-soft); margin-bottom: 2rem; display: flex; gap: 0.7rem; align-items: center; }
.crumb .sep { color: var(--gold); }
@media (max-width: 800px) { .page-head .grid { grid-template-columns: 1fr; gap: 1.5rem; } }

/* ---------- Reveal animations ---------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
  transition-delay: var(--d, 0ms);
}
[data-reveal].in { opacity: 1; transform: translateY(0); }

/* ---------- Misc ---------- */
.center { text-align: center; }
.muted { color: var(--cocoa-soft); }
.shadow-soft { box-shadow: 0 18px 48px -28px rgba(31,20,14,0.45); }

/* CTA banner */
.cta-banner {
  background: var(--cocoa-deep);
  color: var(--cream);
  padding: clamp(4rem, 7vw, 6rem) var(--pad-x);
  position: relative; overflow: hidden;
  border-top: 1px solid var(--gold-deep);
}
.cta-banner .grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 3rem; align-items: end;
}
.cta-banner h2 {
  color: var(--cream);
  font-size: clamp(2rem, 4vw, 3.6rem);
  font-weight: 250;
  letter-spacing: -0.04em;
}
.cta-banner h2 .script { color: var(--gold); display: block; }
.cta-banner p { color: var(--praline); max-width: 30ch; }
.cta-banner .btn { color: var(--cream); border-color: var(--cream); }
.cta-banner .btn::before { background: var(--cream); }
.cta-banner .btn:hover { color: var(--cocoa-deep); }
@media (max-width: 800px) { .cta-banner .grid { grid-template-columns: 1fr; } }

/* Hours table */
.hours { display: grid; grid-template-columns: 1fr auto; gap: 0.6rem 2rem; }
.hours dt { color: var(--cocoa-soft); font-size: 0.85rem; }
.hours dd { font-family: var(--display); font-weight: 400; font-size: 1.05rem; color: var(--cocoa-deep); }
.hours dd.closed { color: var(--burgundy); }

/* Gallery filter bar */
.filter-bar { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 3rem; }

/* Masonry-ish gallery */
.gallery {
  columns: 3;
  column-gap: 1rem;
}
.gallery figure {
  margin: 0 0 1rem;
  break-inside: avoid;
  overflow: hidden;
  position: relative;
  background: var(--paper);
}
.gallery figure img { width: 100%; height: auto; transition: transform 1s var(--ease); }
.gallery figure:hover img { transform: scale(1.04); }
.gallery figcaption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.2rem;
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500;
  color: var(--cream);
  background: linear-gradient(180deg, transparent, rgba(31,20,14,0.7));
  opacity: 0; transition: opacity var(--med) var(--ease);
}
.gallery figure:hover figcaption { opacity: 1; }
@media (max-width: 900px) { .gallery { columns: 2; } }
@media (max-width: 600px) { .gallery { columns: 1; } }

/* Praline hover grid */
.praline-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
@media (max-width: 1100px) { .praline-grid { grid-template-columns: repeat(3, 1fr); } }
.praline {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--paper);
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
  display: block;
  width: 100%;
}
.praline img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.1s var(--ease);
}
.praline-name {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 1.2rem;
  font-family: var(--display);
  font-weight: 400;
  font-size: 1.05rem;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--cream);
  background: linear-gradient(180deg, rgba(31,20,14,0) 35%, rgba(31,20,14,0.82));
  opacity: 0;
  transition: opacity var(--med) var(--ease);
}
@media (hover: hover) {
  .praline:hover img { transform: scale(1.05); }
  .praline:hover .praline-name { opacity: 1; }
}
.praline.is-revealed .praline-name { opacity: 1; }
.praline:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}
@media (max-width: 600px) {
  .praline-grid { grid-template-columns: repeat(2, 1fr); gap: 0.5rem; }
  .praline-name { padding: 0.8rem; font-size: 0.92rem; }
}

/* Pillar steps (01/02/03/04 values blocks) */
.pillars {
  display: grid;
  grid-template-columns: repeat(var(--cols, 4), 1fr);
  gap: 2rem;
}
@media (max-width: 900px) {
  .pillars { grid-template-columns: repeat(2, 1fr); gap: 1.75rem; }
}
@media (max-width: 520px) {
  .pillars { grid-template-columns: 1fr; gap: 1.25rem; }
}

/* Loose grid for creaties */
.collection {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem 1.5rem;
}
.collection article { display: flex; flex-direction: column; gap: 1rem; }
.collection article h3 { font-size: 1.4rem; }
.collection article .meta { font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cocoa-soft); }
.collection .a { grid-column: span 7; }
.collection .b { grid-column: span 5; padding-top: 6rem; }
.collection .c { grid-column: span 5; }
.collection .d { grid-column: span 7; padding-top: 4rem; }
.collection .e { grid-column: span 6; }
.collection .f { grid-column: span 6; padding-top: 3rem; }
@media (max-width: 800px) { .collection > article { grid-column: span 12 !important; padding-top: 0 !important; } }

/* SVG arrow */
.arrow { width: 14px; height: 14px; }

/* Subtle shimmer on load for hero text */
@keyframes drift {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-6px); }
  100% { transform: translateY(0); }
}
.hero-content .script { animation: drift 8s ease-in-out infinite; transform-origin: center; display: inline-block; }

/* Featured circular badge */
.seal {
  width: 130px; height: 130px;
  border-radius: 50%;
  border: 1px solid var(--gold);
  display: grid; place-items: center;
  font-family: var(--display); font-weight: 300; font-size: 0.95rem; line-height: 1.2;
  letter-spacing: -0.02em;
  text-align: center;
  color: var(--cocoa-deep);
  background: var(--cream-soft);
  position: relative;
}
.seal::before {
  content: ''; position: absolute; inset: 8px;
  border: 1px dashed var(--gold);
  border-radius: 50%;
}
.seal small { font-family: var(--body); font-size: 0.6rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold-deep); display: block; }

/* Floating seal on hero */
.hero-seal {
  position: absolute;
  right: clamp(2rem, 6vw, 6rem);
  top: 38vh;
  z-index: 3;
  animation: spin 32s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.hero-seal svg { width: 140px; height: 140px; }
.hero-seal text { font-family: var(--body); font-size: 8.4px; letter-spacing: 0.32em; text-transform: uppercase; fill: var(--cocoa-deep); }
@media (max-width: 900px) { .hero-seal { display: none; } }

/* Quotes carousel mini */
.testimonial-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.5rem; }
.testimonial-row .quote { font-size: clamp(1.2rem, 1.6vw, 1.55rem); }
@media (max-width: 800px) { .testimonial-row { grid-template-columns: 1fr; gap: 2rem; } }

/* Form */
.field { display: grid; gap: 0.5rem; margin-bottom: 1.4rem; }
.field label { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--cocoa-soft); }
.field input, .field textarea {
  font: inherit; font-size: 1rem;
  padding: 0.9rem 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line);
  color: var(--cocoa-deep);
  font-family: var(--display);
  font-weight: 300;
  font-size: 1.15rem;
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--gold); }
.field textarea { resize: vertical; min-height: 110px; }

/* Utilities */
.flow > * + * { margin-top: 1.2rem; }
.gap-2 { gap: 2rem; }
.dot-sep { display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: var(--gold); margin: 0 0.6rem; vertical-align: middle; }

/* Logo wordmark */
.logo-mark {
  font-family: var(--script);
  font-size: 2.3rem;
  color: var(--gold-deep);
  line-height: 1;
}

/* ---------- Dark masthead variant (index page) ---------- */
body.has-dark-masthead .hero {
  background:
    radial-gradient(110% 70% at 90% 8%, rgba(184,137,62,0.18), transparent 55%),
    radial-gradient(70% 60% at 8% 100%, rgba(124,42,31,0.22), transparent 60%),
    linear-gradient(180deg, var(--cocoa-deep) 0%, var(--cocoa) 55%, #34201a 90%, var(--cream-soft) 100%);
}
body.has-dark-masthead .hero::before {
  background:
    radial-gradient(120% 80% at 90% 10%, rgba(184,137,62,0.10), transparent 50%),
    radial-gradient(60% 40% at 10% 100%, rgba(122,133,89,0.05), transparent 60%);
}
body.has-dark-masthead .hero::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 110px;
  background: linear-gradient(180deg, transparent, var(--cream-soft));
  pointer-events: none;
  z-index: 1;
}
body.has-dark-masthead .hero h1 { color: var(--cream); }
body.has-dark-masthead .hero h1 .script { color: var(--gold); }
body.has-dark-masthead .hero .eyebrow { color: var(--praline); }
body.has-dark-masthead .hero .eyebrow::before { background: var(--gold); }
body.has-dark-masthead .hero-lead { color: var(--praline); }

body.has-dark-masthead .hero-meta {
  color: var(--praline);
  border-top-color: rgba(244, 236, 224, 0.18);
}
body.has-dark-masthead .hero-meta b { color: var(--cream); letter-spacing: 0.18em; }
body.has-dark-masthead .hero-meta .marquee-trigger { color: var(--cream); }

body.has-dark-masthead .hero-seal text { fill: var(--praline); }
body.has-dark-masthead .hero-seal circle { fill: var(--gold); }

body.has-dark-masthead .hero .btn {
  color: var(--cream);
  border-color: rgba(244, 236, 224, 0.4);
}
body.has-dark-masthead .hero .btn::before { background: var(--cream); }
body.has-dark-masthead .hero .btn:hover { color: var(--cocoa-deep); }
body.has-dark-masthead .hero .btn--filled {
  background: var(--gold);
  color: var(--cocoa-deep);
  border-color: var(--gold);
}
body.has-dark-masthead .hero .btn--filled::before { background: var(--cream); }
body.has-dark-masthead .hero .btn--filled:hover { color: var(--cocoa-deep); }

body.has-dark-masthead .hero .link-arrow {
  color: var(--cream);
  border-bottom-color: rgba(244, 236, 224, 0.45);
}
body.has-dark-masthead .hero .link-arrow:hover { color: var(--gold); border-bottom-color: var(--gold); }

body.has-dark-masthead .hero-visual .badge { color: var(--cream); }

/* Selection colour inside dark masthead — gold instead of cocoa so it's visible */
body.has-dark-masthead .hero ::selection { background: var(--gold); color: var(--cocoa-deep); }
body.has-dark-masthead .hero ::-moz-selection { background: var(--gold); color: var(--cocoa-deep); }

/* Header on the dark masthead — only when not scrolled */
body.has-dark-masthead .site-header:not(.is-scrolled) {
  border-bottom-color: rgba(244, 236, 224, 0.10);
}
body.has-dark-masthead .site-header:not(.is-scrolled) .brand img {
  filter: brightness(0) invert(1);
}
body.has-dark-masthead .site-header:not(.is-scrolled) .nav a { color: var(--cream); }
body.has-dark-masthead .site-header:not(.is-scrolled) .nav a:hover { color: var(--gold); }
body.has-dark-masthead .site-header:not(.is-scrolled) .nav a[aria-current="page"] { color: var(--gold); }
body.has-dark-masthead .site-header:not(.is-scrolled) .nav a::after { background: var(--gold); }
body.has-dark-masthead .site-header:not(.is-scrolled) .header-end { color: var(--praline); }
body.has-dark-masthead .site-header:not(.is-scrolled) .header-end .pin { box-shadow: 0 0 0 4px rgba(184, 137, 62, 0.22); }
body.has-dark-masthead .site-header:not(.is-scrolled) .menu-toggle { color: var(--cream); }

body.has-dark-masthead .hero > * { position: relative; z-index: 2; }

/* Print niceness */
@media print {
  .site-header, .site-footer, .marquee { display: none; }
}
