  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Emoji&display=swap');

  :root {
    --gold: #4a90d9;
    --gold-light: #6aabf0;
    --dark: #1a1e2e;
    --dark-card: #212636;
    --dark-border: rgba(255,255,255,0.06);
    --cream: rgba(255,255,255,0.9);
    --cream-muted: rgba(255,255,255,0.55);
    --red: #ef4444;
    --red-bg: rgba(239,68,68,0.1);
    --amber: #f59e0b;
    --amber-bg: rgba(245,158,11,0.1);
    --green: #34d399;
    --green-bg: rgba(52,211,153,0.1);
    --bg-card-hover: #262b3d;
    --border-hi: rgba(255,255,255,0.1);
    --text-muted: rgba(255,255,255,0.3);
    --blue: #4a90d9;
    --blue-light: #6aabf0;
    --blue-glow: rgba(74,144,217,0.15);
    --chat-width: 420px;
  }

  * { margin: 0; padding: 0; box-sizing: border-box; }

  /* ── App-like behavior: no zoom, no bounce ── */
  html {
    touch-action: manipulation;
    overscroll-behavior: none;
    -webkit-text-size-adjust: 100%;
    height: 100%;
  }

  body {
    font-family: 'Inter', 'Noto Emoji', system-ui, sans-serif;
    font-variant-emoji: text;
    background: var(--dark);
    color: var(--cream);
    min-height: 100vh;
    min-height: 100dvh;
    -webkit-font-smoothing: antialiased;
    overscroll-behavior: none;
    -webkit-overflow-scrolling: touch;
  }

  /* Prevent iOS pinch-zoom on the entire page */
  html, body { touch-action: pan-x pan-y; }

  /* Safe area insets for notched devices (iPhone X+) */
  body {
    padding-top: env(safe-area-inset-top);
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
  }

  /* Prevent iOS auto-zoom on input focus (requires 16px minimum) */
  @supports (-webkit-touch-callout: none) {
    input, textarea, select { font-size: 16px !important; }
  }

  /* ── Header ─────────────────────────────────── */
  .header {
    background: rgba(33,38,54,0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--dark-border);
    padding: 14px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 100;
  }
  .header-left {
    display: flex;
    align-items: center;
    gap: 20px;
  }
  .header-logo {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--cream);
    letter-spacing: -0.3px;
  }
  .header-logo em { font-weight: 300; font-style: italic; opacity: 0.7; }
  .header-logo .dot { color: var(--blue); }
  .header-sep {
    width: 1px;
    height: 20px;
    background: var(--border-hi);
  }
  .header-age-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--dark-border);
    border-radius: 8px;
    padding: 6px 16px;
    font-size: 0.7rem;
  }
  .header-age-label {
    color: var(--cream-muted);
    font-weight: 400;
  }
  .header-age-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--cream);
  }
  .header-age-unit {
    font-size: 0.6rem;
    color: var(--text-muted);
    margin-left: 2px;
  }
  .header-insight {
    background: var(--amber-bg);
    border: 1px solid rgba(245,158,11,0.15);
    border-radius: 8px;
    padding: 6px 14px;
    font-size: 0.65rem;
    color: var(--amber);
    line-height: 1.4;
    max-width: 340px;
  }
  .header-insight strong { font-weight: 600; }
  .header-insight.green-insight {
    background: var(--green-bg);
    border-color: rgba(52,211,153,0.15);
    color: var(--green);
  }
  .header-divider {
    width: 1px;
    height: 20px;
    background: var(--border-hi);
  }
  .header-client {
    font-size: 0.85rem;
    color: var(--gold);
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    display: none;
  }
  .header-period {
    font-size: 0.65rem;
    color: var(--text-muted);
  }
  .header-right {
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .data-age-badge{cursor:pointer;transition:opacity .2s}
  .data-age-badge:hover{opacity:.8}
  .data-update-popup{display:none;position:fixed;background:#2a2a2a;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:20px 22px;width:340px;z-index:9999;box-shadow:0 12px 32px rgba(0,0,0,.6)}
  .data-update-popup.show{display:block}
  .data-update-popup-title{font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:12px;font-weight:600}
  .data-update-date{font-size:1rem;font-weight:700;color:var(--cream);margin-bottom:4px}
  .data-update-period{font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:16px}
  .data-update-section{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.35);margin:12px 0 6px;font-weight:600}
  .data-update-item{font-size:.78rem;color:rgba(255,255,255,.65);padding:4px 0;display:flex;align-items:center;gap:8px}
  .data-update-item::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
  .data-update-item.available::before{background:#2ecc71}
  .data-update-item.missing::before{background:#e74c3c}
  .header-btn {
    font-family: inherit;
    font-size: .6rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 6px;
    border: 1px solid rgba(74,144,217,.3);
    background: transparent;
    color: var(--blue-light);
    cursor: pointer;
    transition: all .2s;
  }
  .header-btn:hover { background: rgba(74,144,217,0.08); }
  .header-btn.sent { border-color: var(--green); color: var(--green); pointer-events: none; }
  .header-btn.sending { opacity: .5; pointer-events: none; }
  .header-link {
    font-size: .55rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.4);
    text-decoration: none;
    transition: color .2s;
  }
  .header-link:hover { color: var(--cream); }

  /* ── Tab Navigation ─────────────────────────── */
  .tab-nav {
    display: flex;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    background: rgba(33,38,54,0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--dark-border);
    padding: 0 28px;
  }
  .tab-btn {
    padding: 12px 24px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-family: inherit;
    font-size: 0.78rem;
    font-weight: 500;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
    letter-spacing: 0.5px;
    text-transform: uppercase;
  }
  .tab-btn:hover { color: var(--cream); }
  .tab-btn.active {
    color: var(--blue);
    border-bottom-color: var(--blue);
  }

  /* ── Main Content ───────────────────────────── */
  .main { padding: 20px 28px 100px; max-width: 1360px; margin: 0 auto; }
  .tab-content { display: none; }
  .tab-content.active { display: block; }

  /* ── Dashboard full background image ─────────── */
  /* Hero background set per-console via inline <style> */
  #tab-dashboard {
    position: relative;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-top: -20px;
    padding: 28px calc(50vw - 50%) 120px;
    min-height: 100vh;
    margin-bottom: -100px;
  }
  #tab-dashboard::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(10,10,15,.55);
    z-index: 0;
  }
  #tab-dashboard > * {
    position: relative;
    z-index: 1;
  }
  #tab-dashboard .card {
    background: rgba(30,30,35,.55);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-color: rgba(255,255,255,.08);
  }
  #tab-dashboard .card:hover {
    background: rgba(30,30,35,.65);
  }

  /* ── Daily Briefing ────────────────────────────── */
  /* Morning Check-in card (personalized, POS-connected) */
  .checkin-card { background: linear-gradient(135deg, rgba(42,124,111,.15), rgba(20,20,25,.8)); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(52,211,153,.15); border-radius: 16px; padding: 24px 28px; margin-bottom: 16px; }
  .checkin-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
  .checkin-label { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 3px; color: var(--green); font-weight: 600; }
  .checkin-date { font-size: 0.68rem; color: rgba(255,255,255,.35); letter-spacing: 1px; }
  .checkin-lines { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
  .checkin-line { display: flex; align-items: center; gap: 10px; padding: 8px 14px; border-radius: 10px; background: rgba(255,255,255,.04); font-size: 0.82rem; color: rgba(255,255,255,.75); line-height: 1.4; }
  .checkin-line .checkin-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
  .checkin-line.green .checkin-dot { background: var(--green); }
  .checkin-line.amber .checkin-dot { background: var(--amber); }
  .checkin-line.red .checkin-dot { background: var(--red); }
  .checkin-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 14px; }
  .checkin-kpi { background: rgba(255,255,255,.05); border-radius: 10px; padding: 12px 14px; border: 1px solid rgba(255,255,255,.06); }
  .checkin-kpi-label { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.3); margin-bottom: 4px; }
  .checkin-kpi-value { font-size: 1.2rem; font-weight: 600; color: var(--cream); line-height: 1.2; }
  .checkin-kpi-value.green { color: var(--green); }
  .checkin-kpi-value.amber { color: var(--amber); }
  .checkin-kpi-value.red { color: var(--red); }
  .checkin-kpi-sub { font-size: 0.68rem; color: rgba(255,255,255,.3); margin-top: 2px; }
  .checkin-tip { background: rgba(52,211,153,.06); border-radius: 8px; padding: 10px 14px; font-size: 0.78rem; color: rgba(255,255,255,.5); line-height: 1.5; border-left: 3px solid var(--green); }
  .checkin-tip strong { color: rgba(255,255,255,.7); }
  @media(max-width:768px) { .checkin-card { padding: 18px 16px; } .checkin-kpis { grid-template-columns: 1fr 1fr; } }

  /* Daily Briefing card (KPI overview) */
  .briefing-card { background: rgba(20,20,25,.7) !important; backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.1) !important; border-radius: 16px; padding: 24px 28px; margin-bottom: 20px; }
  .briefing-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
  .briefing-date { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 3px; color: rgba(255,255,255,.35); }
  .briefing-title { font-size: 1.1rem; font-weight: 600; color: var(--cream); letter-spacing: 0.5px; }
  .briefing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 16px; }
  .briefing-item { background: rgba(255,255,255,.04); border-radius: 10px; padding: 14px 16px; border: 1px solid rgba(255,255,255,.06); }
  .briefing-item-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.3); margin-bottom: 6px; }
  .briefing-item-value { font-size: 1.3rem; font-weight: 600; color: var(--cream); line-height: 1.2; }
  .briefing-item-sub { font-size: 0.72rem; color: rgba(255,255,255,.35); margin-top: 3px; }
  .briefing-item-value.green { color: var(--green); }
  .briefing-item-value.amber { color: var(--amber); }
  .briefing-item-value.red { color: var(--red); }
  .briefing-insight { background: rgba(255,255,255,.03); border-radius: 8px; padding: 12px 16px; font-size: 0.8rem; color: rgba(255,255,255,.5); line-height: 1.5; border-left: 3px solid var(--accent, rgba(255,255,255,.15)); }
  .briefing-insight strong { color: rgba(255,255,255,.7); }
  .briefing-alerts { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
  .briefing-alert { display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 100px; font-size: 0.68rem; letter-spacing: 0.5px; font-weight: 500; }
  .briefing-alert.green { background: rgba(46,125,79,.12); color: #6ee7a0; }
  .briefing-alert.amber { background: rgba(196,138,26,.12); color: #fbbf24; }
  .briefing-alert.red { background: rgba(196,51,51,.12); color: #f87171; }
  .briefing-alert .alert-dot { width: 6px; height: 6px; border-radius: 50%; }
  .briefing-alert.green .alert-dot { background: #6ee7a0; }
  .briefing-alert.amber .alert-dot { background: #fbbf24; }
  .briefing-alert.red .alert-dot { background: #f87171; }
  @media(max-width:768px) { .briefing-card { padding: 18px 16px; } .briefing-grid { grid-template-columns: 1fr 1fr; } .briefing-title { font-size: 0.95rem; } }

  /* ── For You Insights Feed ── */
  .foryou-card {
    background: rgba(20,20,25,.7); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,.1); border-radius: 16px; padding: 20px 24px; margin-bottom: 20px;
  }
  .foryou-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
  .foryou-title { font-size: .85rem; font-weight: 700; color: var(--cream); letter-spacing: .02em; }
  .foryou-time { font-size: .65rem; color: rgba(255,255,255,.3); }
  .foryou-items { display: flex; flex-direction: column; gap: 8px; }
  .foryou-item {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 10px 12px; background: rgba(255,255,255,.04); border-radius: 10px;
    cursor: pointer; transition: background .2s; border-left: 3px solid transparent;
  }
  .foryou-item:hover { background: rgba(255,255,255,.08); }
  .foryou-item.severity-red { border-left-color: var(--red); }
  .foryou-item.severity-amber { border-left-color: var(--amber); }
  .foryou-item.severity-green { border-left-color: var(--green); }
  .foryou-item.severity-blue { border-left-color: var(--blue); }
  .foryou-dot { width: 6px; height: 6px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
  .foryou-dot.red { background: var(--red); }
  .foryou-dot.amber { background: var(--amber); }
  .foryou-dot.green { background: var(--green); }
  .foryou-dot.blue { background: var(--blue); }
  .foryou-text { font-size: .78rem; color: rgba(255,255,255,.7); line-height: 1.4; }
  .foryou-empty { font-size: .75rem; color: rgba(255,255,255,.3); text-align: center; padding: 8px 0; }
  @media(max-width:768px) { .foryou-card { padding: 16px 14px; } }

  /* REVIEW TOAST */
  .review-toast { position: fixed; bottom: 24px; right: 24px; z-index: 8000; max-width: 400px; width: calc(100vw - 48px); display: flex; flex-direction: column; gap: 10px; }
  .review-toast-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: rgba(20,20,25,.95); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.1); border-radius: 12px 12px 0 0; }
  .review-toast-title { font-size: .75rem; font-weight: 600; color: var(--cream); }
  .review-toast-dismiss-all { font-family: 'DM Mono', monospace; font-size: .55rem; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.3); background: none; border: 1px solid rgba(255,255,255,.1); border-radius: 4px; padding: 3px 8px; cursor: pointer; }
  .review-toast-dismiss-all:hover { color: var(--cream); border-color: rgba(255,255,255,.3); }
  .review-card { background: rgba(20,20,25,.95); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 16px; animation: reviewSlideIn .3s ease-out; }
  .review-card:first-child { border-radius: 0 0 12px 12px; }
  .review-card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
  .review-stars { color: #fbbf24; font-size: .9rem; letter-spacing: 1px; }
  .review-platform { font-family: 'DM Mono', monospace; font-size: .5rem; letter-spacing: 1px; text-transform: uppercase; padding: 2px 6px; border-radius: 3px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.35); }
  .review-text { font-size: .8rem; color: rgba(255,255,255,.6); line-height: 1.5; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
  .review-meta { display: flex; align-items: center; justify-content: space-between; }
  .review-author { font-size: .7rem; color: rgba(255,255,255,.35); }
  .review-dismiss { font-family: 'DM Mono', monospace; font-size: .5rem; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.25); background: none; border: 1px solid rgba(255,255,255,.08); border-radius: 4px; padding: 3px 8px; cursor: pointer; }
  .review-dismiss:hover { color: var(--cream); border-color: rgba(255,255,255,.2); }
  @keyframes reviewSlideIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
  @media(max-width:768px) { .review-toast { bottom: 12px; right: 12px; max-width: calc(100vw - 24px); } }

  .theme-swatch {
    width: 36px; height: 36px; border-radius: 50%; border: 2px solid transparent;
    cursor: pointer; transition: transform 0.15s, border-color 0.2s;
  }
  .theme-swatch:hover { transform: scale(1.15); }
  .theme-swatch.active { border-color: rgba(255,255,255,0.9); transform: scale(1.15); }

  /* ── Menu upload ────────────────────────────────── */
  .menu-tab { padding:6px 14px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:transparent;color:rgba(255,255,255,.4);font-size:.75rem;cursor:pointer;transition:all .2s;font-family:inherit; }
  .menu-tab.active { background:rgba(255,255,255,.1);color:var(--cream);border-color:rgba(255,255,255,.25); }
  .menu-upload-panel { display:none; }
  .menu-upload-panel.active { display:block; }
  #menuTableBody tr { border-bottom:1px solid rgba(255,255,255,.06); }
  #menuTableBody td { padding:6px 8px;color:var(--cream); }
  #menuTableBody .menu-del { cursor:pointer;color:rgba(255,255,255,.2);font-size:1rem;transition:color .2s; }
  #menuTableBody .menu-del:hover { color:#e74c3c; }

  /* ── Date Filter Widget ──────────────────────── */
  .date-filter {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 16px 0 0;
    flex-wrap: wrap;
  }
  .date-btn {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.22);
    color: rgba(255,255,255,.75);
    padding: 7px 16px;
    border-radius: 6px;
    font-size: .78rem;
    font-family: 'DM Mono', monospace;
    cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
    letter-spacing: .02em;
  }
  .date-btn:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.35); color: #fff; }
  .date-btn.active { background: rgba(74,144,217,.25); border-color: rgba(74,144,217,.6); color: #5ba8f7; font-weight: 600; }
  .date-custom { display: none; align-items: center; gap: 8px; margin-top: 8px; }
  .date-custom.show { display: flex; }
  .date-custom input[type="month"] {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.22);
    color: var(--cream);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: .75rem;
    font-family: 'DM Mono', monospace;
  }
  .date-custom button {
    background: var(--blue);
    border: none;
    color: #fff;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: .75rem;
    cursor: pointer;
    font-family: 'DM Mono', monospace;
  }
  /* Mini calendar */
  .mini-cal {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 10px;
    padding: 14px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    margin-top: 10px;
    max-width: 320px;
  }
  .mini-cal-month {
    padding: 8px 6px;
    text-align: center;
    font-size: .72rem;
    font-family: 'DM Mono', monospace;
    color: rgba(255,255,255,.6);
    border-radius: 6px;
    cursor: pointer;
    transition: all .15s;
    border: 1px solid rgba(255,255,255,.1);
  }
  .mini-cal-month:hover { background: rgba(255,255,255,.14); color: #fff; border-color: rgba(255,255,255,.25); }
  .mini-cal-month.active { background: rgba(74,144,217,.3); border-color: rgba(74,144,217,.6); color: #5ba8f7; font-weight: 600; }
  .mini-cal-month.in-range { background: rgba(74,144,217,.15); color: rgba(74,144,217,.8); border-color: rgba(74,144,217,.3); }
  .mini-cal-month.disabled { opacity: .25; cursor: default; pointer-events: none; }
  @media (max-width: 768px) {
    .date-filter { gap: 4px; }
    .date-btn { padding: 4px 8px; font-size: .65rem; }
    .mini-cal { grid-template-columns: repeat(3, 1fr); }
  }

  /* ── Page Title Row ──────────────────────────── */
  .page-title-row {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 20px;
  }
  .page-title {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--cream);
  }
  .page-title-status {
    font-size: 0.7rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 4px;
  }
  .page-title-status.amber {
    background: var(--amber-bg);
    color: var(--amber);
  }
  .page-title-status.green {
    background: var(--green-bg);
    color: var(--green);
  }

  /* ── Card Base ───────────────────────────────── */
  .card {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    overflow: hidden;
    transition: border-color 0.2s;
  }
  .card:hover { border-color: var(--border-hi); }
  .card-header {
    padding: 16px 20px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .card-title {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--cream);
  }
  .card-action {
    font-size: 0.65rem;
    color: var(--blue-light);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    border: 1px solid rgba(74,144,217,0.2);
    border-radius: 6px;
    padding: 4px 10px;
    background: transparent;
    font-family: inherit;
    transition: background 0.15s;
  }
  .card-action:hover { background: rgba(74,144,217,0.08); }
  .card-body { padding: 0 20px 20px; }

  /* ── HERO SECTION: Central Gauge + Radar ───── */
  .hero-row {
    display: grid;
    grid-template-columns: 240px 1fr 300px;
    gap: 16px;
    margin-bottom: 16px;
  }

  /* Radar card */
  .radar-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .radar-card .card-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 16px;
  }
  .dim-tooltip{display:none;position:fixed;background:#2a2a2a;border:1px solid rgba(74,144,217,.25);border-radius:8px;padding:16px 18px;width:300px;z-index:9999;box-shadow:0 12px 32px rgba(0,0,0,.6);text-align:left;pointer-events:none}
  .dim-tooltip.show{display:block}
  .dim-tooltip-title{font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:1px;text-transform:uppercase;color:rgba(74,144,217,.9);margin-bottom:8px;font-weight:600}
  .dim-tooltip-score{font-size:1.1rem;font-weight:700;color:var(--cream);margin-bottom:8px}
  .dim-tooltip-score span{font-size:.7rem;color:rgba(255,255,255,.35);font-weight:400}
  .dim-tooltip-formula{font-size:.72rem;color:rgba(255,255,255,.5);line-height:1.5;margin-bottom:6px}
  .dim-tooltip-formula code{background:rgba(255,255,255,.06);padding:1px 5px;border-radius:3px;font-family:'DM Mono',monospace;font-size:.65rem;color:rgba(255,255,255,.65)}
  .dim-tooltip-note{font-size:.65rem;color:rgba(255,255,255,.3);font-style:italic}

  /* Central gauge */
  .gauge-card {
    text-align: center;
    position: relative;
  }
  .gauge-card .card-body {
    padding: 24px 20px;
  }
  .gauge-wrap {
    position: relative;
    width: 280px;
    height: 160px;
    margin: 0 auto 12px;
  }
  .gauge-svg {
    width: 280px;
    height: 160px;
  }
  .gauge-number {
    position: absolute;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
  }
  .gauge-number-value {
    font-size: 3.2rem;
    font-weight: 800;
    color: var(--cream);
    line-height: 1;
  }
  .gauge-number-th {
    font-size: 1rem;
    font-weight: 400;
    color: var(--text-muted);
    vertical-align: super;
    margin-left: 2px;
  }
  .gauge-number-label {
    font-size: 0.65rem;
    color: var(--text-muted);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-top: 4px;
  }
  .gauge-sub {
    font-size: 0.75rem;
    color: var(--cream-muted);
    line-height: 1.5;
  }

  /* Risk markers around gauge */
  .risk-markers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 20px;
  }
  .risk-marker {
    text-align: center;
  }
  .risk-marker-value {
    font-size: 1.1rem;
    font-weight: 700;
  }
  .risk-marker-pct {
    font-size: 0.6rem;
    color: var(--text-muted);
    margin-left: 2px;
  }
  .risk-marker-label {
    font-size: 0.55rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 2px;
  }

  /* Side info card */
  .side-info .card-body { padding: 16px 20px; }
  .info-block {
    margin-bottom: 16px;
  }
  .info-block:last-child { margin-bottom: 0; }
  .info-block-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 6px;
  }
  .info-block-title {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--cream);
  }
  .status-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.6rem;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 4px;
  }
  .status-pill .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
  }
  .status-pill.green { background: var(--green-bg); color: var(--green); }
  .status-pill.green .dot { background: var(--green); }
  .status-pill.amber { background: var(--amber-bg); color: var(--amber); }
  .status-pill.amber .dot { background: var(--amber); }
  .status-pill.red { background: var(--red-bg); color: var(--red); }
  .status-pill.red .dot { background: var(--red); }
  .info-big-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--cream);
    line-height: 1;
  }
  .info-big-unit {
    font-size: 0.65rem;
    color: var(--text-muted);
    font-weight: 400;
    margin-left: 4px;
  }
  .info-desc {
    font-size: 0.68rem;
    color: var(--cream-muted);
    line-height: 1.5;
    margin-top: 4px;
  }

  /* Range bar */
  .range-bar-wrap {
    margin-top: 8px;
  }
  .range-bar {
    height: 6px;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--green), #a3e635, var(--amber), #f97316, var(--red));
    position: relative;
    opacity: 0.5;
  }
  .range-marker {
    position: absolute;
    top: -3px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--dark-card);
    border: 2.5px solid white;
    transform: translateX(-50%);
    box-shadow: 0 0 6px rgba(0,0,0,0.5);
  }
  .range-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.5rem;
    color: var(--text-muted);
    margin-top: 4px;
  }

  /* ── KPI Cards (legacy, hidden by hero-row) ── */
  .kpi-grid {
    display: none;
  }
  .kpi-card {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    padding: 20px;
    transition: border-color 0.2s;
  }
  .kpi-card:hover {
    border-color: var(--border-hi);
  }
  .kpi-label {
    font-size: 0.72rem;
    color: var(--cream-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
  }
  .kpi-value {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--cream);
  }
  .kpi-sub {
    font-size: 0.75rem;
    color: rgba(255,255,255,0.4);
    margin-top: 4px;
  }

  /* ── Section Headers ────────────────────────── */
  .section-title {
    font-size: 0.78rem;
    color: var(--blue);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin: 24px 0 16px;
    font-weight: 600;
  }

  /* ── Diagnostics / Findings ────────────────── */
  .diagnostics-card {
    margin-bottom: 16px;
  }
  .finding {
    padding: 14px 20px;
    border-bottom: 1px solid var(--dark-border);
    cursor: pointer;
    transition: background 0.15s;
  }
  .finding:last-child { border-bottom: none; }
  .finding:hover { background: var(--bg-card-hover); }
  .finding-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
  }
  .finding-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
  }
  .finding-dot.red { background: var(--red); box-shadow: 0 0 6px rgba(239,68,68,0.4); }
  .finding-dot.amber { background: var(--amber); box-shadow: 0 0 6px rgba(245,158,11,0.3); }
  .finding-dot.blue { background: var(--blue); box-shadow: 0 0 6px rgba(74,144,217,0.3); }
  .finding-agent {
    font-size: 0.55rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 600;
  }
  .finding-agent.red { color: rgba(239,68,68,0.7); }
  .finding-agent.amber { color: rgba(245,158,11,0.7); }
  .finding-agent.blue { color: rgba(74,144,217,0.7); }
  .finding-title {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--cream);
    margin-bottom: 4px;
  }
  .finding-body {
    font-size: 0.65rem;
    color: var(--cream-muted);
    line-height: 1.6;
  }

  /* ── Bottom Grid ─────────────────────────────── */
  .bottom-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
  }

  /* ── Legacy alert styles (kept for agents tab) ── */
  .alert-grid {
    display: none;
  }
  .alert-card {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    padding: 20px;
    cursor: pointer;
    transition: border-color 0.2s;
  }
  .alert-card:hover { border-color: var(--border-hi); }
  .alert-card.red { border-left: 3px solid var(--red); }
  .alert-card.amber { border-left: 3px solid var(--amber); }
  .alert-card.gold-alert { border-left: 3px solid var(--gold); }
  .alert-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
    padding: 4px 10px;
    border-radius: 4px;
  }
  .alert-badge.red { background: var(--red-bg); color: var(--red); }
  .alert-badge.amber { background: var(--amber-bg); color: var(--amber); }
  .alert-badge.gold-badge { background: rgba(74,144,217,0.12); color: var(--blue); }
  .alert-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--cream);
    margin-bottom: 6px;
  }
  .alert-body {
    font-size: 0.82rem;
    color: var(--cream-muted);
    line-height: 1.5;
  }
  .alert-action {
    display: inline-block;
    margin-top: 12px;
    font-size: 0.72rem;
    color: var(--blue);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
  }

  /* ── Rooms Module ──────────────────────────────── */
  .rooms-module {
    background: rgba(20,20,20,0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 20px 24px;
    margin-bottom: 20px;
  }
  .rooms-module-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
  }
  .rooms-module-title {
    font-family: 'Heebo', sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    color: #FAF9F6;
    margin: 0;
  }
  .rooms-module-count {
    font-family: 'DM Mono', monospace;
    font-size: 0.55rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.35);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 4px;
    padding: 3px 8px;
  }
  .rooms-kpi-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
  }
  .rooms-kpi {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    padding: 12px 14px;
    text-align: center;
  }
  .rooms-kpi-value {
    font-family: 'Heebo', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: #FAF9F6;
    margin-bottom: 4px;
  }
  .rooms-kpi-label {
    font-family: 'DM Mono', monospace;
    font-size: 0.5rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
  }
  @media (max-width: 768px) {
    .rooms-kpi-grid { grid-template-columns: repeat(3, 1fr); }
  }
  @media (max-width: 480px) {
    .rooms-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  }

  /* ── Charts ─────────────────────────────────── */
  .chart-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
  }
  .chart-box {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    padding: 20px;
    transition: border-color 0.2s;
  }
  .chart-box:hover {
    border-color: var(--border-hi);
  }
  .chart-box canvas { max-height: 320px; }
  .chart-wrap { padding: 8px 20px 20px; }

  /* ── Tables ─────────────────────────────────── */
  .tab-nav::-webkit-scrollbar { display: none; }

  .data-table-wrap {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 16px;
    transition: border-color 0.2s;
  }
  .data-table-wrap:hover {
    border-color: var(--border-hi);
  }
  .data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.68rem;
  }
  .data-table th {
    text-align: left;
    padding: 8px 14px;
    font-size: 0.58rem;
    font-weight: 500;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--border-hi);
  }
  .data-table td {
    padding: 8px 14px;
    border-bottom: 1px solid var(--dark-border);
    color: var(--cream-muted);
  }
  .data-table tr:last-child td { border-bottom: none; }
  .data-table .num { text-align: right; font-variant-numeric: tabular-nums; font-weight: 500; }
  .data-table .item-name { color: var(--cream); font-weight: 500; }
  .fc-red { color: var(--red); font-weight: 600; }
  .fc-amber { color: var(--amber); font-weight: 600; }
  .fc-green { color: var(--green); }

  /* ── Reports Tab ────────────────────────────── */
  .report-sub-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 0;
  }
  .report-sub-btn {
    padding: 10px 20px;
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-bottom: none;
    color: #8b949e;
    font-family: inherit;
    font-size: 0.8rem;
    cursor: pointer;
    border-radius: 8px 8px 0 0;
    font-weight: 500;
    letter-spacing: 0.5px;
    text-transform: uppercase;
  }
  .report-sub-btn.active {
    background: var(--dark);
    color: var(--blue);
    border-color: var(--blue);
    border-bottom: 1px solid var(--dark);
  }
  .report-iframe-wrap {
    border: 1px solid var(--dark-border);
    border-radius: 0 10px 10px 10px;
    overflow: hidden;
    background: #fff;
  }
  .report-iframe {
    width: 100%;
    height: 85vh;
    border: none;
    display: none;
  }
  .report-iframe.active { display: block; }

  /* ── Agents Tab ─────────────────────────────── */
  .agent-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 20px;
  }
  .agent-card {
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 14px;
    padding: 24px;
    transition: border-color 0.2s;
  }
  .agent-card:hover {
    border-color: var(--border-hi);
  }
  .agent-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
  }
  .agent-icon {
    font-size: 1.6rem;
  }
  .agent-card-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--cream);
  }
  .agent-card-desc {
    font-size: 0.82rem;
    color: #8b949e;
    line-height: 1.5;
    margin-bottom: 16px;
  }
  .agent-card-alert {
    font-size: 0.78rem;
    color: #8b949e;
    padding: 10px 12px;
    background: rgba(255,255,255,0.03);
    border-radius: 6px;
    margin-bottom: 16px;
    line-height: 1.5;
  }
  .ask-agent-btn {
    display: inline-block;
    padding: 8px 20px;
    background: var(--gold);
    color: var(--dark);
    border: none;
    border-radius: 6px;
    font-family: inherit;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: opacity 0.2s;
  }
  .ask-agent-btn:hover { opacity: 0.85; }
  .suggest-q {
    cursor: pointer; color: var(--blue); transition: color 0.2s;
    padding: 3px 0; font-size: 0.82rem;
  }
  .suggest-q:hover { color: var(--blue-light); text-decoration: underline; }
  .suggest-dynamic { font-weight: 600; }
  .suggest-new {
    display: inline-block; font-size: .55rem; background: var(--blue); color: #fff;
    padding: 1px 5px; border-radius: 4px; text-transform: uppercase;
    letter-spacing: .05em; margin-right: 4px; vertical-align: middle; font-weight: 700;
  }

  /* ── Chat Panel ─────────────────────────────── */
  .chat-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 199;
  }
  .chat-overlay.open { display: block; }
  .chat-panel {
    position: fixed;
    top: 0;
    right: -100%;
    width: var(--chat-width);
    height: 100vh;
    height: 100dvh;
    background: rgba(26,30,46,0.92);
    backdrop-filter: blur(40px);
    -webkit-backdrop-filter: blur(40px);
    border-left: 1px solid var(--dark-border);
    z-index: 200;
    display: flex;
    flex-direction: column;
    transition: right 0.3s ease;
  }
  .chat-panel.open { right: 0; }

  .chat-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--dark-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
  }
  .chat-header-left {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .chat-header-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--cream);
  }
  .chat-close-btn {
    background: none;
    border: none;
    color: #8b949e;
    font-size: 1.3rem;
    cursor: pointer;
    padding: 4px 8px;
    line-height: 1;
  }
  .chat-close-btn:hover { color: var(--cream); }

  .agent-selector {
    padding: 12px 20px;
    border-bottom: 1px solid var(--dark-border);
    flex-shrink: 0;
  }
  .agent-select {
    width: 100%;
    padding: 8px 12px;
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 6px;
    color: var(--cream);
    font-family: inherit;
    font-size: 0.82rem;
    cursor: pointer;
  }

  .chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .chat-msg {
    max-width: 92%;
    padding: 12px 16px;
    border-radius: 10px;
    font-size: 0.84rem;
    line-height: 1.6;
    word-wrap: break-word;
  }
  .chat-msg.user {
    align-self: flex-end;
    background: var(--gold);
    color: var(--dark);
    border-bottom-right-radius: 3px;
    white-space: pre-wrap;
    box-shadow: 0 4px 16px rgba(74,144,217,0.25);
  }
  .chat-msg.agent {
    align-self: flex-start;
    background: rgba(255,255,255,0.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 2px 12px rgba(0,0,0,0.1);
    color: var(--cream-muted);
    border-bottom-left-radius: 3px;
  }
  .chat-msg.agent p { margin: 0 0 8px; }
  .chat-msg.agent p:last-child { margin-bottom: 0; }
  .chat-msg.agent strong { color: #fff; font-weight: 600; }
  .chat-msg.agent ul { margin: 6px 0 10px; padding-left: 18px; }
  .chat-msg.agent li { margin-bottom: 4px; }
  .chat-msg.agent li:last-child { margin-bottom: 0; }
  .chat-msg-meta {
    font-size: 0.68rem;
    color: #8b949e;
    margin-bottom: 6px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  .chat-msg.agent .chat-msg-meta { color: var(--gold-light); }
  .typing-indicator {
    display: none;
    align-self: flex-start;
    padding: 12px 16px;
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 10px;
    font-size: 0.82rem;
    color: #8b949e;
  }
  .typing-indicator.active { display: block; }
  .typing-dots span {
    animation: blink 1.4s infinite both;
    font-size: 1.2rem;
    letter-spacing: 2px;
  }
  .typing-dots span:nth-child(2) { animation-delay: 0.2s; }
  .typing-dots span:nth-child(3) { animation-delay: 0.4s; }
  @keyframes blink {
    0%, 80%, 100% { opacity: 0.2; }
    40% { opacity: 1; }
  }

  .chat-input-area {
    padding: 12px 16px;
    padding-bottom: calc(12px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--dark-border);
    display: flex;
    gap: 8px;
    flex-shrink: 0;
  }
  .chat-input {
    flex: 1;
    padding: 10px 14px;
    background: var(--dark-card);
    border: 1px solid var(--dark-border);
    border-radius: 8px;
    color: var(--cream);
    font-family: inherit;
    font-size: 0.84rem;
    resize: none;
    outline: none;
    min-height: 40px;
    max-height: 100px;
  }
  .chat-input:focus { border-color: var(--gold); }
  .chat-input::placeholder { color: #484f58; }
  .chat-send-btn {
    padding: 10px 18px;
    background: var(--gold);
    color: var(--dark);
    border: none;
    border-radius: 8px;
    font-family: inherit;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    flex-shrink: 0;
    transition: opacity 0.2s;
  }
  .chat-send-btn:hover { opacity: 0.85; }
  .chat-send-btn:disabled { opacity: 0.4; cursor: not-allowed; }

  /* ── FAB ─────────────────────────────────────── */
  .fab {
    position: fixed;
    bottom: 28px;
    right: 28px;
    width: 56px;
    height: 56px;
    background: var(--gold);
    color: var(--dark);
    border: none;
    border-radius: 50%;
    font-size: 1.4rem;
    cursor: pointer;
    z-index: 150;
    box-shadow: 0 4px 24px rgba(74,144,217,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .fab:hover { transform: scale(1.08); box-shadow: 0 6px 32px rgba(74,144,217,0.45); }

  /* ── Recommendations Panel ─────────────── */
  .recs-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:199; }
  .recs-overlay.open { display:block; }
  .recs-panel {
    position:fixed; top:0; right:-100%; width:min(440px,92vw); height:100vh; height:100dvh;
    background:rgba(26,30,46,0.95); backdrop-filter:blur(40px);
    border-left:1px solid rgba(255,255,255,0.06);
    z-index:200; display:flex; flex-direction:column;
    transition:right 0.3s ease;
  }
  .recs-panel.open { right:0; }
  .recs-header { padding:16px 20px; border-bottom:1px solid rgba(255,255,255,0.06); display:flex; align-items:center; justify-content:space-between; }
  .recs-header-title { font-weight:700; font-size:1rem; color:var(--cream); }
  .recs-header-count { font-family:'DM Mono',monospace; font-size:.7rem; color:var(--gold); margin-left:8px; }
  .recs-close { background:none; border:none; color:rgba(255,255,255,0.4); font-size:1.2rem; cursor:pointer; padding:4px 8px; }
  .recs-close:hover { color:var(--cream); }
  .recs-tabs { display:flex; gap:0; border-bottom:1px solid rgba(255,255,255,0.06); }
  .recs-tab { flex:1; padding:10px 0; text-align:center; font-family:'DM Mono',monospace; font-size:.65rem; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,0.35); background:none; border:none; cursor:pointer; border-bottom:2px solid transparent; transition:all .2s; }
  .recs-tab.active { color:var(--gold); border-bottom-color:var(--gold); }
  .recs-tab:hover { color:var(--cream); }
  .recs-body { flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; }
  .recs-empty { text-align:center; color:rgba(255,255,255,0.25); font-size:.85rem; padding:40px 20px; line-height:1.6; }
  .rec-card { background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); border-radius:10px; padding:14px 16px; }
  .rec-card.done { border-left:3px solid var(--green); }
  .rec-card.dismissed { opacity:0.5; }
  .rec-meta { display:flex; align-items:center; gap:8px; margin-bottom:6px; font-family:'DM Mono',monospace; font-size:.6rem; letter-spacing:.5px; color:rgba(255,255,255,0.3); }
  .rec-agent { color:var(--gold); }
  .rec-text { font-size:.82rem; color:var(--cream); line-height:1.55; }
  .rec-actions { display:flex; gap:6px; margin-top:10px; }
  .rec-btn { font-family:'DM Mono',monospace; font-size:.6rem; letter-spacing:.5px; padding:4px 10px; border-radius:4px; border:1px solid rgba(255,255,255,0.1); background:none; color:rgba(255,255,255,0.5); cursor:pointer; transition:all .2s; }
  .rec-btn:hover { color:var(--cream); border-color:rgba(255,255,255,0.3); }
  .rec-btn.done-btn:hover { background:rgba(46,125,79,0.2); border-color:var(--green); color:var(--green); }
  .rec-btn.dismiss-btn:hover { background:rgba(255,255,255,0.05); }
  .rec-btn.undo-btn { color:var(--gold); border-color:rgba(161,150,126,0.3); }
  .recs-fab {
    position:fixed; bottom:28px; right:92px; width:44px; height:44px;
    background:rgba(161,150,126,0.15); color:var(--gold); border:1px solid rgba(161,150,126,0.3);
    border-radius:50%; font-size:.95rem; cursor:pointer; z-index:150;
    display:flex; align-items:center; justify-content:center;
    transition:transform 0.2s, background 0.2s;
  }
  .recs-fab:hover { transform:scale(1.08); background:rgba(161,150,126,0.25); }
  .recs-badge { position:absolute; top:-4px; right:-4px; min-width:16px; height:16px; background:var(--red); color:#fff; font-size:.55rem; font-weight:700; border-radius:8px; display:flex; align-items:center; justify-content:center; padding:0 4px; }

  /* ── Welcome Sequence ───────────────────── */
  .welcome-overlay {
    position: fixed; inset: 0; background: #1a1e2e; z-index: 600;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .5s;
  }
  .welcome-overlay.active { opacity: 1; pointer-events: auto; }
  .welcome-container {
    width: 100%; max-width: 600px; padding: 0 32px; text-align: center;
  }
  .welcome-slide {
    display: none; flex-direction: column; align-items: center;
    animation: welcomeFadeIn .6s ease;
  }
  .welcome-slide.active { display: flex; }
  @keyframes welcomeFadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .welcome-icon {
    font-size: 3rem; margin-bottom: 24px; font-variant-emoji: text;
    opacity: .9;
  }
  .welcome-logo {
    font-family: 'Inter', system-ui, sans-serif; font-size: 1.6rem; font-weight: 700;
    color: var(--cream); margin-bottom: 8px; letter-spacing: 1px;
  }
  .welcome-logo em { font-style: italic; color: var(--gold); }
  .welcome-logo .dot { color: var(--gold); }
  .welcome-h {
    font-size: 1.5rem; font-weight: 700; color: var(--cream);
    margin-bottom: 12px; line-height: 1.3;
  }
  .welcome-p {
    font-size: .88rem; color: #8b949e; line-height: 1.6; max-width: 440px;
    margin: 0 auto 32px;
  }
  .welcome-features {
    display: flex; gap: 20px; margin-bottom: 36px; flex-wrap: wrap;
    justify-content: center;
  }
  .welcome-feature {
    background: var(--dark-card); border: 1px solid var(--dark-border);
    border-radius: 12px; padding: 20px 16px; width: 140px; text-align: center;
  }
  .welcome-feature-icon {
    font-size: 1.4rem; margin-bottom: 8px; font-variant-emoji: text;
  }
  .welcome-feature-label {
    font-size: .7rem; color: var(--cream); font-weight: 600;
    letter-spacing: .3px;
  }
  .welcome-feature-sub {
    font-size: .6rem; color: #484f58; margin-top: 4px;
  }
  .welcome-agents {
    display: flex; gap: 12px; margin-bottom: 36px; flex-wrap: wrap;
    justify-content: center;
  }
  .welcome-agent {
    background: var(--dark-card); border: 1px solid var(--dark-border);
    border-radius: 12px; padding: 16px; width: 160px; text-align: left;
  }
  .welcome-agent-name {
    font-size: .75rem; font-weight: 700; color: var(--cream);
    margin-bottom: 4px;
  }
  .welcome-agent-desc {
    font-size: .6rem; color: #8b949e; line-height: 1.4;
  }
  .welcome-agent-badge {
    display: inline-block; font-size: .5rem; font-weight: 700;
    padding: 2px 8px; border-radius: 10px; margin-bottom: 8px;
    text-transform: uppercase; letter-spacing: .5px;
  }
  .welcome-btn {
    padding: 14px 48px; background: var(--gold); color: var(--dark);
    border: none; border-radius: 8px; font-family: inherit; font-size: .88rem;
    font-weight: 600; cursor: pointer; transition: opacity .2s;
    letter-spacing: .3px;
  }
  .welcome-btn:hover { opacity: .85; }
  .welcome-skip {
    display: block; margin-top: 16px; font-size: .65rem; color: #484f58;
    cursor: pointer; background: none; border: none; font-family: inherit;
    letter-spacing: .5px; text-transform: uppercase;
  }
  .welcome-skip:hover { color: #8b949e; }
  .welcome-dots {
    display: flex; gap: 8px; justify-content: center; margin-top: 32px;
  }
  .welcome-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--dark-border); transition: background .3s;
  }
  .welcome-dot.active { background: var(--gold); }
  .welcome-client-name {
    font-size: 1.1rem; color: var(--gold); font-weight: 600;
    margin-bottom: 4px;
  }

  /* ── Onboarding / Preferences ────────────── */
  .onboard-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.85); z-index: 500;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .3s;
  }
  .onboard-overlay.active { opacity: 1; pointer-events: auto; }
  .onboard-box {
    position: relative;
    background: var(--dark); border: 1px solid var(--dark-border); border-radius: 16px;
    padding: 40px; max-width: 520px; width: 90%; max-height: 90vh; overflow-y: auto;
  }
  .onboard-title { font-size: 1.2rem; font-weight: 700; color: var(--cream); margin-bottom: 4px; }
  .onboard-sub { font-size: .78rem; color: #8b949e; margin-bottom: 28px; }
  .onboard-q { margin-bottom: 24px; }
  .onboard-q label { display: block; font-size: .75rem; font-weight: 600; color: var(--cream); margin-bottom: 10px; }
  .onboard-pills { display: flex; flex-wrap: wrap; gap: 8px; }
  .onboard-pill {
    font-family: 'DM Mono', monospace; font-size: .65rem; letter-spacing: .5px;
    padding: 6px 14px; border-radius: 20px;
    border: 1px solid var(--dark-border); background: transparent;
    color: rgba(255,255,255,.5); cursor: pointer; transition: all .2s;
  }
  .onboard-pill:hover { border-color: rgba(255,255,255,.3); color: var(--cream); }
  .onboard-pill.selected { border-color: var(--gold); color: var(--gold); background: rgba(74,144,217,.1); }
  .onboard-text {
    width: 100%; background: rgba(255,255,255,.04); border: 1px solid var(--dark-border);
    border-radius: 8px; padding: 10px 14px; font-family: inherit; font-size: .78rem;
    color: var(--cream); resize: none; outline: none; min-height: 60px;
  }
  .onboard-text::placeholder { color: rgba(255,255,255,.2); }
  .onboard-text:focus { border-color: var(--gold); }
  .onboard-input {
    background: rgba(255,255,255,.04); border: 1px solid var(--dark-border);
    border-radius: 8px; padding: 10px 14px; font-family: inherit; font-size: .78rem;
    color: var(--cream); outline: none; width: 100%; box-sizing: border-box;
  }
  .onboard-input::placeholder { color: rgba(255,255,255,.2); }
  .onboard-input:focus { border-color: var(--gold); }
  .onboard-targets {
    display: flex; gap: 12px; flex-wrap: wrap;
  }
  .onboard-target-group {
    flex: 1; min-width: 120px;
  }
  .onboard-target-group span {
    display: block; font-size: .65rem; color: #8b949e; margin-bottom: 6px;
  }
  .onboard-target-group input {
    width: 100%; background: rgba(255,255,255,.04); border: 1px solid var(--dark-border);
    border-radius: 8px; padding: 8px 12px; font-family: inherit; font-size: .78rem;
    color: var(--cream); outline: none; box-sizing: border-box;
  }
  .onboard-target-group input::placeholder { color: rgba(255,255,255,.2); }
  .onboard-target-group input:focus { border-color: var(--gold); }
  .onboard-save {
    width: 100%; padding: 12px; background: var(--gold); color: var(--dark);
    border: none; border-radius: 8px; font-family: inherit; font-size: .85rem;
    font-weight: 600; cursor: pointer; margin-top: 8px; transition: opacity .2s;
  }
  .onboard-save:hover { opacity: .85; }
  /* Loyverse Sync Modal */
  .loy-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.7); z-index: 9000; display: none; align-items: center; justify-content: center; }
  .loy-overlay.active { display: flex; }
  .loy-modal { background: var(--dark); border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; width: 440px; max-width: 92vw; max-height: 88vh; overflow-y: auto; padding: 32px; }
  .loy-modal h3 { font-family: 'Inter', system-ui, sans-serif; font-size: 1.1rem; color: var(--cream); margin: 0 0 4px; }
  .loy-modal .loy-sub { font-size: .72rem; color: #8b949e; margin-bottom: 20px; line-height: 1.5; }
  .loy-modal label { display: block; font-size: .65rem; color: #8b949e; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; font-family: 'DM Mono', monospace; }
  .loy-modal input, .loy-modal select { width: 100%; padding: 10px 12px; background: #1a1e2e; border: 1px solid rgba(255,255,255,0.06); border-radius: 6px; color: var(--cream); font-family: inherit; font-size: .82rem; margin-bottom: 16px; box-sizing: border-box; }
  .loy-modal input:focus, .loy-modal select:focus { border-color: var(--gold); outline: none; }
  .loy-row { display: flex; gap: 12px; }
  .loy-row > div { flex: 1; }
  .loy-sync-btn { width: 100%; padding: 12px; background: var(--gold); color: var(--dark); border: none; border-radius: 8px; font-family: inherit; font-size: .85rem; font-weight: 600; cursor: pointer; transition: opacity .2s; }
  .loy-sync-btn:hover { opacity: .85; }
  .loy-sync-btn:disabled { opacity: .5; cursor: not-allowed; }
  .loy-status { font-size: .72rem; color: #8b949e; margin-top: 12px; line-height: 1.5; text-align: center; }
  .loy-status.success { color: #4ade80; }
  .loy-status.error { color: #f87171; }
  .loy-close { position: absolute; top: 12px; right: 16px; background: none; border: none; color: #484f58; font-size: 1.3rem; cursor: pointer; }
  .loy-close:hover { color: var(--cream); }
  .loy-disconnect { background: none; border: 1px solid rgba(255,255,255,0.06); color: #8b949e; padding: 8px 16px; border-radius: 6px; font-size: .7rem; cursor: pointer; margin-top: 8px; width: 100%; }
  .loy-disconnect:hover { border-color: #f87171; color: #f87171; }
  .loy-badge { display: inline-block; font-size: .5rem; padding: 2px 6px; border-radius: 3px; text-transform: uppercase; letter-spacing: 1px; font-family: 'DM Mono', monospace; margin-left: 8px; vertical-align: middle; }
  .loy-badge.connected { background: rgba(74,222,128,.15); color: #4ade80; }
  .loy-badge.disconnected { background: rgba(255,255,255,.06); color: #484f58; }
  .loy-help { font-size: .65rem; color: #484f58; margin-top: -10px; margin-bottom: 16px; line-height: 1.5; }
  .loy-help a { color: var(--gold); text-decoration: none; }
  .loy-help a:hover { text-decoration: underline; }
  .loy-last-sync { font-size: .65rem; color: #484f58; margin-bottom: 16px; padding: 8px 12px; background: #1a1e2e; border-radius: 6px; }
  .prefs-btn {
    font-family: inherit; font-size: .55rem; letter-spacing: 0.5px;
    text-transform: uppercase; padding: 5px 12px; border-radius: 6px;
    border: 1px solid var(--dark-border); background: transparent;
    color: rgba(255,255,255,.4); cursor: pointer; transition: all .2s;
  }
  .prefs-btn:hover { border-color: var(--blue); color: var(--blue); }

  /* ── Property Switcher ───────────────────── */
  .prop-switcher { position: relative; }
  .prop-switcher-btn {
    font-family: inherit; font-size: .55rem; letter-spacing: 0.5px;
    text-transform: uppercase; padding: 5px 12px; border-radius: 6px;
    border: 1px solid var(--dark-border); background: transparent;
    color: var(--blue); cursor: pointer; transition: all .2s;
    display: flex; align-items: center; gap: 6px;
  }
  .prop-switcher-btn:hover { border-color: var(--blue); }
  .prop-switcher-btn .arrow { font-size: .5rem; opacity: .5; }
  .prop-dropdown {
    position: absolute; top: 100%; right: 0; margin-top: 6px;
    background: var(--dark); border: 1px solid var(--dark-border);
    border-radius: 8px; min-width: 220px; box-shadow: 0 8px 32px rgba(0,0,0,.5);
    z-index: 200; display: none; overflow: hidden;
  }
  .prop-dropdown.open { display: block; }
  .prop-dropdown a {
    display: flex; flex-direction: column; gap: 2px; padding: 12px 16px;
    text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.04); transition: background .15s;
  }
  .prop-dropdown a:last-child { border-bottom: none; }
  .prop-dropdown a:hover { background: rgba(255,255,255,.04); }
  .prop-dropdown a.current { background: rgba(74,144,217,.08); }
  .prop-dropdown-name { font-size: .78rem; font-weight: 600; color: var(--cream); }
  .prop-dropdown-type { font-family: 'DM Mono', monospace; font-size: .5rem; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.3); }

  /* ── Tablet ─────────────────────────────────── */
  @media (max-width: 1000px) {
    .hero-row { grid-template-columns: 1fr; }
    .bottom-grid { grid-template-columns: 1fr; }
    .header-insight { display: none; }
  }

  /* ── Mobile ────────────────────────────────── */
  @media (max-width: 768px) {
    /* Header: just logo + gear + chat FAB */
    .header { padding: 10px 14px; }
    .header-left { gap: 8px; }
    .header-right { gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
    .header-age-bar { display: none; }
    .header-insight { display: none; }
    .header-sep { display: none; }
    .header-divider { display: none; }
    .header-period { display: none; }
    .header-btn { display: none; } /* exec summary — not useful on phone */
    .header-link { display: none; }
    .data-age-badge { display: none !important; }
    .prop-switcher-btn { font-size: 0.5rem; padding: 5px 8px; }
    .prefs-btn { font-size: 0.5rem; padding: 5px 8px; }
    .prefs-btn .loy-badge { display: none; }

    /* Tabs: horizontal scroll */
    .tab-nav { padding: 0; }
    .tab-btn { padding: 10px 16px; font-size: 0.7rem; white-space: nowrap; flex-shrink: 0; }

    /* Content */
    .main { padding: 12px 10px 100px; }
    .page-title { font-size: 1.05rem; }
    .page-title-row { flex-wrap: wrap; gap: 8px; }
    #tab-dashboard { padding: 16px calc(50vw - 50%) 120px; }
    .section-title { font-size: 0.7rem; margin: 16px 0 12px; }

    /* Hero gauge */
    .hero-row { gap: 12px; }
    .gauge-wrap { width: 220px; height: 130px; }
    .gauge-svg { width: 220px; height: 130px; }
    .gauge-number-value { font-size: 2.4rem; }
    .gauge-card .card-body { padding: 16px 12px; }
    .risk-markers { gap: 8px; }
    .risk-marker-value { font-size: 0.95rem; }

    /* Side info card */
    .side-info .card-body { padding: 12px 14px; }
    .info-big-value { font-size: 1.2rem; }

    /* Cards */
    .card-header { padding: 12px 14px 10px; }
    .card-body { padding: 0 14px 14px; }
    .card-title { font-size: 0.78rem; }

    /* Charts */
    .chart-row { grid-template-columns: 1fr; }
    .chart-box { padding: 14px; }
    .chart-box canvas { max-height: 240px; }

    /* Tables */
    .data-table { font-size: 0.6rem; min-width: 500px; }
    .data-table th { padding: 6px 8px; font-size: 0.52rem; }
    .data-table td { padding: 6px 8px; }

    /* Agent grid */
    .agent-grid { grid-template-columns: 1fr; gap: 12px; }
    .agent-card { padding: 16px; }
    .agent-card-name { font-size: 0.88rem; }
    .agent-card-desc { font-size: 0.75rem; }

    /* Findings */
    .finding { padding: 12px 14px; }
    .finding-title { font-size: 0.72rem; }
    .finding-body { font-size: 0.62rem; }

    /* Bottom grid */
    .bottom-grid { grid-template-columns: 1fr; gap: 12px; }

    /* Reports */
    .report-sub-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .report-sub-btn { font-size: 0.68rem; padding: 8px 14px; white-space: nowrap; flex-shrink: 0; }
    .report-iframe { height: 70vh; }

    /* Chat & recs panels */
    .chat-panel { width: 100vw; }
    .recs-panel { width: 100vw; }

    /* FABs */
    .fab { bottom: 20px; right: 20px; width: 50px; height: 50px; font-size: 1.2rem; }
    .recs-fab { bottom: 20px; right: 78px; }

    /* Onboarding & preferences */
    .onboard-box { padding: 24px 18px; max-height: 85vh; }
    .onboard-title { font-size: 1rem; }
    .onboard-sub { font-size: 0.72rem; margin-bottom: 16px; }
    .onboard-q label { font-size: 0.7rem; }
    .onboard-pill { font-size: 0.6rem; padding: 5px 12px; }
    .onboard-targets { flex-direction: column; gap: 8px; }

    /* Welcome sequence */
    .welcome-container { padding: 0 20px; }
    .welcome-h { font-size: 1.2rem; }
    .welcome-p { font-size: 0.8rem; margin-bottom: 24px; }
    .welcome-btn { padding: 12px 36px; font-size: 0.82rem; }
    .welcome-feature { width: 110px; padding: 14px 10px; }
    .welcome-feature-label { font-size: 0.62rem; }
    .welcome-agent { width: 140px; padding: 12px; }
    .welcome-agent-name { font-size: 0.68rem; }
    .welcome-agent-desc { font-size: 0.55rem; }
    .welcome-icon { font-size: 2.2rem; margin-bottom: 16px; }

    /* POS sync modal */
    .loy-modal { padding: 24px 18px; }

    /* Urgent toast */
    .urgent-toast { bottom: 80px; right: 12px; left: 12px; max-width: none; }
  }

  /* ── Scrollbar ──────────────────────────────── */
  ::-webkit-scrollbar { width: 6px; }
  ::-webkit-scrollbar-track { background: transparent; }
  ::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 3px; }
  ::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.15); }

  /* ── Staggered Animations ────────────────────── */
  @keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes subtlePulse {
    0%, 100% { box-shadow: none; }
    50% { box-shadow: 0 0 12px rgba(239,68,68,0.1); }
  }
  @keyframes urgentSlideIn {
    from { opacity: 0; transform: translateX(-16px); }
    to { opacity: 1; transform: translateX(0); }
  }
  .animate-in { animation: fadeInUp 0.35s ease both; }
  .kpi-danger { animation: subtlePulse 3s ease-in-out infinite; border-color: rgba(248,113,113,0.2) !important; }
  .kpi-warning { animation: subtlePulse 4s ease-in-out infinite; border-color: rgba(251,191,36,0.15) !important; }
  .kpi-danger .kpi-value { color: var(--red); }
  .kpi-warning .kpi-value { color: var(--amber); }

  .urgent-toast {
    position: fixed; bottom: 96px; right: 28px; z-index: 140;
    background: rgba(255,255,255,0.08); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(248,113,113,0.2); border-radius: 14px;
    padding: 16px 20px; max-width: 340px; cursor: pointer;
    animation: urgentSlideIn 0.4s ease both;
    box-shadow: 0 8px 32px rgba(0,0,0,0.25);
    transition: opacity 0.3s ease, transform 0.3s ease;
  }
  .urgent-toast:hover { transform: translateY(-2px); border-color: rgba(248,113,113,0.35); }
  .urgent-toast-badge { font-size: 0.65rem; color: var(--red); font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 6px; }
  .urgent-toast-text { font-size: 0.8rem; color: var(--cream); line-height: 1.5; }
  .urgent-toast-dismiss { position: absolute; top: 8px; right: 12px; background: none; border: none; color: rgba(255,255,255,0.3); cursor: pointer; font-size: 0.9rem; }
  .urgent-toast.hiding { opacity: 0; transform: translateY(8px); }

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

  /* ── Login Gate ── */
  #loginGate { position:fixed; inset:0; z-index:99999; background:#1a1e2e; display:flex; align-items:center; justify-content:center; flex-direction:column; }
  #loginGate.hidden { display:none; }
  .login-box { width:min(360px,90vw); text-align:center; }
  .login-box .login-logo { font-size:1.5rem; font-weight:700; color:#fff; margin-bottom:8px; letter-spacing:-0.5px; }
  .login-box .login-logo em { font-style:normal; color:rgba(255,255,255,0.5); }
  .login-box .login-sub { color:rgba(255,255,255,0.4); font-size:0.85rem; margin-bottom:32px; }
  .login-box input[type="password"] { width:100%; padding:14px 16px; border-radius:10px; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.05); color:#fff; font-size:1rem; font-family:inherit; outline:none; box-sizing:border-box; }
  .login-box input[type="password"]:focus { border-color:rgba(232,115,74,0.5); }
  .login-box input[type="password"]::placeholder { color:rgba(255,255,255,0.25); }
  .login-box button { width:100%; margin-top:12px; padding:14px; border-radius:10px; border:none; background:#E8734A; color:#fff; font-size:1rem; font-weight:600; font-family:inherit; cursor:pointer; }
  .login-box button:hover { background:#ec8a66; }
  .login-box button:disabled { opacity:0.5; cursor:wait; }
  .login-box .login-err { color:#e74c3c; font-size:0.85rem; margin-top:12px; min-height:20px; }

  /* ── Stock Intelligence ───────────────────────────── */
  .stock-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 24px; }
  .stock-kpi { background: var(--dark-card); border-radius: 12px; padding: 20px 16px; text-align: center; border: 1px solid var(--dark-border); }
  .stock-kpi-value { font-size: 1.6rem; font-weight: 700; color: var(--cream); margin-bottom: 4px; }
  .stock-kpi-label { font-size: 0.72rem; color: var(--cream-muted); text-transform: uppercase; letter-spacing: 0.5px; }
  .stock-coverage { background: var(--dark-card); border-radius: 12px; padding: 16px 20px; margin-bottom: 24px; border: 1px solid var(--dark-border); }
  .stock-coverage-label { font-size: 0.82rem; color: var(--cream); margin-bottom: 8px; }
  .stock-coverage-bar { height: 6px; background: rgba(255,255,255,0.08); border-radius: 3px; overflow: hidden; }
  .stock-coverage-fill { height: 100%; border-radius: 3px; transition: width 0.6s ease; }
  .stock-section { margin-bottom: 28px; }
  .stock-section-title { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.7px; color: var(--cream-muted); margin-bottom: 14px; font-weight: 500; }
  .stock-badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 0.7rem; font-weight: 600; margin-left: 8px; }
  .stock-badge.red { background: var(--red-bg); color: var(--red); }
  .stock-badge.green { background: var(--green-bg); color: var(--green); }
  .stock-variance { background: var(--dark-card); border-radius: 12px; padding: 20px; border: 1px solid var(--dark-border); display: flex; flex-wrap: wrap; gap: 20px; }
  .stock-var-item { flex: 1; min-width: 140px; }
  .stock-var-label { display: block; font-size: 0.72rem; color: var(--cream-muted); text-transform: uppercase; letter-spacing: 0.3px; margin-bottom: 4px; }
  .stock-var-val { font-size: 1.1rem; font-weight: 600; color: var(--cream); }
  .stock-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; border: 1px solid var(--dark-border); }
  .stock-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
  .stock-table th { background: rgba(255,255,255,0.04); padding: 10px 14px; text-align: left; font-weight: 500; color: var(--cream-muted); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; }
  .stock-table td { padding: 10px 14px; border-top: 1px solid var(--dark-border); color: var(--cream); white-space: nowrap; }
  .stock-table tbody tr:hover { background: rgba(255,255,255,0.03); }
  .stock-risk-dot { padding: 3px 10px; border-radius: 8px; font-size: 0.72rem; font-weight: 600; text-transform: uppercase; }
  .stock-risk-dot.red { background: var(--red-bg); color: var(--red); }
  .stock-risk-dot.amber { background: var(--amber-bg); color: var(--amber); }
  .stock-risk-dot.green { background: var(--green-bg); color: var(--green); }

  @media (max-width: 768px) {
    .stock-summary { grid-template-columns: repeat(2, 1fr); }
    .stock-kpi-value { font-size: 1.2rem; }
    .stock-variance { flex-direction: column; gap: 12px; }
    .stock-table { font-size: 0.75rem; }
    .stock-table th, .stock-table td { padding: 8px 10px; }
  }

  /* ── Daily Calendar ─────────────────────── */
  .cal-controls { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
  .cal-month { font-size: 1rem; font-weight: 600; color: var(--cream); letter-spacing: -0.5px; }
  .cal-nav { display: flex; gap: 8px; }
  .cal-nav-btn { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 6px; color: var(--cream-muted); padding: 6px 12px; font-size: 0.75rem; cursor: pointer; transition: all .2s; }
  .cal-nav-btn:hover { background: rgba(255,255,255,.1); color: var(--cream); }

  .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
  .cal-header { text-align: center; font-size: 0.55rem; letter-spacing: 2px; text-transform: uppercase; color: var(--cream-muted); padding: 8px 0; font-weight: 600; }
  .cal-day { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); border-radius: 8px; padding: 10px 8px; min-height: 80px; cursor: default; transition: all .2s; position: relative; }
  .cal-day.empty { background: transparent; border-color: transparent; }
  .cal-day.has-data { cursor: pointer; border-color: rgba(255,255,255,.1); }
  .cal-day.has-data:hover { background: rgba(255,255,255,.06); border-color: var(--blue); transform: translateY(-1px); }
  .cal-day.today { border-color: var(--blue); box-shadow: 0 0 0 1px var(--blue); }
  .cal-day.selected { background: rgba(74,144,217,.1); border-color: var(--blue); }
  .cal-day-num { font-size: 0.75rem; font-weight: 600; color: var(--cream-muted); margin-bottom: 4px; }
  .cal-day.has-data .cal-day-num { color: var(--cream); }
  .cal-day-rev { font-size: 0.65rem; font-weight: 700; color: var(--green); }
  .cal-day-sub { font-size: 0.5rem; color: var(--cream-muted); margin-top: 2px; }
  .cal-day-dot { position: absolute; top: 6px; right: 6px; width: 6px; height: 6px; border-radius: 50%; background: var(--green); }

  .cal-detail { background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 24px; margin-top: 20px; display: none; }
  .cal-detail.active { display: block; }
  .cal-detail-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
  .cal-detail-date { font-size: 1rem; font-weight: 600; color: var(--cream); }
  .cal-detail-close { background: none; border: 1px solid rgba(255,255,255,.1); border-radius: 6px; color: var(--cream-muted); padding: 4px 12px; font-size: 0.7rem; cursor: pointer; }
  .cal-detail-kpis { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; margin-bottom: 16px; }
  .cal-detail-kpi { background: rgba(255,255,255,.04); border-radius: 8px; padding: 12px; text-align: center; }
  .cal-detail-kpi-val { font-size: 1.1rem; font-weight: 700; color: var(--cream); }
  .cal-detail-kpi-val.green { color: var(--green); }
  .cal-detail-kpi-val.red { color: var(--red); }
  .cal-detail-kpi-val.amber { color: var(--amber); }
  .cal-detail-kpi-lbl { font-size: 0.55rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--cream-muted); margin-top: 4px; }
  .cal-detail-section { margin-top: 16px; }
  .cal-detail-section-title { font-size: 0.65rem; letter-spacing: 2px; text-transform: uppercase; color: var(--cream-muted); margin-bottom: 8px; font-weight: 600; }
  .cal-detail-table { width: 100%; border-collapse: collapse; font-size: 0.78rem; }
  .cal-detail-table th { text-align: left; padding: 8px 10px; color: var(--cream-muted); font-weight: 500; font-size: 0.65rem; letter-spacing: 1px; text-transform: uppercase; border-bottom: 1px solid rgba(255,255,255,.08); }
  .cal-detail-table td { padding: 8px 10px; border-bottom: 1px solid rgba(255,255,255,.04); color: var(--cream); }
  .cal-detail-table td.num { text-align: right; font-variant-numeric: tabular-nums; }

  @media (max-width: 768px) {
    .cal-grid { gap: 4px; }
    .cal-day { min-height: 60px; padding: 6px 4px; }
    .cal-day-rev { font-size: 0.55rem; }
    .cal-detail-kpis { grid-template-columns: repeat(2, 1fr); }
  }
