/* ============================================
   FamilyClean — v2.0 Terracotta & Butter
   Cascade-first architecture
   ============================================ */
@layer reset, tokens, base, layout, components, utilities;

/* ---------- reset ---------- */
@layer reset {
  *, *::before, *::after { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
  img, svg { display: block; max-inline-size: 100%; }
  button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
  a { color: inherit; text-decoration: none; }
  h1, h2, h3, h4, p, ul, ol { margin: 0; padding: 0; }
  ul, ol { list-style: none; }
  input, select, textarea { font: inherit; color: inherit; }
}

/* ---------- tokens ---------- */
@layer tokens {
  :root {
    /* raw palette */
    --cream-50: #FAF6EE;
    --cream-100: #F5EFE6;
    --cream-200: #EDE4D3;
    --cream-300: #E2D6BD;
    --terracotta: #C4623E;
    --terracotta-deep: #9F4C2D;
    --butter: #E8B663;
    --butter-soft: #F2D7A1;
    --sage: #6F7F5C;
    --sage-deep: #4F5C3F;
    --ink: #2A2522;
    --ink-soft: #4A413B;
    --muted: #786A5E;
    --hairline: rgba(42, 37, 34, 0.12);

    /* semantic */
    --bg: var(--cream-100);
    --bg-elev: var(--cream-50);
    --bg-sunken: var(--cream-200);
    --fg: var(--ink);
    --fg-muted: var(--muted);
    --accent: var(--terracotta);
    --accent-soft: var(--butter);
    --accent-quiet: var(--sage);
    --border: var(--hairline);

    /* space scale */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-7: 3rem;
    --space-8: 4rem;
    --space-9: 6rem;
    --space-10: 8rem;

    /* radius */
    --r-1: 6px;
    --r-2: 12px;
    --r-3: 20px;
    --r-4: 28px;
    --r-5: 40px;
    --r-pill: 999px;

    /* shadow */
    --shadow-soft: 0 24px 48px -28px rgba(42, 37, 34, 0.22);
    --shadow-card: 0 18px 40px -24px rgba(159, 76, 45, 0.25);

    /* type */
    --font-sans: 'Manrope', system-ui, sans-serif;
    --font-serif: 'Fraunces', Georgia, serif;

    /* layout */
    --max-w: 1440px;
    --gutter: clamp(1.25rem, 4vw, 3rem);
  }

  /* dark theme — re-bind semantic tokens to inverted palette */
  :root[data-theme="dark"] {
    --bg: #14110F;
    --bg-elev: #1E1A16;
    --bg-sunken: #0E0C0A;
    --fg: #F5EFE6;
    --fg-muted: #A89E92;
    --ink: #FAF6EE;
    --ink-soft: #E5DDD2;
    --hairline: rgba(245, 239, 230, 0.12);
    --border: rgba(245, 239, 230, 0.14);
    --shadow-soft: 0 24px 48px -28px rgba(0, 0, 0, 0.6);
    --shadow-card: 0 18px 40px -24px rgba(0, 0, 0, 0.55);
  }

  /* saver mode — pure-black OLED-friendly + reduced motion + simplified colors */
  :root[data-theme="saver"] {
    --bg: #000000;
    --bg-elev: #0A0A0A;
    --bg-sunken: #050505;
    --fg: #E5E5E5;
    --fg-muted: #909090;
    --ink: #F0F0F0;
    --ink-soft: #C8C8C8;
    --muted: #707070;
    --hairline: rgba(255, 255, 255, 0.08);
    --border: rgba(255, 255, 255, 0.08);
    --shadow-soft: none;
    --shadow-card: none;
    --butter-soft: #1A1610;
    --cream-50: #050505;
    --cream-100: #000000;
    --cream-200: #0A0A0A;
    --cream-300: #141414;
  }
}

/* ---------- base ---------- */
@layer base {
  html { background: var(--bg); color: var(--fg); }
  body {
    background: inherit; color: inherit;
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.6;
    font-weight: 400;
    overflow-x: hidden;
  }

  h1, h2, h3 { font-weight: 700; letter-spacing: -0.02em; line-height: 1.05; text-wrap: balance; }
  p { text-wrap: pretty; }

  .display { font-size: clamp(2.75rem, 6.4vw, 5.5rem); font-weight: 800; letter-spacing: -0.035em; }
  .display em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 700; }
  .h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .h3 { font-size: 1.25rem; font-weight: 700; letter-spacing: -0.01em; }
  .lede { font-size: clamp(1.05rem, 1.4vw, 1.2rem); color: var(--fg-muted); line-height: 1.55; max-inline-size: 56ch; }
  .eyebrow {
    font-family: var(--font-serif); font-style: italic; font-weight: 400;
    font-size: 0.95rem; color: var(--accent);
    display: inline-flex; align-items: center; gap: var(--space-2);
  }
  .eyebrow::before { content: ""; inline-size: 28px; block-size: 1px; background: var(--accent); }

  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  }
}

/* ---------- layout ---------- */
@layer layout {
  .shell { inline-size: 100%; max-inline-size: var(--max-w); margin-inline: auto; padding-inline: var(--gutter); }
  .section { padding-block: clamp(4rem, 9vw, 8rem); position: relative; }
  .section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
  .section--sunken { background: var(--bg-sunken); }
  .section--ink { background: var(--ink); color: var(--cream-100); }
}

/* ---------- components ---------- */
@layer components {
  /* ----- nav ----- */
  .nav {
    position: sticky; inset-block-start: 0; z-index: 50;
    background: color-mix(in oklab, var(--bg) 80%, transparent);
    backdrop-filter: saturate(180%) blur(14px);
    border-block-end: 1px solid var(--border);
  }
  .nav__inner {
    display: flex; align-items: center; gap: var(--space-6);
    padding-block: var(--space-4);
  }
  .nav__logo { display: inline-flex; align-items: center; gap: var(--space-3); font-weight: 800; letter-spacing: -0.02em; font-size: 1.15rem; }
  .nav__logo em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .nav__mark {
    inline-size: 32px; block-size: 32px; border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--butter), var(--terracotta) 65%, var(--terracotta-deep));
    position: relative;
  }
  .nav__mark::after {
    content: ""; position: absolute; inset-block-start: 6px; inset-inline-start: 8px;
    inline-size: 8px; block-size: 8px; border-radius: 50%;
    background: color-mix(in oklab, var(--cream-50) 80%, transparent);
  }
  .nav__links { display: flex; gap: var(--space-6); margin-inline-start: var(--space-7); list-style: none; }
  .nav__links a { font-size: 0.95rem; color: var(--ink-soft); }
  .nav__links a:hover { color: var(--accent); }
  .nav__actions { margin-inline-start: auto; display: flex; gap: var(--space-3); align-items: center; }
  @media (max-width: 56rem) {
    .nav__links { display: none; }
  }

  /* ----- buttons ----- */
  .btn {
    display: inline-flex; align-items: center; gap: var(--space-2);
    padding-block: 0.85rem; padding-inline: 1.5rem;
    border-radius: var(--r-pill);
    font-weight: 600; font-size: 0.95rem;
    transition: transform .2s ease, background .2s ease, color .2s ease;
    white-space: nowrap;
  }
  .btn--primary { background: var(--ink); color: var(--cream-50); }
  .btn--primary:hover { background: var(--accent); transform: translateY(-1px); }
  .btn--accent { background: var(--accent); color: var(--cream-50); }
  .btn--accent:hover { background: var(--terracotta-deep); transform: translateY(-1px); }
  .btn--ghost { background: transparent; color: var(--ink); border: 1px solid var(--border); }
  .btn--ghost:hover { background: var(--bg-elev); }
  .btn--lg { padding-block: 1.1rem; padding-inline: 2rem; font-size: 1rem; }
  .btn__arrow { transition: transform .2s ease; }
  .btn:hover .btn__arrow { transform: translateX(3px); }

  /* ----- hero ----- */
  .hero { padding-block-start: clamp(3rem, 7vw, 6rem); padding-block-end: clamp(4rem, 8vw, 7rem); position: relative; overflow: hidden; }
  .hero__inner { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: var(--space-8); align-items: center; }
  .hero__blob {
    position: absolute; inset-block-start: -10%; inset-inline-end: -10%;
    inline-size: 56vw; block-size: 56vw; max-inline-size: 800px; max-block-size: 800px;
    background: radial-gradient(circle at 35% 35%, var(--butter-soft), transparent 60%),
                radial-gradient(circle at 65% 65%, color-mix(in oklab, var(--terracotta) 35%, transparent), transparent 55%);
    filter: blur(10px); opacity: 0.55; pointer-events: none; z-index: 0;
  }
  .hero__content { position: relative; z-index: 2; }
  .hero__title { margin-block-end: var(--space-5); }
  .hero__title .marker { background: linear-gradient(transparent 60%, var(--butter-soft) 60%); padding-inline: 0.15em; }
  .hero__lede { margin-block-end: var(--space-7); font-size: 1.2rem; max-inline-size: 52ch; }
  .hero__visual { position: relative; z-index: 1; aspect-ratio: 4/5; }
  @media (max-width: 56rem) {
    .hero__inner { grid-template-columns: 1fr; }
    .hero__visual { display: none; }
  }

  /* ----- search ----- */
  .search {
    background: var(--bg-elev);
    border: 1px solid var(--border);
    border-radius: var(--r-4);
    padding: var(--space-3);
    display: grid; grid-template-columns: 1fr 1px 1fr auto; gap: var(--space-3);
    align-items: stretch;
    box-shadow: var(--shadow-soft);
    max-inline-size: 640px;
  }
  .search__divider { background: var(--border); }
  .search__field { display: flex; flex-direction: column; padding: var(--space-3) var(--space-4); border-radius: var(--r-3); }
  .search__field:hover { background: var(--bg-sunken); }
  .search__label {
    font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--fg-muted); font-weight: 600; margin-block-end: 2px;
  }
  .search__select {
    border: 0; background: transparent; font-weight: 600; font-size: 0.95rem; color: var(--ink);
    padding: 0; appearance: none; cursor: pointer;
  }
  .search__cta { align-self: center; }
  @media (max-width: 56rem) {
    .search { grid-template-columns: 1fr; }
    .search__divider { block-size: 1px; }
  }

  /* ----- hero side card ----- */
  .hero-card {
    position: relative; inline-size: 100%; aspect-ratio: 4/5;
    border-radius: var(--r-5);
    background: linear-gradient(160deg, var(--butter-soft), var(--terracotta) 70%);
    overflow: hidden;
    box-shadow: var(--shadow-card);
  }
  .hero-card__placeholder {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: color-mix(in oklab, var(--cream-50) 85%, transparent);
    font-family: 'Courier New', monospace; font-size: 0.85rem; letter-spacing: 0.08em;
    background-image: repeating-linear-gradient(135deg, transparent 0 18px, rgba(255,255,255,0.07) 18px 19px);
  }
  .hero-card__img {
    position: absolute; inset: 0; z-index: 0;
    inline-size: 100%; block-size: 100%;
    object-fit: cover; object-position: center;
  }
  .hero-card::after {
    content: ""; position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(160deg, color-mix(in oklab, var(--butter-soft) 25%, transparent), color-mix(in oklab, var(--terracotta) 30%, transparent));
    mix-blend-mode: multiply; pointer-events: none;
  }
  .hero-card__badge, .hero-card__sticker { z-index: 2; }
  .hero-card__sticker {
    position: absolute; inset-block-end: -2rem; inset-inline-start: -2rem;
    background: var(--sage); color: var(--cream-50);
    inline-size: 180px; block-size: 180px; border-radius: 50%;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: var(--space-4); text-align: center;
    transform: rotate(-8deg);
    box-shadow: var(--shadow-soft);
  }
  .hero-card__sticker strong { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2.5rem; line-height: 1; }
  .hero-card__sticker span { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.14em; margin-block-start: var(--space-1); }
  .hero-card__badge {
    position: absolute; inset-block-start: var(--space-5); inset-inline-end: var(--space-5);
    background: var(--cream-50); color: var(--ink);
    padding: var(--space-2) var(--space-4); border-radius: var(--r-pill);
    font-size: 0.8rem; font-weight: 600;
    display: inline-flex; align-items: center; gap: var(--space-2);
  }
  .hero-card__badge::before { content: ""; inline-size: 6px; block-size: 6px; border-radius: 50%; background: var(--sage); }

  /* ----- trust strip ----- */
  .trust {
    border-block: 1px solid var(--border);
    padding-block: var(--space-7);
  }
  .trust__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-6); list-style: none; }
  .trust__item { display: flex; flex-direction: column; gap: var(--space-1); }
  .trust__num { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2.4rem; color: var(--accent); line-height: 1; }
  .trust__label { font-size: 0.95rem; color: var(--ink-soft); font-weight: 500; }
  .trust__sub { font-size: 0.85rem; color: var(--fg-muted); }
  @media (max-width: 56rem) {
    .trust__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  }

  /* ----- section header (cat-head) ----- */
  .cat-head { display: flex; justify-content: space-between; align-items: end; gap: var(--space-6); margin-block-end: var(--space-7); flex-wrap: wrap; }

  /* ----- categories ----- */
  .cat-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
  @media (max-width: 56rem) { .cat-grid { grid-template-columns: 1fr; } }
  .cat {
    position: relative; padding: var(--space-6); border-radius: var(--r-4);
    background: var(--bg-elev); border: 1px solid var(--border);
    display: flex; flex-direction: column; gap: var(--space-4);
    min-block-size: 240px;
    transition: transform .25s ease, box-shadow .25s ease;
    overflow: hidden;
  }
  .cat:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); }
  .cat__blob {
    position: absolute; inset-block-end: -40px; inset-inline-end: -40px;
    inline-size: 160px; block-size: 160px; border-radius: 50%;
    background: var(--butter-soft); opacity: 0.5; transition: transform .35s ease;
  }
  .cat:hover .cat__blob { transform: scale(1.15); }
  .cat--terracotta .cat__blob { background: color-mix(in oklab, var(--terracotta) 25%, transparent); }
  .cat--sage .cat__blob { background: color-mix(in oklab, var(--sage) 25%, transparent); }
  .cat--butter .cat__blob { background: var(--butter-soft); opacity: 0.7; }
  .cat__icon {
    position: relative; z-index: 1;
    inline-size: 44px; block-size: 44px; border-radius: var(--r-2);
    background: var(--cream-200); color: var(--accent);
    display: grid; place-items: center;
    font-family: var(--font-serif); font-style: italic; font-weight: 500;
    font-size: 1.4rem;
  }
  .cat__title { position: relative; z-index: 1; font-size: 1.15rem; font-weight: 700; }
  .cat__desc { position: relative; z-index: 1; color: var(--fg-muted); font-size: 0.95rem; }
  .cat__meta {
    position: relative; z-index: 1; margin-block-start: auto;
    display: flex; justify-content: space-between; align-items: center;
    padding-block-start: var(--space-3); border-block-start: 1px solid var(--border);
    font-size: 0.85rem; color: var(--fg-muted);
  }
  .cat__meta-arrow { color: var(--accent); font-family: var(--font-serif); font-style: italic; }

  /* ----- how it works ----- */
  .how { position: relative; }
  .how__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-6); }
  @media (max-width: 56rem) { .how__grid { grid-template-columns: 1fr; } }
  .step {
    display: flex; flex-direction: column; gap: var(--space-4);
    padding: var(--space-6);
    background: var(--bg-elev);
    border-radius: var(--r-4);
    border: 1px solid var(--border);
    position: relative;
  }
  .step__num {
    font-family: var(--font-serif); font-style: italic; font-weight: 500;
    font-size: 4rem; line-height: 1; color: var(--accent); opacity: 0.85;
  }
  .step__title { font-size: 1.3rem; font-weight: 700; }
  .step__desc { color: var(--fg-muted); }
  .step__dot {
    position: absolute; inset-block-start: 50%; inset-inline-end: -3.5rem;
    inline-size: 16px; block-size: 16px; border-radius: 50%;
    background: var(--butter); border: 4px solid var(--bg);
    transform: translateY(-50%);
  }
  .step:last-child .step__dot { display: none; }
  @media (max-width: 56rem) { .step__dot { display: none; } }

  /* ----- reviews ----- */
  .reviews { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
  @media (max-width: 56rem) { .reviews { grid-template-columns: 1fr; } }
  .review {
    padding: var(--space-6); border-radius: var(--r-4);
    background: var(--bg-elev); border: 1px solid var(--border);
    display: flex; flex-direction: column; gap: var(--space-4);
  }
  .review__stars { color: var(--accent); letter-spacing: 0.2em; font-size: 0.9rem; }
  .review__quote { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 1.2rem; line-height: 1.4; color: var(--ink); text-wrap: pretty; }
  .review__footer { display: flex; align-items: center; gap: var(--space-3); margin-block-start: auto; padding-block-start: var(--space-3); border-block-start: 1px solid var(--border); }
  .review__avatar {
    inline-size: 44px; block-size: 44px; border-radius: 50%;
    background: var(--cream-300); display: grid; place-items: center;
    font-weight: 700; color: var(--ink); font-size: 0.95rem;
  }
  .review__name { font-weight: 600; font-size: 0.95rem; }
  .review__meta { font-size: 0.82rem; color: var(--fg-muted); }
  .review--terracotta .review__avatar { background: color-mix(in oklab, var(--terracotta) 25%, var(--cream-200)); }
  .review--sage .review__avatar { background: color-mix(in oklab, var(--sage) 25%, var(--cream-200)); }
  .review--butter .review__avatar { background: var(--butter-soft); }
  .reviews--empty {
    text-align: center; padding: var(--space-8) var(--space-6);
    background: var(--bg-elev); border: 1px dashed var(--border); border-radius: var(--r-4);
  }
  .reviews--empty p { color: var(--fg-muted); font-size: 1.05rem; max-inline-size: 52ch; margin-inline: auto; margin-block-start: var(--space-3); }

  /* ----- two-up: workers / firms ----- */
  .twoup { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
  @media (max-width: 56rem) { .twoup { grid-template-columns: 1fr; } }
  .pcard {
    padding: var(--space-7); border-radius: var(--r-5);
    display: flex; flex-direction: column; gap: var(--space-5);
    position: relative; overflow: hidden;
    min-block-size: 360px;
  }
  .pcard--workers { background: var(--sage); color: var(--cream-50); }
  .pcard--firms { background: var(--cream-200); color: var(--ink); }
  .pcard__eyebrow { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 0.95rem; opacity: 0.85; }
  .pcard--workers .pcard__eyebrow { color: var(--butter-soft); opacity: 1; }
  .pcard--firms .pcard__eyebrow { color: var(--accent); }
  .pcard__title { font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 700; letter-spacing: -0.02em; }
  .pcard__title em { font-family: var(--font-serif); font-style: italic; font-weight: 500; }
  .pcard__list { display: flex; flex-direction: column; gap: var(--space-2); margin-block: var(--space-2); }
  .pcard__list li {
    display: flex; gap: var(--space-3); align-items: start;
    font-size: 0.98rem; line-height: 1.5;
  }
  .pcard__list li::before {
    content: "✓"; flex: 0 0 auto; font-weight: 700; font-size: 0.9rem;
    inline-size: 22px; block-size: 22px; border-radius: 50%;
    background: color-mix(in oklab, currentColor 12%, transparent);
    display: grid; place-items: center;
    margin-block-start: 1px;
  }
  .pcard__cta { margin-block-start: auto; display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
  .pcard--workers .btn--ghost { color: var(--cream-50); border-color: color-mix(in oklab, var(--cream-50) 30%, transparent); }
  .pcard--workers .btn--ghost:hover { background: color-mix(in oklab, var(--cream-50) 10%, transparent); }
  .pcard__price { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 1rem; }
  .pcard__shape {
    position: absolute; inset-block-start: -60px; inset-inline-end: -60px;
    inline-size: 240px; block-size: 240px; border-radius: 50%;
    opacity: 0.18; pointer-events: none;
  }
  .pcard--workers .pcard__shape { background: var(--butter); }
  .pcard--firms .pcard__shape { background: var(--terracotta); }

  /* ----- jobs ----- */
  .jobs { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-4); }
  @media (max-width: 56rem) { .jobs { grid-template-columns: 1fr; } }
  .job {
    padding: var(--space-5) var(--space-6); border-radius: var(--r-3);
    background: var(--bg-elev); border: 1px solid var(--border);
    display: grid; grid-template-columns: 1fr auto; gap: var(--space-4);
    align-items: center;
    transition: border-color .2s ease, transform .2s ease;
  }
  .job:hover { border-color: var(--accent); transform: translateY(-2px); }
  .job__title { font-size: 1.05rem; font-weight: 700; margin-block-end: var(--space-1); }
  .job__meta { display: flex; gap: var(--space-3); font-size: 0.85rem; color: var(--fg-muted); flex-wrap: wrap; }
  .job__meta span { display: inline-flex; align-items: center; gap: var(--space-1); }
  .job__meta span + span::before {
    content: ""; inline-size: 3px; block-size: 3px; border-radius: 50%;
    background: var(--fg-muted); margin-inline-end: var(--space-1);
  }
  .job__pay { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); white-space: nowrap; }
  .jobs--empty {
    grid-column: 1 / -1;
    text-align: center; padding: var(--space-8) var(--space-6);
    background: var(--bg-elev); border: 1px dashed var(--border); border-radius: var(--r-4);
  }
  .jobs--empty p { color: var(--fg-muted); max-inline-size: 52ch; margin-inline: auto; margin-block: var(--space-3) var(--space-5); }

  /* ----- CTA ----- */
  .cta-band {
    background: var(--ink); color: var(--cream-50);
    border-radius: var(--r-5);
    padding: clamp(3rem, 6vw, 5rem);
    display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--space-7); align-items: center;
    position: relative; overflow: hidden;
  }
  @media (max-width: 56rem) { .cta-band { grid-template-columns: 1fr; } }
  .cta-band__title { font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 700; letter-spacing: -0.025em; line-height: 1.05; }
  .cta-band__title em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--butter); }
  .cta-band__lede { color: color-mix(in oklab, var(--cream-50) 75%, transparent); margin-block-start: var(--space-4); max-inline-size: 50ch; }
  .cta-band__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-block-start: var(--space-6); }
  .cta-band .btn--primary { background: var(--butter); color: var(--ink); }
  .cta-band .btn--primary:hover { background: var(--terracotta); color: var(--cream-50); }
  .cta-band .btn--ghost { color: var(--cream-50); border-color: color-mix(in oklab, var(--cream-50) 30%, transparent); }
  .cta-band__visual {
    position: relative; aspect-ratio: 1; max-inline-size: 360px; justify-self: end;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--terracotta), var(--butter));
    display: grid; place-items: center;
  }
  .cta-band__visual span {
    font-family: var(--font-serif); font-style: italic; font-weight: 500;
    color: var(--cream-50); font-size: 2.5rem; transform: rotate(-12deg); text-align: center;
  }
  @media (max-width: 56rem) { .cta-band__visual { display: none; } }

  /* ----- footer ----- */
  .footer { padding-block: var(--space-9) var(--space-7); border-block-start: 1px solid var(--border); }
  .footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-7); margin-block-end: var(--space-7); }
  @media (max-width: 56rem) { .footer__top { grid-template-columns: 1fr 1fr; } }
  .footer__brand p { color: var(--fg-muted); margin-block: var(--space-3); max-inline-size: 36ch; font-size: 0.95rem; }
  .footer h4 { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--fg-muted); font-weight: 600; margin-block-end: var(--space-4); }
  .footer ul { display: flex; flex-direction: column; gap: var(--space-2); list-style: none; padding: 0; }
  .footer ul a { font-size: 0.95rem; color: var(--ink-soft); }
  .footer ul a:hover { color: var(--accent); }
  .footer__contact { font-size: 0.95rem; line-height: 1.5; }
  .footer__contact a { color: var(--accent); font-weight: 700; font-size: 1.05rem; }
  .footer__contact a:hover { color: var(--terracotta-deep); }
  .footer__legal { padding-block-start: var(--space-5); border-block-start: 1px solid var(--border); margin-block-end: var(--space-3); color: var(--fg-muted); font-size: 0.85rem; line-height: 1.55; }
  .footer__legal strong { color: var(--ink); font-weight: 700; }
  .footer__bottom { padding-block-start: var(--space-4); border-block-start: 1px solid var(--border); display: flex; justify-content: space-between; gap: var(--space-4); color: var(--fg-muted); font-size: 0.85rem; flex-wrap: wrap; }

  /* ----- early-stage notice banner ----- */
  .notice {
    background: var(--butter-soft); border: 1px solid color-mix(in oklab, var(--butter) 50%, transparent);
    border-radius: var(--r-3); padding: var(--space-4) var(--space-5);
    display: flex; gap: var(--space-4); align-items: flex-start;
    margin-block: var(--space-5);
  }
  .notice__icon { font-size: 1.4rem; line-height: 1; flex-shrink: 0; }
  .notice__body { font-size: 0.95rem; line-height: 1.5; color: var(--terracotta-deep); }
  .notice__body strong { display: block; margin-block-end: 2px; }
  .notice__body a { color: var(--terracotta-deep); text-decoration: underline; font-weight: 600; }

  /* ----- breadcrumbs ----- */
  .crumbs {
    display: inline-flex; align-items: center; gap: var(--space-2);
    color: var(--fg-muted); font-size: 0.88rem;
    margin-block-end: var(--space-4);
  }
  .crumbs a { color: var(--fg-muted); }
  .crumbs a:hover { color: var(--accent); }
  .crumbs span { opacity: 0.5; }

  /* ----- page hero (secondary pages) ----- */
  .page-hero { padding-block: clamp(2.5rem, 5vw, 4rem); position: relative; }
  .page-hero h1 { font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 800; letter-spacing: -0.025em; line-height: 1.05; }
  .page-hero h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .page-hero .lede { margin-block-start: var(--space-4); }

  /* ----- form field ----- */
  .field { display: flex; flex-direction: column; gap: var(--space-2); margin-block-end: var(--space-4); }
  .field > label { font-size: 0.85rem; font-weight: 600; color: var(--ink-soft); }
  .field input[type="text"],
  .field input[type="email"],
  .field input[type="password"],
  .field input[type="tel"],
  .field input[type="number"],
  .field select,
  .field textarea {
    inline-size: 100%; padding: 0.8rem 1rem;
    background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-2);
    color: var(--ink); font-size: 0.95rem;
    transition: border-color .15s ease, box-shadow .15s ease;
  }
  .field textarea { min-block-size: 140px; resize: vertical; }
  .field input:focus, .field select:focus, .field textarea:focus {
    outline: none; border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 15%, transparent);
  }
  .field .hint { font-size: 0.8rem; color: var(--fg-muted); }
  .field--inline { flex-direction: row; align-items: center; gap: var(--space-3); }
  .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
  @media (max-width: 56rem) { .form-row { grid-template-columns: 1fr; } }
  .form-check { display: flex; gap: var(--space-3); align-items: flex-start; font-size: 0.88rem; color: var(--fg-muted); line-height: 1.5; }
  .form-check input[type="checkbox"] { margin-block-start: 3px; accent-color: var(--accent); flex-shrink: 0; }
  .form-check a { color: var(--accent); text-decoration: underline; }

  /* ----- pricing cards ----- */
  .pricing-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-4);
  }
  .price-card {
    position: relative; padding: var(--space-6); border-radius: var(--r-4);
    background: var(--bg-elev); border: 1px solid var(--border);
    display: flex; flex-direction: column; gap: var(--space-3);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  }
  .price-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); border-color: color-mix(in oklab, var(--accent) 30%, var(--border)); }
  .price-card--popular { background: linear-gradient(160deg, var(--butter-soft), var(--cream-100)); border-color: var(--butter); }
  .price-card__tier {
    font-family: var(--font-serif); font-style: italic; font-size: 0.85rem;
    color: var(--accent); margin-block-end: var(--space-1);
  }
  .price-card__name { font-size: 1.5rem; font-weight: 800; letter-spacing: -0.02em; }
  .price-card__for { font-size: 0.88rem; color: var(--fg-muted); }
  .price-card__amount { display: flex; align-items: baseline; gap: var(--space-1); margin-block: var(--space-3) var(--space-1); }
  .price-card__amount .num { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2.4rem; color: var(--ink); line-height: 1; }
  .price-card__amount .per { font-size: 0.88rem; color: var(--fg-muted); }
  .price-card__note { font-size: 0.82rem; color: var(--fg-muted); }
  .price-card__features { display: flex; flex-direction: column; gap: var(--space-2); margin-block: var(--space-4); }
  .price-card__features li {
    display: flex; gap: var(--space-2); align-items: start;
    font-size: 0.92rem; line-height: 1.5;
  }
  .price-card__features li::before {
    content: "✓"; flex: 0 0 auto; color: var(--accent);
    font-weight: 700; font-size: 0.85rem; line-height: 1.4;
  }
  .price-card .btn { margin-block-start: auto; justify-content: center; }
  .price-card__badge {
    position: absolute; inset-block-start: -10px; inset-inline-end: var(--space-5);
    background: var(--accent); color: var(--cream-50);
    padding: 0.3rem 0.75rem; border-radius: var(--r-pill);
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  }
  .price-foot {
    text-align: center; max-inline-size: 60ch; margin: var(--space-7) auto 0;
    color: var(--fg-muted); font-size: 0.95rem;
  }

  /* ----- compare table ----- */
  .compare-wrap {
    overflow-x: auto; border-radius: var(--r-3); border: 1px solid var(--border);
    background: var(--bg-elev);
  }
  .compare {
    inline-size: 100%; border-collapse: collapse; min-inline-size: 700px;
    font-size: 0.92rem;
  }
  .compare thead th {
    text-align: center; padding: var(--space-4) var(--space-3);
    background: var(--bg-sunken); color: var(--ink); font-weight: 700;
    border-block-end: 1px solid var(--border);
  }
  .compare thead th:first-child { text-align: start; padding-inline-start: var(--space-5); }
  .compare tbody td {
    padding: var(--space-3) var(--space-3); text-align: center;
    border-block-start: 1px solid var(--border); color: var(--ink-soft);
  }
  .compare tbody td:first-child { text-align: start; padding-inline-start: var(--space-5); font-weight: 500; color: var(--ink); }
  .compare .yes { color: var(--accent); font-weight: 700; }
  .compare .no { color: color-mix(in oklab, var(--fg-muted) 50%, transparent); }
  .compare .num { font-family: var(--font-serif); font-style: italic; font-weight: 600; color: var(--ink); }

  /* ----- FAQ ----- */
  .faq-grid { display: flex; flex-direction: column; gap: var(--space-3); max-inline-size: 780px; margin-inline: auto; }
  .faq-item {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-4) var(--space-5);
  }
  .faq-item summary {
    cursor: pointer; list-style: none; font-weight: 700; font-size: 1rem;
    display: flex; justify-content: space-between; align-items: center; gap: var(--space-3);
    color: var(--ink);
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary::after {
    content: "+"; font-family: var(--font-serif); font-style: italic; color: var(--accent);
    font-size: 1.4rem; line-height: 1; transition: transform .2s ease;
  }
  .faq-item[open] summary::after { transform: rotate(45deg); }
  .faq-item__body { margin-block-start: var(--space-3); color: var(--fg-muted); line-height: 1.55; }

  /* ----- listing layout (workers/jobs lists) ----- */
  .listing { display: grid; grid-template-columns: 280px 1fr; gap: var(--space-6); }
  @media (max-width: 56rem) { .listing { grid-template-columns: 1fr; } }
  .filters {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
    block-size: fit-content; position: sticky; inset-block-start: 90px;
  }
  .filters h3 {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 0.92rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--fg-muted); font-weight: 700; margin-block-end: var(--space-4);
  }
  .filters h3 a { font-size: 0.82rem; color: var(--accent); text-transform: none; letter-spacing: 0; font-weight: 500; }
  .filter-block { border-block-start: 1px solid var(--border); padding-block: var(--space-4); }
  .filter-block h4 { font-size: 0.88rem; font-weight: 700; margin-block-end: var(--space-3); color: var(--ink); }
  .filter-options { display: flex; flex-direction: column; gap: var(--space-2); }
  .filter-options label {
    display: flex; align-items: center; gap: var(--space-2);
    font-size: 0.9rem; color: var(--ink-soft); cursor: pointer;
  }
  .filter-options label input { accent-color: var(--accent); }
  .filter-options label .count { margin-inline-start: auto; font-size: 0.78rem; color: var(--fg-muted); }
  .range-row { display: flex; align-items: center; gap: var(--space-2); font-size: 0.88rem; color: var(--fg-muted); }
  .range-row input { inline-size: 80px; padding: 0.5rem 0.75rem; background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-2); }

  .results-bar {
    display: flex; justify-content: space-between; align-items: center;
    margin-block-end: var(--space-5); gap: var(--space-4); flex-wrap: wrap;
  }
  .results-bar .count { color: var(--fg-muted); font-size: 0.95rem; }
  .results-bar .count strong { color: var(--ink); }
  .sort-row { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 0.88rem; color: var(--fg-muted); }
  .sort-row select { padding: 0.4rem 0.6rem; background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-2); }

  /* worker / job cards in listing */
  .listing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }
  .lcard {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
    display: flex; flex-direction: column; gap: var(--space-3);
    transition: transform .2s ease, border-color .2s ease;
  }
  .lcard:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--accent) 30%, var(--border)); }
  .lcard__head { display: flex; gap: var(--space-3); align-items: center; }
  .lcard__avatar {
    inline-size: 52px; block-size: 52px; border-radius: 50%;
    background: color-mix(in oklab, var(--terracotta) 18%, var(--cream-200));
    display: grid; place-items: center;
    font-weight: 800; color: var(--ink); font-size: 0.95rem;
  }
  .lcard__name { font-weight: 700; font-size: 1.05rem; display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
  .lcard__loc { font-size: 0.82rem; color: var(--fg-muted); margin-block-start: 2px; }
  .lcard__tags { display: flex; gap: var(--space-2); flex-wrap: wrap; }
  .tag {
    font-size: 0.78rem; padding: 0.25rem 0.6rem; border-radius: var(--r-pill);
    background: var(--bg-sunken); color: var(--ink-soft);
  }
  .lcard__meta {
    display: flex; justify-content: space-between; align-items: center;
    padding-block-start: var(--space-3); border-block-start: 1px solid var(--border);
    font-size: 0.85rem;
  }
  .lcard__stars { color: var(--accent); letter-spacing: 0.1em; }
  .lcard__rev { color: var(--fg-muted); font-size: 0.8rem; margin-inline-start: var(--space-1); }
  .lcard__price { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--ink); }
  .lcard__price small { color: var(--fg-muted); font-size: 0.78rem; }
  .verified {
    font-size: 0.7rem; font-weight: 600; padding: 0.15rem 0.5rem;
    background: color-mix(in oklab, var(--sage) 18%, var(--cream-100));
    color: var(--sage-deep); border-radius: var(--r-pill);
    text-transform: uppercase; letter-spacing: 0.06em;
  }

  /* job listing cards */
  .jcard {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
    display: flex; flex-direction: column; gap: var(--space-3);
    transition: transform .2s ease, border-color .2s ease;
  }
  .jcard:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--accent) 30%, var(--border)); }
  .jcard__top { display: flex; justify-content: space-between; gap: var(--space-3); align-items: flex-start; }
  .jcard__title { font-weight: 700; font-size: 1.05rem; line-height: 1.3; }
  .jcard__co { font-size: 0.85rem; color: var(--fg-muted); margin-block-start: 4px; display: flex; align-items: center; gap: var(--space-2); }
  .jcard__co .logo {
    inline-size: 24px; block-size: 24px; border-radius: 50%;
    background: var(--bg-sunken); color: var(--ink-soft);
    display: inline-grid; place-items: center; font-size: 0.7rem; font-weight: 700;
  }
  .pill {
    font-size: 0.75rem; padding: 0.25rem 0.6rem; border-radius: var(--r-pill);
    background: var(--bg-sunken); color: var(--ink-soft); white-space: nowrap;
  }
  .pill--full { background: color-mix(in oklab, var(--sage) 18%, var(--cream-100)); color: var(--sage-deep); }
  .pill--brigade { background: color-mix(in oklab, var(--butter) 30%, var(--cream-100)); color: var(--terracotta-deep); }
  .jcard__info { display: flex; gap: var(--space-4); flex-wrap: wrap; font-size: 0.85rem; color: var(--fg-muted); }
  .jcard__info strong { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); margin-inline-end: 4px; }
  .jcard__foot {
    display: flex; justify-content: space-between; align-items: center;
    padding-block-start: var(--space-3); border-block-start: 1px solid var(--border);
    font-size: 0.82rem; color: var(--fg-muted);
  }

  .pagination {
    display: flex; justify-content: center; gap: var(--space-2);
    margin-block-start: var(--space-7); flex-wrap: wrap;
  }
  .pagination a, .pagination span {
    min-inline-size: 38px; block-size: 38px; padding-inline: 0.5rem;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: var(--r-2); border: 1px solid var(--border);
    background: var(--bg-elev); color: var(--ink-soft); font-size: 0.92rem;
  }
  .pagination a:hover { border-color: var(--accent); color: var(--accent); }
  .pagination .active { background: var(--ink); color: var(--cream-50); border-color: var(--ink); font-weight: 700; }
  .pagination .dots { border: 0; background: transparent; color: var(--fg-muted); }

  /* ----- profile detail layout ----- */
  .profile-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: var(--space-6); }
  @media (max-width: 56rem) { .profile-grid { grid-template-columns: 1fr; } }
  .pblock {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-6);
    margin-block-end: var(--space-4);
  }
  .pblock h2 { font-size: 1.3rem; font-weight: 700; margin-block-end: var(--space-3); letter-spacing: -0.015em; }
  .pblock p { color: var(--fg-muted); margin-block-end: var(--space-2); }
  .pblock ul { display: flex; flex-direction: column; gap: var(--space-2); }
  .pblock ul li { display: flex; gap: var(--space-2); color: var(--ink-soft); line-height: 1.55; }
  .pblock ul li::before { content: "•"; color: var(--accent); flex: 0 0 auto; }
  .phead { display: flex; gap: var(--space-5); align-items: center; flex-wrap: wrap; }
  .phead__avatar {
    inline-size: 88px; block-size: 88px; border-radius: 50%;
    background: var(--bg-sunken); color: var(--fg-muted);
    display: grid; place-items: center; font-size: 2rem; font-weight: 700; flex-shrink: 0;
  }
  .phead h1 { font-size: 1.8rem; font-weight: 800; letter-spacing: -0.02em; display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
  .phead .meta {
    display: flex; gap: var(--space-4); flex-wrap: wrap;
    font-size: 0.85rem; color: var(--fg-muted); margin-block: var(--space-2);
  }
  .phead .rating {
    display: flex; gap: var(--space-2); align-items: baseline; margin-block-end: var(--space-3);
    font-size: 0.92rem; color: var(--fg-muted);
  }
  .phead .rating .num { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--ink); font-size: 1.4rem; }
  .phead__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-block-start: var(--space-2); }
  .services { display: flex; flex-wrap: wrap; gap: var(--space-2); }
  .services span {
    padding: 0.4rem 0.8rem; border-radius: var(--r-pill);
    background: var(--bg-sunken); color: var(--ink); font-size: 0.85rem;
  }
  .gallery {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-2);
  }
  .gallery div {
    aspect-ratio: 4/3; background: var(--bg-sunken); border-radius: var(--r-2);
    display: grid; place-items: center; color: var(--fg-muted); font-size: 0.82rem;
  }
  .empty-state {
    text-align: center; padding: var(--space-7) var(--space-5);
    background: var(--bg-sunken); border: 1px dashed var(--border); border-radius: var(--r-3);
  }
  .empty-state h3 { font-size: 1.1rem; font-weight: 700; margin-block-end: var(--space-2); }
  .empty-state p { color: var(--fg-muted); max-inline-size: 50ch; margin-inline: auto; font-size: 0.92rem; }

  .sidebox {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
    margin-block-end: var(--space-4); position: sticky; inset-block-start: 90px;
  }
  .sidebox__price { display: flex; align-items: baseline; gap: var(--space-1); margin-block: var(--space-3); }
  .sidebox__price .num { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2.2rem; color: var(--ink); line-height: 1; }
  .sidebox__price .per { color: var(--fg-muted); font-size: 0.92rem; }
  .sidebox .btn { inline-size: 100%; justify-content: center; }
  .sidebox .btn + .btn { margin-block-start: var(--space-2); }
  .sidebox__note { font-size: 0.82rem; color: var(--fg-muted); margin-block: var(--space-2) var(--space-4); }

  .tip {
    background: color-mix(in oklab, var(--butter-soft) 60%, var(--bg-elev));
    border: 1px solid color-mix(in oklab, var(--butter) 35%, transparent);
    border-radius: var(--r-3); padding: var(--space-4) var(--space-5);
    font-size: 0.92rem; line-height: 1.5; color: var(--terracotta-deep);
  }
  .tip strong { color: var(--terracotta-deep); }

  /* job detail meta row */
  .job-meta-row { display: flex; gap: var(--space-5); flex-wrap: wrap; font-size: 0.9rem; color: var(--fg-muted); margin-block: var(--space-3); }
  .job-meta-row strong { color: var(--ink); }
  .pills-row { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-block: var(--space-3) var(--space-5); }

  /* ----- contact ----- */
  .contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--space-6); }
  @media (max-width: 56rem) { .contact-grid { grid-template-columns: 1fr; } }
  .contact-info {
    background: var(--sage); color: var(--cream-50);
    border-radius: var(--r-4); padding: var(--space-6);
    position: relative; overflow: hidden;
  }
  .contact-info h2 { font-size: 1.5rem; font-weight: 700; margin-block-end: var(--space-3); }
  .contact-info h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--butter-soft); }
  .contact-info > p { color: color-mix(in oklab, var(--cream-50) 80%, transparent); margin-block-end: var(--space-5); font-size: 0.95rem; }
  .contact-info > p a { color: var(--butter-soft); text-decoration: underline; font-weight: 600; }
  .contact-list { display: flex; flex-direction: column; gap: var(--space-4); }
  .contact-list .item { display: flex; gap: var(--space-3); align-items: flex-start; }
  .contact-list .icon {
    inline-size: 38px; block-size: 38px; border-radius: var(--r-2);
    background: color-mix(in oklab, var(--cream-50) 15%, transparent);
    display: grid; place-items: center; flex-shrink: 0;
  }
  .contact-list .icon svg { inline-size: 18px; block-size: 18px; }
  .contact-list .label { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.7; margin-block-end: 2px; }
  .contact-list .val { font-size: 0.95rem; }
  .contact-list .val a { color: var(--cream-50); text-decoration: underline; }
  .contact-form {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-4); padding: var(--space-6);
  }
  .contact-form h2 { font-size: 1.4rem; font-weight: 700; margin-block-end: var(--space-5); }

  /* ----- about / mission cards (kontakt + contact secondary) ----- */
  .mission-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
  @media (max-width: 56rem) { .mission-grid { grid-template-columns: 1fr; } }
  .mission {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-6);
    display: flex; flex-direction: column; gap: var(--space-3);
  }
  .mission__icon {
    font-family: var(--font-serif); font-style: italic; font-size: 2.4rem;
    color: var(--accent); line-height: 1;
  }
  .mission h3 { font-size: 1.15rem; font-weight: 700; }
  .mission p { color: var(--fg-muted); font-size: 0.92rem; line-height: 1.55; }

  /* ----- auth (login/register) ----- */
  .auth { padding-block: clamp(2rem, 5vw, 4rem); }
  .auth__back { margin-block-end: var(--space-4); }
  .auth__back a {
    display: inline-flex; align-items: center; gap: var(--space-2);
    color: var(--fg-muted); font-size: 0.9rem;
  }
  .auth__back a:hover { color: var(--accent); }
  .auth__wrap { max-inline-size: 480px; margin-inline: auto; }
  .auth__grid { display: grid; grid-template-columns: 1fr 0.85fr; gap: var(--space-6); align-items: start; max-inline-size: 1040px; margin-inline: auto; }
  @media (max-width: 56rem) { .auth__grid { grid-template-columns: 1fr; } }
  .auth__card {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-4); padding: clamp(1.5rem, 3vw, 2.5rem);
  }
  .auth__card h1 { font-size: 1.8rem; font-weight: 800; letter-spacing: -0.025em; margin-block-end: var(--space-2); }
  .auth__card h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .auth__sub { color: var(--fg-muted); margin-block-end: var(--space-5); }
  .auth__notice {
    padding: var(--space-3) var(--space-4); border-radius: var(--r-2);
    margin-block-end: var(--space-4); font-size: 0.9rem; line-height: 1.5;
  }
  .auth__notice--error { background: color-mix(in oklab, var(--terracotta) 12%, var(--cream-100)); color: var(--terracotta-deep); border: 1px solid color-mix(in oklab, var(--terracotta) 30%, transparent); }
  .auth__notice--success { background: color-mix(in oklab, var(--sage) 12%, var(--cream-100)); color: var(--sage-deep); border: 1px solid color-mix(in oklab, var(--sage) 30%, transparent); }
  .auth__notice--info { background: var(--butter-soft); color: var(--terracotta-deep); border: 1px solid color-mix(in oklab, var(--butter) 35%, transparent); }
  .auth__form .btn { inline-size: 100%; justify-content: center; }
  .auth__row {
    display: flex; justify-content: space-between; align-items: center; gap: var(--space-3);
    font-size: 0.88rem; color: var(--fg-muted); margin-block-end: var(--space-4); flex-wrap: wrap;
  }
  .auth__row label { display: inline-flex; align-items: center; gap: var(--space-2); cursor: pointer; }
  .auth__row a { color: var(--accent); }
  .auth__foot { text-align: center; margin-block-start: var(--space-5); padding-block-start: var(--space-4); border-block-start: 1px solid var(--border); font-size: 0.92rem; color: var(--fg-muted); }
  .auth__foot a { color: var(--accent); font-weight: 600; margin-inline-start: var(--space-2); }
  .auth__side {
    background: var(--sage); color: var(--cream-50);
    border-radius: var(--r-4); padding: var(--space-6);
    position: relative; overflow: hidden;
  }
  .auth__side h2 { font-size: 1.3rem; font-weight: 700; margin-block-end: var(--space-3); }
  .auth__side > p { color: color-mix(in oklab, var(--cream-50) 80%, transparent); margin-block-end: var(--space-4); font-size: 0.92rem; }
  .auth__side ul { display: flex; flex-direction: column; gap: var(--space-2); margin-block-end: var(--space-5); }
  .auth__side ul li { display: flex; gap: var(--space-2); align-items: start; font-size: 0.9rem; line-height: 1.5; }
  .auth__side ul li::before { content: "✓"; color: var(--butter-soft); font-weight: 700; flex: 0 0 auto; }
  .auth__price-mini {
    background: color-mix(in oklab, var(--cream-50) 12%, transparent);
    border-radius: var(--r-2); padding: var(--space-3) var(--space-4);
    display: flex; justify-content: space-between; align-items: center; gap: var(--space-2);
    font-size: 0.92rem;
  }
  .auth__price-mini strong { color: var(--butter-soft); font-family: var(--font-serif); font-style: italic; font-weight: 500; }

  .roletabs {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-2);
    margin-block-end: var(--space-5);
  }
  .roletabs label { cursor: pointer; min-inline-size: 0; }
  .roletabs input { position: absolute; opacity: 0; }
  .roletabs .pill {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-3); border-radius: var(--r-3);
    background: var(--bg); border: 1px solid var(--border);
    font-size: 0.88rem; color: var(--ink-soft); font-weight: 600;
    line-height: 1.25; min-block-size: 3.25rem;
    text-align: start;
    transition: all .15s ease;
    min-inline-size: 0;
  }
  .roletabs .pill svg { inline-size: 18px; block-size: 18px; flex-shrink: 0; }
  .roletabs .pill__text { flex: 1 1 0; min-inline-size: 0; overflow-wrap: anywhere; }

  /* ---------- pricing: promo strip + billing toggle + new pricing display ---------- */
  .promo-strip {
    display: flex; align-items: flex-start; gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: color-mix(in oklab, var(--butter) 22%, var(--bg));
    border: 1px solid color-mix(in oklab, var(--terracotta) 25%, transparent);
    border-radius: var(--r-3);
    margin-block-end: var(--space-5);
    max-inline-size: 64ch; margin-inline: auto;
  }
  .promo-strip__icon { font-size: 1.5rem; line-height: 1; flex-shrink: 0; }
  .promo-strip__body { font-size: 0.98rem; line-height: 1.55; color: var(--fg); }
  .promo-strip__body strong { color: var(--terracotta-deep); font-weight: 700; }

  .billing-toggle {
    display: inline-flex; gap: var(--space-1);
    padding: var(--space-1);
    background: var(--bg-sunken); border: 1px solid var(--border);
    border-radius: var(--r-pill);
    margin: 0 auto var(--space-6);
    justify-content: center;
  }
  .billing-toggle:has(> *) { display: flex; max-inline-size: max-content; }
  .billing-toggle__btn {
    appearance: none; border: 0; cursor: pointer;
    padding: var(--space-2) var(--space-5);
    background: transparent; border-radius: var(--r-pill);
    font: inherit; font-weight: 600; font-size: 0.95rem;
    color: var(--fg-muted);
    display: inline-flex; align-items: center; gap: var(--space-2);
    transition: background .15s, color .15s;
  }
  .billing-toggle__btn.is-active {
    background: var(--ink); color: var(--cream-50);
  }
  .billing-toggle__btn:hover:not(.is-active) { color: var(--ink); }
  .billing-toggle__save {
    font-size: 0.78rem; font-weight: 700;
    padding: 2px var(--space-2); border-radius: var(--r-pill);
    background: color-mix(in oklab, var(--sage) 30%, var(--bg));
    color: var(--sage-deep);
    text-transform: uppercase; letter-spacing: 0.04em;
  }
  .billing-toggle__btn.is-active .billing-toggle__save {
    background: color-mix(in oklab, var(--butter) 70%, var(--ink));
    color: var(--ink);
  }
  @media (max-width: 32rem) {
    .billing-toggle { inline-size: 100%; max-inline-size: none; }
    .billing-toggle__btn { flex: 1; justify-content: center; padding: var(--space-3); flex-wrap: wrap; }
  }

  .price-card__amount { flex-wrap: wrap; }
  .price-card__strike {
    flex-basis: 100%;
    color: var(--fg-muted);
    text-decoration: line-through;
    font-size: 1rem;
    font-weight: 500;
    white-space: nowrap;
    line-height: 1.2;
    margin-block-end: -2px;
  }
  .price-card__promo {
    margin-block-start: var(--space-2);
    font-size: 0.88rem; color: var(--terracotta-deep);
    line-height: 1.45;
  }
  .price-card__promo strong { color: var(--ink); font-weight: 700; }

  /* ---------- blog: listing + single ---------- */
  .article-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-6);
    margin-block-end: var(--space-7);
  }
  .article-card {
    display: flex; flex-direction: column;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-4);
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
  }
  .article-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); }
  .article-card__thumb {
    display: block; aspect-ratio: 16 / 10;
    background: var(--bg-sunken);
    overflow: hidden;
  }
  .article-card__thumb img { inline-size: 100%; block-size: 100%; object-fit: cover; display: block; }
  .article-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); flex: 1 1 auto; }
  .article-card__cat {
    align-self: flex-start;
    font-family: var(--font-serif); font-style: italic; font-weight: 500;
    color: var(--accent); font-size: 0.92rem; text-decoration: none;
    text-transform: lowercase;
  }
  .article-card__cat:hover { color: var(--terracotta-deep); text-decoration: underline; }
  .article-card__title { font-size: 1.25rem; font-weight: 700; line-height: 1.3; text-wrap: balance; }
  .article-card__title a { color: var(--ink); text-decoration: none; }
  .article-card__title a:hover { color: var(--accent); }
  .article-card__excerpt { color: var(--fg-muted); font-size: 0.95rem; line-height: 1.55; flex: 1 1 auto; }
  .article-card__meta { display: flex; align-items: center; gap: var(--space-2); font-size: 0.85rem; color: var(--fg-muted); margin-block-start: auto; padding-block-start: var(--space-3); border-block-start: 1px solid var(--border); }

  .article-empty {
    text-align: center;
    padding-block: var(--space-9);
    max-inline-size: 56ch; margin-inline: auto;
  }
  .article-empty__icon { font-size: 3rem; display: block; margin-block-end: var(--space-4); }

  .pagination {
    display: flex; gap: var(--space-2); justify-content: center;
    margin-block-start: var(--space-6);
  }
  .pagination .page-numbers {
    min-inline-size: 40px; min-block-size: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    padding-inline: var(--space-3);
    border-radius: var(--r-pill);
    background: var(--bg); border: 1px solid var(--border);
    color: var(--ink); text-decoration: none; font-weight: 600;
    transition: all .15s;
  }
  .pagination .page-numbers:hover { background: var(--bg-sunken); border-color: var(--accent); }
  .pagination .page-numbers.current { background: var(--ink); color: var(--cream-50); border-color: var(--ink); }

  /* ---------- single post ---------- */
  .post-hero h1 {
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    max-inline-size: 24ch;
    text-wrap: balance;
  }
  .post-meta {
    display: flex; align-items: center; gap: var(--space-3);
    margin-block-start: var(--space-6);
  }
  .post-meta__avatar {
    inline-size: 44px; block-size: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--butter), var(--terracotta));
    color: var(--cream-50);
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 1.1rem;
  }
  .post-meta__author { display: block; font-weight: 700; color: var(--ink); }
  .post-meta__sub { display: block; font-size: 0.88rem; color: var(--fg-muted); margin-block-start: 2px; }
  .post-meta__sub span + span { margin-inline-start: var(--space-1); }

  .post-thumb {
    margin-block: var(--space-6);
  }
  .post-thumb img {
    inline-size: 100%; block-size: auto;
    border-radius: var(--r-4);
    aspect-ratio: 16 / 9;
    object-fit: cover;
  }

  .post-content h2 { font-size: clamp(1.4rem, 2.5vw, 1.8rem); font-weight: 700; margin-block: var(--space-7) var(--space-3); letter-spacing: -0.015em; }
  .post-content h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .post-content h3 { font-size: 1.25rem; font-weight: 700; margin-block: var(--space-6) var(--space-3); }
  .post-content ul,
  .post-content ol { margin-block: var(--space-4); padding-inline-start: var(--space-5); }
  .post-content li { margin-block: var(--space-2); line-height: 1.65; }
  .post-content li::marker { color: var(--accent); }
  .post-content blockquote {
    border-inline-start: 3px solid var(--accent);
    padding-inline-start: var(--space-5);
    margin-block: var(--space-6);
    font-family: var(--font-serif); font-style: italic; font-weight: 400;
    font-size: 1.2rem; color: var(--ink-soft);
  }
  .post-content img,
  .post-content figure { margin-block: var(--space-5); border-radius: var(--r-3); }
  .post-content a { color: var(--accent); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
  .post-content a:hover { color: var(--terracotta-deep); }
  .post-content code {
    background: var(--bg-sunken); padding: 2px 6px; border-radius: 4px;
    font-size: 0.92em;
  }

  .post-tags {
    display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2);
    margin-block-start: var(--space-7);
    max-inline-size: 64ch; margin-inline: auto;
  }
  .post-tags__label { color: var(--fg-muted); font-size: 0.9rem; margin-inline-end: var(--space-2); }
  .post-tags__chip {
    display: inline-flex; align-items: center;
    padding: 4px 12px;
    border-radius: var(--r-pill);
    background: var(--bg-sunken);
    color: var(--fg);
    text-decoration: none; font-size: 0.85rem; font-weight: 600;
    transition: background .15s, color .15s;
  }
  .post-tags__chip:hover { background: color-mix(in oklab, var(--accent) 18%, var(--bg-sunken)); color: var(--accent); }

  .post-nav {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4);
    margin-block-start: var(--space-7);
    max-inline-size: 64ch; margin-inline: auto;
  }
  @media (max-width: 40rem) { .post-nav { grid-template-columns: 1fr; } }
  .post-nav__item {
    display: flex; flex-direction: column; gap: var(--space-1);
    padding: var(--space-4) var(--space-5);
    background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-3);
    text-decoration: none;
    transition: all .15s;
  }
  .post-nav__item:hover { border-color: var(--accent); transform: translateY(-2px); }
  .post-nav__item--next { text-align: end; }
  .post-nav__label { font-size: 0.82rem; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
  .post-nav__title { color: var(--ink); font-weight: 700; font-size: 0.98rem; line-height: 1.35; }

  /* ---------- about-prose (O nás page) ---------- */
  .about-prose { max-inline-size: 64ch; margin-inline: auto; }
  .about-prose p {
    color: var(--fg); font-size: clamp(1.02rem, 1.2vw, 1.12rem); line-height: 1.7;
    margin-block-start: var(--space-4);
    text-wrap: pretty;
  }
  .about-prose p strong { color: var(--ink); font-weight: 700; }
  .about-prose .eyebrow { color: var(--accent); }
  .roletabs label:hover .pill { border-color: var(--accent); color: var(--accent); }
  .roletabs input:checked + .pill {
    background: color-mix(in oklab, var(--accent) 12%, var(--bg-elev));
    border-color: var(--accent); color: var(--accent);
  }

  /* ----- dashboard ----- */
  .dash { padding-block: var(--space-7); }
  .dash__welcome {
    display: flex; justify-content: space-between; align-items: center;
    gap: var(--space-5); margin-block-end: var(--space-6); flex-wrap: wrap;
  }
  .dash__welcome-left { display: flex; gap: var(--space-4); align-items: center; }
  .dash__avatar {
    inline-size: 64px; block-size: 64px; border-radius: 50%;
    background: linear-gradient(135deg, var(--butter), var(--terracotta));
    color: var(--cream-50); display: grid; place-items: center;
    font-size: 1.4rem; font-weight: 800;
  }
  .dash__role-badge {
    display: inline-block; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--accent); font-weight: 700; margin-block-end: var(--space-1);
  }
  .dash__welcome h1 { font-size: 1.8rem; font-weight: 800; letter-spacing: -0.025em; }
  .dash__welcome h1 span { color: var(--accent); }
  .dash__who-meta { display: flex; gap: var(--space-4); flex-wrap: wrap; font-size: 0.85rem; color: var(--fg-muted); margin-block-start: var(--space-2); }
  .dash__who-meta span { display: inline-flex; align-items: center; gap: var(--space-2); }
  .dash__who-meta svg { inline-size: 14px; block-size: 14px; }
  .dash__welcome-right { display: flex; gap: var(--space-2); flex-wrap: wrap; }

  .dash__stats {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-4);
    margin-block-end: var(--space-6);
  }
  @media (max-width: 56rem) { .dash__stats { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
  .dash__stat {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
  }
  .dash__stat .lbl { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 0.82rem; color: var(--fg-muted); margin-block-end: var(--space-3); }
  .dash__stat .lbl svg { inline-size: 14px; block-size: 14px; }
  .dash__stat .num { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2rem; color: var(--ink); line-height: 1; }
  .dash__stat .delta { font-size: 0.78rem; color: var(--sage-deep); margin-block-start: var(--space-2); }
  .dash__stat .delta.muted { color: var(--fg-muted); }

  .dash__grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--space-5); }
  @media (max-width: 56rem) { .dash__grid { grid-template-columns: 1fr; } }
  .dash__card {
    background: var(--bg-elev); border: 1px solid var(--border);
    border-radius: var(--r-3); padding: var(--space-5);
    margin-block-end: var(--space-4);
  }
  .dash__card h2 {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 1.1rem; font-weight: 700; margin-block-end: var(--space-4); gap: var(--space-3);
  }
  .dash__card h2 a { font-size: 0.85rem; color: var(--accent); font-weight: 500; }

  .dash__tabs { display: flex; gap: var(--space-1); margin-block-end: var(--space-4); border-block-end: 1px solid var(--border); }
  .dash__tabs button {
    padding: var(--space-3) var(--space-4); font-size: 0.88rem; font-weight: 600;
    color: var(--fg-muted); border-block-end: 2px solid transparent;
    margin-block-end: -1px; transition: color .15s ease, border-color .15s ease;
  }
  .dash__tabs button:hover { color: var(--accent); }
  .dash__tabs button.active { color: var(--accent); border-block-end-color: var(--accent); }

  .dash__activity { display: flex; flex-direction: column; }
  .dash__activity-item {
    display: grid; grid-template-columns: auto 1fr auto; gap: var(--space-3); align-items: start;
    padding-block: var(--space-3); border-block-start: 1px solid var(--border);
  }
  .dash__activity-item:first-child { border-block-start: 0; padding-block-start: 0; }
  .dash__activity-item .av {
    inline-size: 36px; block-size: 36px; border-radius: 50%;
    background: color-mix(in oklab, var(--butter) 35%, var(--cream-200));
    display: grid; place-items: center; font-weight: 700; font-size: 0.8rem; color: var(--ink);
  }
  .dash__activity-item .body strong { display: block; font-size: 0.92rem; margin-block-end: 2px; }
  .dash__activity-item .body p { font-size: 0.88rem; color: var(--fg-muted); line-height: 1.5; margin: 0; }
  .dash__activity-item .time { font-size: 0.78rem; color: var(--fg-muted); white-space: nowrap; }

  .dash__progress { margin-block: var(--space-3) var(--space-4); }
  .dash__progress-bar { block-size: 8px; background: var(--bg-sunken); border-radius: var(--r-pill); overflow: hidden; }
  .dash__progress-fill { block-size: 100%; background: linear-gradient(90deg, var(--butter), var(--terracotta)); border-radius: var(--r-pill); transition: width .4s ease; }
  .dash__progress-meta { display: flex; justify-content: space-between; margin-block-start: var(--space-2); font-size: 0.82rem; color: var(--fg-muted); }
  .dash__progress-meta .pct { font-family: var(--font-serif); font-style: italic; font-weight: 500; color: var(--accent); }
  .dash__checklist { display: flex; flex-direction: column; gap: var(--space-2); }
  .dash__checklist li { display: flex; gap: var(--space-3); align-items: center; font-size: 0.92rem; color: var(--ink-soft); }
  .dash__checklist li::before {
    content: ""; inline-size: 18px; block-size: 18px; border-radius: 50%;
    border: 2px solid var(--border); flex: 0 0 auto;
  }
  .dash__checklist li.done { color: var(--fg-muted); text-decoration: line-through; }
  .dash__checklist li.done::before { background: var(--sage); border-color: var(--sage); content: "✓"; color: var(--cream-50); font-size: 0.7rem; display: grid; place-items: center; font-weight: 700; }

  .dash__plan { background: linear-gradient(160deg, var(--butter-soft), var(--cream-100)); }
  .dash__plan .plan-name { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--terracotta-deep); font-weight: 700; }
  .dash__plan .plan-tier { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 2rem; color: var(--ink); line-height: 1; margin-block: var(--space-2); }
  .dash__plan .plan-stat { font-size: 0.88rem; color: var(--ink-soft); margin-block-end: var(--space-4); }

  .dash__actions { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); }
  .dash__action {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-3); border-radius: var(--r-2);
    font-size: 0.85rem; font-weight: 500; color: var(--ink-soft);
    background: var(--bg-sunken); transition: background .15s ease, color .15s ease;
  }
  .dash__action svg { inline-size: 16px; block-size: 16px; flex-shrink: 0; }
  .dash__action:hover { background: color-mix(in oklab, var(--accent) 10%, var(--bg-sunken)); color: var(--accent); }
  .dash__action--danger { color: var(--terracotta-deep); }
  .dash__action--danger:hover { background: color-mix(in oklab, var(--terracotta) 15%, var(--bg-sunken)); color: var(--terracotta-deep); }

  /* ---------- ribbon (announce bar nad header) ---------- */
  .ribbon {
    background: linear-gradient(95deg, var(--butter-soft), color-mix(in oklab, var(--butter) 60%, var(--bg)));
    color: var(--ink);
    font-size: 0.92rem;
    border-block-end: 1px solid color-mix(in oklab, var(--butter) 40%, transparent);
  }
  .ribbon__inner {
    display: flex; align-items: center; gap: var(--space-4);
    padding-block: var(--space-2);
    flex-wrap: wrap;
  }
  .ribbon__icon { font-size: 1.05rem; line-height: 1; }
  .ribbon__text { flex: 1 1 auto; min-inline-size: 0; }
  .ribbon__text strong { font-weight: 700; margin-inline-end: 0.25rem; }
  .ribbon__cta {
    display: inline-flex; align-items: center; gap: 0.35rem;
    font-weight: 600; color: var(--terracotta-deep);
    text-decoration: none;
    border-block-end: 1px solid color-mix(in oklab, var(--terracotta-deep) 35%, transparent);
    padding-block-end: 1px;
    transition: color .15s, border-color .15s;
  }
  .ribbon__cta:hover { color: var(--terracotta); border-block-end-color: var(--terracotta); }
  @media (max-width: 36rem) {
    .ribbon { font-size: 0.85rem; }
    .ribbon__inner { gap: var(--space-2); padding-block: var(--space-2); }
  }

  /* ---------- theme toggle (light / dark / saver) ---------- */
  .theme-toggle {
    appearance: none; border: 1px solid var(--border); background: var(--bg-elev);
    inline-size: 40px; block-size: 40px;
    border-radius: var(--r-pill);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; color: var(--fg);
    transition: background .15s, color .15s, border-color .15s, transform .15s;
    flex-shrink: 0;
  }
  .theme-toggle:hover { border-color: var(--accent); color: var(--accent); transform: rotate(15deg); }
  .theme-toggle svg { inline-size: 18px; block-size: 18px; }
  .theme-toggle__icon { display: none; }
  :root[data-theme="light"] .theme-toggle__icon--light,
  html:not([data-theme]) .theme-toggle__icon--light { display: block; }
  :root[data-theme="dark"] .theme-toggle__icon--dark { display: block; }
  :root[data-theme="saver"] .theme-toggle__icon--saver { display: block; }

  /* ---------- dark mode component tweaks (override hardcoded paletové farby) ---------- */
  :root[data-theme="dark"] .ribbon { background: linear-gradient(95deg, #2A2218, #1F1A12); color: var(--fg); }
  :root[data-theme="dark"] .ribbon__text strong,
  :root[data-theme="dark"] .ribbon__cta { color: var(--butter); border-color: rgba(232, 182, 99, 0.4); }
  :root[data-theme="dark"] .hero__blob { opacity: 0.4; }
  :root[data-theme="dark"] .promo-strip { background: rgba(232, 182, 99, 0.08); border-color: rgba(196, 98, 62, 0.4); }
  :root[data-theme="dark"] .cta-band { background: var(--bg-sunken); border: 1px solid var(--border); }
  :root[data-theme="dark"] .footer__legal,
  :root[data-theme="dark"] .footer__bottom { color: var(--fg-muted); }
  :root[data-theme="dark"] .price-card,
  :root[data-theme="dark"] .article-card,
  :root[data-theme="dark"] .payflow__step,
  :root[data-theme="dark"] .post-nav__item { background: var(--bg-elev); }
  :root[data-theme="dark"] .billing-toggle__btn.is-active { background: var(--accent); }
  /* dark: invisible buttons fix — ink bg + cream text becomes light on light */
  :root[data-theme="dark"] .btn--primary { background: var(--accent); color: #FAF6EE; }
  :root[data-theme="dark"] .btn--primary:hover { background: var(--terracotta-deep); }
  :root[data-theme="dark"] .btn--ghost { color: var(--fg); border-color: var(--border); }
  :root[data-theme="dark"] .btn--ghost:hover { background: var(--bg-elev); }
  :root[data-theme="dark"] .cta-band .btn--primary { background: var(--butter); color: #1A1612; }
  :root[data-theme="dark"] .cta-band .btn--primary:hover { background: var(--terracotta); color: #FAF6EE; }
  /* dark: pcard tweaks — firms card was cream-200 (raw, not rebound) */
  :root[data-theme="dark"] .pcard--firms { background: var(--bg-elev); color: var(--fg); }
  :root[data-theme="dark"] .pcard--firms .pcard__eyebrow { color: var(--accent); }
  :root[data-theme="dark"] .pcard__shape { opacity: 0.35; }
  /* dark: hero card — slight dim of bright gradient */
  :root[data-theme="dark"] .hero-card { background: linear-gradient(160deg, #3A2A18, var(--terracotta-deep) 80%); }
  /* dark: marker highlight on hero title — butter-soft on dark text reads bad */
  :root[data-theme="dark"] .hero__title .marker { background: linear-gradient(transparent 60%, rgba(232, 182, 99, 0.4) 60%); }

  /* ---------- saver mode — pure black + no motion + simplified bg ---------- */
  :root[data-theme="saver"] *,
  :root[data-theme="saver"] *::before,
  :root[data-theme="saver"] *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
  :root[data-theme="saver"] .ribbon { background: var(--bg-elev); color: var(--fg); border-block-end-color: var(--border); }
  :root[data-theme="saver"] .ribbon__text strong { color: var(--accent); }
  :root[data-theme="saver"] .ribbon__cta { color: var(--accent); border-block-end-color: var(--accent); }
  :root[data-theme="saver"] .hero__blob,
  :root[data-theme="saver"] .cat__blob,
  :root[data-theme="saver"] .pcard__shape,
  :root[data-theme="saver"] .cta-band__visual { display: none !important; }
  :root[data-theme="saver"] .hero-card { background: var(--bg-elev) !important; border: 1px solid var(--border); }
  :root[data-theme="saver"] .hero-card__img,
  :root[data-theme="saver"] .post-thumb img,
  :root[data-theme="saver"] .article-card__thumb img { filter: brightness(0.85) contrast(1.1); }
  :root[data-theme="saver"] .cat,
  :root[data-theme="saver"] .price-card,
  :root[data-theme="saver"] .article-card,
  :root[data-theme="saver"] .payflow__step,
  :root[data-theme="saver"] .post-nav__item { background: var(--bg-elev); border-color: var(--border); }
  :root[data-theme="saver"] .cta-band { background: var(--bg-elev); border: 1px solid var(--border); }
  :root[data-theme="saver"] .promo-strip { background: var(--bg-elev); border-color: var(--border); }
  :root[data-theme="saver"] .cta-band .btn--primary { background: var(--accent); color: var(--bg); }
  :root[data-theme="saver"] .billing-toggle { background: var(--bg-elev); }
  :root[data-theme="saver"] .billing-toggle__btn.is-active { background: var(--accent); color: #000; }
  /* saver: invisible buttons fix */
  :root[data-theme="saver"] .btn--primary { background: var(--accent); color: #F0F0F0; }
  :root[data-theme="saver"] .btn--primary:hover { background: var(--terracotta-deep); }
  :root[data-theme="saver"] .btn--ghost { color: var(--fg); border-color: var(--border); }
  :root[data-theme="saver"] .btn--ghost:hover { background: var(--bg-elev); }
  :root[data-theme="saver"] .cta-band .btn--primary { background: var(--accent); color: #000; }
  :root[data-theme="saver"] .pcard--firms,
  :root[data-theme="saver"] .pcard--workers { background: var(--bg-elev); color: var(--fg); border: 1px solid var(--border); }
  :root[data-theme="saver"] .pcard--firms .pcard__eyebrow,
  :root[data-theme="saver"] .pcard--workers .pcard__eyebrow { color: var(--accent); }
  :root[data-theme="saver"] .hero-card { background: var(--bg-elev) !important; }
  :root[data-theme="saver"] .hero__title .marker { background: transparent; color: var(--accent); }

  /* respect OS-level reduced motion always */
  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      transition-duration: 0.01ms !important;
      animation-duration: 0.01ms !important;
    }
  }
}

/* ---------- utilities ---------- */
@layer utilities {
  .full-bleed { inline-size: 100vw; margin-inline: calc(50% - 50vw); }
  .center { text-align: center; }
  .stack-3 > * + * { margin-block-start: var(--space-3); }
  .stack-4 > * + * { margin-block-start: var(--space-4); }
  .stack-5 > * + * { margin-block-start: var(--space-5); }
}
