/* ============================================================
   Linenform mockups — shared design system
   Auto-extracted from 114 v1.0 wireframes. Linked by every
   mockup as <link rel="stylesheet" href="../styles.css">.
   One canonical body per selector (modal across the corpus);
   per-file <style> residuals (loaded after) override tokens,
   base/element resets, and any deviating component bodies.
   ============================================================ */

:root {
  --linen: #EFEAE0;
  --linen-soft: #F5F1E8;
  --linen-deep: #E3DCCB;
  --forest: #2D6A4F;
  --forest-deep: #1F4A37;
  --ink: #1F2421;
  --ink-soft: #4A524C;
  --ink-muted: #7A827C;
  --paper: #FBF8F1;
  --paper-pure: #FFFFFF;
  --font-heading: Georgia, serif;
  --font-body: 'Plus Jakarta Sans', -apple-system, system-ui, sans-serif;
  --font-mono: "SF Mono", Menlo, Consolas, monospace;
  --fs-3xs: 10px;
  --fs-2xs: 11px;
  --fs-xs: 12px;
  --fs-sm: 13px;
  --fs-base: 15px;
  --fs-md: 17px;
  --fs-lg: 20px;
  --fs-xl: 26px;
  --fs-2xl: 34px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-7: 32px;
  --sp-8: 40px;
  --r-md: 8px;
  --r-lg: 12px;
  --r-pill: 999px;
  --container-max: 1200px;
  --container-px: 24px;
  --nav-h: 56px;

  /* semantic colour tokens — promoted from per-file residual :root (Sweep 2) */
  --accent: #2D6A4F;
  --accent-deep: #1F4A37;
  --alert: #B5524A;
  --alert-deep: #8E3F38;
  --warning: #B58A2E;
  --warning-deep: #8E6E25;
  /* C.16 — autosave conflict accent (between alert and warning). Added in
     P4a.1 reconciliation so mockups/styles.css and src/app.css agree on the
     :root token set. Dark-theme override deferred — no dark mockup currently
     exhibits the autosave conflict surface. */
  --warn: #B8702E;
  --info: #4A6B82;
  --info-deep: #324E63;
  --success: #2D6A4F;
  --note-bg: #F5EFDF;
  --forest-soft: #3D8064;
  --green-up: #2D6A4F;
  --red-down: #B5524A;

  /* interaction-state shadow tokens */
  --focus-ring: 0 0 0 3px rgba(45, 106, 79, 0.1);
}

/* Dark theme — token inversion per dark-mode-pattern.html.
   Applied via explicit class (html.theme-dark) OR via prefers-color-scheme
   when the user hasn't opted out. Single ruleset re-themes all shared
   selectors that consume tokens via var(...). */
html.theme-dark {
  --linen: #1A1E1B;
  --linen-soft: #1F2421;
  --linen-deep: #3A3F3B;
  --paper: #232826;
  --paper-pure: #2D332F;
  --ink: #ECE7DC;
  --ink-soft: #C5C0B6;
  --ink-muted: #8C918A;
  --note-bg: #332E1F;
  --forest: #4CAF7F;
  --forest-deep: #3D8064;
  --forest-soft: #5DC890;
  --accent: #4CAF7F;
  --accent-deep: #3D8064;
  --alert: #D27A73;
  --alert-deep: #B5524A;
  --warning: #D4A84C;
  --warning-deep: #B58A2E;
  --info: #7A9CB5;
  --info-deep: #4A6B82;
  --success: #4CAF7F;
  --green-up: #4CAF7F;
  --red-down: #D27A73;
  --focus-ring: 0 0 0 3px rgba(76, 175, 127, 0.20);
}

@media (prefers-color-scheme: dark) {
  html:not(.theme-light) {
    --linen: #1A1E1B;
    --linen-soft: #1F2421;
    --linen-deep: #3A3F3B;
    --paper: #232826;
    --paper-pure: #2D332F;
    --ink: #ECE7DC;
    --ink-soft: #C5C0B6;
    --ink-muted: #8C918A;
    --note-bg: #332E1F;
    --forest: #4CAF7F;
    --forest-deep: #3D8064;
    --forest-soft: #5DC890;
    --accent: #4CAF7F;
    --accent-deep: #3D8064;
    --alert: #D27A73;
    --alert-deep: #B5524A;
    --warning: #D4A84C;
    --warning-deep: #B58A2E;
    --info: #7A9CB5;
    --info-deep: #4A6B82;
    --success: #4CAF7F;
    --green-up: #4CAF7F;
    --red-down: #D27A73;
    --focus-ring: 0 0 0 3px rgba(76, 175, 127, 0.20);
  }
}

*, *::before, *::after { box-sizing: border-box; }
.mockup-banner { background: var(--ink); color: var(--linen); font-size: var(--fs-xs); text-align: center; padding: 6px var(--container-px); letter-spacing: 0.08em; text-transform: uppercase; }
.mockup-banner a { color: var(--linen); text-decoration: underline; }
.site-nav { padding: var(--sp-5) var(--container-px); }
.site-nav__inner { max-width: var(--container-max); margin: 0 auto; display: flex; justify-content: space-between; align-items: center; }
.site-brand { font-family: var(--font-heading); font-size: var(--fs-lg); color: var(--ink); }
.site-brand::after { content: '.'; color: var(--forest); }
.site-nav__links { display: flex; align-items: center; gap: var(--sp-7); }
.site-nav__link { font-size: var(--fs-sm); color: var(--ink-soft); }
.site-nav__signin { font-size: var(--fs-sm); color: var(--ink); padding: 8px 16px; border-radius: var(--r-md); border: 1px solid var(--linen-deep); }
.container { max-width: var(--container-max); margin: 0 auto; }
.container--narrow { max-width: 820px; }
.eyebrow { font-size: var(--fs-xs); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-muted); font-weight: 500; }
.hero { padding: var(--sp-10) 0 var(--sp-9); text-align: center; }
.hero__eyebrow { margin-bottom: var(--sp-5); }
.hero h1 { font-size: var(--fs-3xl); margin: var(--sp-4) 0 var(--sp-4); }
.hero__sub { font-size: var(--fs-lg); color: var(--ink-soft); max-width: 580px; margin: 0 auto var(--sp-8); line-height: 1.55; }
.btn { display: inline-flex; align-items: center; gap: var(--sp-2); padding: 9px 16px; border-radius: var(--r-md); font-size: var(--fs-sm); font-weight: 500; font-family: var(--font-body); line-height: 1; }
.btn--primary { background: var(--forest); color: var(--paper-pure); }
.btn--primary:hover { background: var(--forest-deep); }
.btn--ghost { color: var(--ink-soft); }
.btn--ghost:hover { color: var(--ink); }
.btn--secondary { background: transparent; color: var(--ink); border: 1px solid var(--linen-deep); }
.btn--secondary:hover { background: var(--linen-soft); }
.section { margin-bottom: var(--sp-7); padding-bottom: var(--sp-6); border-bottom: 1px solid var(--linen-deep); }
.section-title { font-family: var(--font-heading); font-size: var(--fs-xl); color: var(--ink); margin-bottom: var(--sp-5); letter-spacing: -0.015em; }
.final-cta { padding: var(--sp-10) 0; text-align: center; }
.final-cta h2 { font-size: var(--fs-2xl); margin-bottom: var(--sp-4); }
.final-cta p { color: var(--ink-soft); margin-bottom: var(--sp-6); }
.footer-note { font-size: var(--fs-xs); color: var(--ink-muted); text-align: center; margin-top: var(--sp-8); padding-top: var(--sp-5); border-top: 1px solid var(--linen-deep); }
.site-nav__link.is-active { color: var(--ink); font-weight: 500; }
.hero p { color: var(--ink-soft); font-size: var(--fs-lg); margin-bottom: var(--sp-6); }
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-9); }
.field { margin-bottom: var(--sp-5); }
.field__label { display: block; font-size: var(--fs-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; margin-bottom: 6px; }
.field__input, .field__textarea { width: 100%; padding: 12px 14px; font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink); background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); }
.field__textarea { min-height: 130px; resize: vertical; }
.radio-stack { display: flex; flex-direction: column; gap: var(--sp-2); }
.radio { display: flex; align-items: center; gap: var(--sp-3); padding: 11px 14px; background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); font-size: var(--fs-sm); cursor: pointer; }
.radio.is-checked { border-color: var(--forest); background: rgba(45,106,79,0.04); }
.radio__mark { width: 16px; height: 16px; border: 1.5px solid var(--ink-muted); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.is-checked .radio__mark { border-color: var(--forest); }
.is-checked .radio__mark::after { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--forest); }
.form-foot { display: flex; justify-content: space-between; align-items: center; margin-top: var(--sp-6); padding-top: var(--sp-5); border-top: 1px solid var(--linen-deep); }
.hero__updated { font-size: var(--fs-xs); color: var(--ink-muted); letter-spacing: 0.08em; text-transform: uppercase; }
.layout { padding: var(--sp-9) 0 var(--sp-9); display: grid; grid-template-columns: 240px 1fr; gap: var(--sp-8); align-items: start; }
.toc { position: sticky; top: var(--sp-5); font-size: var(--fs-sm); }
.toc__title { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; padding: 0 12px var(--sp-3); border-bottom: 1px solid var(--linen-deep); margin-bottom: var(--sp-3); }
.toc ol { list-style: none; }
.toc li { margin-bottom: 2px; }
.toc a { display: block; padding: 6px 12px; color: var(--ink-soft); border-radius: var(--r-md); font-size: 13px; }
.toc a:hover { background: var(--paper); color: var(--ink); }
.toc a.is-active { background: var(--paper); color: var(--ink); font-weight: 500; border-left: 2px solid var(--forest); padding-left: 10px; }
.body { max-width: 660px; }
.body section { margin-bottom: var(--sp-9); }
.body section:last-child { margin-bottom: 0; }
.section__num { font-size: var(--fs-xs); letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-muted); font-weight: 600; margin-bottom: var(--sp-3); }
.body h2 { font-size: var(--fs-xl); margin-bottom: var(--sp-4); }
.body p { margin: 0 0 var(--sp-5); color: var(--ink); line-height: 1.7; }
.body p strong { font-weight: 500; }
.foot { padding: var(--sp-9) 0; border-top: 1px solid var(--linen-deep); text-align: center; font-size: var(--fs-sm); color: var(--ink-soft); }
.foot a { color: var(--forest); text-decoration: underline; }
img, svg { display: block; max-width: 100%; }
.btn--google { background: var(--paper-pure); color: var(--ink); border: 1px solid var(--linen-deep); }
.btn--google:hover { border-color: var(--ink-muted); background: var(--paper); }
.divider { border: 0; border-top: 1px solid var(--linen-deep); margin: var(--sp-5) 0; }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--linen-deep); }
.field__input { width: 100%; padding: 11px 14px; font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink); background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); transition: border-color .15s, box-shadow .15s; }
.field__input:focus { outline: 0; border-color: var(--forest); box-shadow: 0 0 0 3px rgba(45,106,79,0.10); }
.top-brand { padding: var(--sp-7) var(--sp-7) 0; max-width: 1200px; margin: 0 auto; width: 100%; }
.brand { font-family: var(--font-heading); font-size: var(--fs-md); color: var(--ink); }
.brand::after { content: '.'; color: var(--forest); }
.wrap { flex: 1; display: flex; align-items: center; justify-content: center; padding: var(--sp-7) var(--sp-5); }
.card { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-9) var(--sp-8); max-width: 460px; width: 100%; text-align: center; }
.icon-wrap { width: 56px; height: 56px; margin: 0 auto var(--sp-5); border-radius: 50%; background: rgba(45,106,79,0.10); color: var(--forest); display: inline-flex; align-items: center; justify-content: center; }
.card h1 { font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.card__lede { color: var(--ink-soft); font-size: var(--fs-base); margin-bottom: var(--sp-7); line-height: 1.6; max-width: 36ch; margin-left: auto; margin-right: auto; }
.card__email { font-family: var(--font-heading); color: var(--ink); font-size: var(--fs-md); margin-bottom: var(--sp-5); }
.btn-stack { display: flex; flex-direction: column; gap: var(--sp-3); }
.head { text-align: center; margin-bottom: var(--sp-7); }
.code-input { display: flex; gap: var(--sp-2); max-width: 280px; }
.actions { display: flex; flex-direction: column; gap: var(--sp-3); }
.lock-icon { width: 48px; height: 48px; margin: 0 auto var(--sp-5); border-radius: 50%; background: var(--linen-soft); color: var(--forest); display: inline-flex; align-items: center; justify-content: center; }
.card__sub { color: var(--ink-soft); font-size: var(--fs-sm); margin-bottom: var(--sp-7); }
.nav { height: var(--nav-h); background: var(--linen); border-bottom: 1px solid var(--linen-deep); display: flex; align-items: center; padding: 0 var(--container-px); }
.nav__inner { width: 100%; max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; gap: var(--sp-7); }
.nav__brand { font-family: var(--font-heading); font-size: var(--fs-md); color: var(--ink); }
.nav__brand::after { content: '.'; color: var(--forest); }
.nav__tabs { display: flex; gap: var(--sp-2); flex: 1; }
.nav__tab { padding: 6px 12px; border-radius: var(--r-md); font-size: var(--fs-sm); color: var(--ink-soft); }
.nav__tab.is-active { color: var(--ink); background: var(--paper); }
.nav__right { display: flex; align-items: center; gap: var(--sp-4); }
.nav__avatar { display: inline-flex; align-items: center; gap: var(--sp-2); padding: 4px 8px 4px 4px; font-size: var(--fs-sm); color: var(--ink-soft); }
.avatar { width: 28px; height: 28px; border-radius: var(--r-pill); background: var(--forest); color: var(--paper-pure); display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-xs); font-weight: 600; }
.dropdown { position: absolute; top: calc(var(--nav-h) - 4px); right: var(--container-px); width: 320px; background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); box-shadow: var(--shadow-pop); z-index: 200; overflow: hidden; }
.dropdown__head { padding: var(--sp-4) var(--sp-5); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; border-bottom: 1px solid var(--linen-deep); }
.dropdown__foot { padding: var(--sp-2) var(--sp-3) var(--sp-3); }
.main { padding: var(--sp-6) var(--container-px) var(--sp-8); }
.greeting { font-family: var(--font-heading); font-size: var(--fs-2xl); margin-bottom: 4px; }
.sub { color: var(--ink-soft); font-size: var(--fs-md); margin-bottom: var(--sp-7); }
.scrim { position: fixed; inset: 0; background: rgba(31,36,33,0.45); z-index: 100; display: flex; align-items: center; justify-content: center; padding: var(--sp-5); }
.breadcrumb { font-size: var(--fs-sm); color: var(--ink-muted); margin-bottom: var(--sp-4); }
.breadcrumb a { color: var(--ink-soft); }
.page-title { font-size: var(--fs-2xl); margin-bottom: var(--sp-7); }
.panel-head { margin-bottom: var(--sp-6); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--linen-deep); }
.panel-head h2 { font-size: var(--fs-xl); margin-bottom: 4px; }
.panel-head__sub { font-size: var(--fs-sm); color: var(--ink-soft); }
.field-row { display: grid; grid-template-columns: 180px 1fr; gap: var(--sp-5); padding: var(--sp-4) 0; align-items: center; }
.field-row__label { font-size: var(--fs-sm); color: var(--ink); font-weight: 500; }
.field-row__hint { font-size: var(--fs-xs); color: var(--ink-muted); font-weight: 400; margin-top: 2px; }
.field__input, .field__select { width: 100%; padding: 10px 14px; font-family: var(--font-body); font-size: var(--fs-base); color: var(--ink); background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); }
.field__input:focus, .field__select:focus { outline: 0; border-color: var(--forest); box-shadow: 0 0 0 3px rgba(45,106,79,0.10); }
.btn--sm { padding: 6px 12px; font-size: var(--fs-xs); }
.panel-foot { margin-top: var(--sp-6); padding-top: var(--sp-5); border-top: 1px solid var(--linen-deep); display: flex; justify-content: flex-end; }
.sidebar { position: sticky; top: 80px; }
.sidebar__title { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; padding: 0 12px var(--sp-3); }
.sidebar__item { display: block; padding: 9px 12px; font-size: var(--fs-sm); color: var(--ink-soft); border-radius: var(--r-md); margin-bottom: 2px; }
.sidebar__item:hover { background: var(--paper); color: var(--ink); }
.sidebar__item.is-active { background: var(--paper); color: var(--ink); font-weight: 500; border-left: 2px solid var(--forest); padding-left: 10px; }
.sidebar__divider { margin: var(--sp-4) 12px var(--sp-3); border: 0; border-top: 1px solid var(--linen-deep); }
.panel { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-7); }
.panel-head__title { font-size: var(--fs-xl); margin-bottom: 4px; }
.section:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: 0; }
.section__title { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: var(--sp-4); }
.field:last-child { margin-bottom: 0; }
.color-swatch { width: 36px; height: 36px; border-radius: var(--r-md); border: 2px solid var(--linen-deep); cursor: pointer; }
.color-swatch.is-active { border-color: var(--ink); }
.nav__bell { width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; color: var(--ink-soft); }
.cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-4); }
.card__title { font-family: var(--font-heading); font-size: var(--fs-md); margin-bottom: 6px; }
.card__type { font-size: var(--fs-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--sp-3); }
.bg-container { max-width: var(--container-max); margin: 0 auto; }
.bg-greeting { font-family: var(--font-heading); font-size: var(--fs-2xl); margin-bottom: 4px; }
.bg-sub { color: var(--ink-soft); font-size: var(--fs-md); margin-bottom: var(--sp-7); }
.bg-card { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-6); margin-bottom: var(--sp-3); height: 80px; }
.modal { background: var(--paper); border-radius: var(--r-lg); max-width: 440px; width: 100%; box-shadow: 0 20px 60px rgba(31,36,33,0.30); overflow: hidden; padding: var(--sp-7) var(--sp-7) var(--sp-6); }
.confetti { font-size: 32px; letter-spacing: 12px; margin-bottom: var(--sp-5); }
.modal__title { font-size: var(--fs-3xl); margin-bottom: var(--sp-5); line-height: 1.05; letter-spacing: -0.02em; }
.modal__close { position: absolute; top: 16px; right: 16px; width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; color: var(--ink-muted); border-radius: var(--r-pill); }
.modal__close:hover { background: var(--linen-soft); color: var(--ink); }
.footer-note a { color: var(--paper); text-decoration: underline; }
.nav__tab:hover { color: var(--ink); background: var(--linen-soft); }
.page-header { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--sp-6); margin-bottom: var(--sp-7); }
.page-header__meta { text-align: right; font-size: var(--fs-sm); color: var(--ink-soft); line-height: 1.6; }
.greeting__sub { display: block; font-size: var(--fs-md); color: var(--ink-soft); margin-top: var(--sp-2); letter-spacing: -0.005em; }
.card--last { margin-bottom: 0; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-7); }
.stat { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); }
.stat__label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-muted); font-weight: 500; margin-bottom: var(--sp-2); }
.stat__value { font-family: var(--font-heading); font-weight: 400; font-size: var(--fs-2xl); color: var(--ink); letter-spacing: -0.015em; line-height: 1.1; }
.stat__delta { font-size: var(--fs-xs); color: var(--ink-soft); margin-top: 4px; }
.stat__delta--up { color: var(--forest); }
.queue { display: flex; flex-direction: column; }
.activity { display: flex; flex-direction: column; }
.activity__item { display: grid; grid-template-columns: 12px 1fr auto; gap: var(--sp-4); padding: var(--sp-3) 0; align-items: baseline; font-size: var(--fs-sm); color: var(--ink-soft); }
.activity__dot { width: 6px; height: 6px; border-radius: var(--r-pill); background: var(--ink-muted); margin-top: 6px; }
.activity__dot--client { background: var(--forest); }
.activity__text { color: var(--ink); }
.activity__text strong { font-weight: 500; }
.activity__time { color: var(--ink-muted); font-size: var(--fs-xs); font-variant-numeric: tabular-nums; }
.page-head { margin-bottom: var(--sp-7); }
.filter-pill { padding: 7px 14px; font-size: var(--fs-xs); color: var(--ink-soft); background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-pill); cursor: pointer; }
.filter-pill:hover { color: var(--ink); }
.table { width: 100%; border-collapse: collapse; }
.client-cell { display: flex; align-items: center; gap: var(--sp-3); }
.client-meta { font-size: var(--fs-xs); color: var(--ink-muted); }
.client-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: var(--sp-5); }
.client-head h1 { font-size: var(--fs-2xl); }
.client-head__sub { font-size: var(--fs-sm); color: var(--ink-soft); margin-top: 4px; }
.tab-bar { display: flex; gap: 4px; border-bottom: 1px solid var(--linen-deep); margin-bottom: var(--sp-6); overflow-x: auto; }
.tab-bar__tab { padding: 10px 14px; font-size: var(--fs-sm); color: var(--ink-soft); border-bottom: 2px solid transparent; margin-bottom: -1px; white-space: nowrap; }
.tab-bar__tab.is-active { color: var(--ink); border-bottom-color: var(--forest); font-weight: 500; }
.section-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: var(--sp-3); }
.section-head h2 { font-size: var(--fs-xl); }
.article-row { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); display: grid; grid-template-columns: 1fr auto; gap: var(--sp-4); align-items: center; }
.radio-group { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.radio.is-checked .radio__mark { border-color: var(--forest); }
.radio.is-checked .radio__mark::after { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--forest); }
.status-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.field__hint { font-size: var(--fs-xs); color: var(--ink-muted); margin-bottom: 6px; }
.check-row { display: flex; align-items: center; gap: var(--sp-3); padding: 8px 0; font-size: var(--fs-sm); color: var(--ink); }
.check-box { width: 16px; height: 16px; border: 1.5px solid var(--ink-muted); border-radius: 3px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.check-row.is-checked .check-box { background: var(--forest); border-color: var(--forest); color: var(--paper-pure); }
.save-bar { margin-top: var(--sp-6); padding-top: var(--sp-5); border-top: 1px solid var(--linen-deep); display: flex; justify-content: flex-end; }
.toolbar { display: flex; gap: var(--sp-3); align-items: center; margin-bottom: var(--sp-6); }
.toolbar__select { padding: 6px 12px; font-size: var(--fs-xs); color: var(--ink-soft); background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-pill); cursor: pointer; }
.toolbar__count { font-size: var(--fs-xs); color: var(--ink-muted); margin-left: auto; }
.legend { display: flex; gap: var(--sp-5); margin-bottom: var(--sp-5); font-size: var(--fs-xs); color: var(--ink-soft); }
.legend-item { display: inline-flex; align-items: center; gap: 6px; }
.page-head h1 { font-size: var(--fs-2xl); }
.empty { text-align: center; padding: var(--sp-9) var(--container-px); max-width: 540px; margin: 0 auto; }
.empty__title { font-size: var(--fs-xl); margin-bottom: var(--sp-4); }
.empty__lede { color: var(--ink-soft); font-size: var(--fs-base); margin-bottom: var(--sp-7); line-height: 1.65; max-width: 44ch; margin-left: auto; margin-right: auto; }
.empty__lede strong { color: var(--ink); font-weight: 500; }

/* Portal-empty padding override (N4/M3/I3 consumers). */
.empty--portal { padding: var(--sp-9) 0 var(--sp-7); }

/* — empty-state hero pattern (promoted from F6/H5 residual) — */

.section-head {
  text-align: center;
  max-width: 560px;
  margin: var(--sp-5) auto var(--sp-8);
}

.section-head__eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
  margin-bottom: var(--sp-3);
}

.section-head__title {
  font-size: var(--fs-2xl);
  margin-bottom: var(--sp-3);
}

.section-head__sub {
  font-size: var(--fs-md);
  color: var(--ink-soft);
  line-height: 1.55;
}

.empty-hero { text-align: center; margin-bottom: var(--sp-9); }

.empty-hero__link {
  display: inline-block;
  margin-top: var(--sp-4);
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  text-decoration: underline;
}

.empty-hero__link:hover { color: var(--ink); }

.process {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}

.step {
  background: var(--paper);
  border: 1px solid var(--linen-deep);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
}

.step__n {
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
  margin-bottom: var(--sp-2);
}

.step__title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: var(--fs-lg);
  color: var(--ink);
  margin-bottom: var(--sp-3);
}

.step__body {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.6;
}

/* — empty-state decorative-frame pattern (promoted from E2/L4 residual) — */

.empty__primary { margin-bottom: var(--sp-7); }

.empty__divider {
  width: 60px;
  height: 1px;
  background: var(--linen-deep);
  margin: 0 auto var(--sp-5);
}

.empty__demo {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
}

.empty__demo a { color: var(--forest); text-decoration: underline; }
.empty__demo a:hover { color: var(--forest-deep); }

/* — loading skeleton primitives (promoted from L6/R6 residual) — */

.skeleton__bar {
  display: block;
  block-size: 12px;
  background: var(--linen-deep);
  border-radius: var(--r-md);
  margin-block: 3px;
}
.skeleton__bar--secondary {
  background: var(--linen);
  block-size: 10px;
}

/* — client-portal empty primitives (promoted from N4/M3 residual) — */

.sparkle {
  width: 56px; height: 56px;
  margin: 0 auto var(--sp-6);
  border-radius: 50%;
  background: rgba(45,106,79,0.10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 28px;
}

.suggest-card {
  background: var(--paper);
  border: 1px solid var(--linen-deep);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  max-width: 460px;
  margin: 0 auto;
  text-align: left;
}

.suggest-card__title {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-muted);
  font-weight: 600;
  margin-bottom: var(--sp-4);
}

.suggest-row {
  display: flex; align-items: center; gap: var(--sp-4);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--linen-deep);
  font-size: 14px;
}

.suggest-row:last-child { border-bottom: 0; }

.suggest-row__icon {
  width: 32px; height: 32px;
  background: var(--linen-soft);
  border-radius: var(--r-md);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

.suggest-row__body { flex: 1; color: var(--ink); }

.suggest-row__meta {
  font-size: var(--fs-2xs);
  color: var(--ink-muted);
  margin-top: 2px;
}

.suggest-row__cta {
  font-size: 13px;
  color: var(--accent);
}
.page-sub { font-size: var(--fs-sm); color: var(--ink-soft); margin-bottom: var(--sp-6); }
.field__label .required { color: var(--forest); }
.section-divider { margin: var(--sp-7) calc(var(--sp-7) * -1); border: 0; border-top: 1px solid var(--linen-deep); }
.email-body { background: var(--paper-pure); border-radius: var(--r-md); padding: var(--sp-7); }
.email-logo { font-family: var(--font-heading); font-size: var(--fs-xl); color: var(--ink); padding-bottom: var(--sp-5); margin-bottom: var(--sp-6); border-bottom: 2px solid var(--forest); letter-spacing: -0.01em; }
.email-cta { display: inline-block; background: var(--forest); color: var(--paper-pure); padding: 12px 24px; border-radius: var(--r-md); font-size: var(--fs-sm); font-weight: 500; margin: var(--sp-3) 0 var(--sp-6); text-decoration: none; }
.summary { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); margin-bottom: var(--sp-6); }
.summary-row { display: grid; grid-template-columns: 130px 1fr; gap: var(--sp-4); padding: 8px 0; border-bottom: 1px dashed var(--linen-deep); font-size: var(--fs-sm); align-items: baseline; }
.summary-row:last-child { border-bottom: 0; }
.summary-row__label { color: var(--ink-muted); text-transform: uppercase; font-size: var(--fs-xs); letter-spacing: 0.08em; }
.summary-row__value { color: var(--ink); }
.device-wrap { max-width: var(--device-w); margin: 24px auto 60px; background: var(--paper); border-radius: 24px; box-shadow: 0 12px 40px rgba(31,36,33,0.20); overflow: hidden; border: 8px solid var(--ink); position: relative; }
.device-app { background: var(--paper); color: var(--ink); font-size: var(--fs-base); line-height: 1.55; padding-bottom: var(--bottom-bar-h); min-height: 720px; }
.status-bar { display: flex; justify-content: space-between; align-items: center; padding: 12px 20px 4px; font-size: var(--fs-2xs); color: var(--ink); font-weight: 600; }
.back-link { display: inline-flex; align-items: center; gap: 4px; font-size: var(--fs-sm); color: var(--ink-soft); margin-bottom: var(--sp-3); }
.content { padding: var(--sp-4); }
.bottom-bar { position: absolute; bottom: 0; left: 0; right: 0; background: var(--paper-pure); border-top: 1px solid var(--linen-deep); padding: 12px 14px; display: flex; gap: var(--sp-2); }
.client-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: var(--sp-6); gap: var(--sp-5); }
.client-title { display: flex; align-items: center; gap: var(--sp-4); }
.client-title h1 { font-size: var(--fs-2xl); }
.client-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: var(--r-pill); font-size: var(--fs-xs); font-weight: 500; background: rgba(181,82,74,0.10); color: var(--alert); }
.client-pill__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.tab-nav { display: flex; gap: 4px; border-bottom: 1px solid var(--linen-deep); margin-bottom: var(--sp-6); overflow-x: auto; }
.tab-nav__tab { padding: 10px 14px; font-size: var(--fs-sm); color: var(--ink-soft); border-bottom: 2px solid transparent; margin-bottom: -1px; white-space: nowrap; }
.tab-nav__tab:hover { color: var(--ink); }
.tab-nav__tab.is-active { color: var(--ink); border-bottom-color: var(--forest); font-weight: 500; }
.tab-bar__tab:hover { color: var(--ink); }
.q-section { margin-bottom: var(--sp-7); }
.q-section__eyebrow { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: 4px; }
.q-section__title { font-size: var(--fs-xl); }
.question { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); margin-bottom: var(--sp-3); }
.question__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-3); padding-bottom: var(--sp-3); border-bottom: 1px dashed var(--linen-deep); }
.round { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-6) var(--sp-7); margin-bottom: var(--sp-4); display: grid; grid-template-columns: 1fr auto; gap: var(--sp-5); align-items: center; }
.round__head { display: flex; align-items: baseline; gap: var(--sp-4); margin-bottom: var(--sp-2); flex-wrap: wrap; }
.round__title { font-family: var(--font-heading); font-size: var(--fs-xl); }
.round__meta { font-size: var(--fs-sm); color: var(--ink-soft); line-height: 1.65; }
.round__meta strong { color: var(--ink); font-weight: 500; }
.round__actions { display: flex; gap: var(--sp-3); }
.report-card { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); display: grid; grid-template-columns: 1fr auto; gap: var(--sp-4); align-items: center; }
.report-card__body { line-height: 1.5; }
.report-card__title { font-family: var(--font-heading); font-size: var(--fs-md); margin-bottom: 4px; display: flex; align-items: center; gap: var(--sp-3); }
.status-pill { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-2xs); padding: 3px 9px; border-radius: var(--r-pill); font-weight: 500; letter-spacing: 0.04em; font-family: var(--font-body); }
.status-pill__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.status-pill--draft { background: rgba(181,138,46,0.10); color: var(--warning); }
.status-pill--published { background: rgba(45,106,79,0.10); color: var(--forest); }
.progress-bar { flex: 1; height: 4px; background: var(--linen-deep); border-radius: var(--r-pill); max-width: 240px; overflow: hidden; position: relative; }
.progress-bar__fill { position: absolute; top: 0; left: 0; bottom: 0; width: 42%; background: var(--accent); border-radius: var(--r-pill); }
.section-actions { display: flex; gap: var(--sp-2); }
.row { display: grid; grid-template-columns: 100px 1fr 80px 110px 130px 100px; gap: var(--sp-4); padding: var(--sp-3) var(--sp-5); border-bottom: 1px solid var(--linen-deep); align-items: center; font-size: var(--fs-sm); }
.row:last-child { border-bottom: 0; }
.row:hover:not(.row--head) { background: var(--linen-soft); cursor: pointer; }
.row--head { background: var(--linen-soft); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); font-weight: 600; }
.locale-tabs { display: inline-flex; background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); padding: 3px; margin-bottom: var(--sp-3); }
.locale-tabs__tab { padding: 4px 12px; border-radius: 4px; font-size: var(--fs-xs); color: var(--ink-soft); font-weight: 500; }
.locale-tabs__tab.is-active { background: var(--ink); color: var(--paper); }
.checkbox-box { width: 16px; height: 16px; border: 1.5px solid var(--ink-muted); border-radius: 3px; display: inline-flex; align-items: center; justify-content: center; }
.is-checked .checkbox-box { background: var(--forest); border-color: var(--forest); color: var(--paper-pure); }
.option-row { display: grid; grid-template-columns: 24px 60px 1fr 1fr 32px; gap: var(--sp-3); align-items: center; padding: var(--sp-3); background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); margin-bottom: var(--sp-2); }
.preview-banner { background: var(--info); color: var(--paper-pure); padding: var(--sp-3) var(--container-px); }
.preview-banner__inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: var(--sp-4); }
.preview-banner__icon { width: 24px; height: 24px; flex-shrink: 0; background: rgba(255,255,255,0.20); color: var(--paper-pure); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.preview-banner__body { flex: 1; font-size: var(--fs-sm); line-height: 1.4; }
.preview-banner__title { font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; font-size: var(--fs-2xs); margin-bottom: 2px; }
.preview-banner__detail { font-size: var(--fs-xs); opacity: 0.85; }
.preview-banner__controls { display: flex; gap: var(--sp-3); align-items: center; }
.preview-banner__select { background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.20); color: var(--paper-pure); font-family: var(--font-body); font-size: var(--fs-xs); padding: 6px 10px; border-radius: var(--r-md); }
.preview-banner__exit { background: rgba(255,255,255,0.20); color: var(--paper-pure); padding: 7px 14px; border-radius: var(--r-md); font-size: var(--fs-xs); font-weight: 500; }
.portal-nav { height: var(--nav-h); background: var(--paper); border-bottom: 1px solid var(--linen-deep); display: flex; align-items: center; padding: 0 var(--container-px); }
.portal-nav__inner { width: 100%; max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; gap: var(--sp-7); }
.portal-brand { font-family: var(--font-heading); font-size: var(--fs-md); color: var(--ink); }
.portal-brand__mark { display: inline-block; width: 8px; height: 8px; border-radius: 2px; background: var(--accent); margin-right: 8px; vertical-align: middle; }
.portal-nav__tabs { display: flex; gap: var(--sp-2); flex: 1; }
.portal-nav__tab { padding: 6px 12px; border-radius: var(--r-md); font-size: var(--fs-sm); color: var(--ink-soft); }
.portal-nav__tab.is-active { color: var(--ink); background: var(--linen-soft); font-weight: 500; }
.portal-nav__right { display: flex; align-items: center; gap: var(--sp-4); }
.locale-toggle { font-size: var(--fs-xs); color: var(--ink-muted); letter-spacing: 0.06em; }
.portal-avatar { display: inline-flex; align-items: center; gap: var(--sp-2); padding: 4px 8px 4px 4px; font-size: 13px; color: var(--ink-soft); }
.portal-avatar__circle { width: 28px; height: 28px; border-radius: var(--r-pill); background: var(--accent); color: var(--paper-pure); display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-xs); font-weight: 600; }
.review-head { margin-bottom: var(--sp-5); }
.canvas-wrap { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); }
.canvas-toolbar { display: flex; justify-content: space-between; align-items: center; padding-bottom: var(--sp-3); margin-bottom: var(--sp-4); border-bottom: 1px solid var(--linen-deep); }
.canvas { width: 100%; aspect-ratio: 16 / 9; background: var(--paper-pure); border-radius: var(--r-md); border: 1px solid var(--linen-deep); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.mock-brand { text-align: center; padding: var(--sp-7); }
.mock-brand__word { font-family: var(--font-heading); font-size: 48px; letter-spacing: -0.02em; color: var(--ink); }
.mock-brand__amp { color: var(--accent); font-style: italic; }
.mock-brand__tag { font-size: var(--fs-xs); letter-spacing: 0.4em; text-transform: uppercase; color: var(--ink-muted); margin-top: var(--sp-3); }
.pin { position: absolute; width: 26px; height: 26px; border-radius: 50%; background: var(--alert); color: var(--paper-pure); display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-xs); font-weight: 600; border: 2px solid var(--paper-pure); box-shadow: 0 2px 6px rgba(31,36,33,0.20); }
.pin--1 { top: 22%; left: 28%; }
.pin--2 { top: 40%; right: 30%; }
.pin--3 { bottom: 24%; left: 38%; }
.btn--danger { background: transparent; color: var(--alert); border: 1px solid rgba(181,82,74,0.30); }
.btn--danger:hover { background: rgba(181,82,74,0.06); }
.options { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); overflow: hidden; }
.decision { background: rgba(181,82,74,0.04); border: 1px solid rgba(181,82,74,0.20); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4); }
.page-head__sub { font-size: var(--fs-sm); color: var(--ink-soft); }
.timeline { position: relative; padding-left: 28px; }
.timeline::before { content: ''; position: absolute; top: 14px; bottom: 14px; left: 9px; width: 2px; background: var(--linen-deep); }
.p15-item__label { font-size: var(--fs-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); font-weight: 500; margin-bottom: 2px; }
.p15-item__value { font-size: var(--fs-sm); color: var(--ink); line-height: 1.5; }
.what-changed { background: var(--linen-soft); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); margin-bottom: var(--sp-5); display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-4); }
.what-changed__label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--accent); font-weight: 600; margin-bottom: var(--sp-3); }
.what-changed ul { padding-left: 22px; list-style: disc; }
.what-changed li { padding: 2px 0; }
.thread { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); overflow: hidden; }
.zoom-display { font-family: 'SF Mono', Menlo, monospace; font-size: var(--fs-2xs); color: var(--ink); padding: 0 4px; min-width: 36px; text-align: center; }
.back-link:hover { color: var(--ink); }
.modal__head { text-align: center; margin-bottom: var(--sp-5); }
.modal__sub { font-size: var(--fs-xs); color: var(--ink-muted); font-family: var(--font-mono); margin-top: 4px; }
.modal__foot { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-4) var(--sp-6); border-top: 1px solid var(--linen-deep); }
.editor-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-5); }
.save-indicator { display: inline-flex; align-items: center; gap: 6px; }
.save-indicator__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--forest); }
.save-indicator--error { color: var(--alert); }
.save-indicator--error .save-indicator__dot { background: var(--alert); }
.editor-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--sp-5); align-items: start; }
.editor-panel { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-7); }
.metric-row { display: grid; grid-template-columns: 1fr auto auto auto; gap: var(--sp-4); padding: 8px 0; align-items: center; font-size: var(--fs-sm); border-bottom: 1px solid var(--linen-deep); }
.section-eyebrow { font-size: var(--fs-3xs); text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-muted); font-weight: 600; margin-bottom: 4px; }
.report-head { text-align: center; padding: var(--sp-7) 0 var(--sp-8); border-bottom: 1px solid var(--linen-deep); margin-bottom: var(--sp-8); }
.report-eyebrow { font-size: var(--fs-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: var(--sp-4); }
.report-head h1 { font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.tldr { background: var(--paper); border-left: 3px solid var(--accent); padding: var(--sp-5) var(--sp-6); margin-bottom: var(--sp-8); border-radius: 0 var(--r-md) var(--r-md) 0; }
.metrics { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); margin-bottom: var(--sp-8); }
.metric { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); }
.metric__value { font-family: var(--font-heading); font-size: 32px; line-height: 1; color: var(--ink); display: flex; align-items: baseline; gap: var(--sp-3); }
.bg { padding: var(--sp-6) var(--container-px); filter: blur(2px); opacity: 0.5; }
.bg__sub { color: var(--ink-soft); font-size: var(--fs-sm); margin-bottom: var(--sp-7); }
.modal__body { padding: var(--sp-6) var(--sp-7); }
.section-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: var(--sp-3); }
.filters { display: flex; gap: var(--sp-2); margin-bottom: var(--sp-5); flex-wrap: wrap; }
.filter-pill.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tldr__body { font-family: var(--font-heading); font-size: var(--fs-lg); line-height: 1.55; color: var(--ink); letter-spacing: -0.005em; }
.metric__name { font-size: var(--fs-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-muted); font-weight: 500; margin-bottom: var(--sp-3); display: flex; justify-content: space-between; align-items: center; }
.metric__delta { font-size: var(--fs-sm); color: var(--accent); font-weight: 500; }
.metric__delta--down { color: var(--accent); }
.editor-head__title { font-size: var(--fs-xl); font-family: var(--font-body); font-weight: 500; }
.editor-head__sub { font-size: var(--fs-xs); color: var(--ink-muted); margin-top: 2px; display: inline-flex; align-items: center; gap: 6px; }
.toggle { width: 32px; height: 18px; border-radius: var(--r-pill); background: var(--linen-deep); position: relative; cursor: pointer; }
.toggle.is-on { background: var(--forest); }
.toggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; border-radius: 50%; background: var(--paper-pure); }
.toggle.is-on::after { left: 16px; }
.q-head { margin-bottom: var(--sp-7); }
.btn--disabled { background: var(--linen-deep); color: var(--ink-muted); cursor: not-allowed; }
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--linen-deep); }
.textarea { width: 100%; padding: 10px 12px; font-family: var(--font-body); font-size: var(--fs-sm); color: var(--ink); background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); resize: vertical; min-height: 80px; line-height: 1.55; }
.page-greeting { font-family: var(--font-heading); font-size: var(--fs-2xl); margin-bottom: 4px; }
.bg-title { font-family: var(--font-heading); font-size: var(--fs-2xl); margin-bottom: var(--sp-5); }
.modal__eyebrow { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: 4px; }
.article-title { font-family: var(--font-heading); font-size: var(--fs-md); color: var(--ink); letter-spacing: -0.005em; }
.deliverables { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-5); }
.deliverable { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); display: flex; flex-direction: column; }
.deliverable__icon { width: 36px; height: 36px; border-radius: var(--r-md); background: var(--linen-soft); color: var(--ink-soft); display: inline-flex; align-items: center; justify-content: center; margin-bottom: var(--sp-3); }
.deliverable__meta { font-size: var(--fs-xs); color: var(--ink-muted); margin-top: 2px; }
.filter-pill__count { display: inline-block; background: rgba(0,0,0,0.10); padding: 0 5px; border-radius: var(--r-pill); font-size: var(--fs-3xs); margin-left: 3px; }
.completed-row { display: flex; align-items: center; gap: 8px; font-size: var(--fs-sm); color: var(--ink-soft); padding: 6px 0; }
.member-row { display: grid; grid-template-columns: 48px 1fr auto; gap: var(--sp-4); padding: var(--sp-5) var(--sp-6); border-bottom: 1px solid var(--linen-deep); align-items: center; }
.member-avatar { width: 40px; height: 40px; border-radius: var(--r-pill); background: var(--linen-soft); border: 1px solid var(--linen-deep); display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-md); font-weight: 600; color: var(--ink-soft); font-family: var(--font-body); }
.member-avatar--owner { background: var(--accent); color: var(--paper-pure); border-color: var(--accent); }
.member-name { font-size: var(--fs-sm); color: var(--ink); font-weight: 500; }
.member-name__self { color: var(--ink-muted); font-weight: 400; font-size: 12px; margin-left: 6px; }
.member-email { font-size: var(--fs-xs); color: var(--ink-muted); margin-top: 2px; }
.role-pill { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: var(--r-pill); font-size: var(--fs-2xs); font-weight: 500; letter-spacing: 0.04em; margin-top: var(--sp-2); }
.role-pill--owner { background: rgba(45,106,79,0.10); color: var(--accent); }
.role-pill--member { background: rgba(74,107,130,0.10); color: #4A6B82; }
.row-actions { display: flex; gap: var(--sp-2); }
.plan-note { margin-top: var(--sp-5); padding: var(--sp-4) var(--sp-5); background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-md); font-size: var(--fs-sm); color: var(--ink-soft); }
.plan-note strong { color: var(--ink); font-weight: 500; }
.email-row { display: flex; align-items: center; gap: var(--sp-3); padding: 10px 12px; background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); font-family: 'SF Mono', Menlo, monospace; font-size: var(--fs-sm); }
.settings-layout { display: grid; grid-template-columns: 220px 1fr; gap: var(--sp-6); align-items: start; }
.settings-sidebar { position: sticky; top: 80px; }
.settings-sidebar__title { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; padding: 0 12px var(--sp-3); }
.settings-sidebar__item { display: block; padding: 9px 12px; font-size: var(--fs-sm); color: var(--ink-soft); border-radius: var(--r-md); margin-bottom: 2px; }
.settings-sidebar__item:hover { background: var(--paper); color: var(--ink); }
.settings-sidebar__item.is-active { background: var(--paper); color: var(--ink); font-weight: 500; border-left: 2px solid var(--forest); padding-left: 10px; }
.settings-sidebar__divider { margin: var(--sp-4) 12px var(--sp-3); border: 0; border-top: 1px solid var(--linen-deep); }
.settings-sidebar__item--danger { color: var(--ink-muted); }
.settings-content { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-7); }
.current-plan { background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); overflow: hidden; }
.usage { padding: var(--sp-5) var(--sp-6); }
.usage-bar { height: 6px; background: var(--linen-soft); border-radius: var(--r-pill); position: relative; overflow: hidden; }
.usage-bar__fill { position: absolute; top: 0; left: 0; bottom: 0; background: var(--forest); }
.plan-card { background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-6); text-align: center; }
.plan-card__name { font-family: var(--font-heading); font-size: var(--fs-md); color: var(--ink); margin-bottom: 4px; }
.plan-card__price { font-family: var(--font-heading); font-size: var(--fs-3xl); color: var(--ink); line-height: 1; margin-bottom: 2px; }
.plan-card__head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--sp-6); }
.plan-card__price strong { color: var(--ink); font-weight: 500; }
.countdown { background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); padding: var(--sp-5); margin-bottom: var(--sp-7); }
.countdown__label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: var(--sp-3); }
.countdown__sub { font-size: var(--fs-xs); color: var(--ink-muted); }
.nav__bell-dot { position: absolute; top: 6px; right: 8px; width: 8px; height: 8px; border-radius: 50%; background: var(--alert); border: 2px solid var(--linen); }
.notif { display: grid; grid-template-columns: 32px 1fr auto; gap: var(--sp-3); padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--linen-deep); position: relative; cursor: pointer; }
.notif:hover { background: var(--linen-soft); }
.notif__icon { width: 32px; height: 32px; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-xs); font-weight: 600; flex-shrink: 0; }
.notif__icon--system { background: var(--linen-soft); color: var(--ink-soft); border: 1px solid var(--linen-deep); }
.notif__icon--alert { background: rgba(181,82,74,0.10); color: var(--alert); }
.notif__body { font-size: var(--fs-sm); line-height: 1.45; }
.notif__time { font-size: var(--fs-xs); color: var(--ink-muted); white-space: nowrap; }
.deliverable:last-child { border-bottom: 0; }
.deliverable__name { font-size: var(--fs-sm); color: var(--ink); font-weight: 500; }
.error-card { text-align: center; max-width: 440px; }
.error-title { font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.error-sub { color: var(--ink-soft); font-size: var(--fs-md); margin-bottom: var(--sp-7); line-height: 1.55; }
.help-link { margin-top: var(--sp-5); padding-top: var(--sp-5); border-top: 1px solid var(--linen-deep); font-size: var(--fs-xs); color: var(--ink-muted); }
.help-link a { color: var(--forest); text-decoration: underline; }
.options__title { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.10em; color: var(--ink-muted); font-weight: 600; margin-bottom: var(--sp-3); }
.option-row__bullet { color: var(--forest); margin-top: 4px; flex-shrink: 0; }
.option-row strong { color: var(--ink); font-weight: 500; }
.modal h1 { font-size: var(--fs-xl); margin-bottom: var(--sp-3); }
.modal__lede { font-size: var(--fs-sm); color: var(--ink-soft); line-height: 1.65; }
.modal__lede strong { color: var(--ink); font-weight: 500; }
.action-context { background: var(--paper-pure); border: 1px solid var(--linen-deep); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); color: var(--ink); margin-bottom: var(--sp-5); }
.action-context__label { font-size: var(--fs-2xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); font-weight: 600; margin-bottom: 4px; }
.greeting-sub { color: var(--ink-soft); font-size: var(--fs-md); margin-bottom: var(--sp-7); }
.cards-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-6); }
.stat-card { background: var(--paper); border: 1px solid var(--linen-deep); border-radius: var(--r-lg); padding: var(--sp-5); }
.stat-card__label { font-size: var(--fs-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--sp-2); }
.stat-card__value { font-family: var(--font-heading); font-size: 28px; color: var(--ink); line-height: 1; }
.stat-card__sub { font-size: var(--fs-xs); color: var(--ink-muted); margin-top: var(--sp-3); }
.modal__icon { width: 56px; height: 56px; margin: 0 auto var(--sp-5); border-radius: 50%; background: rgba(181,138,46,0.10); color: var(--warning); display: inline-flex; align-items: center; justify-content: center; }
.actions .btn { flex: 1; }
.upgrade-note { text-align: center; font-size: var(--fs-sm); color: var(--ink-soft); margin-bottom: var(--sp-6); line-height: 1.65; }
.upgrade-note strong { color: var(--forest); font-weight: 600; }
.warn-banner { background: var(--warning); color: var(--paper-pure); padding: var(--sp-3) var(--container-px); }
.warn-banner__inner { max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; gap: var(--sp-4); }
.warn-banner__icon { width: 24px; height: 24px; background: rgba(255,255,255,0.20); border-radius: 50%; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; }
.warn-banner__body { flex: 1; line-height: 1.4; font-size: var(--fs-sm); }
.warn-banner__cta { background: var(--paper-pure); color: var(--warning); padding: 8px 16px; border-radius: var(--r-md); font-size: var(--fs-xs); font-weight: 600; white-space: nowrap; }
