/* =========================================================================
   Juris Advisory — Services design system  ·  v2 "editorial + colour"
   Spacing/type from the Transparency Index landing (reference).
   Card system: soft-neobrutalist colour blocks (Freshfields-energy),
   colour-coded by priority so the hierarchy is unmissable.
   Locked palette only; tints derived harmonically from it.
   No mono (labels = Fira Sans). Near-square CTAs + hairlines retained.
   ========================================================================= */

:root {
  /* ---- Locked palette ---- */
  --white:     #FFFFFF;
  --cream:     #F7F5F0;
  --cream2:    #EDE9E0;
  --navy:      #1B2B6B;
  --deep-navy: #0F1A45;
  --orange:    #F5921E;
  --ink:       #111118;

  --ink-80: rgba(17,17,24,0.82);
  --ink-60: rgba(17,17,24,0.62);
  --ink-40: rgba(17,17,24,0.42);
  --ink-10: rgba(17,17,24,0.10);
  --rule:   rgba(17,17,24,0.13);

  --cream-80: rgba(247,245,240,0.82);
  --cream-55: rgba(247,245,240,0.55);
  --cream-line: rgba(247,245,240,0.16);

  /* ---- Harmonic card tints (derived from navy/orange/cream) ---- */
  --sky:      #E5EAF7;   --sky-bd:   #C7D2EE;  --sky-ink:  #243a86;
  --sage:     #E7EDE2;   --sage-bd:  #D1DEC8;  --sage-ink: #2c3b29;
  --peach:    #FBE9D4;   --peach-bd: #F2D2A8;  --peach-ink:#5c3a09;
  --clay:     #EFE7DC;   --clay-bd:  #DDD0BD;
  --lilac:    #ECE7F4;   --lilac-bd: #D9CFEA;  --lilac-ink:#3b3160;

  /* ---- Type ---- */
  --display: "Plus Jakarta Sans", system-ui, sans-serif;
  --body:    "DM Sans", system-ui, sans-serif;
  --label:   "Fira Sans", system-ui, sans-serif;

  /* ---- Geometry ---- */
  --radius-btn: 3px;        /* near-square CTA */
  --radius-card: 18px;      /* soft block */
  --radius-soft: 12px;
  --gutter: clamp(1.25rem, 4.5vw, 3.5rem);
  --maxw: 1280px;
}

/* ----------------------------------------------------------------- reset */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--white);
  color: var(--ink);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.62;
  font-feature-settings: "kern" 1, "liga" 1;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
::selection { background: var(--orange); color: var(--ink); }

.tnum { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1, "lnum" 1; }

/* ----------------------------------------------------------------- layout */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(4.5rem, 9vw, 8.5rem); }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.bleed { width: 100%; }

/* ----------------------------------------------------------------- type */
.kicker {
  font-family: var(--label);
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--orange);
  display: inline-flex;
  align-items: center;
  gap: 0.85em;
}
.kicker::before { content: ""; width: 1.7rem; height: 1.5px; background: currentColor; }
.kicker.no-rule::before { display: none; }
.kicker--ink { color: var(--ink-40); }

.display {
  font-family: var(--display);
  font-weight: 700;
  line-height: 0.99;
  letter-spacing: -0.04em;
  margin: 0;
  text-wrap: pretty;
}
.display-xl { font-size: clamp(2.9rem, 7vw, 5.5rem); }
.display-l  { font-size: clamp(2.1rem, 4.4vw, 3.5rem); }
.display-m  { font-size: clamp(1.65rem, 3vw, 2.4rem); }

.lede {
  font-size: clamp(1.12rem, 1.55vw, 1.4rem);
  line-height: 1.5;
  color: var(--ink-80);
  max-width: 44ch;
  text-wrap: pretty;
}
.muted { color: var(--ink-60); }
em { font-style: italic; }

/* generous editorial section head: label/headline left, support right */
.shead { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr); gap: clamp(1.5rem, 6vw, 6rem); align-items: end; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.shead__r { color: var(--ink-60); font-size: 1.05rem; line-height: 1.55; max-width: 48ch; }
@media (max-width: 860px) { .shead { grid-template-columns: 1fr; gap: 1.4rem; align-items: start; } }

.eyebrow-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.6rem; }

/* ----------------------------------------------------------------- split hero (calling card) */
.hero-split { display: grid; grid-template-columns: minmax(0,1.14fr) minmax(0,0.86fr); align-items: stretch; min-height: clamp(520px, 74vh, 780px); border-bottom: 1px solid var(--rule); }
.hero-split__text { display: flex; flex-direction: column; justify-content: center; padding-block: clamp(2.5rem,5vw,4rem); padding-right: clamp(1.5rem,4vw,3.5rem); padding-left: max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter))); }
.hero-split__h { font-family: var(--display); font-weight: 700; line-height: 0.99; letter-spacing: -0.04em; margin: 1.4rem 0 0; font-size: clamp(2.5rem, 4.6vw, 4.4rem); text-wrap: pretty; }
.hero-split__cta { display: flex; gap: 0.7rem; flex-wrap: wrap; margin-top: clamp(1.8rem,3vw,2.4rem); }
.hero-split__media { position: relative; isolation: isolate; overflow: hidden; background: var(--deep-navy); }
.hero-split__media > image-slot,
.hero-split__media > img { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; object-fit: cover; display: block; }
.hero-badge { position: absolute; z-index: 3; left: clamp(1.5rem,2.6vw,2.6rem); right: clamp(1.5rem,2.6vw,2.6rem); bottom: clamp(1.5rem,2.6vw,2.6rem); display: flex; align-items: baseline; gap: 1rem; color: var(--cream); pointer-events: none; }
.hero-badge__n { font-family: var(--display); font-weight: 700; font-size: clamp(3rem,5vw,4.6rem); letter-spacing: -0.04em; line-height: 0.85; }
.hero-badge__l { font-family: var(--label); font-size: 0.82rem; letter-spacing: 0.02em; color: var(--cream-80); line-height: 1.45; max-width: 24ch; }
.hero-badge__l b { color: var(--cream); font-weight: 600; }
@media (max-width: 980px) {
  .hero-split { grid-template-columns: 1fr; }
  .hero-split__text { padding-inline: var(--gutter); padding-block: clamp(2.4rem,7vw,3.5rem); }
  .hero-split__media { min-height: clamp(300px, 56vw, 440px); order: 2; }
}

/* ----------------------------------------------------------------- buttons */
.btn {
  --bg: var(--navy); --fg: var(--cream); --bd: var(--navy);
  display: inline-flex; align-items: center; gap: 0.6em;
  font-family: var(--label); font-weight: 500; font-size: 0.95rem; letter-spacing: 0.01em;
  padding: 1rem 1.5rem; border-radius: var(--radius-btn);
  background: var(--bg); color: var(--fg); border: 1.5px solid var(--bd);
  transition: transform .15s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn .arr { transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }
.btn:hover .arr.down { transform: translateY(3px); }
.btn--navy { --bg: var(--navy); --fg: var(--cream); --bd: var(--navy); }
.btn--navy:hover { --bg: var(--deep-navy); --bd: var(--deep-navy); }
.btn--orange { --bg: var(--orange); --fg: var(--ink); --bd: var(--orange); }
.btn--orange:hover { --bg: #e7860f; --bd: #e7860f; }
.btn--ghost { --bg: transparent; --fg: var(--ink); --bd: var(--rule); }
.btn--ghost:hover { --bg: var(--ink); --fg: var(--cream); --bd: var(--ink); }
.btn--on-navy-ghost { --bg: transparent; --fg: var(--cream); --bd: var(--cream-line); }
.btn--on-navy-ghost:hover { --bg: var(--cream); --fg: var(--ink); --bd: var(--cream); }
.btn--sm { padding: 0.62rem 1rem; font-size: 0.82rem; }

/* editorial underline link (from reference) */
.btn-line {
  font-family: var(--label); font-weight: 500; font-size: 0.95rem;
  display: inline-flex; align-items: center; gap: 0.6em;
  color: var(--ink); border-bottom: 1.5px solid var(--ink); padding-bottom: 6px;
  transition: gap .2s, color .2s, border-color .2s;
}
.btn-line:hover { gap: 0.9em; color: var(--navy); border-color: var(--orange); }
.btn-line .arr { transition: transform .2s; }
.btn-line:hover .arr { transform: translateX(3px); }

.textlink {
  font-family: var(--label); font-weight: 500; font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 0.5em; color: var(--ink);
  border-bottom: 1px solid var(--rule); padding-bottom: 3px;
  transition: gap .2s, border-color .2s, color .2s;
}
.textlink:hover { gap: 0.85em; border-color: var(--orange); color: var(--navy); }
.textlink .arr { transition: transform .2s; }
.textlink:hover .arr { transform: translateX(3px); }

.hr { height: 1px; background: var(--rule); border: 0; margin: 0; }

/* ----------------------------------------------------------------- navbar */
.nav { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--white) 86%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid var(--rule); }
.nav__in { display: flex; align-items: center; gap: 1.4rem; height: 72px; }
.brand { display: flex; align-items: baseline; gap: 0.55rem; }
.brand__mark { font-family: var(--display); font-weight: 800; font-size: 1.35rem; letter-spacing: -0.03em; color: var(--ink); }
.brand__mark b { color: var(--orange); }
.brand__tag { font-family: var(--label); font-size: 0.62rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-40); }
.nav__links { display: flex; gap: 1.15rem; margin-left: auto; }
.nav__links a { font-family: var(--label); font-size: 0.88rem; color: var(--ink-80); padding: 0.3rem 0; border-bottom: 1.5px solid transparent; white-space: nowrap; transition: color .2s, border-color .2s; }
.nav__links a:hover { color: var(--ink); }
.nav__links a[aria-current] { color: var(--ink); border-color: var(--orange); }
.nav__m-panel a[aria-current="page"] { color: var(--ink); font-weight: 600; background: var(--peach); }
.lang { display: flex; align-items: center; font-family: var(--label); font-size: 0.78rem; border: 1px solid var(--rule); border-radius: var(--radius-btn); overflow: hidden; }
.lang a { padding: 0.34rem 0.55rem; color: var(--ink-60); transition: background .2s, color .2s; }
.lang a[aria-current] { background: var(--ink); color: var(--cream); }
.lang a:not([aria-current]):hover { background: var(--ink-10); color: var(--ink); }
.nav__cta { margin-left: 0.4rem; }
@media (max-width: 980px) { .nav__links { display: none; } }

/* ----------------------------------------------------------------- proof bar */
.proofbar { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.5rem, 4vw, 3.5rem); }
.proofbar__item { position: relative; padding-left: 1.4rem; }
.proofbar__item::before { content: ""; position: absolute; left: 0; top: 0.35rem; bottom: 0.35rem; width: 2px; background: var(--orange); border-radius: 2px; }
.proofbar__n { font-family: var(--display); font-weight: 700; font-size: clamp(2.1rem, 3.4vw, 3rem); letter-spacing: -0.03em; line-height: 1; color: var(--navy); }
.proofbar__n .u { color: var(--orange); }
.proofbar__l { margin-top: 0.55rem; font-size: 0.9rem; line-height: 1.4; color: var(--ink-60); }
@media (max-width: 720px) { .proofbar { grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; } }

/* ----------------------------------------------------------------- running-line chips (marquee) */
.runline { position: relative; overflow: hidden; min-width: 0; -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent); mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent); }
.runline__track { display: inline-flex; align-items: center; gap: 0.55rem; white-space: nowrap; padding-block: 0.15rem; animation: runline 40s linear infinite; will-change: transform; }
.runline:hover .runline__track { animation-play-state: paused; }
.chip { font-family: var(--label); font-size: 0.78rem; letter-spacing: 0.02em; color: var(--ink-80); padding: 0.34rem 0.75rem; border: 1px solid var(--rule); border-radius: 999px; background: var(--white); }
.chip .dot { color: var(--orange); margin-right: 0.2rem; }
@keyframes runline { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .runline__track { animation: none; flex-wrap: wrap; white-space: normal; } .runline { -webkit-mask-image: none; mask-image: none; } }

/* ----------------------------------------------------------------- PILLAR GRID — colour blocks */
.pillars { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(1rem, 1.8vw, 1.5rem); }

.pcard {
  --c-bg: var(--white); --c-fg: var(--ink); --c-bd: var(--rule);
  --c-mut: var(--ink-60); --c-acc: var(--orange); --c-sh: rgba(17,17,24,0.13);
  position: relative; display: flex; flex-direction: column;
  background: var(--c-bg); color: var(--c-fg);
  border: 1.5px solid var(--c-bd); border-radius: var(--radius-card);
  padding: clamp(1.6rem, 2.4vw, 2.3rem);
  box-shadow: 5px 6px 0 -1px var(--c-sh);
  transition: transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s;
  overflow: hidden;
}
.pcard:hover { transform: translate(-2px, -3px); box-shadow: 11px 14px 0 -1px var(--c-sh); }
.pcard__top { display: flex; align-items: center; gap: 0.8rem; padding-right: 3rem; }
.pcard__idx { font-family: var(--label); font-weight: 500; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-mut); white-space: nowrap; }
.pcard__tier { font-family: var(--label); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-acc); border: 1px solid currentColor; border-radius: 999px; padding: 0.2rem 0.6rem; white-space: nowrap; }
.pcard__name { font-family: var(--display); font-weight: 700; letter-spacing: -0.03em; line-height: 1.0; margin: 1.1rem 0 0; }
.pcard__vp { color: var(--c-fg); opacity: 0.86; margin: 0.85rem 0 0; font-size: 0.99rem; line-height: 1.5; max-width: 42ch; }
.pcard__foot { margin-top: auto; padding-top: 1.6rem; }
.pcard__arrow { position: absolute; top: clamp(1.4rem,2.2vw,2rem); right: clamp(1.4rem,2.2vw,2rem); width: 2.4rem; height: 2.4rem; border-radius: 999px; border: 1.5px solid var(--c-bd); display: grid; place-items: center; color: var(--c-fg); font-size: 1.05rem; transition: background .2s, color .2s, border-color .2s, transform .25s; }
.pcard:hover .pcard__arrow { background: var(--c-acc); color: var(--c-bg); border-color: var(--c-acc); transform: rotate(45deg); }

/* chips adapt to dark card backgrounds */
.pcard__foot .chip { background: color-mix(in oklab, var(--c-bg) 78%, transparent); border-color: color-mix(in oklab, var(--c-fg) 22%, transparent); color: var(--c-fg); }
.pcard__foot .chip .dot { color: var(--c-acc); }

/* ---- colour variants ---- */
.pcard--navy { --c-bg: var(--navy); --c-fg: var(--cream); --c-bd: var(--navy); --c-mut: var(--cream-55); --c-acc: var(--orange); --c-sh: var(--deep-navy); }
.pcard--orange { --c-bg: var(--orange); --c-fg: var(--ink); --c-bd: var(--orange); --c-mut: rgba(17,17,24,0.6); --c-acc: var(--navy); --c-sh: #c9740b; }
.pcard--sky { --c-bg: var(--sky); --c-fg: var(--sky-ink); --c-bd: var(--sky-bd); --c-mut: rgba(36,58,134,0.6); --c-acc: var(--navy); --c-sh: var(--sky-bd); }
.pcard--sage { --c-bg: var(--sage); --c-fg: var(--sage-ink); --c-bd: var(--sage-bd); --c-mut: rgba(44,59,41,0.6); --c-acc: #3f7a4a; --c-sh: var(--sage-bd); }
.pcard--cream { --c-bg: var(--cream2); --c-fg: var(--ink); --c-bd: var(--clay-bd); --c-mut: var(--ink-60); --c-acc: var(--orange); --c-sh: var(--clay-bd); }

/* ---- sizes (priority weight) ---- */
.pcard--lg { grid-column: span 7; min-height: 360px; padding: clamp(2rem, 3vw, 2.8rem); }
.pcard--lg .pcard__name { font-size: clamp(2.1rem, 3.4vw, 3rem); }
.pcard--md { grid-column: span 5; }
.pcard--md .pcard__name { font-size: clamp(1.5rem, 2.3vw, 2rem); }
.pcard--wide { grid-column: span 12; }
.pcard--wide .pcard__inner { display: grid; grid-template-columns: minmax(0,1.1fr) minmax(0,1fr); gap: clamp(1.5rem,4vw,3rem); align-items: center; }
.pcard--wide .pcard__name { font-size: clamp(1.5rem, 2.3vw, 2.1rem); }

@media (max-width: 960px) {
  .pcard--lg, .pcard--md, .pcard--wide { grid-column: span 12; }
  .pcard--wide .pcard__inner { grid-template-columns: 1fr; }
}

/* ---- extras: colourful blocks (quieter than the five via size) ---- */
.extras { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem,1.8vw,1.5rem); margin-top: clamp(1rem,1.8vw,1.5rem); }
.xcard {
  --c-bg: var(--cream2); --c-fg: var(--ink); --c-bd: var(--clay-bd); --c-acc: var(--orange); --c-sh: var(--clay-bd);
  position: relative; display: flex; flex-direction: column;
  background: var(--c-bg); color: var(--c-fg);
  border: 1.5px solid var(--c-bd); border-radius: var(--radius-card);
  padding: clamp(1.6rem,2.4vw,2.1rem);
  box-shadow: 5px 6px 0 -1px var(--c-sh);
  transition: transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s;
}
.xcard:hover { transform: translate(-2px,-3px); box-shadow: 11px 14px 0 -1px var(--c-sh); }
.xcard--peach { --c-bg: var(--peach); --c-fg: var(--peach-ink); --c-bd: var(--peach-bd); --c-acc: #b9690a; --c-sh: var(--peach-bd); }
.xcard--lilac { --c-bg: var(--lilac); --c-fg: var(--lilac-ink); --c-bd: var(--lilac-bd); --c-acc: #6b4fa3; --c-sh: var(--lilac-bd); }
.xcard .kicker { color: var(--c-acc); }
.xcard__name { font-family: var(--display); font-weight: 700; font-size: clamp(1.4rem,2vw,1.7rem); letter-spacing: -0.02em; margin: 0.7rem 0 0; }
.xcard__vp { color: var(--c-fg); opacity: 0.82; font-size: 0.96rem; margin: 0.6rem 0 0; max-width: 46ch; line-height: 1.5; }
.xcard__list { list-style: none; margin: 1.3rem 0 0; padding: 0; columns: 2; column-gap: 1.4rem; }
.xcard__list li { font-size: 0.85rem; color: var(--c-fg); opacity: 0.82; padding: 0.3rem 0; break-inside: avoid; }
.xcard__list li::before { content: "\00b7"; color: var(--c-acc); margin-right: 0.5rem; font-weight: 700; }
@media (max-width: 720px) { .extras { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- router */
.router { border: 1.5px solid var(--rule); border-radius: var(--radius-card); background: var(--cream); overflow: hidden; }
.router__tabs { display: flex; border-bottom: 1px solid var(--rule); }
.router__tab { flex: 0 0 auto; background: transparent; border: 0; border-right: 1px solid var(--rule); font-family: var(--label); font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-60); padding: 1rem 1.7rem; position: relative; }
.router__tab[aria-selected="true"] { color: var(--ink); background: var(--white); }
.router__tab[aria-selected="true"]::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--orange); }
.router__panel { padding: 1.5rem 1.7rem; }
.router__panel[hidden] { display: none; }
.router__grid { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.router__link { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--body); font-size: 0.92rem; padding: 0.6rem 1rem; border: 1.5px solid var(--rule); border-radius: 999px; background: var(--white); color: var(--ink-80); transition: border-color .2s, color .2s, background .2s; }
.router__link:hover { border-color: var(--navy); color: var(--navy); }
.router__link .n { font-family: var(--label); font-size: 0.7rem; color: var(--ink-40); }

/* ----------------------------------------------------------------- umbrella strip (image-backed) */
.umbrella { position: relative; isolation: isolate; overflow: hidden; background: var(--deep-navy); color: var(--cream); min-height: clamp(220px, 28vw, 340px); }
.umbrella > image-slot,
.umbrella > img { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; object-fit: cover; display: block; }
.umbrella__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(110deg, rgba(15,26,69,0.92) 0%, rgba(15,26,69,0.78) 48%, rgba(15,26,69,0.52) 100%); }
.umbrella__in { position: relative; z-index: 2; display: grid; grid-template-columns: auto 1fr; gap: clamp(1.2rem, 3vw, 2.8rem); align-items: center; padding-block: clamp(2.2rem, 4vw, 3.2rem); }
.umbrella__h { font-family: var(--display); font-weight: 700; letter-spacing: -0.03em; line-height: 0.98; font-size: clamp(1.55rem, 2.6vw, 2.2rem); margin: 0; }
.umbrella__h .o { color: var(--orange); }
.umbrella__p { color: var(--cream-80); font-size: 1rem; line-height: 1.5; margin: 0; max-width: 58ch; }
.umbrella__p b { color: var(--cream); font-weight: 600; }
@media (max-width: 820px) { .umbrella__in { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- full-bleed photo band */
.photoband { position: relative; isolation: isolate; overflow: hidden; background: var(--deep-navy); min-height: clamp(320px, 44vw, 540px); display: flex; align-items: flex-end; }
.photoband > image-slot,
.photoband > img { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; object-fit: cover; display: block; }
.photoband__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none; background:
  linear-gradient(180deg, rgba(15,26,69,0.30) 0%, rgba(15,26,69,0.05) 32%, rgba(15,26,69,0.55) 74%, rgba(15,26,69,0.88) 100%); }
.photoband__in { position: relative; z-index: 2; width: 100%; color: var(--cream); padding-block: clamp(2.4rem, 5vw, 4.2rem); pointer-events: none; }
.photoband__in a { pointer-events: auto; }
.photoband__cap { font-family: var(--label); font-weight: 600; font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream); display: inline-flex; align-items: center; gap: 0.8em; }
.photoband__cap::before { content: ""; width: 1.8rem; height: 1.5px; background: var(--orange); }
.photoband__h { font-family: var(--display); font-weight: 700; letter-spacing: -0.03em; line-height: 1.0; font-size: clamp(2rem, 4.4vw, 3.6rem); margin: 1.1rem 0 0; max-width: 17ch; text-wrap: pretty; }
.photoband__h .o { color: var(--orange); }
.photoband__p { color: var(--cream-80); margin: 1.1rem 0 0; max-width: 50ch; font-size: 1.06rem; line-height: 1.55; }
.photoband--slim { min-height: clamp(240px, 30vw, 380px); }

/* duotone treatment — navy shadows + warm highlights (“orient meets tech”) */
.photoband--duo > image-slot,
.photoband--duo > img { filter: grayscale(1) contrast(1.05) brightness(1.03); object-fit: cover; }
.photoband--duo .photoband__tone { position: absolute; inset: 0; z-index: 1; pointer-events: none; background: var(--deep-navy); mix-blend-mode: multiply; }
.photoband--duo .photoband__tone--warm { background: linear-gradient(120deg, rgba(245,146,30,0.45) 0%, rgba(245,146,30,0.05) 55%, transparent 100%); mix-blend-mode: screen; }
/* empty-slot hint sits centred so the band reads as an image zone before a photo is dropped */
.photoband > image-slot::part(empty) { color: var(--cream-55); }

/* ----------------------------------------------------------------- how-we-work loop */
.loop { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem,1.8vw,1.5rem); }
.loop__step { background: var(--white); border: 1.5px solid var(--rule); border-radius: var(--radius-card); padding: 1.8rem 1.6rem; transition: border-color .2s, transform .2s; }
.loop__step:hover { border-color: var(--ink-40); transform: translateY(-3px); }
.loop__n { font-family: var(--display); font-weight: 700; font-size: 2.6rem; color: var(--cream2); line-height: 1; letter-spacing: -0.03em; transition: color .2s; }
.loop__step:hover .loop__n { color: var(--orange); }
.loop__t { font-family: var(--display); font-weight: 600; font-size: 1.18rem; letter-spacing: -0.02em; margin: 0.7rem 0 0.45rem; }
.loop__d { font-size: 0.93rem; color: var(--ink-60); margin: 0; line-height: 1.45; }
@media (max-width: 820px) { .loop { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .loop { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- FAQ accordion */
.faq { border-top: 1px solid var(--rule); }
.faq__item { border-bottom: 1px solid var(--rule); }
.faq__q { width: 100%; text-align: left; background: transparent; border: 0; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.5rem 0; font-family: var(--display); font-weight: 600; font-size: clamp(1.1rem, 1.6vw, 1.35rem); letter-spacing: -0.02em; color: var(--ink); }
.faq__q:hover { color: var(--navy); }
.faq__sign { flex: 0 0 auto; width: 1.5rem; height: 1.5rem; position: relative; }
.faq__sign::before, .faq__sign::after { content: ""; position: absolute; background: var(--orange); transition: transform .25s ease; }
.faq__sign::before { left: 0; right: 0; top: 50%; height: 2px; transform: translateY(-50%); }
.faq__sign::after { top: 0; bottom: 0; left: 50%; width: 2px; transform: translateX(-50%); }
.faq__item.open .faq__sign::after { transform: translateX(-50%) scaleY(0); }
.faq__a { overflow: hidden; height: 0; transition: height .28s ease; }
.faq__a-in { padding: 0 0 1.5rem; color: var(--ink-80); max-width: 70ch; line-height: 1.6; }
.verify { color: #a8600a; background: var(--peach); font-family: var(--label); font-size: 0.66rem; font-weight: 600; letter-spacing: 0.08em; border-radius: 999px; padding: 0.1rem 0.5rem; white-space: nowrap; vertical-align: middle; }

/* ----------------------------------------------------------------- nested-sphere proof card */
.nest { background: var(--deep-navy); color: var(--cream); border-radius: var(--radius-card); padding: clamp(1.8rem, 3.2vw, 3rem); position: relative; overflow: hidden; }
.nest__head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 1.8rem; }
.nest__big { font-family: var(--display); font-weight: 700; letter-spacing: -0.04em; line-height: 0.88; font-size: clamp(3.2rem, 8vw, 6rem); }
.nest__big .u { color: var(--orange); }
.nest__cap { font-family: var(--label); font-size: 0.78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cream-55); max-width: 24ch; text-align: right; line-height: 1.5; }
.nest__primary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.8rem; margin-bottom: 0.8rem; }
.nest__pcard { background: color-mix(in oklab, var(--orange) 16%, transparent); border: 1px solid color-mix(in oklab, var(--orange) 40%, transparent); border-radius: var(--radius-soft); padding: 1.2rem 1.2rem; }
.nest__pcard .lab { font-family: var(--label); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--orange); }
.nest__pcard .val { font-family: var(--display); font-weight: 600; font-size: 1.22rem; letter-spacing: -0.02em; margin-top: 0.4rem; }
.nest__mini { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.8rem; }
.nest__mcard { background: transparent; border: 1px solid var(--cream-line); border-radius: var(--radius-soft); padding: 1rem 1.1rem; }
.nest__mcard .n { font-family: var(--display); font-weight: 700; font-size: 1.6rem; letter-spacing: -0.03em; }
.nest__mcard .l { font-size: 0.78rem; color: var(--cream-80); margin-top: 0.25rem; line-height: 1.25; }
@media (max-width: 720px) { .nest__primary, .nest__mini { grid-template-columns: 1fr 1fr; } }

/* ----------------------------------------------------------------- definitions grid (pillar pages) */
.defs { border-top: 1px solid var(--rule); }
.def { display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 2fr); gap: clamp(1.4rem, 5vw, 4rem); padding: clamp(1.7rem, 3vw, 2.5rem) 0; border-bottom: 1px solid var(--rule); align-items: start; }
.def__term { font-family: var(--display); font-weight: 700; font-size: clamp(1.3rem, 2vw, 1.75rem); letter-spacing: -0.025em; line-height: 1.05; margin: 0; }
.def__term .sub { display: block; font-family: var(--label); font-weight: 500; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--orange); margin-bottom: 0.7rem; }
.def__body { margin: 0; color: var(--ink-80); font-size: 1.04rem; line-height: 1.62; max-width: 64ch; }
.def__body strong { color: var(--ink); font-weight: 600; }
.def__body + .def__body { margin-top: 0.8rem; }
.def__note { margin-top: 1rem; padding-left: 1.05rem; border-left: 2px solid var(--orange); font-size: 0.98rem; line-height: 1.55; color: var(--ink); }
.def__note b { font-weight: 600; }
@media (max-width: 760px) { .def { grid-template-columns: 1fr; gap: 0.7rem; } }

/* ----------------------------------------------------------------- regulator split (licensing scope) */
.regs { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 1.8vw, 1.5rem); }
.reg { border-radius: var(--radius-card); padding: clamp(1.7rem, 2.4vw, 2.3rem); border: 1.5px solid var(--c-bd); background: var(--c-bg); color: var(--c-fg); box-shadow: 5px 6px 0 -1px var(--c-sh); transition: transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s; }
.reg:hover { transform: translate(-2px, -3px); box-shadow: 11px 14px 0 -1px var(--c-sh); }
.reg--sky { --c-bg: var(--sky); --c-fg: var(--sky-ink); --c-bd: var(--sky-bd); --c-acc: var(--navy); --c-sh: var(--sky-bd); }
.reg--sage { --c-bg: var(--sage); --c-fg: var(--sage-ink); --c-bd: var(--sage-bd); --c-acc: #3f7a4a; --c-sh: var(--sage-bd); }
.reg__abbr { font-family: var(--display); font-weight: 700; font-size: clamp(1.9rem, 3vw, 2.6rem); letter-spacing: -0.035em; line-height: 1; }
.reg__name { font-family: var(--label); font-size: 0.76rem; letter-spacing: 0.08em; text-transform: uppercase; opacity: 0.72; margin-top: 0.45rem; }
.reg__lab { font-family: var(--label); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-acc); margin-top: 1.3rem; }
.reg__list { list-style: none; margin: 0.7rem 0 0; padding: 0; }
.reg__list li { padding: 0.5rem 0; font-size: 0.97rem; line-height: 1.4; border-top: 1px solid color-mix(in oklab, currentColor 16%, transparent); }
.reg__list li:first-child { border-top: 0; }
@media (max-width: 700px) { .regs { grid-template-columns: 1fr; } }
@media (hover: none) { .reg:hover { transform: none; box-shadow: 5px 6px 0 -1px var(--c-sh); } }

/* ----------------------------------------------------------------- why-us grid (pillar pages) */
.whygrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 1.8vw, 1.5rem);
  align-items: stretch;
}
.whygrid--quad { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.whygrid .pcard { min-width: 0; height: 100%; }
.whygrid .pcard__name { font-size: clamp(1.4rem, 1.9vw, 1.8rem); margin-top: 1.2rem; }
.whygrid .pcard__vp { margin-top: 1rem; }
@media (max-width: 700px) { .whygrid, .whygrid--quad { grid-template-columns: 1fr; } }

.asof { font-family: var(--label); font-size: 0.7rem; letter-spacing: 0.06em; color: var(--ink-40); }

/* ----------------------------------------------------------------- scope prose (pillar pages) */
.scope-prose { max-width: 68ch; }
.scope-prose p { margin: 0 0 1.1rem; color: var(--ink-80); line-height: 1.62; }
.scope-prose p:last-child { margin-bottom: 0; }
.scope-prose a { color: var(--navy); border-bottom: 1px solid var(--orange); text-decoration: none; }
.scope-prose a:hover { color: var(--orange); }

/* ----------------------------------------------------------------- claims (colour blocks, soft) */
.claims { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem,1.8vw,1.4rem); }
.claim { border-radius: var(--radius-card); padding: clamp(1.6rem,2.2vw,2rem); border: 1.5px solid var(--c-bd, var(--rule)); background: var(--c-bg, var(--cream)); color: var(--c-fg, var(--ink)); }
.claim--sky { --c-bg: var(--sky); --c-fg: var(--sky-ink); --c-bd: var(--sky-bd); }
.claim--sage { --c-bg: var(--sage); --c-fg: var(--sage-ink); --c-bd: var(--sage-bd); }
.claim--peach { --c-bg: var(--peach); --c-fg: var(--peach-ink); --c-bd: var(--peach-bd); }
.claim__t { font-family: var(--display); font-weight: 600; font-size: 1.2rem; letter-spacing: -0.02em; margin: 0 0 0.6rem; display: flex; align-items: baseline; gap: 0.6rem; }
.claim__t .mk { font-family: var(--label); font-size: 0.8rem; opacity: 0.6; }
.claim__d { font-size: 0.97rem; line-height: 1.55; margin: 0; opacity: 0.86; }
@media (max-width: 760px) { .claims { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- insights — article cards */
.insights { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem,2vw,1.8rem); }
.icard { display: flex; flex-direction: column; border: 1.5px solid var(--rule); border-radius: var(--radius-card); background: var(--white); overflow: hidden; transition: transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s, border-color .2s; box-shadow: 5px 6px 0 -1px var(--ink-10); }
.icard:hover { border-color: var(--ink-40); transform: translate(-2px,-3px); box-shadow: 11px 14px 0 -1px var(--ink-10); }
.icard__media { width: 100%; aspect-ratio: 3 / 2; display: block; background: var(--cream2); border-bottom: 1.5px solid var(--rule); overflow: hidden; }
.icard__media image-slot,
.icard__media img { width: 100%; height: 100%; display: block; object-fit: cover; }
.icard__body { display: flex; flex-direction: column; flex: 1; padding: clamp(1.3rem,1.9vw,1.7rem); }
.icard__tag { font-family: var(--label); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--orange); }
.icard__t { font-family: var(--display); font-weight: 600; font-size: clamp(1.25rem,1.7vw,1.5rem); letter-spacing: -0.02em; line-height: 1.1; margin: 0.7rem 0 0; }
.icard__desc { color: var(--ink-60); font-size: 0.95rem; line-height: 1.5; margin: 0.7rem 0 0; }
.icard__foot { margin-top: auto; padding-top: 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.icard__meta { font-family: var(--label); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--ink-40); }
.icard__more { font-family: var(--label); font-size: 0.74rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink); display: inline-flex; align-items: center; gap: 0.45em; border-bottom: 1.5px solid var(--orange); padding-bottom: 3px; transition: gap .2s; }
.icard:hover .icard__more { gap: 0.75em; }
@media (max-width: 820px) { .insights { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- credentials strip */
.creds { display: flex; flex-wrap: wrap; gap: 0.7rem 1rem; align-items: center; }
.cred { font-family: var(--label); font-size: 0.86rem; color: var(--ink-80); display: inline-flex; align-items: center; gap: 0.6rem; }
.cred + .cred::before { content: ""; width: 4px; height: 4px; border-radius: 50%; background: var(--orange); margin-right: 0.4rem; }

/* ----------------------------------------------------------------- closer band */
.closer { background: var(--navy); color: var(--cream); border-radius: var(--radius-card); padding: clamp(2rem, 4.5vw, 3.5rem); display: grid; grid-template-columns: 1fr auto; gap: 1.8rem; align-items: center; box-shadow: 8px 10px 0 -1px var(--deep-navy); }
.closer__h { font-family: var(--display); font-weight: 700; font-size: clamp(1.6rem, 2.8vw, 2.4rem); letter-spacing: -0.03em; line-height: 1.02; margin: 0; max-width: 22ch; }
.closer__p { color: var(--cream-80); margin: 0.8rem 0 0; max-width: 50ch; }
.closer__cta { display: flex; gap: 0.7rem; flex-wrap: wrap; }
@media (max-width: 760px) { .closer { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- breadcrumb */
.crumb { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; font-family: var(--label); font-size: 0.78rem; letter-spacing: 0.04em; color: var(--ink-60); }
.crumb a:hover { color: var(--navy); }
.crumb .sep { color: var(--ink-40); }
.crumb [aria-current] { color: var(--ink); }

/* ----------------------------------------------------------------- footer */
.foot { background: var(--ink); color: var(--cream-80); }
.foot__in { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem; padding-block: clamp(3rem, 5vw, 4rem); }
.foot h4 { font-family: var(--label); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cream-55); margin: 0 0 1rem; font-weight: 500; }
.foot a { display: block; padding: 0.32rem 0; color: var(--cream-80); font-size: 0.92rem; }
.foot a:hover { color: var(--cream); }
.foot__brand .brand__mark { color: var(--cream); }
.foot__brand p { color: var(--cream-55); font-size: 0.9rem; max-width: 34ch; line-height: 1.5; }
.foot__social { display: flex; gap: 0.6rem; margin-top: 1.15rem; }
.foot__social a { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; padding: 0; border: 1.5px solid var(--cream-line); border-radius: 10px; color: var(--cream-80); transition: color .2s, border-color .2s, transform .2s; }
.foot__social a:hover { color: var(--cream); border-color: var(--cream-55); transform: translateY(-2px); }
.foot__social svg { width: 18px; height: 18px; }
.foot__bottom { border-top: 1px solid var(--cream-line); padding-block: 1.3rem; display: flex; flex-wrap: wrap; gap: 0.6rem 1.5rem; justify-content: space-between; font-size: 0.78rem; color: var(--cream-55); }
@media (max-width: 820px) { .foot__in { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .foot__in { grid-template-columns: 1fr; gap: 1.6rem; } }

/* ============================================================================
   MOBILE NAV (CSS-only disclosure) + RESPONSIVE HARDENING
   Covers phone → tablet → desktop → ultrawide. No fixed widths; nothing
   should ever cause horizontal scroll.
   ============================================================================ */

/* mobile menu — hidden on desktop, shown <=880 alongside the always-on CTA */
.nav__m { display: none; position: relative; margin-left: 0.2rem; }
.nav__m > summary { list-style: none; cursor: pointer; width: 42px; height: 42px; border: 1px solid var(--rule); border-radius: var(--radius-btn); display: grid; place-items: center; background: var(--white); }
.nav__m > summary::-webkit-details-marker { display: none; }
.nav__m > summary .bars, .nav__m > summary .bars::before, .nav__m > summary .bars::after { content: ""; display: block; width: 18px; height: 2px; background: var(--ink); transition: transform .2s, opacity .2s; }
.nav__m > summary .bars { position: relative; }
.nav__m > summary .bars::before { position: absolute; top: -6px; }
.nav__m > summary .bars::after { position: absolute; top: 6px; }
.nav__m[open] > summary .bars { background: transparent; }
.nav__m[open] > summary .bars::before { transform: translateY(6px) rotate(45deg); }
.nav__m[open] > summary .bars::after { transform: translateY(-6px) rotate(-45deg); }
.nav__m-panel { position: absolute; right: 0; top: calc(100% + 12px); background: var(--white); border: 1px solid var(--rule); border-radius: var(--radius-soft); box-shadow: 0 18px 44px -22px rgba(15,26,69,0.4); min-width: 220px; display: flex; flex-direction: column; padding: 0.5rem; z-index: 60; }
.nav__m-panel a { padding: 0.7rem 0.85rem; border-radius: 6px; font-family: var(--label); font-size: 0.95rem; color: var(--ink-80); }
.nav__m-panel a:hover { background: var(--cream2); color: var(--ink); }
@media (max-width: 980px) {
  .nav__m { display: block; }
  .nav__cta { display: none; }   /* CTA lives inside the mobile menu instead */
  /* nav__links carried the only margin-left:auto; with it hidden, push the
     lang switcher + hamburger group to the right edge instead of the left. */
  .nav__in { gap: 1rem; }
  .lang { margin-left: auto; }
}
@media (max-width: 560px) { .brand__tag { display: none; } }

/* tablet: let medium cards sit two-up instead of one giant column */
@media (min-width: 641px) and (max-width: 960px) {
  .pcard--md { grid-column: span 6; }
  .pcard--lg, .pcard--wide { grid-column: span 12; }
}

/* type can never overflow its container */
.display, .hero-split__h, .pcard__name, .display-xl, .display-l, .display-m { overflow-wrap: break-word; }

/* phones: tighten the hero so the headline always fits */
@media (max-width: 480px) {
  .hero-split__h { font-size: clamp(2rem, 8.5vw, 2.6rem); }
  .display-xl { font-size: clamp(2rem, 8.5vw, 3rem); }
  .display-l  { font-size: clamp(1.7rem, 6.4vw, 2.1rem); }
  .display-m  { font-size: clamp(1.4rem, 5vw, 1.75rem); }
  .hero-badge__n { font-size: 2.6rem; }
  .proofbar { grid-template-columns: 1fr 1fr; }
  .closer { gap: 1.3rem; }
  .creds { font-size: 0.82rem; }
}

/* ultrawide: keep content from stranding — cap and centre is handled by .wrap;
   bleed sections stay full-width by design. Nudge hero text gutter on huge screens. */
@media (min-width: 1700px) {
  .hero-split { min-height: clamp(640px, 60vh, 860px); }
}

/* touch: disable hover-lift transforms that feel sticky on tap */
@media (hover: none) {
  .pcard:hover, .xcard:hover, .icard:hover, .loop__step:hover { transform: none; }
}

/* Real <img> replacements for mockup image-slot elements */
.aboutsum__media image-slot,
.aboutsum__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.feature__media image-slot,
.feature__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.feature__media { overflow: hidden; }

/* Hybrid legacy pages load style.css or inline store CSS after this file.
   Re-assert site chrome when bare `nav` / `.btn` rules leak onto header.nav. */
header.nav { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--white) 86%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid var(--rule); }
header.nav nav.nav__links,
header.nav nav.nav__m-panel {
  position: static; inset: auto; padding: 0; margin: 0;
  display: flex; flex-direction: row; align-items: center; gap: 1.15rem;
  background: none; box-shadow: none; backdrop-filter: none; z-index: auto;
  cursor: auto;
}
header.nav nav.nav__links { margin-left: auto; }
header.nav nav.nav__m-panel { flex-direction: column; align-items: stretch; gap: 0; position: absolute; right: 0; top: calc(100% + 12px); background: var(--white); border: 1px solid var(--rule); border-radius: var(--radius-soft); box-shadow: 0 18px 44px -22px rgba(15,26,69,0.4); min-width: 220px; padding: 0.5rem; z-index: 60; }
header.nav .btn {
  --bg: var(--navy); --fg: var(--cream); --bd: var(--navy);
  display: inline-flex; align-items: center; gap: 0.6em;
  font-family: var(--label); font-weight: 500; font-size: 0.95rem; letter-spacing: 0.01em;
  padding: 1rem 1.5rem; border-radius: var(--radius-btn);
  background: var(--bg); color: var(--fg); border: 1.5px solid var(--bd);
  box-shadow: none; text-decoration: none; white-space: nowrap;
  transition: transform .15s ease, background .2s, color .2s, border-color .2s;
}
header.nav .btn:hover { transform: translateY(-2px); box-shadow: none; }
header.nav .btn:active { transform: none; box-shadow: none; }
header.nav .btn.btn--sm { padding: 0.62rem 1rem; font-size: 0.82rem; }
header.nav .btn.btn--navy:hover { --bg: var(--deep-navy); --bd: var(--deep-navy); }
/* Mobile: the re-assert rules above (header.nav nav.nav__links / header.nav .btn)
   outrank the plain .nav__links / .nav__cta display:none rules, so the desktop
   links + CTA never hid on small screens (long, wrapping navbar). Re-hide them
   here at matching/higher specificity inside the breakpoint. */
@media (max-width: 980px) {
  header.nav nav.nav__links { display: none; }
  header.nav .nav__cta { display: none; }
}
footer.foot { background: var(--ink); color: var(--cream-80); border-top: none; padding: 0; }
