/* Pinch design-system foundation. Generated/assembled; self-hosted fonts (no CDN). */
/* ===== schibsted ===== */
/* latin-ext */
@font-face {
  font-family: 'Schibsted Grotesk';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url(/static/fonts/schibsted-1.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Schibsted Grotesk';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url(/static/fonts/schibsted-2.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ===== hanken ===== */
/* cyrillic-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(/static/fonts/hanken-1.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(/static/fonts/hanken-2.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(/static/fonts/hanken-3.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(/static/fonts/hanken-4.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ===== tiro ===== */
/* devanagari */
@font-face {
  font-family: 'Tiro Devanagari Hindi';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/tiro-1.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: 'Tiro Devanagari Hindi';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/tiro-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Tiro Devanagari Hindi';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/tiro-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ===== mukta ===== */
/* devanagari */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/mukta-1.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/mukta-2.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/static/fonts/mukta-3.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/static/fonts/mukta-4.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/static/fonts/mukta-5.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/static/fonts/mukta-6.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/static/fonts/mukta-7.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/static/fonts/mukta-8.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/static/fonts/mukta-9.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/static/fonts/mukta-10.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/static/fonts/mukta-11.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Mukta';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/static/fonts/mukta-12.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ════════════════════════════════════════════════════════════════════════
   Pinch design system — foundation tokens + primitives
   Source of truth: pinch-design-system-complete.html
   Namespaced `ds-*` so it can coexist with the legacy shared.css during the
   surface-by-surface migration. Nothing here hardcodes a colour at a call site.
   ════════════════════════════════════════════════════════════════════════ */

:root{
  /* ── palette (role) ─────────────────────────────────────────────────── */
  --ds-paper:#ECEAE3; --ds-paper-2:#E3E1D9;
  --ds-card:#FFFFFF; --ds-card-2:#F7F6F1; --ds-card-3:#EFEDE5;
  --ds-ink:#1A1C17; --ds-ink-2:#6E7066; --ds-ink-3:#A6A79C;
  --ds-line:#E2E0D7; --ds-line-2:#D3D1C7;
  --ds-pine:#2F5D4B; --ds-pine-deep:#244C3D; --ds-pine-soft:#E4EDE8;
  --ds-mint:#84B79E;
  --ds-honey:#C9A56B; --ds-honey-ink:#3A2C0E;   /* warm accent, used sparingly */
  --ds-amber:#EBA82F; --ds-amber-ink:#3A2A06;    /* retired as primary; kept for rare use */
  --ds-clay:#C5897C; --ds-clay-soft:#F4E6E1; --ds-clay-ink:#3A211C;
  --ds-slate:#2E3F4F; --ds-ink-on-dark:#FAFAF6;

  /* ── radius ─────────────────────────────────────────────────────────── */
  --ds-r-sm:12px; --ds-r-md:18px; --ds-r-lg:24px; --ds-r-xl:32px; --ds-r-pill:999px;

  /* ── shadow ─────────────────────────────────────────────────────────── */
  --ds-shadow-sm:0 1px 3px rgba(26,28,23,0.06),0 4px 10px rgba(26,28,23,0.04);
  --ds-shadow-card:0 2px 6px rgba(26,28,23,0.05),0 14px 34px rgba(26,28,23,0.07);
  --ds-shadow-pop:0 8px 18px rgba(26,28,23,0.10),0 28px 60px rgba(26,28,23,0.12);
  --ds-shadow-mesh:0 10px 30px rgba(26,28,23,0.10),0 30px 70px rgba(26,28,23,0.10);

  /* ── type ───────────────────────────────────────────────────────────── */
  --ds-font-display:'Schibsted Grotesk','Helvetica Neue',Arial,sans-serif;
  --ds-font-body:'Hanken Grotesk','Helvetica Neue',Arial,sans-serif;
  --ds-font-deva:'Tiro Devanagari Hindi',Georgia,serif;
  --ds-font-deva-ui:'Mukta','Hanken Grotesk',sans-serif;
  --ds-font-data:'DotGothic16',ui-monospace,Menlo,monospace; /* dot-matrix figures */

  /* ── spacing rhythm + layout ────────────────────────────────────────── */
  --ds-maxw:1140px;
  --ds-space-section:96px;   /* standard vertical section rhythm */
  --ds-space-pad:5%;         /* standard horizontal padding */

  /* ── glass: ONE blur across the whole product ───────────────────────── */
  --ds-glass:saturate(165%) blur(20px);
  --ds-glass-light:rgba(255,255,255,0.70);
  --ds-glass-dark:rgba(15,28,21,0.42);
}

/* ── base type helpers ─────────────────────────────────────────────────── */
.ds-wrap{max-width:var(--ds-maxw);margin:0 auto;padding:0 32px;}
.ds-disp{font-family:var(--ds-font-display);letter-spacing:-0.03em;line-height:1.04;font-weight:500;}
.ds-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--ds-ink-2);}
.ds-sec-title{font-family:var(--ds-font-display);font-weight:600;font-size:clamp(1.6rem,3vw,2.1rem);letter-spacing:-0.025em;}
.ds-sec-desc{color:var(--ds-ink-2);font-size:17px;max-width:62ch;line-height:1.6;}
.ds-link{color:var(--ds-pine);font-weight:600;display:inline-flex;align-items:center;gap:5px;cursor:pointer;}
.ds-link svg{width:16px;height:16px;}

/* Figure: DotGothic16 dot-matrix, pine. The dot font carries the "data" voice. */
.ds-fig{font-family:var(--ds-font-data);font-weight:400;letter-spacing:0;line-height:1;color:var(--ds-pine);}
.ds-fig--honey{color:var(--ds-honey);} .ds-fig--mint{color:var(--ds-mint);} .ds-fig--light{color:var(--ds-ink-on-dark);}

/* ── icons (inline Lucide, monochrome, currentColor) ───────────────────── */
.ds-i{display:inline-flex;align-items:center;justify-content:center;flex:none;}
.ds-i svg{width:100%;height:100%;display:block;stroke-width:1.75;}

/* ════════ BUTTONS ════════════════════════════════════════════════════════
   Solid variants sit on flat paper. Amber carries the primary action,
   pine the anchor action; the rest stay quiet. Glass variant is for use
   OVER an image/art only. */
.ds-btn{display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 24px;
  font-family:var(--ds-font-body);font-size:15px;font-weight:600;border-radius:var(--ds-r-pill);
  cursor:pointer;border:1px solid transparent;text-decoration:none;line-height:1;transition:transform .15s ease,background .15s ease,box-shadow .15s ease;}
.ds-btn svg{width:18px;height:18px;}
.ds-btn:active{transform:translateY(1px);}
/* primary = pine (the brand action); honey = the rare warm-accent CTA */
.ds-btn--primary{background:var(--ds-pine);color:#fff;box-shadow:var(--ds-shadow-sm);}
.ds-btn--primary:hover{background:var(--ds-pine-deep);box-shadow:var(--ds-shadow-pop);}
.ds-btn--pine{background:var(--ds-pine);color:#fff;}
.ds-btn--pine:hover{background:var(--ds-pine-deep);}
.ds-btn--honey{background:var(--ds-honey);color:var(--ds-honey-ink);box-shadow:var(--ds-shadow-sm);}
.ds-btn--honey:hover{box-shadow:var(--ds-shadow-pop);}
.ds-btn--soft{background:var(--ds-card-3);color:var(--ds-ink);}
.ds-btn--soft:hover{background:var(--ds-line);}
.ds-btn--outline{background:transparent;border-color:var(--ds-line-2);color:var(--ds-ink);}
.ds-btn--outline:hover{border-color:var(--ds-ink-2);}
.ds-btn--ghost{background:transparent;color:var(--ds-ink);}
.ds-btn--ghost:hover{background:var(--ds-card-2);}
/* glass button — frosted, for over art */
.ds-btn--glass{background:var(--ds-glass-light);backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);
  color:var(--ds-ink);box-shadow:var(--ds-shadow-pop),inset 0 0 0 1px rgba(255,255,255,0.6);}
.ds-btn--glass.ds-on-dark{background:var(--ds-glass-dark);color:#fff;border-color:rgba(255,255,255,0.4);}

/* ════════ PILLS / TAGS ════════════════════════════════════════════════ */
.ds-tag{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 14px;border-radius:var(--ds-r-pill);
  font-family:var(--ds-font-body);font-size:13px;font-weight:600;}
.ds-tag svg{width:14px;height:14px;}
.ds-tag--pine{background:var(--ds-pine-soft);color:var(--ds-pine);}
.ds-tag--honey{background:var(--ds-honey);color:var(--ds-honey-ink);}
.ds-tag--amber{background:var(--ds-amber);color:var(--ds-amber-ink);}
.ds-tag--clay{background:var(--ds-clay-soft);color:var(--ds-clay-ink);}
.ds-tag--dark{background:var(--ds-ink);color:#fff;}
/* frosted tag — for over art only */
.ds-tag--frost{background:var(--ds-glass-light);backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);
  color:var(--ds-ink);box-shadow:var(--ds-shadow-sm);}

/* ════════ CARD ════════════════════════════════════════════════════════ */
.ds-card{background:var(--ds-card);border-radius:var(--ds-r-lg);box-shadow:var(--ds-shadow-card);padding:28px;}

/* ════════ BOTTOM FLOATING GLASS NAV ════════════════════════════════════ */
/* top:auto/right:auto/max-width/border resets neutralise the legacy bare
   `nav{}` rule in shared.css (top:18px etc.) leaking into this <nav>. */
.ds-botnav{position:fixed;left:50%;bottom:22px;top:auto;right:auto;transform:translateX(-50%);z-index:1000;
  display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;border-radius:var(--ds-r-pill);
  max-width:none;border:none;white-space:nowrap;
  background:rgba(255,255,255,0.72);backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);
  box-shadow:var(--ds-shadow-pop),inset 0 0 0 1px rgba(255,255,255,0.6);
  padding-bottom:max(8px,env(safe-area-inset-bottom));}
.ds-botnav a{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:62px;height:50px;
  justify-content:center;border-radius:var(--ds-r-pill);color:var(--ds-ink-2);
  font-family:var(--ds-font-body);font-size:11px;font-weight:600;text-decoration:none;cursor:pointer;}
.ds-botnav a svg{width:21px;height:21px;}
.ds-botnav a.active{color:var(--ds-pine);}
.ds-botnav a:hover{color:var(--ds-ink);}
.ds-botnav .ds-nav-cta{background:var(--ds-pine);color:#fff;flex-direction:row;gap:7px;padding:0 18px;min-width:0;font-size:14px;}
.ds-botnav .ds-nav-cta svg{width:18px;height:18px;}

/* top minimal brand bar */
.ds-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;}
.ds-wordmark{font-family:var(--ds-font-display);font-weight:700;font-size:22px;letter-spacing:-0.03em;color:var(--ds-ink);}
.ds-wordmark .dot{color:var(--ds-clay);}

/* ════════ GLASS CONTROLS (over art) ════════════════════════════════════ */
.ds-g-play{width:64px;height:64px;border-radius:50%;background:var(--ds-glass-dark);
  backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);border:1px solid rgba(255,255,255,0.4);
  display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;}
.ds-g-play svg{width:26px;height:26px;margin-left:3px;}
.ds-g-chip{display:inline-flex;align-items:center;gap:6px;background:var(--ds-glass-light);
  backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);box-shadow:var(--ds-shadow-sm);
  color:var(--ds-ink);font-size:13px;font-weight:600;padding:8px 14px;border-radius:var(--ds-r-pill);}
.ds-g-caption{background:var(--ds-glass-dark);backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);
  color:#fff;font-size:13px;font-weight:600;padding:8px 14px;border-radius:var(--ds-r-md);}
.ds-g-card{background:var(--ds-glass-light);backdrop-filter:var(--ds-glass);-webkit-backdrop-filter:var(--ds-glass);
  border:1px solid rgba(255,255,255,0.5);border-radius:var(--ds-r-md);padding:16px 18px;box-shadow:var(--ds-shadow-pop);}
.ds-g-card h4{font-family:var(--ds-font-display);font-weight:600;font-size:15px;color:var(--ds-ink);}
.ds-g-card p{font-size:13px;color:var(--ds-ink-2);margin-top:4px;}

/* ════════ ART (striated landscape) ═════════════════════════════════════
   Atmosphere only — never a face in the same frame. drawArt() renders into
   the <canvas>; CSS provides the frame, scrim and full-bleed behaviour. */
.ds-art{position:relative;overflow:hidden;border-radius:var(--ds-r-lg);box-shadow:var(--ds-shadow-card);min-height:170px;}
.ds-art canvas{position:absolute;inset:0;width:100%;height:100%;display:block;}
.ds-art .ds-moodlabel{position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 8px rgba(0,0,0,.4);}
.ds-fullbleed{position:relative;width:100vw;margin-left:calc(50% - 50vw);overflow:hidden;}
.ds-fullbleed canvas{display:block;width:100%;height:100%;position:absolute;inset:0;}
.ds-fullbleed::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(15,28,21,0.6),transparent 62%);z-index:1;}
.ds-fb-tall{height:64vh;min-height:460px;} .ds-fb-band{height:300px;}
.ds-fb-in{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;
  max-width:var(--ds-maxw);margin:0 auto;padding:0 32px 48px;color:#fff;}

/* ════════ ACCESSIBILITY: reduced transparency / no backdrop-filter ══════
   Solid fallback so glass never drops below AA on unsupported / reduced UAs. */
@media (prefers-reduced-transparency: reduce){
  .ds-btn--glass,.ds-tag--frost,.ds-g-chip,.ds-g-card,.ds-botnav{background:rgba(255,255,255,0.96)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  .ds-btn--glass.ds-on-dark,.ds-g-play,.ds-g-caption{background:var(--ds-pine-deep)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .ds-btn--glass,.ds-tag--frost,.ds-g-chip,.ds-g-card,.ds-botnav{background:rgba(255,255,255,0.96);}
  .ds-btn--glass.ds-on-dark,.ds-g-play,.ds-g-caption{background:var(--ds-pine-deep);}
}

/* ════════════════════════════════════════════════════════════════════════
   DotGothic16 (Latin slice) — dot-matrix figures
   ════════════════════════════════════════════════════════════════════════ */
@font-face{
  font-family:'DotGothic16';font-style:normal;font-weight:400;font-display:swap;
  src:url(/static/fonts/dotgothic-latin.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+2000-206F,U+2122,U+2191,U+2193,U+2212,U+2215;
}

/* ════════════════════════════════════════════════════════════════════════
   ART ENGINE overlays (canvas striated landscape; drawArt in ds-art.ts)
   .ds-art / .ds-fullbleed frames already defined above.
   ════════════════════════════════════════════════════════════════════════ */
.ds-art--text::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(20,28,23,0.58),transparent 62%);}
.ds-art-in{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:30px;color:#fff;}
.ds-art-in.top{justify-content:flex-start;}

/* ════════ LAYOUT FAMILY 01 — asymmetric editorial split ════════════════ */
.ds-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.ds-split.flip .ds-s-art{order:2;}
.ds-s-art{min-height:380px;}
.ds-split h3{font-family:var(--ds-font-display);font-weight:600;font-size:clamp(1.7rem,3vw,2.3rem);letter-spacing:-0.025em;max-width:18ch;line-height:1.1;color:var(--ds-ink);}
.ds-split p{margin-top:16px;color:var(--ds-ink-2);font-size:17px;max-width:44ch;line-height:1.6;}
.ds-split .ds-link{margin-top:20px;}

/* ════════ LAYOUT FAMILY 03 — index list (airy, anti card-overload) ═════ */
.ds-index{border-top:1px solid var(--ds-line-2);}
.ds-idx-row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:24px;padding:26px 8px;border-bottom:1px solid var(--ds-line);cursor:pointer;transition:background .2s,padding .2s,box-shadow .2s;text-decoration:none;color:inherit;}
.ds-idx-row:hover{background:var(--ds-card);padding-left:18px;padding-right:18px;border-radius:var(--ds-r-md);box-shadow:var(--ds-shadow-sm);}
.ds-idx-no{font-family:var(--ds-font-data);font-size:22px;color:var(--ds-pine);}
.ds-idx-main h4{font-family:var(--ds-font-display);font-weight:600;font-size:21px;letter-spacing:-0.01em;color:var(--ds-ink);}
.ds-idx-main p{color:var(--ds-ink-2);font-size:15px;margin-top:4px;max-width:62ch;line-height:1.5;}
.ds-idx-arr{color:var(--ds-ink-3);transition:transform .2s,color .2s;display:inline-flex;}
.ds-idx-arr svg{width:22px;height:22px;}
.ds-idx-row:hover .ds-idx-arr{color:var(--ds-pine);transform:translateX(4px);}

/* ════════ LAYOUT FAMILY 04 — horizontal rail ══════════════════════════ */
.ds-rail{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 4px 18px;margin:0 -4px;-webkit-overflow-scrolling:touch;}
.ds-rail::-webkit-scrollbar{height:8px;} .ds-rail::-webkit-scrollbar-thumb{background:var(--ds-line-2);border-radius:99px;}
.ds-rail-item{flex:0 0 300px;scroll-snap-align:start;background:var(--ds-card);border-radius:var(--ds-r-lg);overflow:hidden;box-shadow:var(--ds-shadow-card);}
.ds-rail-item .ds-art{height:150px;border-radius:0;box-shadow:none;min-height:0;}
.ds-ri-body{padding:20px 22px 24px;}
.ds-rail-item h4{font-family:var(--ds-font-display);font-weight:600;font-size:18px;margin-bottom:6px;color:var(--ds-ink);}
.ds-rail-item p{color:var(--ds-ink-2);font-size:14.5px;line-height:1.5;}
.ds-rail-hint{font-size:13px;color:var(--ds-ink-3);margin-top:6px;display:flex;align-items:center;gap:6px;}
.ds-rail-hint svg{width:16px;height:16px;}

/* ════════ LAYOUT FAMILY 05 — big-type manifesto ═══════════════════════ */
.ds-manifesto{padding:40px 0;}
.ds-manifesto p{font-family:var(--ds-font-display);font-weight:500;font-size:clamp(2rem,5vw,3.6rem);letter-spacing:-0.035em;line-height:1.08;max-width:20ch;color:var(--ds-ink);}
.ds-manifesto .g{color:var(--ds-pine);} .ds-manifesto .c{color:var(--ds-clay);} .ds-manifesto .h{color:var(--ds-honey);}
.ds-manifesto .sub{font-family:var(--ds-font-body);font-weight:400;font-size:18px;color:var(--ds-ink-2);max-width:48ch;margin-top:24px;letter-spacing:0;line-height:1.6;}

/* ════════ LAYOUT FAMILY 07 — layered composition ══════════════════════ */
.ds-layer{position:relative;}
.ds-layer .ds-art{min-height:420px;}
.ds-layer .ds-float{position:absolute;left:34px;bottom:-28px;background:var(--ds-card);border-radius:var(--ds-r-lg);box-shadow:var(--ds-shadow-pop);padding:22px 26px;display:flex;align-items:center;gap:22px;}
.ds-layer .ds-float .n{font-family:var(--ds-font-data);font-size:40px;color:var(--ds-pine);line-height:.9;}
.ds-layer .ds-float .l{font-size:14px;color:var(--ds-ink-2);max-width:18ch;}
.ds-layer-pad{height:42px;}

@media(max-width:820px){
  .ds-split,.ds-split.flip{grid-template-columns:1fr;gap:26px;} .ds-split.flip .ds-s-art{order:0;}
  .ds-layer .ds-float{left:16px;right:16px;bottom:-20px;}
}
@media(max-width:560px){
  .ds-idx-row{grid-template-columns:40px 1fr auto;gap:14px;padding:20px 4px;} .ds-idx-main h4{font-size:18px;}
}
