      :root {
        --bg: #f7f5ef;
        --bg-deep: #edeae0;
        --surface: #ffffff;
        --surface-2: #fafaf6;
        --ink: #111111;
        --ink-2: #4a4a4a;
        --ink-3: #8a8a82;
        --line: #e6e3db;
        --line-2: #f0ede5;
        --line-strong: #d4d0c2;
        --blue: #1335d0;
        --blue-tint: #eef0fc;
        --blue-soft: rgba(19, 53, 208, 0.10);
        --yellow: #f8e84a;
        --yellow-deep: #d4c41c;
        --penny: #d62a3c;
        --pos: #0a8544;
        --pos-tint: #e6f4ed;
        --neg: #c2410c;
        --neg-tint: #fbeee5;
        --f: 'Roboto Flex', system-ui, -apple-system, Segoe UI, sans-serif;
        --mono: 'Roboto Mono', ui-monospace, monospace;
      }

      * { margin: 0; padding: 0; box-sizing: border-box; }
      html { scroll-behavior: smooth; }
      body {
        font-family: var(--f);
        font-variation-settings: "wght" 400, "wdth" 100, "opsz" 14;
        background: var(--bg);
        color: var(--ink);
        line-height: 1.5;
        -webkit-font-smoothing: antialiased;
        overflow-x: hidden;
      }
      .num { font-variant-numeric: tabular-nums; }

      /* ========== TYPE UTILITIES ========== */
      .eyebrow {
        font-family: var(--f);
        font-size: 0.66rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-2);
      }
      .eyebrow.muted { color: var(--ink-3); }
      .eyebrow.on-dark { color: rgba(255,255,255,0.6); }

      .title-xl {
        font-family: var(--f);
        font-variation-settings: "wght" 900, "wdth" 85, "opsz" 60;
        font-size: clamp(1.85rem, 2.8vw, 2.35rem);
        line-height: 1.02;
        letter-spacing: -0.015em;
        color: var(--ink);
      }
      .title-md {
        font-family: var(--f);
        font-variation-settings: "wght" 900, "wdth" 90, "opsz" 32;
        font-size: clamp(1.15rem, 1.5vw, 1.35rem);
        line-height: 1.05;
        letter-spacing: -0.005em;
        color: var(--ink);
      }
      .display {
        font-variation-settings: "wght" 900, "wdth" 80, "opsz" 48;
        line-height: 0.95;
        letter-spacing: -0.01em;
        font-variant-numeric: tabular-nums;
        color: var(--ink);
      }
      .display.xl { font-size: 3.2rem; font-variation-settings: "wght" 900, "wdth" 76, "opsz" 72; }
      .display.lg { font-size: 2.4rem; font-variation-settings: "wght" 900, "wdth" 78, "opsz" 56; }
      .display.md { font-size: 1.9rem; font-variation-settings: "wght" 900, "wdth" 82, "opsz" 40; }
      .display.sm { font-size: 1.45rem; font-variation-settings: "wght" 900, "wdth" 85, "opsz" 32; }

      /* ========== TOPBAR ========== */
      .topbar {
        background: var(--ink);
        position: sticky;
        top: 0;
        z-index: 50;
        border-bottom: 3px solid var(--yellow);
      }
      .topbar-inner {
        max-width: 1480px;
        margin: 0 auto;
        padding: 12px 28px;
        display: flex;
        align-items: center;
        gap: 16px;
        min-height: 68px;
      }
      .topbar-brand {
        display: flex;
        align-items: center;
        gap: 16px;
        flex-shrink: 0;
      }
      .topbar-logo {
        height: 34px;
        width: auto;
        display: block;
      }
      .topbar-titleblock {
        display: flex;
        flex-direction: column;
        gap: 2px;
        min-width: 0;
      }
      .topbar-client {
        color: #fff;
        font-variation-settings: "wght" 900, "wdth" 90, "opsz" 14;
        font-size: 0.62rem;
        text-transform: uppercase;
        letter-spacing: 0.16em;
        line-height: 1;
      }
      .topbar-client .reg {
        color: rgba(255,255,255,0.5);
        margin-left: 4px;
        font-size: 0.9em;
      }
      .topbar-title {
        color: #fff;
        font-variation-settings: "wght" 700, "wdth" 95, "opsz" 18;
        font-size: 0.94rem;
        letter-spacing: 0.005em;
        line-height: 1.15;
        white-space: nowrap;
      }
      .topbar-sub {
        color: rgba(255,255,255,0.5);
        font-size: 0.7rem;
        letter-spacing: 0.02em;
        white-space: nowrap;
      }
      @media (max-width: 820px) {
        .topbar-sub { display: none; }
        .topbar-client { display: none; }
      }
      .topbar-divider-v {
        width: 1px;
        height: 30px;
        background: rgba(255,255,255,0.14);
      }
      .cd-mark {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-size: 0.64rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        color: rgba(255,255,255,0.7);
        text-transform: uppercase;
        letter-spacing: 0.14em;
        white-space: nowrap;
      }
      .cd-dot {
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--yellow);
        flex-shrink: 0;
      }
      .topbar-flex { flex: 1; }
      .topbar-right {
        display: flex;
        gap: 8px;
        align-items: center;
      }
      .btn-ghost {
        padding: 8px 13px;
        font-family: var(--f);
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        font-size: 0.74rem;
        color: rgba(255,255,255,0.8);
        background: transparent;
        border: 1px solid rgba(255,255,255,0.16);
        border-radius: 7px;
        cursor: pointer;
        transition: all 0.12s;
        display: inline-flex;
        align-items: center;
        gap: 6px;
        white-space: nowrap;
      }
      .btn-ghost:hover {
        color: #fff;
        border-color: rgba(255,255,255,0.32);
        background: rgba(255,255,255,0.05);
      }
      .btn-save {
        padding: 8px 14px;
        font-family: var(--f);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        font-size: 0.74rem;
        color: var(--ink);
        background: var(--yellow);
        border: 1px solid var(--yellow-deep);
        border-radius: 7px;
        cursor: pointer;
        transition: all 0.12s;
        display: inline-flex;
        align-items: center;
        gap: 6px;
      }
      .btn-save:hover { background: #fff07a; }

      .penny-fallback {
        font-size: 1.35rem;
        font-variation-settings: "wght" 900, "wdth" 95, "opsz" 32;
        color: var(--penny);
        letter-spacing: -0.01em;
        line-height: 1;
      }

      /* ========== FILTER BAR ========== */
      .filters {
        position: sticky;
        top: 67px;
        z-index: 40;
        background: rgba(247, 245, 239, 0.94);
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
        border-bottom: 1px solid var(--line);
        padding: 10px 28px;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 14px;
      }
      .filter-group { display: flex; align-items: center; gap: 6px; }
      .filter-label {
        font-size: 0.6rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--ink-3);
      }
      .chip {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 6px 11px;
        border-radius: 999px;
        border: 1px solid var(--line-strong);
        background: var(--surface);
        color: var(--ink-2);
        font-family: var(--f);
        font-size: 0.7rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        cursor: pointer;
        transition: 0.15s;
      }
      .chip:hover { border-color: var(--blue); color: var(--blue); }
      .chip.active {
        background: var(--blue);
        color: #fff;
        border-color: var(--blue);
      }
      .live-dot {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 6px 12px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
        font-size: 0.62rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--ink-2);
        background: var(--surface);
      }
      .live-dot .d {
        width: 7px; height: 7px; border-radius: 50%;
        background: var(--pos);
        animation: pulse 2s infinite;
      }
      .live-dot.demo .d {
        background: var(--ink-3);
        animation: none;
      }
      @keyframes pulse {
        0%, 100% { box-shadow: 0 0 0 0 rgba(10,133,68,0.45); }
        50% { box-shadow: 0 0 0 6px rgba(10,133,68,0); }
      }
      .period-pill {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 6px 12px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
        background: var(--surface);
        font-size: 0.72rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        color: var(--ink);
        cursor: pointer;
        transition: border-color 0.12s, color 0.12s;
      }
      .period-pill:hover { border-color: var(--ink); }
      .period-pill .label {
        font-size: 0.58rem;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-3);
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
      }
      .period-pill .caret { color: var(--ink-3); font-size: 0.7rem; }

      .filter-dd-wrap { position: relative; display: inline-flex; align-items: center; gap: 6px; }
      .filter-select {
        appearance: none;
        -webkit-appearance: none;
        padding: 6px 28px 6px 12px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
        background: var(--surface);
        color: var(--ink);
        font-family: var(--f);
        font-size: 0.72rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        cursor: pointer;
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%238a8a82' stroke-width='1.4' fill='none'/></svg>");
        background-repeat: no-repeat;
        background-position: right 10px center;
      }
      .filter-select:hover { border-color: var(--ink); }
      .filter-select:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-soft); }
      .filter-select.active {
        background-color: var(--blue);
        border-color: var(--blue);
        color: #fff;
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23ffffff' stroke-width='1.6' fill='none'/></svg>");
      }

      .dropdown {
        position: absolute;
        top: calc(100% + 6px);
        right: 0;
        min-width: 220px;
        background: var(--surface);
        border: 1px solid var(--line);
        border-radius: 10px;
        box-shadow: 0 12px 32px rgba(0,0,0,0.10);
        padding: 6px;
        z-index: 80;
      }
      .dd-item {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 8px 10px;
        border-radius: 6px;
        cursor: pointer;
        font-size: 0.8rem;
        color: var(--ink-2);
        gap: 10px;
      }
      .dd-item:hover { background: var(--surface-2); color: var(--ink); }
      .dd-item.active {
        background: var(--blue-tint);
        color: var(--blue);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .dd-item .dd-hint { color: var(--ink-3); font-size: 0.7rem; }

      /* ========== TABS ========== */
      .tabs {
        background: var(--bg);
        border-bottom: 1px solid var(--line);
        padding: 0 28px;
        display: flex;
        gap: 4px;
        position: sticky;
        top: 116px;
        z-index: 30;
        overflow-x: auto;
      }
      .tab-btn {
        background: transparent;
        border: none;
        padding: 13px 16px;
        font-family: var(--f);
        font-size: 0.76rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--ink-3);
        cursor: pointer;
        position: relative;
        transition: color 0.12s;
        white-space: nowrap;
        display: inline-flex;
        align-items: center;
        gap: 8px;
      }
      .tab-btn:hover { color: var(--ink); }
      .tab-btn.active { color: var(--ink); }
      .tab-btn.active::after {
        content: '';
        position: absolute;
        bottom: -1px;
        left: 12px;
        right: 12px;
        height: 2px;
        background: var(--ink);
        border-radius: 2px 2px 0 0;
      }
      .tab-num {
        font-size: 0.66rem;
        color: var(--ink-3);
        opacity: 0.55;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .tab-btn.active .tab-num { color: var(--ink); opacity: 1; }
      .new-tab-badge {
        display: inline-block;
        padding: 2px 6px;
        border-radius: 4px;
        background: var(--yellow);
        color: var(--ink);
        font-size: 0.56rem;
        font-variation-settings: "wght" 800, "wdth" 110, "opsz" 14;
        letter-spacing: 0.1em;
        margin-right: 2px;
      }

      /* ========== LAYOUT ========== */
      main {
        max-width: 1480px;
        margin: 0 auto;
        padding: 28px;
        min-height: calc(100vh - 240px);
      }

      /* ========== PAGE HEAD ========== */
      .page-head {
        margin-bottom: 6px;
      }
      .page-title {
        margin-top: 10px;
      }
      .page-sub {
        font-size: 0.88rem;
        color: var(--ink-2);
        max-width: 620px;
        margin-top: 10px;
        line-height: 1.5;
      }

      /* ========== SECTION HEAD ========== */
      .sec-head {
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        gap: 24px;
        margin: 32px 0 14px;
      }
      .sec-head-left { display: flex; flex-direction: column; gap: 8px; }
      .sec-num {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 3px 10px;
        border-radius: 5px;
        background: var(--blue-tint);
        color: var(--blue);
        font-size: 0.6rem;
        font-variation-settings: "wght" 800, "wdth" 105, "opsz" 14;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        width: max-content;
      }
      .sec-hint {
        font-size: 0.8rem;
        color: var(--ink-2);
        max-width: 460px;
        text-align: right;
        line-height: 1.5;
      }

      /* ========== CARD ========== */
      .card {
        background: var(--surface);
        border: 1px solid var(--line);
        border-radius: 14px;
        padding: 22px;
        position: relative;
      }
      .card.tight { padding: 18px; }
      .card.hl {
        border-color: var(--blue);
        box-shadow: 0 0 0 3px var(--blue-soft);
      }
      .card.clickable {
        cursor: pointer;
        transition: border-color 0.14s, box-shadow 0.14s, transform 0.14s;
      }
      .card.clickable:hover {
        border-color: var(--line-strong);
      }
      .card.clickable.hl:hover {
        border-color: var(--blue);
        box-shadow: 0 0 0 4px var(--blue-soft);
      }
      .card.clickable:active { transform: translateY(1px); }
      .card.accent {
        background: var(--surface-2);
        border-color: var(--line);
        color: var(--ink);
        overflow: hidden;
        padding-left: 26px;
      }
      .card.accent::before {
        content: '';
        position: absolute;
        left: 0; top: 12px; bottom: 12px;
        width: 3px;
        border-radius: 0 3px 3px 0;
        background: var(--yellow-deep);
      }
      .card.accent .kpi-label { color: var(--ink-2); }
      .card.accent .kpi-value { color: var(--ink); }
      .card.accent .kpi-sub { color: var(--ink-3); }
      .card.accent .accent-tag {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        margin-top: 10px;
        padding: 2px 8px;
        border-radius: 4px;
        background: var(--bg-deep);
        color: var(--ink-2);
        font-size: 0.58rem;
        font-variation-settings: "wght" 800, "wdth" 110, "opsz" 14;
        letter-spacing: 0.14em;
        text-transform: uppercase;
      }
      .card.accent .accent-tag::before {
        content: '';
        width: 5px; height: 5px;
        border-radius: 50%;
        background: var(--yellow-deep);
      }

      /* ========== KPI ========== */
      .kpi-label {
        font-size: 0.64rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-2);
      }
      .kpi-row {
        display: flex;
        align-items: baseline;
        gap: 10px;
        flex-wrap: wrap;
        margin-top: 10px;
      }
      .kpi-value {
        font-variation-settings: "wght" 900, "wdth" 80, "opsz" 48;
        font-size: 2rem;
        line-height: 1;
        color: var(--ink);
        font-variant-numeric: tabular-nums;
        letter-spacing: -0.01em;
      }
      .kpi-value.sm { font-size: 1.5rem; font-variation-settings: "wght" 900, "wdth" 85, "opsz" 32; }
      .kpi-value.xl { font-size: 2.7rem; font-variation-settings: "wght" 900, "wdth" 76, "opsz" 72; }
      .card.hl .kpi-value { color: var(--blue); }
      .kpi-sub {
        font-size: 0.74rem;
        color: var(--ink-3);
        margin-top: 8px;
        line-height: 1.4;
      }

      /* ========== DELTA ========== */
      .delta {
        display: inline-flex;
        align-items: center;
        gap: 3px;
        font-size: 0.7rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        padding: 2px 8px;
        border-radius: 999px;
        font-variant-numeric: tabular-nums;
      }
      .delta.up { background: var(--pos-tint); color: var(--pos); }
      .delta.down { background: var(--neg-tint); color: var(--neg); }
      .delta.zero { background: var(--line-2); color: var(--ink-3); }
      .card.accent .delta.up { background: rgba(10,133,68,0.2); color: #7fdfa5; }
      .card.accent .delta.down { background: rgba(194,65,12,0.2); color: #ffb089; }

      /* ========== GRID ========== */
      .grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
      .grid-5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
      .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
      .grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
      .span-3 { grid-column: span 3; }
      .span-4 { grid-column: span 4; }
      .span-5 { grid-column: span 5; }
      .span-6 { grid-column: span 6; }
      .span-7 { grid-column: span 7; }
      .span-8 { grid-column: span 8; }
      .span-9 { grid-column: span 9; }
      @media (max-width: 960px) {
        .grid-4, .grid-5, .grid-3 { grid-template-columns: repeat(2, 1fr); }
        .span-3, .span-4, .span-5, .span-6, .span-7, .span-8, .span-9 { grid-column: span 12; }
      }
      @media (max-width: 600px) {
        .grid-4, .grid-5, .grid-3 { grid-template-columns: 1fr; }
      }

      /* ========== GOAL CARD ========== */
      .goal-card {
        padding: 26px 28px;
      }
      .goal-grid {
        display: grid;
        grid-template-columns: 1.25fr 1fr;
        gap: 36px;
        align-items: center;
      }
      .goal-statement {
        font-size: 0.96rem;
        color: var(--ink-2);
        line-height: 1.45;
        margin-top: 10px;
      }
      .goal-statement b {
        color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .goal-right { text-align: right; }
      .goal-current {
        font-variation-settings: "wght" 900, "wdth" 76, "opsz" 72;
        font-size: 3rem;
        color: var(--blue);
        line-height: 1;
        font-variant-numeric: tabular-nums;
        letter-spacing: -0.015em;
      }
      .goal-target {
        color: var(--ink-3);
        font-size: 0.9rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        margin-top: 8px;
      }
      .goal-bar-wrap { margin-top: 22px; }
      .goal-bar-track {
        position: relative;
        height: 12px;
        background: var(--bg-deep);
        border-radius: 6px;
        overflow: hidden;
      }
      .goal-bar-fill {
        height: 100%;
        background: var(--yellow);
        border-radius: 6px;
        transition: width 0.4s ease;
      }
      .goal-bar-meta {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 10px;
        font-size: 0.74rem;
        color: var(--ink-3);
      }
      .goal-bar-meta b {
        color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .pace-pill {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 3px 10px;
        border-radius: 999px;
        font-size: 0.66rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.12em;
      }
      .pace-pill.on { background: var(--pos-tint); color: var(--pos); }
      .pace-pill.below { background: var(--neg-tint); color: var(--neg); }
      @media (max-width: 760px) {
        .goal-grid { grid-template-columns: 1fr; }
        .goal-right { text-align: left; }
      }

      .goal-edit-btn {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        padding: 4px 10px;
        font-size: 0.68rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        background: var(--surface);
        border: 1px solid var(--line-strong);
        border-radius: 6px;
        color: var(--ink-2);
        cursor: pointer;
        transition: all 0.12s;
      }
      .goal-edit-btn:hover { border-color: var(--ink); color: var(--ink); }

      .modal-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(17,17,17,0.35);
        z-index: 120;
        display: flex;
        align-items: center;
        justify-content: center;
      }
      .modal {
        background: var(--surface);
        border-radius: 14px;
        padding: 24px 26px;
        width: 460px;
        max-width: 92vw;
        box-shadow: 0 24px 48px rgba(0,0,0,0.24);
        animation: toastIn 0.16s ease;
      }
      .modal-title {
        font-variation-settings: "wght" 900, "wdth" 92, "opsz" 24;
        font-size: 1.1rem;
        margin-bottom: 6px;
      }
      .modal-sub {
        font-size: 0.82rem;
        color: var(--ink-2);
        margin-bottom: 18px;
      }
      .modal-actions {
        display: flex;
        gap: 8px;
        justify-content: flex-end;
        margin-top: 20px;
      }

      .settings-section {
        margin-top: 18px;
        padding-top: 14px;
        border-top: 1px solid var(--line);
      }
      .settings-section:first-of-type {
        margin-top: 4px;
        padding-top: 0;
        border-top: none;
      }
      .settings-section.danger .settings-label { color: var(--neg); }
      .settings-label {
        font-size: 0.64rem;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-3);
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        margin-bottom: 10px;
      }
      .settings-hint {
        font-size: 0.76rem;
        color: var(--ink-3);
        margin-top: 10px;
        line-height: 1.5;
      }
      .settings-hint code {
        background: var(--surface-2);
        padding: 1px 6px;
        border-radius: 4px;
        font-family: var(--mono);
        font-size: 0.72rem;
        color: var(--ink-2);
      }
      .settings-hint b { color: var(--ink); font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14; }

      .audit-log {
        margin-top: 14px;
        border: 1px solid var(--line);
        border-radius: 14px;
        background: var(--surface);
        overflow: hidden;
      }
      .audit-head {
        padding: 14px 20px;
        border-bottom: 1px solid var(--line);
        background: var(--surface-2);
        display: flex;
        justify-content: space-between;
        align-items: center;
      }
      .audit-row {
        display: grid;
        grid-template-columns: 160px 180px 1fr auto;
        gap: 14px;
        padding: 12px 20px;
        border-bottom: 1px solid var(--line-2);
        align-items: center;
      }
      .audit-row:last-child { border-bottom: none; }
      .audit-ts {
        font-variant-numeric: tabular-nums;
        font-family: var(--mono);
        font-size: 0.78rem;
        color: var(--ink-2);
      }
      .audit-user {
        font-size: 0.85rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
        display: inline-flex;
        align-items: center;
        gap: 8px;
      }
      .audit-role-tag {
        font-size: 0.6rem;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 12;
        padding: 1px 6px;
        border-radius: 999px;
        background: var(--blue-tint);
        color: var(--blue);
      }
      .audit-role-tag.sync {
        background: var(--surface-2);
        color: var(--ink-3);
      }
      .audit-summary {
        font-size: 0.78rem;
        color: var(--ink-2);
      }
      .audit-count {
        display: inline-flex;
        align-items: center;
        padding: 3px 10px;
        border-radius: 999px;
        background: var(--blue-tint);
        color: var(--blue);
        font-size: 0.7rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .audit-empty {
        padding: 28px 20px;
        text-align: center;
        color: var(--ink-3);
        font-size: 0.84rem;
      }
      @media (max-width: 760px) {
        .audit-row { grid-template-columns: 1fr; gap: 6px; }
      }

      /* ========== FUNNEL ========== */
      .f-rows { display: flex; flex-direction: column; }
      .f-row {
        background: var(--surface);
        border: 1px solid var(--line);
        border-radius: 14px;
        padding: 18px 22px;
        display: grid;
        grid-template-columns: minmax(260px, 1.1fr) 1fr minmax(200px, 1fr);
        gap: 20px;
        align-items: center;
      }
      .f-row.final {
        background: var(--ink);
        color: #fff;
        border-color: var(--ink);
      }
      .f-row.final .f-stage-name { color: rgba(255,255,255,0.6); }
      .f-row.final .f-count { color: #fff; }
      .f-row.final .f-desc { color: rgba(255,255,255,0.7); }
      .f-row.final .f-sec-label { color: rgba(255,255,255,0.6); }
      .f-row.final .f-sec-value { color: #fff; }
      .f-row.final .f-sec-sub { color: rgba(255,255,255,0.55); }
      .f-row.final .f-sub { color: rgba(255,255,255,0.55); }
      .f-row.final .f-icon {
        background: var(--yellow);
        color: var(--ink);
      }
      .f-row.final .delta.up { background: rgba(10,133,68,0.22); color: #7fdfa5; }
      .f-row.final .delta.down { background: rgba(194,65,12,0.22); color: #ffb089; }
      .f-left { display: flex; align-items: center; gap: 14px; min-width: 0; }
      .f-icon {
        flex-shrink: 0;
        width: 44px; height: 44px;
        background: var(--blue-tint);
        border-radius: 10px;
        display: inline-flex;
        align-items: center; justify-content: center;
        color: var(--blue);
        font-variation-settings: "wght" 900, "wdth" 85, "opsz" 32;
        font-size: 0.9rem;
        letter-spacing: 0.02em;
      }
      .f-stage-name {
        font-size: 0.64rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-3);
      }
      .f-count-row {
        display: flex;
        align-items: baseline;
        gap: 8px;
        margin-top: 4px;
      }
      .f-count {
        font-variation-settings: "wght" 900, "wdth" 78, "opsz" 48;
        font-size: 1.9rem;
        line-height: 1;
        color: var(--ink);
        font-variant-numeric: tabular-nums;
        letter-spacing: -0.01em;
      }
      .f-sub {
        font-size: 0.68rem;
        color: var(--ink-3);
        margin-top: 4px;
        font-variant-numeric: tabular-nums;
      }
      .f-leads-split {
        display: flex;
        gap: 8px;
        margin-top: 8px;
        flex-wrap: wrap;
      }
      .f-leads-chip {
        display: inline-flex;
        align-items: baseline;
        gap: 5px;
        padding: 5px 11px;
        background: var(--blue-tint);
        border-radius: 999px;
        font-size: 0.82rem;
        color: var(--ink-2);
        font-variant-numeric: tabular-nums;
      }
      .f-leads-chip b {
        color: var(--blue);
        font-variation-settings: "wght" 900, "wdth" 82, "opsz" 24;
        font-size: 0.98rem;
      }
      .f-desc {
        font-size: 0.82rem;
        font-style: italic;
        color: var(--ink-3);
        text-align: center;
        line-height: 1.35;
      }
      .f-right { text-align: right; }
      .f-sec-label {
        font-size: 0.58rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-3);
      }
      .f-sec-row {
        display: flex;
        align-items: baseline;
        gap: 8px;
        justify-content: flex-end;
        margin-top: 4px;
      }
      .f-sec-value {
        font-variation-settings: "wght" 900, "wdth" 82, "opsz" 32;
        font-size: 1.4rem;
        line-height: 1;
        color: var(--ink);
        font-variant-numeric: tabular-nums;
      }
      .f-sec-sub {
        font-size: 0.66rem;
        color: var(--ink-3);
        margin-top: 4px;
      }
      .f-arrow {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 8px 0;
        position: relative;
      }
      .f-arrow::before {
        content: '';
        position: absolute;
        left: 50%;
        top: 0; bottom: 0;
        width: 1px;
        background: var(--line-strong);
      }
      .f-connector {
        position: relative;
        z-index: 1;
        display: inline-flex;
        align-items: center;
        gap: 10px;
        padding: 7px 14px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
        background: var(--surface);
        font-size: 0.7rem;
        color: var(--ink-3);
        font-variant-numeric: tabular-nums;
      }
      .f-connector .cvr {
        color: var(--ink);
        font-variation-settings: "wght" 800, "wdth" 95, "opsz" 14;
        font-size: 0.82rem;
      }
      .f-connector .dv {
        width: 1px;
        height: 12px;
        background: var(--line-strong);
      }
      .f-connector .loss {
        color: var(--ink-3);
        font-size: 0.66rem;
      }
      .f-connector .loss b {
        color: var(--ink-2);
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
      }
      @media (max-width: 860px) {
        .f-row { grid-template-columns: 1fr; gap: 12px; }
        .f-right { text-align: left; }
        .f-desc { text-align: left; }
        .f-sec-row { justify-content: flex-start; }
      }

      /* ========== PIPELINE BARS ========== */
      .pipe-row { margin-bottom: 14px; }
      .pipe-row:last-child { margin-bottom: 0; }
      .pipe-head {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        font-size: 0.8rem;
        margin-bottom: 6px;
        color: var(--ink-2);
      }
      .pipe-stage {
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
      }
      .pipe-value {
        font-variation-settings: "wght" 900, "wdth" 85, "opsz" 32;
        font-size: 1rem;
        color: var(--ink);
        font-variant-numeric: tabular-nums;
      }
      .pipe-bar {
        height: 10px;
        background: var(--bg-deep);
        border-radius: 5px;
        overflow: hidden;
      }
      .pipe-fill {
        height: 100%;
        background: var(--blue);
        border-radius: 5px;
      }
      .pipe-meta {
        font-size: 0.7rem;
        color: var(--ink-3);
        margin-top: 4px;
        font-variant-numeric: tabular-nums;
      }

      /* ========== TIMING ========== */
      .timing-row {
        display: grid;
        grid-template-columns: 220px 1fr 140px;
        gap: 16px;
        align-items: center;
        padding: 12px 0;
      }
      .timing-row + .timing-row { border-top: 1px solid var(--line-2); }
      .timing-label {
        font-size: 0.82rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
      }
      .timing-track {
        height: 28px;
        background: var(--bg-deep);
        border-radius: 6px;
        position: relative;
        overflow: hidden;
      }
      .timing-fill {
        height: 100%;
        background: var(--ink);
        border-radius: 6px;
        display: flex;
        align-items: center;
        padding: 0 12px;
        color: #fff;
        font-size: 0.74rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        font-variant-numeric: tabular-nums;
      }
      .timing-fill.hot { background: var(--neg); color: #fff; }
      .timing-delta {
        text-align: right;
        font-size: 0.74rem;
        font-variant-numeric: tabular-nums;
        display: inline-flex;
        justify-content: flex-end;
        gap: 6px;
        align-items: center;
      }
      .timing-delta .vs {
        font-size: 0.58rem;
        color: var(--ink-3);
        text-transform: uppercase;
        letter-spacing: 0.12em;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
      }

      /* ========== TABLE ========== */
      .table { width: 100%; border-collapse: collapse; }
      .table th {
        font-family: var(--f);
        font-size: 0.6rem;
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--ink-3);
        text-align: left;
        padding: 13px 18px;
        border-bottom: 1px solid var(--line);
        background: var(--surface-2);
      }
      .table th.r { text-align: right; }
      .table td {
        font-size: 0.85rem;
        color: var(--ink-2);
        padding: 14px 18px;
        border-bottom: 1px solid var(--line-2);
        vertical-align: middle;
      }
      .table td.r {
        text-align: right;
        font-variant-numeric: tabular-nums;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
      }
      .table tbody tr:last-child td { border-bottom: none; }

      .initials {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px; height: 28px;
        background: var(--blue-tint);
        color: var(--blue);
        font-variation-settings: "wght" 800, "wdth" 100, "opsz" 14;
        font-size: 0.72rem;
        border-radius: 50%;
        margin-right: 10px;
        flex-shrink: 0;
      }
      .writer-cell {
        display: flex;
        align-items: center;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
      }
      .tag {
        display: inline-block;
        font-size: 0.56rem;
        font-variation-settings: "wght" 800, "wdth" 110, "opsz" 14;
        text-transform: uppercase;
        letter-spacing: 0.1em;
        padding: 3px 8px;
        border-radius: 4px;
        margin-left: 10px;
      }
      .tag.warn { background: var(--neg-tint); color: var(--neg); }
      .tag.good { background: var(--pos-tint); color: var(--pos); }

      /* ========== MINI BAR (in tables) ========== */
      .mini-bar-row {
        display: flex;
        align-items: center;
        gap: 12px;
        min-width: 130px;
      }
      .mini-bar {
        flex: 1;
        height: 6px;
        background: var(--bg-deep);
        border-radius: 3px;
        overflow: hidden;
        min-width: 40px;
      }
      .mini-bar-fill {
        height: 100%;
        background: var(--blue);
        border-radius: 3px;
      }
      .mini-bar-fill.warn { background: var(--neg); }
      .mini-bar-fill.yellow { background: var(--yellow-deep); }
      .mini-bar-value {
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
        font-size: 0.8rem;
        font-variant-numeric: tabular-nums;
        min-width: 44px;
        text-align: right;
      }

      /* ========== TIMELINE CHART CONTROLS ========== */
      .timeline-head {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 18px;
        flex-wrap: wrap;
      }
      .timeline-controls {
        display: flex;
        gap: 8px;
        flex-wrap: wrap;
      }
      .segmented {
        display: inline-flex;
        align-items: center;
        padding: 3px;
        background: var(--surface-2);
        border: 1px solid var(--line);
        border-radius: 8px;
        gap: 2px;
      }
      .seg-btn {
        font-family: var(--f);
        font-size: 0.7rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        padding: 6px 11px;
        border: none;
        background: transparent;
        color: var(--ink-3);
        border-radius: 6px;
        cursor: pointer;
        transition: all 0.12s;
        letter-spacing: 0.02em;
      }
      .seg-btn:hover { color: var(--ink); }
      .seg-btn.active {
        background: var(--ink);
        color: #fff;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .seg-btn.hide-proj.active {
        background: var(--line-strong);
        color: var(--ink);
      }

      .channel-tabs {
        display: flex;
        gap: 6px;
        margin: 16px 0 6px;
        flex-wrap: wrap;
      }
      .chan-tab {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        padding: 6px 12px;
        border-radius: 999px;
        border: 1px solid var(--line-strong);
        background: var(--surface);
        color: var(--ink-2);
        font-family: var(--f);
        font-size: 0.72rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        cursor: pointer;
        transition: all 0.12s;
      }
      .chan-tab:hover { border-color: var(--ink); color: var(--ink); }
      .chan-tab.active {
        background: var(--ink);
        color: #fff;
        border-color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .chan-tab.chan-soon {
        opacity: 0.5;
        cursor: not-allowed;
        font-style: italic;
      }
      .chan-tab.chan-soon:hover { border-color: var(--line-strong); color: var(--ink-2); }
      .chan-dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        flex-shrink: 0;
      }

      .timeline-stats {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 14px;
        margin-top: 18px;
        padding-top: 18px;
        border-top: 1px solid var(--line-2);
      }
      .ts-item {
        display: flex;
        flex-direction: column;
        gap: 2px;
      }
      .ts-item .ts-note {
        font-size: 0.68rem;
        color: var(--ink-3);
        margin-top: 4px;
      }
      @media (max-width: 760px) {
        .timeline-stats { grid-template-columns: repeat(2, 1fr); }
      }

      .journey-card {
        padding: 22px 26px;
      }
      .journey-row {
        display: flex;
        align-items: center;
        gap: 10px;
        flex-wrap: wrap;
      }
      .journey-step {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 6px;
        min-width: 72px;
      }
      .journey-count {
        font-variation-settings: "wght" 900, "wdth" 85, "opsz" 32;
        font-size: 1.3rem;
        color: var(--ink);
        font-variant-numeric: tabular-nums;
      }
      .journey-label {
        font-size: 0.62rem;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--ink-3);
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
      }
      .journey-arrow {
        color: var(--ink-3);
        font-size: 0.8rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        flex: 1;
        text-align: center;
        min-width: 50px;
        font-variant-numeric: tabular-nums;
      }
      .journey-arrow b {
        color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }

      /* ========== CHART ========== */
      .chart-wrap { width: 100%; height: 220px; margin-top: 14px; }
      .chart-wrap.sm { height: 160px; }
      .chart-legend {
        display: flex;
        gap: 16px;
        font-size: 0.7rem;
        color: var(--ink-2);
      }
      .chart-legend span {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
      }
      .swatch { width: 10px; height: 10px; border-radius: 2px; }
      .swatch.dashed {
        background: transparent;
        border-top: 2px dashed var(--blue);
        border-radius: 0;
        height: 2px;
        width: 16px;
        margin-top: 4px;
      }

      /* ========== SPARKLINE ========== */
      svg.spark { width: 84px; height: 26px; }

      /* ========== ALERT ========== */
      .alert {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px 14px;
        border: 1px solid var(--line);
        border-left: 3px solid var(--neg);
        background: var(--surface);
        border-radius: 8px;
      }
      .alert.ok { border-left-color: var(--pos); }
      .alert.info { border-left-color: var(--blue); }
      .alert-icon {
        width: 22px; height: 22px;
        display: flex; align-items: center; justify-content: center;
        flex-shrink: 0;
        color: var(--neg);
        font-variation-settings: "wght" 900, "wdth" 100, "opsz" 14;
      }
      .alert.ok .alert-icon { color: var(--pos); }
      .alert.info .alert-icon { color: var(--blue); }
      .alert-body { flex: 1; }
      .alert-title {
        font-size: 0.8rem;
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        color: var(--ink);
      }
      .alert-desc {
        font-size: 0.74rem;
        color: var(--ink-2);
        margin-top: 2px;
        line-height: 1.4;
      }

      /* ========== INPUTS ========== */
      .input-section {
        margin-bottom: 14px;
        border: 1px solid var(--line);
        border-radius: 14px;
        overflow: hidden;
        background: var(--surface);
      }
      .input-section-head {
        padding: 16px 22px;
        background: var(--surface-2);
        border-bottom: 1px solid var(--line);
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 18px;
      }
      .input-section-title {
        font-variation-settings: "wght" 900, "wdth" 92, "opsz" 24;
        font-size: 1.02rem;
        color: var(--ink);
        letter-spacing: -0.005em;
        line-height: 1.1;
      }
      .input-section-sub {
        font-size: 0.78rem;
        color: var(--ink-2);
        margin-top: 4px;
        max-width: 520px;
        line-height: 1.4;
      }
      .input-section-badge {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 3px 10px;
        border-radius: 999px;
        background: var(--blue-tint);
        color: var(--blue);
        font-size: 0.62rem;
        font-variation-settings: "wght" 800, "wdth" 105, "opsz" 14;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        white-space: nowrap;
      }
      .input-section-body {
        padding: 20px 22px 22px;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 16px;
      }
      .field-label {
        font-size: 0.6rem;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--ink-3);
        font-variation-settings: "wght" 700, "wdth" 110, "opsz" 14;
        margin-bottom: 7px;
        display: block;
      }
      .field-input {
        width: 100%;
        padding: 10px 12px;
        border: 1px solid var(--line-strong);
        border-radius: 6px;
        background: var(--surface);
        color: var(--ink);
        font-family: var(--f);
        font-size: 0.92rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        font-variant-numeric: tabular-nums;
        outline: none;
        transition: border 0.12s, box-shadow 0.12s;
      }
      .field-input:focus {
        border-color: var(--blue);
        box-shadow: 0 0 0 3px var(--blue-soft);
      }
      .field-input[readonly] {
        background: var(--surface-2);
        color: var(--ink-2);
      }
      /* Role-locked field: greyed + non-interactive. The lock is UI-only; the server
         re-checks role scope and rejects out-of-scope edits with 403. */
      .field-input:disabled {
        background: var(--surface-2);
        color: var(--ink-3);
        cursor: not-allowed;
      }
      .field-locked { opacity: 0.72; }
      .field-lock-pill {
        margin-left: 6px;
        font-size: 0.72rem;
        opacity: 0.7;
      }
      .field-wrap { position: relative; }
      .field-wrap.money .field-input { padding-left: 24px; }
      .field-wrap.money::before {
        content: '$';
        position: absolute;
        left: 12px;
        top: 50%;
        transform: translateY(-50%);
        color: var(--ink-3);
        font-size: 0.88rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        pointer-events: none;
      }
      .field-wrap.pct .field-input { padding-right: 30px; }
      .field-wrap.pct::after {
        content: '%';
        position: absolute;
        right: 12px;
        top: 50%;
        transform: translateY(-50%);
        color: var(--ink-3);
        font-size: 0.88rem;
        pointer-events: none;
      }
      .field-help {
        font-size: 0.7rem;
        color: var(--ink-3);
        margin-top: 6px;
        line-height: 1.3;
      }

      .hint-bar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        padding: 14px 18px;
        background: var(--surface-2);
        border: 1px solid var(--line);
        border-radius: 12px;
        margin: 22px 0 18px;
      }
      .hint-bar-text {
        font-size: 0.84rem;
        color: var(--ink-2);
        line-height: 1.4;
      }
      .hint-bar-text b {
        color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }
      .btn {
        padding: 9px 16px;
        border-radius: 7px;
        font-family: var(--f);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
        font-size: 0.76rem;
        cursor: pointer;
        border: 1px solid var(--line-strong);
        background: var(--surface);
        color: var(--ink-2);
        transition: all 0.12s;
        white-space: nowrap;
        display: inline-flex;
        align-items: center;
        gap: 6px;
      }
      .btn:hover { border-color: var(--ink); color: var(--ink); }
      .btn.primary {
        background: var(--ink);
        border-color: var(--ink);
        color: #fff;
      }
      .btn.primary:hover { background: #000; }
      .btn.dirty {
        background: var(--yellow);
        border-color: var(--yellow-deep);
        color: var(--ink);
      }
      .btn.dirty:hover { background: #fff07a; }
      .btn:disabled {
        opacity: 0.5;
        cursor: not-allowed;
      }
      .btn.sm { padding: 6px 12px; font-size: 0.72rem; }

      .action-bar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        padding: 16px 18px;
        background: var(--surface);
        border: 1px solid var(--line);
        border-radius: 12px;
        margin-top: 18px;
      }
      .action-bar-status {
        font-size: 0.8rem;
        color: var(--ink-2);
        display: flex;
        align-items: center;
        gap: 10px;
      }
      .action-bar-status b {
        color: var(--ink);
        font-variation-settings: "wght" 700, "wdth" 100, "opsz" 14;
      }

      /* ========== TOAST ========== */
      .toast-wrap {
        position: fixed;
        top: 88px;
        right: 28px;
        z-index: 100;
        pointer-events: none;
      }
      .toast {
        pointer-events: auto;
        background: var(--ink);
        color: #fff;
        padding: 12px 18px;
        border-radius: 9px;
        font-size: 0.82rem;
        font-variation-settings: "wght" 600, "wdth" 100, "opsz" 14;
        display: inline-flex;
        align-items: center;
        gap: 10px;
        animation: toastIn 0.22s ease;
        box-shadow: 0 10px 30px rgba(0,0,0,0.18);
      }
      .toast .check {
        width: 18px; height: 18px;
        border-radius: 50%;
        background: var(--pos);
        color: #fff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 0.66rem;
        font-variation-settings: "wght" 900, "wdth" 100, "opsz" 14;
      }
      @keyframes toastIn {
        from { opacity: 0; transform: translateY(-8px); }
        to { opacity: 1; transform: translateY(0); }
      }

      /* ========== FADE ========== */
      .fade-in {
        opacity: 0;
        transform: translateY(8px);
        animation: fadeUp 0.38s ease forwards;
      }
      @keyframes fadeUp {
        to { opacity: 1; transform: translateY(0); }
      }
      .fade-in:nth-child(1) { animation-delay: 0.02s; }
      .fade-in:nth-child(2) { animation-delay: 0.06s; }
      .fade-in:nth-child(3) { animation-delay: 0.10s; }
      .fade-in:nth-child(4) { animation-delay: 0.14s; }
      .fade-in:nth-child(5) { animation-delay: 0.18s; }
      .fade-in:nth-child(6) { animation-delay: 0.22s; }
      .fade-in:nth-child(7) { animation-delay: 0.26s; }
      .fade-in:nth-child(8) { animation-delay: 0.30s; }

      ::-webkit-scrollbar { width: 10px; height: 10px; }
      ::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 10px; }
      ::-webkit-scrollbar-track { background: transparent; }

      footer {
        padding: 24px 28px;
        border-top: 1px solid var(--line);
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: 0.7rem;
        color: var(--ink-3);
        max-width: 1480px;
        margin: 0 auto;
        flex-wrap: wrap;
        gap: 10px;
      }
      footer .cd-dot { width: 5px; height: 5px; }

      /* ========== OPERATOR LANDING (/dashboard/) ========== */
      .landing {
        min-height: 80vh;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 48px 20px;
      }
      .landing-card {
        width: 100%;
        max-width: 520px;
        background: var(--surface);
        border: 1px solid var(--line);
        border-radius: 16px;
        padding: 36px 32px;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);
      }
      .landing-mark {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-size: 0.66rem;
        font-variation-settings: "wght" 800, "wdth" 110, "opsz" 14;
        color: var(--ink-3);
        text-transform: uppercase;
        letter-spacing: 0.16em;
      }
      .landing-mark .cd-dot { background: var(--yellow); }
      .landing-title {
        margin-top: 14px;
        font-variation-settings: "wght" 900, "wdth" 95, "opsz" 40;
        font-size: 1.6rem;
        color: var(--ink);
        letter-spacing: -0.01em;
      }
      .landing-sub {
        margin-top: 6px;
        font-size: 0.86rem;
        color: var(--ink-2);
      }
      .landing-list {
        margin-top: 24px;
        display: flex;
        flex-direction: column;
        gap: 10px;
      }
      .landing-item {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 14px 16px;
        background: var(--surface-2);
        border: 1px solid var(--line);
        border-radius: 11px;
        text-decoration: none;
        transition: all 0.12s;
      }
      .landing-item:hover {
        border-color: var(--blue);
        background: var(--blue-tint);
        transform: translateY(-1px);
      }
      .landing-item-name {
        font-variation-settings: "wght" 800, "wdth" 100, "opsz" 18;
        font-size: 0.98rem;
        color: var(--ink);
      }
      .landing-item-meta {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        font-size: 0.72rem;
        color: var(--ink-3);
      }
      .landing-status {
        text-transform: uppercase;
        letter-spacing: 0.1em;
        font-variation-settings: "wght" 700;
        padding: 2px 8px;
        border-radius: 999px;
        background: var(--line-2);
        color: var(--ink-2);
      }
      .landing-status.on {
        background: var(--pos-tint);
        color: var(--pos);
      }
      .landing-slug { font-family: var(--mono); }
      .landing-arrow {
        color: var(--blue);
        font-variation-settings: "wght" 700;
      }
      .landing-empty {
        margin-top: 24px;
        padding: 18px;
        text-align: center;
        font-size: 0.85rem;
        color: var(--ink-3);
        background: var(--surface-2);
        border: 1px dashed var(--line-strong);
        border-radius: 11px;
      }
