/* AZOURANE × FRISA  ·  v4. Visual-first. Skim-able. Label-DNA. */

:root {
  --sky: #61afd7;
  --sky-light: #c5e0ee;
  --sky-deep: #2d5870;
  --sky-tint: #eaf4fa;
  --cream: #f6eedf;
  --cream-light: #fbf7ee;
  --cream-deep: #ede4d0;
  --cream-edge: #e6dcc6;
  --ink: #1a1a1a;
  --ink-warm: #1f1c1a;
  --body: #3b3833;
  --taupe: #8a7d6a;
  --line: #e6dcc6;

  /* Label colour-coding (matched to the actual print artwork) */
  --c-sky: #61afd7;
  --c-sky-soft: #b7dbed;
  --c-amber: #c6913c;
  --c-green: #618d3b;
  --c-earth: #a67955;
  --c-ink: #1a1a1a;
  --c-blue: #2657a8;
  --c-red: #a93b3b;
  --c-brown: #7b4a2d;
  --c-saffron: #e8781e;
  --c-coral: #f08773;
  --c-teal: #4f9b96;

  --font-display: 'Fraunces', Georgia, serif;
  --font-sans: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;

  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 24px; --s-6: 32px;
  --s-7: 48px; --s-8: 64px; --s-9: 80px; --s-10: 96px; --s-11: 128px; --s-12: 160px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-sans); font-size: 16px; line-height: 1.55;
  color: var(--body); background: var(--cream-light);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button { font-family: inherit; cursor: pointer; }

.wrap { max-width: 1320px; margin: 0 auto; padding: 0 24px; }
@media (min-width: 880px) { .wrap { padding: 0 56px; } }

/* Typography */
.display-xl, .display-l, .display-m, .display-s {
  font-family: var(--font-display); font-weight: 500;
  letter-spacing: -0.02em; line-height: 1.05; color: var(--ink); margin: 0;
}
.display-xl { font-size: clamp(40px, 6vw, 72px); }
.display-l  { font-size: clamp(32px, 4.5vw, 52px); }
.display-m  { font-size: clamp(24px, 3vw, 36px); }
.display-s  { font-size: clamp(20px, 2.4vw, 28px); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-sans); font-weight: 600; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--taupe);
}
.eyebrow::before {
  content: ""; display: inline-block; width: 22px; height: 1.5px;
  background: currentColor; opacity: 0.7;
}
.eyebrow-light { color: rgba(251,247,238,0.88); }
.lead-light { color: rgba(251,247,238,0.92); font-size: 17px; line-height: 1.55; max-width: 50ch; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 52px; padding: 0 26px; font-family: var(--font-sans);
  font-weight: 700; font-size: 13px; letter-spacing: 0.10em;
  text-transform: uppercase; text-decoration: none; border-radius: 4px;
  border: 0; transition: background 180ms ease, color 180ms ease, transform 180ms ease;
}
.btn-sm { height: 40px; padding: 0 18px; font-size: 11px; }
.btn-primary { background: var(--sky); color: #ffffff; }
.btn-primary:hover { background: var(--sky-deep); transform: translateY(-1px); }
.btn-ghost-light {
  background: transparent; color: var(--cream-light);
  border: 1.5px solid rgba(197,224,238,0.7);
}
.btn-ghost-light:hover { background: rgba(97,175,215,0.18); border-color: var(--sky-light); color: #ffffff; }

/* Backgrounds */
.bg-cream { background: var(--cream); color: var(--body); }
.bg-cream-deep { background: var(--cream-deep); color: var(--body); }
.bg-ink { background: var(--ink); color: var(--cream-light); }
.bg-ink h2 { color: var(--cream-light); }

/* Announcement bar */
.annc {
  background: var(--sky); color: #ffffff; font-family: var(--font-sans);
  font-weight: 600; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
}
.annc-inner {
  display: flex; align-items: center; justify-content: center;
  gap: var(--s-3); padding: 10px 24px; flex-wrap: wrap;
}
.annc-dot { opacity: 0.6; }

/* Header */
.hdr {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246,238,223,0.94); backdrop-filter: saturate(160%) blur(10px);
  border-bottom: 1px solid rgba(31,28,26,0.06);
}
.hdr-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5); padding: 16px 24px;
}
.wordmark {
  font-family: var(--font-display); font-weight: 500;
  font-size: 22px; letter-spacing: 0.32em; color: var(--ink);
}
.nav { display: none; gap: var(--s-6); }
@media (min-width: 980px) { .nav { display: flex; } }
.nav a { font-family: var(--font-sans); font-weight: 600; font-size: 13px; color: var(--body); transition: color 160ms; }
.nav a:hover { color: var(--sky-deep); }

/* HERO */
.hero { position: relative; background: var(--ink); color: var(--cream-light); overflow: hidden; isolation: isolate; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-scrim {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(17,17,17,0.80) 0%, rgba(17,17,17,0.55) 35%, rgba(17,17,17,0.15) 70%, rgba(17,17,17,0) 100%);
}
@media (max-width:879px) {
  .hero-scrim { background: linear-gradient(180deg, rgba(17,17,17,0.25) 0%, rgba(17,17,17,0.70) 70%, rgba(17,17,17,0.88) 100%); }
}
.hero-inner {
  position: relative; z-index: 2;
  padding: var(--s-10) 24px var(--s-10);
  display: flex; flex-direction: column; gap: var(--s-4);
}
@media (min-width:880px) { .hero-inner { padding: var(--s-11) 56px var(--s-11); gap: var(--s-5); } }
.hero-title {
  margin: 0; font-family: var(--font-display); font-weight: 500;
  font-size: clamp(40px, 6.2vw, 76px); line-height: 1.04; letter-spacing: -0.025em;
  max-width: 20ch; color: var(--cream-light);
}
.hero-lead { margin: 0; font-size: 17px; line-height: 1.55; max-width: 56ch; color: rgba(251,247,238,0.92); }
.hero-ctas { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-4); }

/* FOUNDER 1-sentence card */
.fcard { padding: var(--s-9) 0; }
.fcard-inner {
  display: grid; grid-template-columns: 1fr; gap: var(--s-5); align-items: center;
}
@media (min-width:880px) {
  .fcard-inner { grid-template-columns: 200px 1fr; gap: var(--s-7); }
}
.fcard-photo {
  width: 100%; max-width: 200px; aspect-ratio: 3/4; object-fit: cover; object-position: center top;
  border-radius: 8px;
}
.fcard-text { display: flex; flex-direction: column; gap: var(--s-3); }
.fcard-line {
  margin: 0; font-family: var(--font-display); font-weight: 500;
  font-size: clamp(28px, 4vw, 44px); line-height: 1.12; letter-spacing: -0.02em; color: var(--ink);
}
.fcard-line-2 { color: var(--taupe); font-style: italic; }
.fcard-sig { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--taupe); font-weight: 600; }

/* RANGE GRID  ·  label-dna cards */
.range { padding: var(--s-10) 0; }
.range-head { max-width: 720px; margin-bottom: var(--s-6); display: flex; flex-direction: column; gap: var(--s-3); }

.filters { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-bottom: var(--s-6); padding-bottom: var(--s-5); border-bottom: 1px solid var(--line); }
.filter {
  display: inline-flex; align-items: center; gap: 8px;
  height: 38px; padding: 0 16px; background: transparent;
  border: 1px solid var(--line); border-radius: 999px;
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 0.06em; color: var(--body); transition: all 150ms;
}
.filter:hover { border-color: var(--sky); color: var(--sky-deep); }
.filter.is-active { background: var(--sky); border-color: var(--sky); color: #ffffff; }
.filter.is-active .filter-count { background: rgba(255,255,255,0.20); color: #ffffff; }
.filter-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 18px; padding: 0 6px;
  background: var(--cream-deep); color: var(--taupe);
  border-radius: 999px; font-size: 10px; font-weight: 700;
}

.rgrid {
  display: grid; grid-template-columns: 1fr; gap: var(--s-5);
}
@media (min-width:640px) { .rgrid { grid-template-columns: repeat(2,1fr); } }
@media (min-width:980px) { .rgrid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:1280px) { .rgrid { grid-template-columns: repeat(4,1fr); } }

.pcard {
  position: relative; display: flex; flex-direction: column;
  background: var(--cream-light); border-radius: 12px; overflow: hidden;
  box-shadow: 0 1px 0 rgba(31,28,26,0.06);
  transition: transform 220ms, box-shadow 220ms; cursor: pointer; border: 1px solid transparent;
}
.pcard:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(31,28,26,0.12); border-color: var(--sky); }

/* The colour-arch  ·  recreated from the print labels */
.pcard-arch {
  position: relative; aspect-ratio: 5/4;
  background: var(--c-arch, var(--c-sky-soft));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.pcard-arch::before {
  /* zellij/arabesque overlay using SVG-style background */
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 50% 0%, transparent 0%, transparent 60%, rgba(255,255,255,0.12) 61%),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.06) 0 6px, transparent 6px 18px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,0.06) 0 6px, transparent 6px 18px);
  opacity: 0.7;
}
.pcard-arch::after {
  /* arch silhouette frame */
  content: ""; position: absolute; left: 18%; right: 18%; top: 12%; bottom: 0;
  border-radius: 50% 50% 6px 6px / 42% 42% 6px 6px;
  background: rgba(255,255,255,0.10);
  border: 1.5px solid rgba(255,255,255,0.35);
}
.pcard-arch img {
  position: relative; z-index: 2; max-height: 78%; max-width: 60%;
  object-fit: contain; filter: drop-shadow(0 8px 16px rgba(0,0,0,0.25));
}
/* PLATE mode · real photo or print label fills the tile, no colour overlay */
.pcard.is-plate .pcard-arch { background: #f6eedf; aspect-ratio: 1/1; }
.pcard.is-plate .pcard-arch::before,
.pcard.is-plate .pcard-arch::after { display: none; }
.pcard.is-plate .pcard-arch img {
  max-height: 100%; max-width: 100%; width: 100%; height: 100%;
  object-fit: cover; filter: none;
}
/* For print labels (white-bg JPGs in assets/labels/) use contain so the full label is visible */
.pcard.is-plate.is-label .pcard-arch img { object-fit: contain; padding: 4%; }
.pcard.c-sky        .pcard-arch { --c-arch: var(--c-sky); }
.pcard.c-sky-soft   .pcard-arch { --c-arch: var(--c-sky-soft); }
.pcard.c-amber      .pcard-arch { --c-arch: var(--c-amber); }
.pcard.c-green      .pcard-arch { --c-arch: var(--c-green); }
.pcard.c-earth      .pcard-arch { --c-arch: var(--c-earth); }
.pcard.c-ink        .pcard-arch { --c-arch: var(--c-ink); }
.pcard.c-blue       .pcard-arch { --c-arch: var(--c-blue); }
.pcard.c-red        .pcard-arch { --c-arch: var(--c-red); }
.pcard.c-brown      .pcard-arch { --c-arch: var(--c-brown); }
.pcard.c-saffron    .pcard-arch { --c-arch: var(--c-saffron); }
.pcard.c-coral      .pcard-arch { --c-arch: var(--c-coral); }
.pcard.c-teal       .pcard-arch { --c-arch: var(--c-teal); }

.pcard-body { padding: var(--s-4) var(--s-5) var(--s-5); display: flex; flex-direction: column; gap: var(--s-2); flex: 1; }
.pcard-flags { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 2px; }
.pcard-flag {
  font-size: 9px; font-weight: 700; letter-spacing: 0.14em;
  padding: 3px 7px; border-radius: 2px; text-transform: uppercase;
  background: var(--cream-deep); color: var(--taupe);
}
.pcard-flag.s-shelf   { background: var(--sky); color: #fff; }
.pcard-flag.s-inbound { background: var(--sky-deep); color: #fff; }
.pcard-flag.s-hero    { background: var(--ink); color: var(--cream-light); }
.pcard-flag.s-excl    { background: var(--c-red); color: #fff; }
.pcard-flag.s-best    { background: var(--c-amber); color: #fff; }
.pcard-name {
  margin: 4px 0 0; font-family: var(--font-display); font-weight: 500;
  font-size: 30px; line-height: 1.05; letter-spacing: -0.01em; color: var(--ink);
}
.pcard-type {
  font-size: 10px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  color: #fff; background: var(--c-pill, var(--ink));
  padding: 4px 8px; border-radius: 2px; align-self: flex-start;
}
.pcard.c-sky      .pcard-type { background: var(--c-sky); }
.pcard.c-sky-soft .pcard-type { background: var(--c-sky); }
.pcard.c-amber    .pcard-type { background: var(--c-amber); }
.pcard.c-green    .pcard-type { background: var(--c-green); }
.pcard.c-earth    .pcard-type { background: var(--c-earth); }
.pcard.c-ink      .pcard-type { background: var(--c-ink); }
.pcard.c-blue     .pcard-type { background: var(--c-blue); }
.pcard.c-red      .pcard-type { background: var(--c-red); }
.pcard.c-brown    .pcard-type { background: var(--c-brown); }
.pcard.c-saffron  .pcard-type { background: var(--c-saffron); }
.pcard.c-coral    .pcard-type { background: var(--c-coral); }
.pcard.c-teal     .pcard-type { background: var(--c-teal); }

.pcard-tag {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--taupe);
}
.pcard-star { font-size: 13px; color: var(--body); margin: 0; }
.pcard-size { font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--taupe); font-weight: 600; }

/* Slider bars (from labels) */
.pcard-sliders { display: flex; flex-direction: column; gap: 8px; margin-top: var(--s-3); padding-top: var(--s-3); border-top: 1px solid var(--cream-edge); }
.slider-row { display: grid; grid-template-columns: 80px 1fr; gap: var(--s-3); align-items: center; font-size: 11px; }
.slider-label { letter-spacing: 0.08em; text-transform: uppercase; color: var(--taupe); font-weight: 600; }
.slider-track { position: relative; height: 4px; background: var(--cream-deep); border-radius: 999px; overflow: visible; }
.slider-fill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--c-arch, var(--sky)); border-radius: 999px; width: 0; transition: width 800ms cubic-bezier(.2,.7,.2,1); }
.slider-dot { position: absolute; top: 50%; transform: translate(50%, -50%); width: 10px; height: 10px; border-radius: 50%; background: var(--c-arch, var(--sky)); right: 100%; box-shadow: 0 0 0 2px var(--cream-light); transition: right 800ms cubic-bezier(.2,.7,.2,1); }

.pcard-means {
  font-family: var(--font-display); font-style: italic;
  font-size: 13px; line-height: 1.4; color: var(--taupe); margin-top: auto; padding-top: var(--s-3); border-top: 1px dashed var(--cream-edge);
}

/* ──────────── SCROLLYTELLING ────────────── */
.story { position: relative; background: var(--cream); padding: 0; }
.story:nth-of-type(even) { background: var(--cream-light); }
.story.story-ink { background: var(--cream); }
.story-track { position: relative; min-height: 380vh; }
@media (max-width: 879px) { .story-track { min-height: 340vh; } }
.story-pin {
  position: sticky; top: 0; height: 100vh;
  display: grid; grid-template-columns: 1fr; align-items: center; gap: var(--s-5);
  padding: var(--s-5) 24px;
}
@media (min-width:880px) {
  .story-pin {
    grid-template-columns: 1.2fr 1fr; padding: var(--s-7) 56px; gap: var(--s-8);
    max-width: 1320px; margin: 0 auto;
  }
}
.story-art { position: relative; aspect-ratio: 3/4; max-height: 78vh; border-radius: 12px; overflow: hidden; background: var(--cream-deep); }
.story-frame { position: absolute; inset: 0; opacity: 0; transition: opacity 700ms ease; }
.story-frame.is-on { opacity: 1; }
.story-frame img { width: 100%; height: 100%; object-fit: cover; }

.story-side { display: flex; flex-direction: column; gap: var(--s-3); }
.story-kicker { font-size: 11px; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: var(--sky-deep); }
.story-h { margin: 0; font-family: var(--font-display); font-weight: 500; font-size: clamp(30px, 4vw, 48px); line-height: 1.06; letter-spacing: -0.02em; color: var(--ink); }
.story-cap {
  font-family: var(--font-display); font-style: italic; font-size: clamp(18px, 2vw, 24px);
  line-height: 1.3; color: var(--ink); opacity: 0; max-height: 0;
  transition: opacity 500ms ease, max-height 500ms ease;
}
.story-cap.is-on { opacity: 1; max-height: 100px; margin: var(--s-2) 0; }
.story-facts {
  list-style: none; padding: var(--s-4) 0 0; margin: var(--s-3) 0 0;
  border-top: 1px solid var(--cream-edge);
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3);
}
.story-facts li { font-size: 13px; color: var(--body); display: flex; flex-direction: column; gap: 2px; }
.story-facts span { font-family: var(--font-display); font-size: 22px; font-weight: 500; color: var(--ink); letter-spacing: -0.01em; }

/* INK story panel (Aker Fassi pen-ink) */
.story-ink .story-art { background: #f4ecd9; }

/* ALOE specific  ·  slices stacking */
.aloe-stage { position: relative; aspect-ratio: 3/4; max-height: 78vh; overflow: hidden; border-radius: 12px; background: #e7eed8; }
.aloe-leaf { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 1; transition: opacity 800ms ease; }
.aloe-slice {
  position: absolute; left: 50%; bottom: -10%;
  width: 80%; height: auto; transform: translate(-50%, 0) scale(0.4) rotate(0deg);
  opacity: 0; transition: transform 900ms cubic-bezier(.2,.7,.2,1), opacity 700ms ease;
  border-radius: 12px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.15);
}
.aloe-bottle {
  position: absolute; left: 50%; bottom: 6%; transform: translateX(-50%) scale(0.7);
  width: 30%; max-width: 200px; opacity: 0; transition: opacity 800ms ease, transform 800ms ease;
}
.story.story-aloe.stage-1 .aloe-leaf { opacity: 1; }
.story.story-aloe.stage-2 .aloe-leaf { opacity: 0.25; }
.story.story-aloe.stage-2 .aloe-s1 { opacity: 1; transform: translate(-50%, -30%) scale(0.6); }
.story.story-aloe.stage-3 .aloe-leaf { opacity: 0.15; }
.story.story-aloe.stage-3 .aloe-s1 { opacity: 0.95; transform: translate(-50%, -42%) scale(0.6); }
.story.story-aloe.stage-3 .aloe-s2 { opacity: 1; transform: translate(-50%, -22%) scale(0.6); }
.story.story-aloe.stage-4 .aloe-leaf { opacity: 0.10; }
.story.story-aloe.stage-4 .aloe-s1 { opacity: 0.85; transform: translate(-50%, -55%) scale(0.55); }
.story.story-aloe.stage-4 .aloe-s2 { opacity: 0.92; transform: translate(-50%, -35%) scale(0.55); }
.story.story-aloe.stage-4 .aloe-s3 { opacity: 1; transform: translate(-50%, -15%) scale(0.55); }
.story.story-aloe.stage-5 .aloe-leaf { opacity: 0.05; }
.story.story-aloe.stage-5 .aloe-slice { opacity: 0; transform: translate(-50%, -150%) scale(0.3); }
.story.story-aloe.stage-5 .aloe-bottle { opacity: 1; transform: translateX(-50%) scale(1); }

/* SHELF FIT 2x2 */
.fit { padding: var(--s-10) 0; }
.fit2 { display: grid; grid-template-columns: 1fr; gap: var(--s-5); }
@media (min-width:768px) { .fit2 { grid-template-columns: 1fr 1fr; } }
.fit2-cell {
  background: var(--cream-light); border-radius: 10px; padding: var(--s-5);
  border-left: 4px solid var(--sky); display: flex; flex-direction: column; gap: var(--s-3);
}
.fit2-cell header { display: flex; justify-content: space-between; align-items: baseline; gap: var(--s-3); }
.fit2-cat { font-family: var(--font-sans); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sky-deep); }
.fit2-count { font-family: var(--font-display); font-size: 36px; font-weight: 500; color: var(--sky); letter-spacing: -0.02em; }
.fit2-skus { margin: 0; font-family: var(--font-display); font-size: 18px; color: var(--ink); line-height: 1.3; }
.fit2-note { margin: 0; font-size: 13px; color: var(--taupe); line-height: 1.45; }

/* 6 FACTS WALL */
.facts { padding: var(--s-10) 0; }
.fwall { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); }
@media (min-width:880px) { .fwall { grid-template-columns: repeat(3, 1fr); gap: var(--s-7); } }
.fw {
  padding: var(--s-5) 0 var(--s-3); border-top: 1px solid var(--cream-edge);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.fw-n {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(48px, 6vw, 84px); line-height: 1; letter-spacing: -0.04em;
  color: var(--sky-deep);
}
.fw-u { font-size: 0.4em; margin-left: 2px; letter-spacing: 0; font-weight: 500; color: var(--taupe); }
.fw-l { font-size: 13px; color: var(--body); line-height: 1.45; max-width: 36ch; }

/* TERMS TABLE */
.terms { padding: var(--s-10) 0; }
.ttable {
  width: 100%; border-collapse: collapse; background: var(--cream-light); border-radius: 10px; overflow: hidden;
}
.ttable th, .ttable td { padding: var(--s-4) var(--s-5); text-align: left; font-size: 14px; vertical-align: top; }
.ttable th {
  width: 30%; background: var(--cream); color: var(--sky-deep);
  font-family: var(--font-sans); font-weight: 700; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  border-bottom: 1px solid var(--cream-edge);
}
.ttable td { color: var(--body); border-bottom: 1px solid var(--cream-edge); }
.ttable tr:last-child th, .ttable tr:last-child td { border-bottom: 0; }

/* CONTACT */
.contact { padding: var(--s-10) 0; }
.contact-inner {
  display: grid; grid-template-columns: 1fr; gap: var(--s-7); align-items: start;
}
@media (min-width:980px) { .contact-inner { grid-template-columns: 1fr 1fr; gap: var(--s-10); } }
.contact-text { display: flex; flex-direction: column; gap: var(--s-4); }
.contact-text h2 { color: var(--cream-light); }
.contact-cards { display: grid; grid-template-columns: 1fr; gap: var(--s-3); }
@media (min-width:600px) { .contact-cards { grid-template-columns: 1fr 1fr; } }
.contact-card {
  padding: var(--s-5); background: rgba(251,247,238,0.06);
  border: 1px solid rgba(251,247,238,0.10); border-radius: 8px;
  display: flex; flex-direction: column; gap: 4px; transition: all 180ms;
}
.contact-card:not(.contact-card-static):hover {
  background: rgba(97,175,215,0.20); border-color: var(--sky); transform: translateY(-2px);
}
.contact-l { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(251,247,238,0.6); font-weight: 600; }
.contact-v { font-family: var(--font-display); font-size: 18px; color: var(--cream-light); margin: 4px 0 2px; }
.contact-sub { font-size: 12px; color: rgba(251,247,238,0.65); }

/* FOOTER */
.ftr {
  padding: var(--s-6) 0; background: var(--sky); color: rgba(255,255,255,0.92); font-size: 12px;
}
.ftr-inner {
  display: flex; flex-direction: column; gap: var(--s-2); align-items: flex-start;
}
@media (min-width:700px) { .ftr-inner { flex-direction: row; justify-content: space-between; align-items: center; } }
.ftr a { color: #ffffff; text-decoration: underline; text-underline-offset: 2px; }
.ftr a:hover { color: var(--cream); }

/* MODAL */
.modal { position: fixed; inset: 0; z-index: 100; display: flex; align-items: flex-start; justify-content: center; padding: 24px; overflow-y: auto; }
.modal[hidden] { display: none; }
.modal-bg { position: fixed; inset: 0; background: rgba(17,17,17,0.78); backdrop-filter: blur(4px); cursor: pointer; }
.modal-inner { position: relative; z-index: 2; max-width: 760px; width: 100%; background: var(--cream-light); border-radius: 14px; overflow: hidden; box-shadow: 0 50px 100px rgba(0,0,0,0.4); margin: 24px auto; }
.modal-close { position: absolute; top: 16px; right: 16px; z-index: 5; width: 40px; height: 40px; background: rgba(255,255,255,0.85); border: 0; border-radius: 50%; font-size: 24px; line-height: 1; color: var(--ink); }
.modal-close:hover { background: var(--sky); color: #ffffff; }
.modal-body { padding: var(--s-7); display: flex; flex-direction: column; gap: var(--s-4); }
.modal-name { margin: 0; font-family: var(--font-display); font-weight: 500; font-size: 40px; letter-spacing: -0.02em; }
.modal-section { padding-top: var(--s-3); border-top: 1px solid var(--cream-edge); }
.modal-section h4 { margin: 0 0 var(--s-2); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sky-deep); font-weight: 700; }
.modal-use { margin: 0; padding-left: var(--s-4); }
.modal-use li { margin-bottom: 4px; font-size: 14px; }
.modal-inci { font-size: 12px; line-height: 1.55; color: var(--taupe); }

section { scroll-margin-top: 80px; }

/* ─── LIFESTYLE BAND (catalogue trio) ──────────────────── */
.lifestyle-band { position: relative; background: #fff; border-top: 1px solid var(--cream-edge); border-bottom: 1px solid var(--cream-edge); }
.lifestyle-band img { display: block; width: 100%; height: auto; object-fit: cover; }
.lifestyle-cap { padding: var(--s-4) 0 var(--s-5); text-align: center; }
.lifestyle-line { margin: 4px 0 0; font-size: 14px; letter-spacing: 0.04em; color: var(--taupe); font-weight: 500; }
@media (min-width:900px) { .lifestyle-line { font-size: 16px; } }
