/* =============================================================
   Resto AI · Reports section styles (ported from reports_v1)
   GENERATED by _handoff_reports/_build_css.cjs — do not hand-edit.
   All rules scoped under .rai-reports so they never touch the
   production shell. .resty-mark animations kept global (unique).
   ============================================================= */
.rai-reports, .rai-reports *, .rai-reports *::before, .rai-reports *::after { box-sizing: border-box; }
.rai-reports { font-family: var(--font-ui); color: var(--fg-1); font-size: var(--fs-md); line-height: var(--lh-normal); font-variant-numeric: tabular-nums; }

/* ===== Reports design tokens — scoped to .rai-reports ===== */
/* Seed: colors_and_type.css :root (v1 warm palette) */
.rai-reports {
  

  
  --orange-50:  #FFF1EA;
  --orange-100: #FFD9C5;
  --orange-200: #FFB394;
  --orange-300: #FF8A5C;
  --orange-400: #FB5F2C; 
  --orange-500: #E54E1E;
  --orange-600: #B33B14;
  --orange-700: #7A270B;

  
  --ink-0:    #0E0B09; 
  --ink-50:   #14110D;
  --ink-100:  #1A1612;
  --ink-150:  #211C17;
  --ink-200:  #2A241E;
  --ink-300:  #3A322A;
  --ink-400:  #524739;
  --ink-500:  #756753;
  --ink-600:  #998973;
  --ink-700:  #BAAA94;
  --ink-800:  #D8CBB6;
  --ink-850:  #E8DDCB;
  --ink-900:  #F1E8D9;
  --ink-950:  #F8F2E7;
  --ink-1000: #FDFAF3; 

  
  --brown-400: #9E6D40;
  --brown-200: rgba(158, 109, 64, 0.18);
  --brown-100: rgba(158, 109, 64, 0.10);
  --brown-50:  rgba(158, 109, 64, 0.06);

  
  --green-400: #4FB477;
  --green-500: #2F9D5F;
  --green-bg:  rgba(79, 180, 119, 0.14);

  --red-400:   #F26B5C;
  --red-500:   #E04A38;
  --red-bg:    rgba(242, 107, 92, 0.14);

  --amber-400: #F4A93A;
  --amber-500: #DC8E1C;
  --amber-bg:  rgba(244, 169, 58, 0.14);

  --blue-400:  #6CA9F2;
  --blue-500:  #3F86E0;
  --blue-bg:   rgba(108, 169, 242, 0.14);

  

  
  --surface-page:     var(--ink-50);   
  --surface-rail:     var(--ink-100);  
  --surface-1:        var(--ink-150);  
  --surface-2:        var(--ink-200);  
  --surface-3:        var(--ink-300);  
  --surface-inverse:  var(--ink-950);
  --surface-overlay:  rgba(14, 11, 9, 0.72);

  
  --fg-1:        var(--ink-950); 
  --fg-2:        var(--ink-800); 
  --fg-3:        var(--ink-600); 
  --fg-muted:    var(--ink-500); 
  --fg-inverse:  var(--ink-50);
  --fg-onbrand:  var(--ink-1000);

  
  --border-subtle:  rgba(251, 95, 44, 0.08);
  --border-default: rgba(251, 95, 44, 0.14);
  --border-strong:  rgba(251, 95, 44, 0.28);
  --divider:        rgba(216, 203, 182, 0.07);

  
  --brand:           var(--orange-400);
  --brand-hover:     var(--orange-500);
  --brand-press:     var(--orange-600);
  --brand-soft:      rgba(251, 95, 44, 0.14);
  --brand-soft-hi:   rgba(251, 95, 44, 0.22);

  
  --success:    var(--green-400);
  --success-bg: var(--green-bg);
  --danger:     var(--red-400);
  --danger-bg:  var(--red-bg);
  --warning:    var(--amber-400);
  --warning-bg: var(--amber-bg);
  --info:       var(--blue-400);
  --info-bg:    var(--blue-bg);

  
  --page-gradient:
    radial-gradient(ellipse 70% 50% at 92% -5%,  rgba(251, 95, 44, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse 38% 30% at 0% 95%,   rgba(251, 95, 44, 0.04) 0%, transparent 60%);

  

  --font-display: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-ui:      'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-alt:     'Inter', ui-sans-serif, system-ui, sans-serif;
  /* Jesus's dashboard renders ALL numbers/labels in Inter (his font-mono is
     defined but never applied). So "mono" here = Inter too; tabular-nums on the
     .rai-reports root keeps figures column-aligned without a monospace face. */
  --font-mono:    'Inter', ui-sans-serif, system-ui, sans-serif;

  
  --fs-2xs: 10px;
  --fs-xs:  11px;
  --fs-sm:  12px;
  --fs-md:  13px;  
  --fs-lg:  15px;
  --fs-xl:  18px;
  --fs-2xl: 22px;
  --fs-3xl: 28px;
  --fs-4xl: 36px;
  --fs-5xl: 48px;
  --fs-6xl: 64px;

  --lh-tight:   1.15;
  --lh-snug:    1.25;
  --lh-normal:  1.45;
  --lh-loose:   1.6;

  --tracking-display: -0.02em;
  --tracking-h:       -0.015em;
  --tracking-body:    0;
  --tracking-label:   0.06em; 
  --tracking-mono:    0;

  
  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;

  

  --sp-0:  0;
  --sp-1:  2px;
  --sp-2:  5px;
  --sp-3:  10px;
  --sp-4:  15px;
  --sp-5:  20px;
  --sp-6:  25px;
  --sp-7:  30px;
  --sp-8:  40px;
  --sp-9:  50px;
  --sp-10: 60px;
  --sp-12: 80px;

  

  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-pill: 999px;

  

  --shadow-xs:  0 1px 0 rgba(0,0,0,.20);
  --shadow-sm:  0 1px 2px rgba(0,0,0,.30), 0 0 0 1px rgba(251, 95, 44, 0.06);
  --shadow-md:  0 6px 18px -6px rgba(0,0,0,.45), 0 0 0 1px rgba(251, 95, 44, 0.08);
  --shadow-lg:  0 18px 40px -12px rgba(0,0,0,.55), 0 0 0 1px rgba(251, 95, 44, 0.10);
  --shadow-xl:  0 32px 80px -16px rgba(0,0,0,.65), 0 0 0 1px rgba(251, 95, 44, 0.12);
  --shadow-glow: 0 0 0 4px rgba(251, 95, 44, 0.18);

  

  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --dur-instant: 80ms;
  --dur-fast:    140ms;
  --dur-base:    220ms;
  --dur-slow:    380ms;

  

  --rail-width:   72px;   
  --sidebar-width: 240px; 
  --container-max: 1440px;
}
/* Override: tokens-v2.css :root (LIGHT default, v2 wins) */
.rai-reports {
  

  
  --orange-50:  oklch(0.97 0.025 50);
  --orange-100: oklch(0.93 0.06  50);
  --orange-200: oklch(0.86 0.11  48);
  --orange-300: oklch(0.78 0.16  45);
  --orange-400: oklch(0.68 0.19  42); 
  --orange-500: oklch(0.60 0.18  38);
  --orange-600: oklch(0.50 0.16  35);
  --orange-700: oklch(0.40 0.13  32);

  
  --cream-0:    oklch(1.000 0     0);
  --cream-50:   oklch(0.992 0.003 70);   
  --cream-100:  oklch(0.985 0.005 70);   
  --cream-150:  oklch(0.975 0.006 70);   
  --cream-200:  oklch(0.960 0.007 70);   
  --cream-300:  oklch(0.935 0.008 70);   
  --cream-400:  oklch(0.880 0.010 70);   

  
  --ink-100:  oklch(0.143 0.010 60);   
  --ink-150:  oklch(0.180 0.011 60);
  --ink-200:  oklch(0.220 0.012 60);   
  --ink-300:  oklch(0.290 0.013 60);
  --ink-400:  oklch(0.380 0.013 60);
  --ink-500:  oklch(0.500 0.012 60);   
  --ink-600:  oklch(0.620 0.010 60);   
  --ink-700:  oklch(0.730 0.008 60);
  --ink-800:  oklch(0.830 0.006 60);
  --ink-900:  oklch(0.920 0.005 60);
  --ink-950:  oklch(0.962 0.005 65);

  
  --green-400: oklch(0.72 0.13 155);
  --green-500: oklch(0.62 0.14 155);
  --green-600: oklch(0.52 0.13 155);

  --red-400:   oklch(0.68 0.18  25);
  --red-500:   oklch(0.58 0.20  25);
  --red-600:   oklch(0.48 0.18  25);

  --amber-400: oklch(0.78 0.13  75);
  --amber-500: oklch(0.70 0.14  70);

  --blue-400:  oklch(0.68 0.13 250);
  --blue-500:  oklch(0.58 0.16 250);

  --purple-400: oklch(0.68 0.13 295);

  

  --chart-1:    oklch(0.68 0.19 42);   
  --chart-1-fill: oklch(0.68 0.19 42 / 0.18);
  --chart-2:    oklch(0.42 0.04 50);   
  --chart-2-fill: oklch(0.42 0.04 50 / 0.10);
  --chart-3:    oklch(0.78 0.13 75);   
  --chart-3-fill: oklch(0.78 0.13 75 / 0.18);
  --chart-4:    oklch(0.62 0.14 155);  
  --chart-4-fill: oklch(0.62 0.14 155 / 0.18);
  --chart-5:    oklch(0.58 0.16 250);  
  --chart-5-fill: oklch(0.58 0.16 250 / 0.18);

  --chart-grid:    oklch(0.92 0.005 70);  
  --chart-axis:    oklch(0.55 0.008 60);  
  --chart-tooltip-bg: oklch(0.143 0.010 60);
  --chart-tooltip-fg: oklch(0.962 0.005 65);

  

  
  --surface-page:     var(--cream-50);
  --surface-rail:     var(--cream-0);
  --surface-1:        var(--cream-0);    
  --surface-2:        var(--cream-100);  
  --surface-3:        var(--cream-150);  
  --surface-hover:    var(--cream-200);
  --surface-inverse:  var(--ink-150);
  --surface-overlay:  oklch(0.143 0.010 60 / 0.40);

  
  --fg-1:        var(--ink-100);   
  --fg-2:        var(--ink-400);   
  --fg-3:        var(--ink-500);   
  --fg-muted:    var(--ink-600);   
  --fg-inverse:  var(--cream-0);
  --fg-onbrand:  var(--cream-0);

  
  --border-subtle:  oklch(0 0 0 / 0.06);   
  --border-default: oklch(0 0 0 / 0.09);   
  --border-strong:  oklch(0 0 0 / 0.14);   
  --divider:        oklch(0 0 0 / 0.06);

  
  --brand:           var(--orange-400);
  --brand-hover:     var(--orange-500);
  --brand-press:     var(--orange-600);
  --brand-soft:      oklch(0.68 0.19 42 / 0.10);
  --brand-soft-hi:   oklch(0.68 0.19 42 / 0.18);
  --brand-ring:      oklch(0.68 0.19 42 / 0.22);

  
  --success:    var(--green-500);
  --success-bg: oklch(0.62 0.14 155 / 0.10);
  --danger:     var(--red-500);
  --danger-bg:  oklch(0.58 0.20 25 / 0.10);
  --warning:    var(--amber-500);
  --warning-bg: oklch(0.70 0.14 70 / 0.12);
  --info:       var(--blue-500);
  --info-bg:    oklch(0.58 0.16 250 / 0.10);

  
  --page-gradient: none;

  
  --dot-grid-color: oklch(0 0 0 / 0.04);

  

  --font-display: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-ui:      'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-alt:     'Inter', ui-sans-serif, system-ui, sans-serif;
  /* Jesus's dashboard renders ALL numbers/labels in Inter (his font-mono is
     defined but never applied). So "mono" here = Inter too; tabular-nums on the
     .rai-reports root keeps figures column-aligned without a monospace face. */
  --font-mono:    'Inter', ui-sans-serif, system-ui, sans-serif;

  
  --fs-2xs: 10px;
  --fs-xs:  11px;
  --fs-sm:  12px;
  --fs-md:  13px;   
  --fs-lg:  15px;
  --fs-xl:  18px;
  --fs-2xl: 22px;
  --fs-3xl: 28px;
  --fs-4xl: 36px;
  --fs-5xl: 48px;
  --fs-6xl: 64px;
  --fs-7xl: 88px;   

  --lh-tight:   1.1;
  --lh-snug:    1.25;
  --lh-normal:  1.5;
  --lh-loose:   1.65;

  --tracking-display: -0.025em;
  --tracking-h:       -0.015em;
  --tracking-body:    0;
  --tracking-label:   0.06em;
  --tracking-mono-tight: -0.015em;

  --fw-regular:   400;
  --fw-medium:    500;
  --fw-semibold:  600;
  --fw-bold:      700;

  

  --sp-0:   0;
  --sp-1:   2px;
  --sp-2:   4px;
  --sp-3:   8px;
  --sp-4:  12px;
  --sp-5:  16px;
  --sp-6:  20px;
  --sp-7:  24px;
  --sp-8:  32px;
  --sp-9:  40px;
  --sp-10: 48px;
  --sp-12: 64px;
  --sp-14: 80px;
  --sp-16: 96px;

  

  --radius-xs:  3px;
  --radius-sm:  5px;
  --radius-md:  7px;
  --radius-lg:  10px;
  --radius-xl:  14px;
  --radius-2xl: 18px;
  --radius-3xl: 24px;
  --radius-pill: 999px;

  

  --shadow-xs:  none;
  --shadow-sm:  0 1px 2px oklch(0 0 0 / 0.06);
  --shadow-md:  0 2px 8px -2px oklch(0 0 0 / 0.10), 0 1px 2px oklch(0 0 0 / 0.04);
  --shadow-lg:  0 8px 24px -8px oklch(0 0 0 / 0.16), 0 2px 6px -2px oklch(0 0 0 / 0.06);
  --shadow-xl:  0 24px 56px -12px oklch(0 0 0 / 0.22), 0 4px 12px -4px oklch(0 0 0 / 0.08);
  --shadow-glow: 0 0 0 3px var(--brand-ring);

  

  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --dur-instant: 80ms;
  --dur-fast:    140ms;
  --dur-base:    220ms;
  --dur-slow:    380ms;

  

  --rail-width:    52px;
  --sidebar-width: 224px;
  --container-max: 1440px;
  --header-height: 56px;

  color-scheme: light dark;
  --ink-50: var(--cream-100);
}
/* Dark mode — driven by the production [data-theme="dark"] on <html> */
[data-theme="dark"] .rai-reports {
  --surface-page:     var(--ink-100);
  --surface-rail:     var(--ink-150);
  --surface-1:        var(--ink-150);
  --surface-2:        var(--ink-200);
  --surface-3:        var(--ink-200);
  --surface-hover:    var(--ink-300);
  --surface-inverse:  var(--cream-0);
  --surface-overlay:  oklch(0 0 0 / 0.60);

  --fg-1:        var(--ink-950);
  --fg-2:        var(--ink-800);
  --fg-3:        var(--ink-700);
  --fg-muted:    var(--ink-600);
  --fg-inverse:  var(--ink-100);
  --fg-onbrand:  var(--ink-950);

  --border-subtle:  oklch(1 0 0 / 0.06);
  --border-default: oklch(1 0 0 / 0.10);
  --border-strong:  oklch(1 0 0 / 0.16);
  --divider:        oklch(1 0 0 / 0.06);

  --chart-grid:    oklch(1 0 0 / 0.08);
  --chart-axis:    oklch(0.72 0.010 60);
  --chart-tooltip-bg: var(--ink-200);
  --chart-tooltip-fg: var(--ink-950);

  --dot-grid-color: oklch(1 0 0 / 0.04);

  --shadow-sm:  0 1px 2px oklch(0 0 0 / 0.30);
  --shadow-md:  0 2px 12px -2px oklch(0 0 0 / 0.45), 0 1px 2px oklch(0 0 0 / 0.20);
  --shadow-lg:  0 12px 32px -10px oklch(0 0 0 / 0.55), 0 2px 6px -2px oklch(0 0 0 / 0.25);
  --shadow-xl:  0 28px 64px -16px oklch(0 0 0 / 0.65);

  --ink-50: oklch(0.143 0.010 60);
}
/* v1 light overrides retained for any v1-only var consumers */
[data-theme="light"] .rai-reports {
  --surface-page:     var(--ink-1000);
  --surface-rail:     #fdfaf5;
  --surface-1:        #ffffff;
  --surface-2:        #fbf6ee;
  --surface-3:        #f1eade;
  --surface-inverse:  var(--ink-50);
  --surface-overlay:  rgba(20, 17, 13, 0.40);

  --fg-1:        #1a1612;
  --fg-2:        #514738;
  --fg-3:        #7a6f66;
  --fg-muted:    #999088;
  --fg-inverse:  var(--ink-1000);
  --fg-onbrand:  #ffffff;

  --border-subtle:  rgba(158, 109, 64, 0.08);
  --border-default: rgba(158, 109, 64, 0.14);
  --border-strong:  rgba(158, 109, 64, 0.28);
  --divider:        rgba(158, 109, 64, 0.08);

  --page-gradient:
    radial-gradient(ellipse 85% 60% at 80% -10%, rgba(251, 100, 50, 0.14) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 100% 40%, rgba(251, 95, 44, 0.05) 0%, transparent 60%);

  --shadow-sm:  0 1px 2px rgba(160, 80, 30, 0.10), 0 0 0 1px rgba(158, 109, 64, 0.06);
  --shadow-md:  0 6px 18px -6px rgba(160, 80, 30, 0.18), 0 0 0 1px rgba(158, 109, 64, 0.08);
  --shadow-lg:  0 18px 40px -12px rgba(160, 80, 30, 0.22), 0 0 0 1px rgba(158, 109, 64, 0.10);
  --shadow-xl:  0 32px 80px -16px rgba(160, 80, 30, 0.28), 0 0 0 1px rgba(158, 109, 64, 0.12);

  --ink-50: var(--cream-100);
}

/* ============================================================
   LIGHT-MODE HARDCODED-COLOR FIXES
   These selectors carry dark-only hardcoded colors (near-black
   surfaces, fixed dark --ink-* borders, white washes, dark-forced
   native controls) that DON'T flip with the theme. Overriding them
   ONLY under [data-theme="light"] keeps the dark appearance
   byte-identical while making light mode read correctly.
   ============================================================ */

/* Sticky header + report toolbar: hardcoded near-black rgba(20,17,13)
   stayed dark on a light page. Use a light translucent surface (keeps the
   backdrop-blur). */
[data-theme="light"] .rai-reports .topbar {
  background: rgba(255, 252, 247, 0.85);
}
[data-theme="light"] .rai-reports .rep-toolbar {
  background: rgba(255, 252, 247, 0.92);
}

/* Native form controls were color-scheme:dark → dark dropdown/date picker
   on a light page. Match the page in light mode. */
[data-theme="light"] .rai-reports .tf-custom-row input[type="date"],
[data-theme="light"] .rai-reports .fb-sel select,
[data-theme="light"] .rai-reports .rep-sel {
  color-scheme: light;
}

/* Section footer gradient ended on a fixed dark --ink-150 → dark wedge on a
   light page. Resolve the dark stop to a light surface. */
[data-theme="light"] .rai-reports .rsec-footer {
  background: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-3) 100%);
}

/* SEO local-map (lsm-* / slm-*) entries used translucent-white washes +
   fixed dark --ink-200 borders → invisible fills + dark borders on light. */
[data-theme="light"] .rai-reports .lsm-cat,
[data-theme="light"] .rai-reports .lsm-rec,
[data-theme="light"] .rai-reports .slm-pop-cat {
  background: var(--surface-2);
  border-color: var(--border-default);
}
[data-theme="light"] .rai-reports .lsm-recs {
  border-color: var(--border-default);
}
[data-theme="light"] .rai-reports .slm-pop-row + .slm-pop-row {
  border-top-color: var(--divider);
}

/* SEO local-map keyword chips: fixed dark --ink-100/--ink-200 borders. */
[data-theme="light"] .rai-reports .lsm-kw-chips {
  border-top-color: var(--divider);
}
[data-theme="light"] .rai-reports .lsm-kw-chip {
  border-color: var(--border-default);
}

/* ===== dashboard.css (scoped) ===== */
.rai-reports .font-mono, .rai-reports [class*="-mono"], .rai-reports code, .rai-reports kbd, .rai-reports pre {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .shell {
  display: grid;
  grid-template-columns: var(--rail-width) var(--sidebar-width) 1fr;
  height: 100vh;
  transition: grid-template-columns var(--dur-base) var(--ease-out);
}
.rai-reports .shell.sidebar-collapsed {
  grid-template-columns: var(--rail-width) 0 1fr;
}
.rai-reports .shell.sidebar-collapsed .sidebar {
  width: 0;
  padding: 0;
  border-right: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}
.rai-reports .rail {
  background: var(--surface-rail);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 0 12px;
  gap: 4px;
}
.rai-reports .rail-logo {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, #FB5F2C 0%, #E54E1E 100%);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 16px -6px rgba(251,95,44,.6);
  overflow: hidden;
  margin-bottom: 18px;
  flex-shrink: 0;
}
.rai-reports .rail-logo img { width: 38px; height: 38px; object-fit: cover; }
.rai-reports .rail-btn {
  width: 56px; min-height: 56px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
  padding: 6px 2px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--fg-3);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  position: relative;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rail-btn:hover { color: var(--fg-1); background: var(--surface-1); }
.rai-reports .rail-btn.active {
  color: var(--brand);
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.18);
}
.rai-reports .rail-btn.active::before {
  content: "";
  position: absolute;
  left: -14px; top: 12px; bottom: 12px;
  width: 3px;
  background: var(--brand);
  border-radius: 0 3px 3px 0;
}
.rai-reports .rail-btn svg { width: 18px; height: 18px; }
.rai-reports .rail-label {
  font: 500 9.5px var(--font-ui);
  letter-spacing: -.005em;
  color: inherit;
  line-height: 1;
  white-space: nowrap;
  opacity: .9;
}
.rai-reports .rail-btn.active .rail-label { opacity: 1; }
.rai-reports .rail-spacer { flex: 1; }
.rai-reports .rail-badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--brand);
  color: var(--fg-onbrand);
  font: 600 9px var(--font-mono);
  padding: 1px 5px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
  border: 2px solid var(--surface-rail);
}
.rai-reports .sidebar {
  background: var(--surface-page);
  border-right: 1px solid var(--border-subtle);
  padding: 18px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  overflow-y: auto;
}
.rai-reports .sidebar-section-label {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
  padding: 12px 10px 6px;
}
.rai-reports .sidebar-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--fg-2);
  font: 500 13px var(--font-ui);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  width: 100%;
  text-align: left;
}
.rai-reports .sidebar-item:hover { background: var(--surface-1); color: var(--fg-1); }
.rai-reports .sidebar-item.active {
  background: var(--brand-soft);
  color: var(--brand);
}
.rai-reports .sidebar-item svg { width: 16px; height: 16px; flex-shrink: 0; opacity: .85; }
.rai-reports .sidebar-item .count {
  margin-left: auto;
  font: 600 10px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 1px 6px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .sidebar-item.active .count { background: var(--brand); color: var(--fg-onbrand); }
.rai-reports .sidebar-search { margin-bottom: 10px; position: relative; }
.rai-reports .sidebar-search svg { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--fg-muted); width: 14px; height: 14px; }
.rai-reports .sidebar-search input {
  width: 100%; box-sizing: border-box;
  padding: 8px 10px 8px 32px;
  font: 400 12px var(--font-ui);
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  color: var(--fg-1);
  outline: none;
}
.rai-reports .sidebar-search input:focus { border-color: var(--brand); }
.rai-reports .sidebar-search kbd {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  font: 500 9px var(--font-mono);
  color: var(--fg-3);
  background: var(--surface-3);
  padding: 1px 5px;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
}
.rai-reports .sidebar-footer {
  margin-top: auto;
  padding: 10px 4px 4px;
  border-top: 1px solid var(--border-subtle);
  display: flex; align-items: center; gap: 10px;
}
.rai-reports .avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, #FB5F2C, #B33B14);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font: 600 11px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .sidebar-footer .who { display: flex; flex-direction: column; min-width: 0; }
.rai-reports .sidebar-footer .name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .sidebar-footer .role { font: 400 10px var(--font-mono); color: var(--fg-3); }
.rai-reports .client-chip {
  margin: 6px 4px 12px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 10px;
  padding: 10px 12px;
  display: flex; align-items: center; gap: 10px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .client-chip:hover { border-color: var(--border-strong); background: var(--surface-2); }
.rai-reports .client-chip .mark {
  width: 30px; height: 30px; border-radius: 7px;
  background: linear-gradient(135deg, var(--brand) 0%, #B33B14 100%);
  display: flex; align-items: center; justify-content: center;
  font: 600 12px var(--font-ui); color: white;
  flex-shrink: 0;
}
.rai-reports .client-chip .info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.rai-reports .client-chip .info .name { font: 600 12px var(--font-ui); color: var(--fg-1); white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.rai-reports .client-chip .info .meta { font: 500 10px var(--font-mono); color: var(--fg-3); white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.rai-reports .client-chip .switch { color: var(--fg-3); }
.rai-reports .main {
  overflow-y: auto;
  padding: 0;
}
.rai-reports .topbar {
  position: sticky; top: 0; z-index: 5;
  height: 56px;
  display: flex; align-items: center;
  padding: 0 28px;
  gap: 14px;
  background: rgba(20, 17, 13, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-subtle);
}
.rai-reports .crumbs { display: flex; align-items: center; gap: 8px; font: 500 12px var(--font-ui); color: var(--fg-3); }
.rai-reports .crumbs .now { color: var(--fg-1); }
.rai-reports .crumbs .sep { color: var(--ink-300); }
.rai-reports .topbar .grow { flex: 1; }
.rai-reports .topbar .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  font: 500 11px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .topbar .pill .dot { width: 6px; height: 6px; border-radius: 50%; background: #4FB477; box-shadow: 0 0 8px #4FB477; }
.rai-reports .icon-btn {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--fg-2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .icon-btn:hover { background: var(--surface-1); color: var(--fg-1); border-color: var(--border-subtle); }
.rai-reports .icon-btn svg { width: 15px; height: 15px; }
.rai-reports .sidebar-toggle { margin-right: 4px; }
.rai-reports .user-menu { position: relative; }
.rai-reports .user-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 4px 10px 4px 4px;
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  cursor: pointer;
  color: var(--fg-2);
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .user-chip:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .avatar-sm {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, #FB5F2C, #9E6D40);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 600 10px var(--font-ui);
  letter-spacing: .02em;
  flex-shrink: 0;
}
.rai-reports .who-mini { display: flex; flex-direction: column; gap: 0; line-height: 1.15; text-align: left; }
.rai-reports .who-mini .name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .who-mini .role { font: 500 10px var(--font-ui); color: var(--fg-3); }
@media (max-width: 900px) {
.rai-reports .who-mini { display: none; }
}
.rai-reports .user-pop {
  position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 240px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.32), 0 2px 8px rgba(0,0,0,.18);
  padding: 6px;
  z-index: 100;
}
.rai-reports .user-pop-head {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 10px 12px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 4px;
}
.rai-reports .user-pop-head .avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, #FB5F2C, #9E6D40);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font: 600 13px var(--font-ui);
}
.rai-reports .user-pop-head .name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .user-pop-head .email { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .user-pop-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 8px 10px;
  background: transparent; border: 0;
  font: 500 13px var(--font-ui);
  color: var(--fg-2);
  border-radius: 7px; cursor: pointer; text-align: left;
}
.rai-reports .user-pop-item:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .user-pop-item.danger { color: var(--danger); }
.rai-reports .user-pop-sep { height: 1px; background: var(--divider); margin: 4px 0; }
.rai-reports .page { padding: 24px 28px 60px; max-width: 1440px; }
.rai-reports .page-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: flex-start;
  margin-bottom: 22px;
}
.rai-reports .page-head .eyebrow {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 10px;
}
.rai-reports .page-head .eyebrow .crumb-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--ink-400); }
.rai-reports .page-head .eyebrow .crumb-muted { color: var(--fg-3); letter-spacing: .08em; }
.rai-reports .page-head h1 {
  font-family: var(--font-ui);
  font-weight: 600;
  letter-spacing: -.022em;
  font-size: 32px;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--fg-1);
  margin: 0;
}
.rai-reports .page-head h1 em { font-style: italic; color: var(--brand); }
.rai-reports .page-head .sub { font: 400 14px var(--font-ui); color: var(--fg-3); max-width: 580px; margin-top: 8px; }
.rai-reports .page-head .actions { display: flex; gap: 8px; align-items: center; }
.rai-reports .btn {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 12px var(--font-ui);
  padding: 8px 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
.rai-reports .btn svg { width: 14px; height: 14px; }
.rai-reports .btn-primary { background: var(--brand); color: var(--fg-onbrand); }
.rai-reports .btn-primary:hover { background: var(--brand-hover); }
.rai-reports .btn-secondary { background: var(--surface-1); color: var(--fg-1); border-color: var(--border-default); }
.rai-reports .btn-secondary:hover { background: var(--surface-2); }
.rai-reports .btn-ghost { background: transparent; color: var(--fg-2); }
.rai-reports .btn-ghost:hover { background: var(--surface-1); color: var(--fg-1); }
.rai-reports .tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 22px;
  position: relative;
}
.rai-reports .tab {
  background: transparent;
  border: none;
  color: var(--fg-3);
  font: 500 13px var(--font-ui);
  padding: 10px 14px 12px;
  cursor: pointer;
  position: relative;
  transition: color var(--dur-fast) var(--ease-out);
  display: inline-flex; align-items: center; gap: 7px;
}
.rai-reports .tab:hover { color: var(--fg-1); }
.rai-reports .tab.on { color: var(--fg-1); }
.rai-reports .tab.on::after {
  content: "";
  position: absolute; left: 8px; right: 8px; bottom: -1px;
  height: 2px;
  background: var(--brand);
  border-radius: 2px 2px 0 0;
}
.rai-reports .tab .badge-tiny {
  background: var(--surface-2);
  color: var(--fg-3);
  font: 600 9px var(--font-mono);
  padding: 1px 6px;
  border-radius: 999px;
}
.rai-reports .tab.on .badge-tiny { background: var(--brand-soft); color: var(--brand); }
.rai-reports .card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.rai-reports .card-head { padding: 16px 20px; border-bottom: 1px solid var(--divider); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.rai-reports .card-head h3 { margin: 0; font: 600 14px var(--font-ui); color: var(--fg-1); }
.rai-reports .card-head .sub { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 2px; }
.rai-reports .card-body { padding: 20px; }
.rai-reports .badge {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11px var(--font-ui);
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid transparent;
}
.rai-reports .badge .dot { width: 6px; height: 6px; border-radius: 50%; }
.rai-reports .badge-success { background: var(--success-bg); color: var(--success); border-color: rgba(79,180,119,.3); }
.rai-reports .badge-danger { background: var(--danger-bg); color: var(--danger); border-color: rgba(242,107,92,.3); }
.rai-reports .badge-warning { background: var(--warning-bg); color: var(--warning); border-color: rgba(244,169,58,.3); }
.rai-reports .badge-info { background: var(--info-bg); color: var(--info); border-color: rgba(108,169,242,.3); }
.rai-reports .badge-brand { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .badge-neutral { background: var(--surface-3); color: var(--fg-2); border-color: var(--border-default); }
.rai-reports .kpi-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  margin-bottom: 18px;
}
.rai-reports .kpi {
  padding: 22px 24px;
  border-right: 1px solid var(--divider);
  position: relative;
  display: flex; flex-direction: column; gap: 8px;
}
.rai-reports .kpi:last-child { border-right: none; }
.rai-reports .kpi.is-active { background: linear-gradient(180deg, rgba(251,95,44,.06) 0%, transparent 60%); }
.rai-reports .kpi.is-active::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--brand);
}
.rai-reports .kpi .lbl { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); display: flex; align-items: center; gap: 6px; }
.rai-reports .kpi .lbl .dot { width: 6px; height: 6px; border-radius: 50%; }
.rai-reports .kpi .val { font-family: var(--font-mono); font-size: 32px; font-weight: 500; line-height: 1; letter-spacing: -.025em; font-variant-numeric: tabular-nums; color: var(--fg-1); display: flex; align-items: baseline; gap: 4px; }
.rai-reports .kpi .val .unit { font-size: 14px; color: var(--fg-3); margin-left: 2px; font-weight: 400; }
.rai-reports .kpi .val .pre { font-size: 18px; color: var(--fg-3); margin-right: 1px; font-weight: 400; }
.rai-reports .kpi .delta-row { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; font-variant-numeric: tabular-nums; color: var(--fg-3); }
.rai-reports .kpi .delta { display: inline-flex; align-items: center; gap: 3px; font-weight: 600; }
.rai-reports .kpi .delta.up { color: var(--success); }
.rai-reports .kpi .delta.down { color: var(--danger); }
.rai-reports .kpi .delta.neutral { color: var(--fg-2); }
.rai-reports .kpi .vs { color: var(--fg-muted); }
.rai-reports .kpi .spark { margin-top: 6px; height: 32px; }
.rai-reports .micro-grid { display: grid; gap: 1px; background: var(--border-subtle); border: 1px solid var(--border-default); border-radius: var(--radius-md); overflow: hidden; }
.rai-reports .micro {
  padding: 14px 16px;
  background: var(--surface-1);
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .micro .lbl { font: 600 9px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .micro .val { font-family: var(--font-mono); font-size: 18px; font-weight: 500; line-height: 1.1; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .micro .delta { font-family: var(--font-mono); font-size: 10px; }
.rai-reports .micro .delta.up { color: var(--success); }
.rai-reports .micro .delta.down { color: var(--danger); }
.rai-reports .seg {
  display: inline-flex;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}
.rai-reports .seg button {
  background: transparent;
  border: none;
  color: var(--fg-3);
  font: 600 11px var(--font-ui);
  padding: 5px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .seg button.on { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .seg button:hover:not(.on) { color: var(--fg-1); }
.rai-reports .table { width: 100%; border-collapse: collapse; }
.rai-reports .table th {
  text-align: left;
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding: 10px 16px;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
}
.rai-reports .table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--divider);
  font: 400 13px var(--font-ui);
  color: var(--fg-2);
  vertical-align: middle;
}
.rai-reports .table tr:last-child td { border-bottom: none; }
.rai-reports .table tr:hover td { background: var(--surface-2); }
.rai-reports .table .num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--fg-1); }
.rai-reports .stars { color: #F4A93A; letter-spacing: 1.5px; font-size: 13px; line-height: 1; }
.rai-reports .stars .empty { color: var(--ink-300); }
.rai-reports .timefilter {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: 14px 18px 16px;
  margin-bottom: 18px;
  box-shadow: var(--shadow-sm);
}
.rai-reports .tf-top {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.rai-reports .tf-range {
  display: flex; flex-direction: column; gap: 2px;
  margin-right: 6px;
  min-width: 200px;
}
.rai-reports .tf-range .label { font: 600 9px var(--font-ui); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-3); }
.rai-reports .tf-range .value {
  font-family: var(--font-ui);
  font-weight: 600;
  letter-spacing: -.012em;
  font-size: 18px;
  line-height: 1.1;
  letter-spacing: -.01em;
  color: var(--fg-1);
}
.rai-reports .tf-range .value em { font-style: italic; color: var(--brand); }
.rai-reports .tf-presets {
  display: inline-flex;
  background: transparent;
  border: 1px solid var(--border-default);
  border-radius: 8px;
  padding: 0;
  overflow: hidden;
}
.rai-reports .tf-presets button {
  background: transparent;
  border: none;
  border-right: 1px solid var(--border-subtle);
  color: var(--fg-3);
  font: 600 11px var(--font-ui);
  padding: 7px 12px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .tf-presets button:last-child { border-right: none; }
.rai-reports .tf-presets button:hover { color: var(--fg-1); background: var(--surface-2); }
.rai-reports .tf-presets button.on { background: var(--brand-soft); color: var(--brand); }
.rai-reports .tf-grow { flex: 1; }
.rai-reports .tf-compare {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
  padding: 6px 10px;
  border: 1px solid var(--border-default);
  border-radius: 8px;
  cursor: pointer;
}
.rai-reports .tf-compare:hover { background: var(--surface-2); }
.rai-reports .tf-compare svg { width: 13px; height: 13px; color: var(--fg-3); }
.rai-reports .tf-compare .compare-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand); }
.rai-reports .tf-compare .compare-dot.muted { background: var(--ink-400); }
.rai-reports .tf-gran {
  display: inline-flex;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: 8px;
  padding: 3px;
  gap: 1px;
}
.rai-reports .tf-gran button {
  background: transparent; border: none;
  color: var(--fg-3);
  font: 600 11px var(--font-mono);
  padding: 4px 9px;
  border-radius: 6px;
  cursor: pointer;
  width: 26px;
}
.rai-reports .tf-gran button.on { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .tf-strip {
  position: relative;
  height: 56px;
  background: var(--surface-page);
  border-radius: 8px;
  border: 1px solid var(--border-subtle);
  padding: 8px 10px;
  display: flex; align-items: stretch;
  gap: 2px;
  user-select: none;
  cursor: crosshair;
}
.rai-reports .tf-month {
  flex: 1;
  position: relative;
  border-radius: 4px;
  background: var(--surface-2);
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 2px;
  transition: background var(--dur-fast) var(--ease-out);
  cursor: pointer;
  min-width: 0;
}
.rai-reports .tf-month:hover { background: var(--surface-3); }
.rai-reports .tf-month .bar {
  position: absolute;
  left: 4px; right: 4px; bottom: 12px;
  background: var(--ink-400);
  border-radius: 2px 2px 0 0;
  transition: background var(--dur-fast) var(--ease-out);
}
.rai-reports .tf-presets { position: relative; }
.rai-reports .tf-custom-pop {
  position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 260px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  box-shadow: 0 14px 36px rgba(0,0,0,.34), 0 2px 8px rgba(0,0,0,.2);
  padding: 14px;
  z-index: 80;
  display: flex; flex-direction: column; gap: 10px;
}
.rai-reports .tf-custom-row { display: flex; align-items: center; gap: 10px; justify-content: space-between; }
.rai-reports .tf-custom-row label { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .tf-custom-row input[type="date"] {
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  padding: 6px 9px;
  color: var(--fg-1);
  font: 500 12px var(--font-ui);
  font-variant-numeric: tabular-nums;
  outline: none;
  color-scheme: dark;
}
.rai-reports .tf-custom-row input[type="date"]:focus { border-color: var(--brand); }
.rai-reports .tf-custom-foot { display: flex; justify-content: flex-end; gap: 8px; margin-top: 4px; }
.rai-reports .tf-custom-foot button {
  background: transparent; border: 1px solid var(--border-subtle);
  color: var(--fg-2); font: 500 12px var(--font-ui);
  padding: 6px 12px; border-radius: 7px; cursor: pointer;
}
.rai-reports .tf-custom-foot button.primary { background: var(--brand); border-color: var(--brand); color: var(--fg-onbrand); }
.rai-reports .tf-month .lab {
  font: 600 9px var(--font-mono);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: .04em;
  position: relative; z-index: 2;
}
.rai-reports .tf-month.in-range .bar { background: var(--brand); box-shadow: 0 0 12px rgba(251,95,44,.35); }
.rai-reports .tf-month.in-range .lab { color: var(--fg-1); }
.rai-reports .tf-month.in-range { background: rgba(251,95,44,.10); }
.rai-reports .tf-month.now { outline: 1px solid var(--brand); outline-offset: -1px; }
.rai-reports .dot-matrix { display: grid; grid-template-columns: repeat(53, 1fr); gap: 2px; }
.rai-reports .dot-cell { aspect-ratio: 1; border-radius: 2px; background: var(--surface-2); }
.rai-reports .dot-cell.l1 { background: rgba(251,95,44,.18); }
.rai-reports .dot-cell.l2 { background: rgba(251,95,44,.38); }
.rai-reports .dot-cell.l3 { background: rgba(251,95,44,.62); }
.rai-reports .dot-cell.l4 { background: rgba(251,95,44,.95); }
.rai-reports .statusdot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.rai-reports .statusdot.live { background: #4FB477; box-shadow: 0 0 8px #4FB477; }
.rai-reports .statusdot.warn { background: #F4A93A; box-shadow: 0 0 8px rgba(244,169,58,.6); }
.rai-reports .statusdot.crit { background: #F26B5C; box-shadow: 0 0 8px rgba(242,107,92,.6); }
.rai-reports .statusdot.idle { background: var(--ink-400); }
.rai-reports .log-feed { display: flex; flex-direction: column; gap: 0; }
.rai-reports .log-row {
  display: grid;
  grid-template-columns: 64px 100px 22px 1fr auto;
  gap: 12px;
  padding: 9px 20px;
  align-items: center;
  border-bottom: 1px solid var(--divider);
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--fg-2);
}
.rai-reports .log-row:last-child { border-bottom: none; }
.rai-reports .log-row:hover { background: var(--surface-2); }
.rai-reports .log-row .ts { color: var(--fg-muted); font-variant-numeric: tabular-nums; }
.rai-reports .log-row .src { color: var(--brand); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rai-reports .log-row .msg { color: var(--fg-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-ui); font-size: 12.5px; }
.rai-reports .log-row .meta { color: var(--fg-muted); font-size: 10.5px; }
.rai-reports .bdown-row { display: flex; flex-direction: column; gap: 6px; padding: 12px 0; border-bottom: 1px solid var(--divider); }
.rai-reports .bdown-row:last-child { border-bottom: none; }
.rai-reports .bdown-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; font-size: 13px; }
.rai-reports .bdown-head .name { color: var(--fg-1); font-weight: 500; display: flex; align-items: center; gap: 8px; }
.rai-reports .bdown-head .vals { font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--fg-3); font-size: 12px; }
.rai-reports .bdown-head .vals .v { color: var(--fg-1); font-weight: 500; }
.rai-reports .bdown-bar { height: 6px; background: var(--surface-3); border-radius: 999px; overflow: hidden; position: relative; }
.rai-reports .bdown-fill { height: 100%; border-radius: 999px; transition: width var(--dur-base) var(--ease-out); }
.rai-reports .source-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 11px var(--font-ui);
  padding: 3px 8px 3px 6px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  color: var(--fg-2);
}
.rai-reports .source-pill .ico { width: 14px; height: 14px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font: 700 8px var(--font-ui); color: white; }
.rai-reports .source-pill .ico.g { background: #4285F4; }
.rai-reports .source-pill .ico.y { background: #D32323; }
.rai-reports .source-pill .ico.t { background: #00B27A; }
.rai-reports .source-pill .ico.f { background: #1877F2; }
.rai-reports .star-row { display: grid; grid-template-columns: 36px 1fr 50px; align-items: center; gap: 10px; padding: 5px 0; }
.rai-reports .star-row .star-lbl { font: 600 11px var(--font-mono); color: var(--fg-3); display: flex; align-items: center; gap: 3px; }
.rai-reports .star-row .star-bar { height: 8px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .star-row .star-fill { height: 100%; border-radius: 999px; }
.rai-reports .star-row .star-fill.s5 { background: #4FB477; }
.rai-reports .star-row .star-fill.s4 { background: #92C580; }
.rai-reports .star-row .star-fill.s3 { background: #F4A93A; }
.rai-reports .star-row .star-fill.s2 { background: #ED8845; }
.rai-reports .star-row .star-fill.s1 { background: #F26B5C; }
.rai-reports .star-row .star-num { font: 600 11px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; text-align: right; }
.rai-reports .sec-h {
  display: flex; align-items: baseline; justify-content: space-between; gap: 14px;
  margin: 26px 0 12px;
}
.rai-reports .sec-h h2 {
  font-family: var(--font-ui);
  font-weight: 600;
  letter-spacing: -.014em;
  font-size: 20px;
  letter-spacing: -.015em;
  color: var(--fg-1);
  margin: 0;
}
.rai-reports .sec-h .h-meta { font: 500 11px var(--font-mono); color: var(--fg-3); text-transform: uppercase; letter-spacing: .08em; }
.rai-reports .loc-card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 14px;
  display: flex; flex-direction: column; gap: 10px;
  transition: all var(--dur-fast) var(--ease-out);
  cursor: pointer;
}
.rai-reports .loc-card:hover { border-color: var(--border-strong); transform: translateY(-1px); }
.rai-reports .loc-card .name { font: 600 13px var(--font-ui); color: var(--fg-1); display: flex; align-items: center; gap: 8px; }
.rai-reports .loc-card .addr { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .loc-card .row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding-top: 8px; border-top: 1px solid var(--divider); }
.rai-reports .loc-card .row .k { font: 600 9px var(--font-ui); text-transform: uppercase; letter-spacing: .08em; color: var(--fg-3); margin-bottom: 2px; }
.rai-reports .loc-card .row .v { font: 500 14px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .rank {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  background: var(--surface-3); color: var(--fg-2);
  border-radius: 6px;
  font: 700 10px var(--font-mono);
}
.rai-reports .rank.gold { background: linear-gradient(135deg, #F4A93A, #DC8E1C); color: #1a1612; }
.rai-reports .rank.silver { background: linear-gradient(135deg, #BAAA94, #998973); color: #1a1612; }
.rai-reports .rank.bronze { background: linear-gradient(135deg, #B97A4A, #9E6D40); color: #1a1612; }
.rai-reports .g-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
.rai-reports .col-8 { grid-column: span 8; }
.rai-reports .col-7 { grid-column: span 7; }
.rai-reports .col-6 { grid-column: span 6; }
.rai-reports .col-5 { grid-column: span 5; }
.rai-reports .col-4 { grid-column: span 4; }
.rai-reports .col-3 { grid-column: span 3; }

/* ===== extensions.css (scoped) ===== */
.rai-reports .sidebar-client {
  padding: 8px 10px;
  align-items: center;
  gap: 10px;
}
.rai-reports .sidebar-client .client-mark {
  width: 24px; height: 24px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font: 700 11px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .sidebar-client .client-meta {
  display: flex; flex-direction: column; gap: 1px;
  flex: 1; min-width: 0;
  overflow: hidden;
}
.rai-reports .sidebar-client .client-meta .cn {
  font: 500 12.5px var(--font-ui);
  color: var(--fg-1);
  white-space: nowrap; text-overflow: ellipsis; overflow: hidden;
}
.rai-reports .sidebar-client .client-meta .cs {
  font: 400 10px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .sidebar-client .client-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  opacity: 0.85;
}
.rai-reports .sidebar-footer-meta {
  margin-top: auto;
  padding: 10px 12px 4px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center; gap: 8px;
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.rai-reports .sidebar-footer-meta svg { color: var(--success); width: 12px; height: 12px; }
.rai-reports .page-head h1 {
  text-wrap: balance;
  max-width: 920px;
}
.rai-reports .kpi .lbl .dot { width: 7px; height: 7px; border-radius: 2px; }
.rai-reports .margin-spread { display: flex; flex-direction: column; gap: 14px; padding-bottom: 6px; }
.rai-reports .margin-spread .ms-rail {
  position: relative;
  height: 6px; border-radius: 999px;
  background: var(--surface-3);
  margin-bottom: 6px;
}
.rai-reports .margin-spread .ms-band {
  position: absolute; top: 0; bottom: 0;
  border-radius: 999px;
}
.rai-reports .margin-spread .ms-band.ok { background: rgba(79,180,119,.16); }
.rai-reports .margin-spread .ms-band.warn { background: rgba(244,169,58,.16); }
.rai-reports .margin-spread .ms-band.crit { background: rgba(242,107,92,.16); }
.rai-reports .margin-spread .ms-tick {
  position: absolute; top: 100%;
  width: 1px; height: 6px;
  background: var(--border-default);
  margin-left: -0.5px;
  margin-top: 2px;
}
.rai-reports .margin-spread .ms-tick span {
  position: absolute; left: 50%; top: 8px;
  transform: translateX(-50%);
  font: 500 9.5px var(--font-mono);
  color: var(--fg-muted);
}
.rai-reports .margin-spread .ms-row { display: grid; grid-template-columns: 110px 1fr; gap: 12px; align-items: center; }
.rai-reports .margin-spread .ms-label { font: 500 12px var(--font-ui); color: var(--fg-1); white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.rai-reports .margin-spread .ms-track {
  position: relative;
  height: 22px;
}
.rai-reports .margin-spread .ms-line {
  position: absolute; top: 50%; left: 0; right: 0;
  height: 1px; background: var(--divider);
  transform: translateY(-50%);
}
.rai-reports .margin-spread .ms-dot {
  position: absolute; top: 50%;
  width: 11px; height: 11px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
.rai-reports .margin-spread .ms-value {
  position: absolute; top: 50%;
  transform: translate(-50%, calc(-50% - 14px));
  font: 600 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.rai-reports .margin-foot {
  border-top: 1px solid var(--divider);
  margin-top: 18px; padding-top: 12px;
  display: flex; flex-direction: column; gap: 6px;
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .margin-foot .mf-row { display: flex; align-items: center; gap: 8px; }
.rai-reports .margin-foot .mf-band {
  width: 12px; height: 8px; border-radius: 3px;
}
.rai-reports .margin-foot .mf-band.ok { background: rgba(79,180,119,.5); }
.rai-reports .margin-foot .mf-band.warn { background: rgba(244,169,58,.5); }
.rai-reports .margin-foot .mf-band.crit { background: rgba(242,107,92,.5); }
.rai-reports .hmx {
  display: grid;
  grid-template-columns: 230px repeat(7, 1fr) 110px 90px;
  font-size: 12px;
}
.rai-reports .hmx-row {
  display: contents;
}
.rai-reports .hmx-row > .hmx-cell:first-child { border-left: 0; }
.rai-reports .hmx-cell {
  padding: 12px 8px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-2);
}
.rai-reports .hmx-row.hmx-head .hmx-cell {
  border-top: 0;
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding: 4px 8px 14px;
  gap: 4px;
}
.rai-reports .hmx-cell.client {
  justify-content: flex-start;
  gap: 10px;
  padding-left: 4px;
  padding-right: 8px;
}
.rai-reports .hmx-cell.num {
  justify-content: flex-end;
  font: 500 12.5px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  padding-right: 4px;
}
.rai-reports .hmx-cell .client-mark {
  width: 26px; height: 26px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .hmx-pending {
  display: inline-block;
  width: 18px; height: 2px; border-radius: 2px;
  background: var(--ink-300);
  position: relative;
}
.rai-reports .hmx-pending::after {
  content: ""; position: absolute; top: -1.5px; left: 0;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--ink-400);
  box-shadow: 8px 0 0 var(--ink-400);
}
.rai-reports .hmx-pending-tag {
  display: inline-block;
  font: 500 8.5px var(--font-mono);
  color: var(--fg-muted);
  text-transform: lowercase;
  letter-spacing: .02em;
  padding: 1px 5px;
  background: var(--surface-3);
  border-radius: 4px;
}
.rai-reports .ai-strip {
  background:
    radial-gradient(800px 200px at 12% 0%, rgba(251,95,44,.10) 0%, transparent 60%),
    var(--surface-1);
  border: 1px solid var(--border-default);
}
.rai-reports .ai-strip-head {
  padding: 18px 22px 8px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px;
}
.rai-reports .ai-strip-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--brand) 0%, #B33B14 100%);
  display: flex; align-items: center; justify-content: center;
  color: white;
  box-shadow: 0 8px 20px -8px rgba(251,95,44,.55), inset 0 1px 0 rgba(255,255,255,.18);
}
.rai-reports .ai-strip-body { padding: 6px 22px 22px; }
.rai-reports .ai-strip-prompt {
  display: flex; align-items: center; gap: 10px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: 10px;
  padding: 11px 14px;
  margin-bottom: 12px;
}
.rai-reports .ai-strip-prompt:focus-within { border-color: var(--brand); }
.rai-reports .ai-strip-prompt svg { color: var(--brand); }
.rai-reports .ai-strip-prompt input {
  flex: 1; background: transparent; border: 0; outline: 0;
  color: var(--fg-1);
  font: 500 13.5px var(--font-ui);
}
.rai-reports .ai-strip-prompt input::placeholder { color: var(--fg-3); }
.rai-reports .ai-strip-prompt kbd {
  font: 500 10px var(--font-mono);
  color: var(--fg-3);
  background: var(--surface-2);
  padding: 2px 7px;
  border-radius: 5px;
  border: 1px solid var(--border-subtle);
}
.rai-reports .ai-strip-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.rai-reports .ai-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  font: 500 12px var(--font-ui);
  padding: 6px 11px 6px 10px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ai-chip:hover {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.3);
  color: var(--brand);
}
.rai-reports .ai-chip svg { color: var(--fg-muted); }
.rai-reports .ai-chip:hover svg { color: var(--brand); }
.rai-reports .placeholder-card { margin-top: 14px; }
.rai-reports .planned-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 1100px) {
.rai-reports .planned-grid { grid-template-columns: 1fr; }
}
.rai-reports .planned-section {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 16px 18px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.rai-reports .planned-section:hover { border-color: var(--border-default); }
.rai-reports .planned-section .ps-num {
  font: 600 11px var(--font-mono);
  color: var(--brand);
  background: var(--brand-soft);
  border-radius: 6px;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  font-variant-numeric: tabular-nums;
}
.rai-reports .planned-section .ps-body { min-width: 0; }
.rai-reports .planned-section .ps-title {
  font: 600 13.5px var(--font-ui);
  color: var(--fg-1);
  margin-bottom: 4px;
}
.rai-reports .planned-section .ps-desc {
  font: 400 12px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.5;
}
.rai-reports .planned-section .ps-metrics {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin-top: 10px;
}
.rai-reports .planned-section .ps-metric {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-2);
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  padding: 2px 8px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .planned-section .ps-status {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 10px;
  font: 600 10.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.rai-reports .planned-section .ps-status.live { color: var(--success); }
.rai-reports .planned-section .ps-status.pending { color: var(--fg-muted); }
.rai-reports .cust-table {
  display: grid;
  grid-template-columns: 1.8fr 100px 100px 90px 110px 110px 100px 70px;
  width: 100%;
}
.rai-reports .cust-row {
  display: contents;
}
.rai-reports .cust-row > div {
  padding: 14px 14px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .cust-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.rai-reports .cust-row.cust-head > div {
  border-top: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding-top: 12px; padding-bottom: 12px;
}
.rai-reports .cust-row:not(.cust-head):hover > div { background: var(--surface-2); }
.rai-reports .tf-compare-wrap { position: relative; }
.rai-reports .tf-compare-pop {
  position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 220px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 10px;
  box-shadow: 0 14px 36px rgba(0,0,0,.34), 0 2px 8px rgba(0,0,0,.2);
  padding: 4px;
  z-index: 80;
  display: flex; flex-direction: column;
}
.rai-reports .tf-cmp-opt {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 7px 10px;
  background: transparent; border: 0;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
  border-radius: 6px;
  cursor: pointer; text-align: left;
}
.rai-reports .tf-cmp-opt:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .tf-cmp-opt.on { color: var(--brand); }
.rai-reports .tf-cmp-opt svg { opacity: 0.5; }
.rai-reports .tf-cmp-opt.on svg { opacity: 1; color: var(--brand); }
.rai-reports .tf-custom-note {
  font: 400 10.5px var(--font-ui);
  color: var(--fg-muted);
  padding: 4px 2px 0;
  font-style: italic;
}
.rai-reports .client-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 0;
}
.rai-reports .client-chip-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  color: var(--fg-2);
  font: 500 12px var(--font-ui);
  padding: 7px 12px 7px 11px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .client-chip-btn:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .client-chip-btn.on {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.3);
  color: var(--brand);
}
.rai-reports .client-chip-btn .cc-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.rai-reports .client-chip-btn .cc-num {
  font: 600 10px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-3);
  background: var(--surface-2);
  padding: 1px 6px;
  border-radius: 999px;
}
.rai-reports .client-chip-btn.on .cc-num { background: var(--brand); color: var(--fg-onbrand); }
.rai-reports .rsec-snapshot {
  background: linear-gradient(135deg, rgba(108,169,242,.04) 0%, var(--surface-1) 60%);
}
.rai-reports .rcs-heroes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 18px;
}
.rai-reports .rcs-hero {
  padding: 16px 18px;
  background: var(--surface-page);
  border-right: 1px solid var(--divider);
  display: flex; flex-direction: column; gap: 3px;
}
.rai-reports .rcs-hero:last-child { border-right: 0; }
.rai-reports .rcs-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
}
.rai-reports .rcs-val {
  font: 600 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.022em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rcs-delta {
  font: 600 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .rcs-delta.up { color: var(--success); }
.rai-reports .rcs-delta.down { color: var(--danger); }
.rai-reports .rcs-rank {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--surface-page);
  margin-bottom: 14px;
}
.rai-reports .rcs-rank-head {
  padding: 11px 14px;
  background: var(--surface-1);
  border-bottom: 1px solid var(--divider);
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-3);
}
.rai-reports .rcs-rank-grid {
  display: grid;
}
.rai-reports .rcs-rank-row {
  display: grid;
  grid-template-columns: 1.6fr 80px 70px 80px 70px 90px 80px 130px;
  align-items: center;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rcs-rank-row:last-child { border-bottom: 0; }
.rai-reports .rcs-rank-row > div {
  padding: 10px 12px;
  font: 500 12px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .rcs-rank-row > div.num {
  text-align: right;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  justify-self: stretch;
}
.rai-reports .rcs-rank-row.rcs-rank-head-row > div {
  background: var(--surface-1);
  font: 700 9.5px var(--font-mono);
  letter-spacing: .1em;
  color: var(--fg-muted);
}
.rai-reports .rcs-rank-name { display: flex; align-items: center; gap: 10px; }
.rai-reports .rcs-rank-pos {
  font: 700 11px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
  background: var(--surface-2);
  width: 24px; height: 24px;
  border-radius: 5px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .rcs-rl-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .rcs-rl-city { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .rcs-badge {
  font: 700 9px var(--font-mono);
  letter-spacing: .08em;
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
}
.rai-reports .rcs-badge.best { background: var(--success-bg); color: var(--success); }
.rai-reports .rcs-badge.watch { background: var(--warning-bg); color: var(--warning); }
.rai-reports .rcs-callouts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.rai-reports .rcs-callout {
  display: flex; gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
}
.rai-reports .rcs-callout svg { flex-shrink: 0; margin-top: 4px; }
.rai-reports .rcs-callout.rcs-best { background: var(--success-bg); border-color: rgba(79,180,119,.3); }
.rai-reports .rcs-callout.rcs-best svg { color: var(--success); }
.rai-reports .rcs-callout.rcs-watch { background: var(--warning-bg); border-color: rgba(244,169,58,.3); }
.rai-reports .rcs-callout.rcs-watch svg { color: var(--warning); }
.rai-reports .rcsc-head {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
}
.rai-reports .rcsc-name {
  font: 600 18px var(--font-ui);
  color: var(--fg-1);
  margin: 4px 0 6px;
}
.rai-reports .rcsc-text {
  font: 400 12px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.55;
}
.rai-reports .rsec-loc-divider {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 20px;
  align-items: center;
  padding: 22px 22px 22px 28px;
  background: var(--ink-50);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
.rai-reports .rsec-loc-divider::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--brand);
}
.rai-reports .rlocdv-num {
  font: 700 36px var(--font-mono);
  color: var(--brand);
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.rai-reports .rlocdv-eyebrow {
  font: 700 10px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.rai-reports .rlocdv-name {
  font: 600 34px var(--font-ui);
  font-style: italic;
  color: var(--fg-1);
  letter-spacing: -.024em;
  margin: 0;
  line-height: 1.05;
}
.rai-reports .rlocdv-city {
  font: 500 12px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
}
.rai-reports .rlocdv-line {
  position: absolute;
  bottom: 0; left: 28px; right: 28px;
  height: 0;
  border-top: 1px dashed var(--border-default);
}
.rai-reports .rpresent {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: var(--ink-50);
  display: flex; flex-direction: column;
  animation: rpres-in 200ms cubic-bezier(.2,.8,.2,1);
}
@keyframes rpres-in {
  from { opacity: 0; transform: scale(0.98); }
  to   { opacity: 1; transform: scale(1); }
}
.rai-reports .rpres-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 26px;
  background: var(--surface-page);
  border-bottom: 1px solid var(--border-default);
  flex-shrink: 0;
}
.rai-reports .rpres-brand { display: flex; align-items: center; gap: 12px; }
.rai-reports .rpres-brand img {
  width: 32px; height: 32px;
  border-radius: 7px;
  object-fit: cover;
}
.rai-reports .rpres-cli {
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .rpres-period {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rpres-exit {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  color: var(--fg-2);
  font: 500 12px var(--font-ui);
  padding: 7px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rpres-exit:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rpres-exit kbd {
  font: 600 9.5px var(--font-mono);
  background: var(--surface-3);
  color: var(--fg-3);
  padding: 1px 6px;
  border-radius: 4px;
  border: 1px solid var(--border-subtle);
}
.rai-reports .rpres-stage {
  flex: 1; min-height: 0;
  overflow-y: auto;
  padding: 40px 60px;
  display: flex; align-items: flex-start; justify-content: center;
}
.rai-reports .rpres-slide {
  width: 100%;
  max-width: 1100px;
  
}
.rai-reports .rpres-slide .rsec {
  padding: 56px 64px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,.32), 0 2px 8px rgba(0,0,0,.18);
}
.rai-reports .rpres-slide .rsec-title {
  font-size: 30px;
}
.rai-reports .rpres-slide .rsec-lead {
  font-size: 16px;
  max-width: 100%;
}
.rai-reports .rpres-slide .ch-val, .rai-reports .rpres-slide .rp-val, .rai-reports .rpres-slide .reh-val, .rai-reports .rpres-slide .rcs-val {
  font-size: 52px;
}
.rai-reports .rpres-slide .cov2-name { font-size: 88px; }
.rai-reports .rpres-slide .rlocdv-name { font-size: 64px; }
.rai-reports .rpres-slide .rlocdv-num { font-size: 56px; }
.rai-reports .rpres-slide .rwi-imp-val { font-size: 60px; }
.rai-reports .rpres-slide .rsec-loc-divider { padding: 64px 72px; }
.rai-reports .rpres-controls {
  display: flex; align-items: center; gap: 18px;
  padding: 14px 26px;
  background: var(--surface-page);
  border-top: 1px solid var(--border-default);
  justify-content: center;
  flex-shrink: 0;
}
.rai-reports .rpres-nav {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  color: var(--fg-2);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rpres-nav:hover:not(:disabled) {
  background: var(--brand);
  border-color: var(--brand);
  color: var(--fg-onbrand);
}
.rai-reports .rpres-nav:disabled { opacity: 0.3; cursor: not-allowed; }
.rai-reports .rpres-counter {
  display: flex; align-items: baseline; gap: 4px;
  font: 600 14px var(--font-mono);
  color: var(--fg-2);
  font-variant-numeric: tabular-nums;
  min-width: 60px; justify-content: center;
}
.rai-reports .rpres-cur { color: var(--brand); font-size: 18px; }
.rai-reports .rpres-sep { color: var(--fg-muted); }
.rai-reports .rpres-total { color: var(--fg-3); }
.rai-reports .rpres-progress {
  display: flex; gap: 4px;
  flex-wrap: wrap;
  max-width: 480px;
  justify-content: center;
}
.rai-reports .rpres-dot {
  width: 24px; height: 5px;
  background: var(--surface-3);
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  padding: 0;
}
.rai-reports .rpres-dot:hover { background: var(--ink-400); }
.rai-reports .rpres-dot.on { background: var(--brand); }
.rai-reports .rpres-dot.is-loc { background: var(--surface-2); border-top: 2px solid var(--ink-400); border-radius: 0; }
.rai-reports .rpres-dot.is-loc.on { background: var(--brand); border-color: var(--brand-press); }
.rai-reports .sidebar-resty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-left: -1px;
}
.rai-reports html[data-theme="dark"] {
  --surface-page: #0A0A0A;
  --surface-1: #141414;
  --surface-2: #1C1C1C;
  --surface-3: #242424;
}
.rai-reports html[data-theme="dark"] .main .page {
  background-image: radial-gradient(
    circle,
    rgba(255, 255, 255, 0.05) 1px,
    transparent 1px
  );
  background-size: 22px 22px;
  background-position: 0 0;
}
.rai-reports html[data-theme="light"] .main .page {
  background-image: radial-gradient(
    circle,
    rgba(0, 0, 0, 0.06) 1px,
    transparent 1px
  );
  background-size: 22px 22px;
  background-position: 0 0;
}
.rai-reports .page:has(.reports-shell), .rai-reports .page:has(.agent-shell) {
  background-image: none !important;
}
.resty-mark {
  display: inline-block;
  position: relative;
  flex-shrink: 0;
}
.resty-mark svg {
  display: block;
  transition: transform 220ms cubic-bezier(.2,.8,.2,1);
}
.resty-mark:hover svg { transform: translateY(-2px); }
.resty-mark:hover .resty-eyes { transform: translateY(-0.3px); }
.resty-mark .resty-body {
  transform-origin: center;
  animation: resty-breathe 4.5s ease-in-out infinite;
}
@keyframes resty-breathe {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.025); }
}
.resty-mark .resty-eyes {
  transform-origin: center;
  animation: resty-blink-eyes 5s ease-in-out infinite;
}
@keyframes resty-blink-eyes {
  0%, 92%, 100% { transform: scaleY(1); }
  94%, 98%      { transform: scaleY(0.08); }
}
.resty-mark .resty-pupil {
  transform-origin: center;
  animation: resty-glance 6.4s ease-in-out infinite;
}
@keyframes resty-glance {
  0%, 18%, 100% { transform: translateX(0); }
  22%, 40%      { transform: translateX(1px); }
  44%, 62%      { transform: translateX(0); }
  66%, 84%      { transform: translateX(-1px); }
  88%           { transform: translateX(0); }
}
.resty-mark .resty-mouth {
  transform-origin: 16px 22px;
  animation: resty-mouth 7s ease-in-out infinite;
}
@keyframes resty-mouth {
  0%, 100% { transform: scaleY(1); }
  50%      { transform: scaleY(0.85); }
}
.resty-mark .resty-breath {
  transform-origin: center;
  animation: resty-breath-glow 4.5s ease-in-out infinite;
}
@keyframes resty-breath-glow {
  0%, 100% { transform: scale(0.97); opacity: 0; }
  50%      { transform: scale(1.10); opacity: 0.25; }
}
.resty-mark .resty-ai-dot {
  transform-origin: 27px 27px;
  animation: resty-ai-pulse 2.4s ease-in-out infinite;
}
@keyframes resty-ai-pulse {
  0%, 100% { transform: scale(1);   opacity: 0;   }
  50%      { transform: scale(2.0); opacity: 0.35; }
}
.resty-mark .resty-hat {
  transform-origin: 16px 8px;
  animation: resty-hat-idle 6.8s ease-in-out infinite;
}
@keyframes resty-hat-idle {
  0%, 100% { transform: rotate(-0.6deg) translateY(0); }
  50%      { transform: rotate(0.6deg)  translateY(-0.4px); }
}
.resty-mark .resty-flame {
  transform-origin: 16px 30px;
  animation: resty-flame-flicker 0.6s ease-in-out infinite alternate;
}
.resty-mark .resty-flame-outer {
  animation: resty-flame-outer 0.8s ease-in-out infinite alternate;
  transform-origin: 16px 30px;
}
.resty-mark .resty-flame-inner {
  animation: resty-flame-inner 0.45s ease-in-out infinite alternate;
  transform-origin: 16px 30px;
}
.resty-mark .resty-flame-spark {
  animation: resty-spark 1.4s ease-out infinite;
}
@keyframes resty-flame-flicker {
  0%   { transform: scaleY(0.95) scaleX(0.98); }
  100% { transform: scaleY(1.08) scaleX(1.02); }
}
@keyframes resty-flame-outer {
  0%   { transform: scaleY(0.9)  translateY(0); opacity: 0.92; }
  100% { transform: scaleY(1.12) translateY(0.5px); opacity: 1; }
}
@keyframes resty-flame-inner {
  0%   { transform: scaleY(0.85); opacity: 0.85; }
  100% { transform: scaleY(1.18); opacity: 1; }
}
@keyframes resty-spark {
  0%   { transform: translateY(0)   scale(1);   opacity: 0; }
  25%  { transform: translateY(0)   scale(1.1); opacity: 1; }
  100% { transform: translateY(-6px) scale(0.2); opacity: 0; }
}
.resty-mark .resty-fins {
  transform-origin: 16px 24px;
}
.resty-mark.is-thinking .resty-body { animation-duration: 1.6s; }
.resty-mark.is-thinking .resty-hat { animation: resty-hat-thinking 0.9s ease-in-out infinite; }
.resty-mark.is-thinking .resty-flame { animation-duration: 0.35s; }
.resty-mark.is-thinking .resty-flame-outer { animation-duration: 0.4s; }
.resty-mark.is-thinking .resty-flame-inner { animation-duration: 0.22s; }
@keyframes resty-hat-thinking {
  0%, 100% { transform: rotate(-2deg) translateY(0); }
  50%      { transform: rotate(2deg)  translateY(-0.8px); }
}
.resty-mark.is-thinking .resty-eyes {
  animation: resty-thinking-eyes 1.2s ease-in-out infinite;
}
@keyframes resty-thinking-eyes {
  0%, 100% { transform: scaleY(0.5); }
  50%      { transform: scaleY(0.85); }
}
.resty-mark.is-thinking .resty-pupil {
  animation: resty-thinking-pupils 1s linear infinite;
}
@keyframes resty-thinking-pupils {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(0.8px, -0.4px); }
  50%  { transform: translate(0, 0.4px); }
  75%  { transform: translate(-0.8px, -0.4px); }
  100% { transform: translate(0, 0); }
}
.resty-mark.is-thinking .resty-mouth {
  animation: resty-thinking-mouth 1.8s ease-in-out infinite;
}
@keyframes resty-thinking-mouth {
  0%, 100% { transform: scaleX(1); opacity: 0.95; }
  50%      { transform: scaleX(0.3); opacity: 0.7; }
}
.resty-mark.v-hero svg { filter: drop-shadow(0 14px 28px rgba(251,95,44,.42)); }
.rai-reports .ac-empty-mark {
  width: auto !important;
  height: auto !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.rai-reports .ac-empty-head h2 em {
  font-style: italic;
  color: var(--brand);
  font-weight: 600;
}
.rai-reports .ac-msg-avatar.resty-avatar {
  background: transparent !important;
  width: 32px;
  height: 32px;
  padding: 0;
}
.rai-reports .agent-rail .ar-title {
  font-weight: 700;
  letter-spacing: -.01em;
}
.rai-reports .agent-shell {
  display: grid;
  grid-template-columns: 280px 1fr 340px;
  height: 100%;
  margin: 0;
}
.rai-reports .agent-shell.memory-hidden {
  grid-template-columns: 280px 1fr;
}
@media (max-width: 1280px) {
.rai-reports .agent-shell { grid-template-columns: 240px 1fr 300px; }
.rai-reports .agent-shell.memory-hidden { grid-template-columns: 240px 1fr; }
}
.rai-reports .agent-rail {
  background: var(--surface-1);
  border-right: 1px solid var(--border-default);
  display: flex; flex-direction: column;
  overflow: hidden;
  min-height: 0;
  min-width: 0;
}
.rai-reports .ar-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 16px 12px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .ar-title {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .ar-title svg { color: var(--brand); }
.rai-reports .ar-new-btn {
  width: 26px; height: 26px;
  background: var(--surface-2);
  border: 1px solid var(--border-default);
  border-radius: 6px;
  color: var(--fg-2);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.rai-reports .ar-new-btn:hover { background: var(--brand); border-color: var(--brand); color: var(--fg-onbrand); }
.rai-reports .ar-new-chat {
  display: flex; align-items: center; gap: 10px;
  margin: 12px;
  padding: 9px 12px;
  background: var(--brand-soft);
  border: 1px solid rgba(251,95,44,.2);
  border-radius: 8px;
  color: var(--brand);
  font: 600 12.5px var(--font-ui);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ar-new-chat:hover { background: var(--brand); color: var(--fg-onbrand); }
.rai-reports .ar-new-chat kbd {
  margin-left: auto;
  font: 500 10px var(--font-mono);
  background: rgba(0,0,0,.15);
  color: inherit;
  padding: 1px 6px;
  border-radius: 4px;
  opacity: 0.7;
}
.rai-reports .ar-section-label {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-muted);
  padding: 14px 16px 6px;
}
.rai-reports .ar-clients {
  padding: 0 8px;
  display: flex; flex-direction: column; gap: 2px;
}
.rai-reports .ar-client {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  background: transparent;
  border: 0;
  border-radius: 6px;
  color: var(--fg-2);
  font: 500 12.5px var(--font-ui);
  cursor: pointer;
  text-align: left;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ar-client:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .ar-client.on {
  background: var(--brand-soft);
  color: var(--brand);
}
.rai-reports .ar-client svg { opacity: 0.6; }
.rai-reports .ar-client.on svg { opacity: 1; }
.rai-reports .ar-mark {
  width: 22px; height: 22px;
  border-radius: 5px;
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 11px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .ar-cname { flex: 1; }
.rai-reports .ar-convos {
  flex: 1;
  overflow-y: auto;
  padding: 0 8px 12px;
  display: flex; flex-direction: column; gap: 2px;
}
.rai-reports .ar-convo {
  display: flex; flex-direction: column; gap: 4px;
  padding: 9px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 7px;
  color: var(--fg-2);
  cursor: pointer;
  text-align: left;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ar-convo:hover { background: var(--surface-2); border-color: var(--border-subtle); }
.rai-reports .ar-convo.on { background: var(--surface-2); border-color: var(--border-default); }
.rai-reports .ar-convo-title {
  font: 500 12.5px var(--font-ui);
  color: var(--fg-1);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.rai-reports .ar-convo-meta {
  display: flex; gap: 8px; align-items: center;
  font: 500 10.5px var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .ar-convo-tag { font-weight: 600; }
.rai-reports .ar-convo-when { color: var(--fg-muted); }
.rai-reports .ar-empty {
  padding: 16px 12px;
  font: 400 11.5px var(--font-ui);
  color: var(--fg-muted);
  font-style: italic;
  text-align: center;
}
.rai-reports .ar-foot {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 16px;
  border-top: 1px solid var(--divider);
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  letter-spacing: .04em;
}
.rai-reports .ar-foot svg { color: var(--brand); }
.rai-reports .agent-main {
  display: flex; flex-direction: column;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: var(--surface-page);
}
.rai-reports .ac-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 22px;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
}
.rai-reports .ac-topbar-left {
  display: flex; align-items: center; gap: 12px;
}
.rai-reports .ac-tb-eyebrow {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-muted);
}
.rai-reports .ac-tb-client {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 13.5px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .ac-tb-client svg { color: var(--fg-muted); }
.rai-reports .ac-tb-meta {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .ac-tb-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--fg-2);
  font: 500 12px var(--font-ui);
  padding: 6px 10px;
  border-radius: 7px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-tb-btn:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .ac-stream {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 24px 28px 12px;
}
.rai-reports .ac-empty {
  max-width: 720px;
  margin: 20px auto;
  display: flex; flex-direction: column; gap: 28px;
}
.rai-reports .ac-empty-head {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.rai-reports .ac-empty-mark {
  width: 64px; height: 64px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--brand) 0%, #B33B14 100%);
  display: inline-flex; align-items: center; justify-content: center;
  color: white;
  box-shadow: 0 14px 32px -8px rgba(251,95,44,.5);
}
.rai-reports .ac-empty-head h2 {
  font: 600 24px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.016em;
  margin: 0;
}
.rai-reports .ac-empty-head p {
  font: 400 13.5px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.55;
  max-width: 520px;
  margin: 0;
}
.rai-reports .ac-starters-label, .rai-reports .ac-caps-label {
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
  margin-bottom: 10px;
}
.rai-reports .ac-starters-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.rai-reports .ac-starter {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 10px;
  color: var(--fg-2);
  font: 500 12.5px var(--font-ui);
  cursor: pointer;
  text-align: left;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-starter:hover {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.3);
  color: var(--brand);
}
.rai-reports .ac-starter svg { color: var(--fg-muted); }
.rai-reports .ac-starter:hover svg { color: var(--brand); }
.rai-reports .ac-caps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.rai-reports .ac-cap {
  display: flex; gap: 10px;
  padding: 11px 12px;
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .ac-cap-icon {
  width: 28px; height: 28px;
  border-radius: 7px;
  background: var(--brand-soft);
  color: var(--brand);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .ac-cap-t {
  font: 600 12px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .ac-cap-d {
  font: 400 10.5px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.4;
}
.rai-reports .ac-msg {
  display: flex; gap: 12px;
  margin-bottom: 18px;
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
}
.rai-reports .ac-msg-user { justify-content: flex-end; }
.rai-reports .ac-msg-ai { justify-content: flex-start; }
.rai-reports .ac-msg-avatar {
  width: 28px; height: 28px;
  border-radius: 7px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font: 700 10px var(--font-mono);
}
.rai-reports .ac-msg-avatar.user {
  background: var(--surface-2);
  color: var(--fg-2);
}
.rai-reports .ac-msg-avatar.ai {
  background: linear-gradient(135deg, var(--brand) 0%, #B33B14 100%);
  color: white;
}
.rai-reports .ac-msg-body {
  max-width: 620px;
  padding: 12px 16px;
  border-radius: 14px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
}
.rai-reports .ac-msg-user .ac-msg-body {
  background: var(--brand);
  border-color: var(--brand);
  color: var(--fg-onbrand);
  font: 500 13px var(--font-ui);
  line-height: 1.5;
}
.rai-reports .ac-msg-ai .ac-msg-body {
  background: var(--surface-1);
  font: 400 13.5px var(--font-ui);
  color: var(--fg-1);
  line-height: 1.6;
}
.rai-reports .ac-msg-body.is-error {
  background: var(--danger-bg);
  border-color: rgba(242,107,92,.3);
  color: var(--danger);
}
.rai-reports .ac-msg-text p { margin: 0 0 10px; }
.rai-reports .ac-msg-text p:last-child { margin-bottom: 0; }
.rai-reports .ac-msg-text strong { color: var(--brand); font-weight: 700; }
.rai-reports .ac-md-list {
  margin: 8px 0;
  padding-left: 22px;
}
.rai-reports .ac-md-list li { margin-bottom: 4px; line-height: 1.55; }
.rai-reports .ac-msg-actions {
  display: flex; gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--border-subtle);
  opacity: 0;
  transition: opacity var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-msg-ai:hover .ac-msg-actions { opacity: 1; }
.rai-reports .ac-msg-actions button {
  width: 22px; height: 22px;
  border-radius: 5px;
  background: transparent;
  border: 0;
  color: var(--fg-muted);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.rai-reports .ac-msg-actions button:hover { background: var(--surface-2); color: var(--brand); }
.rai-reports .ac-pending {
  display: inline-flex; gap: 5px;
  align-items: center;
  padding: 4px 0;
}
.rai-reports .ac-pending-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand);
  animation: ac-bounce 1.4s infinite ease-in-out;
  opacity: 0.7;
}
.rai-reports .ac-pending-dot:nth-child(2) { animation-delay: .16s; }
.rai-reports .ac-pending-dot:nth-child(3) { animation-delay: .32s; }
@keyframes ac-bounce {
  0%, 80%, 100% { transform: translateY(0); opacity: 0.4; }
  40%           { transform: translateY(-4px); opacity: 1; }
}
.rai-reports .ac-quick {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 28px 0;
  border-top: 1px solid var(--divider);
}
.rai-reports .ac-quick-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  font: 500 11.5px var(--font-ui);
  padding: 5px 10px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-quick-btn:hover:not(:disabled) {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.3);
  color: var(--brand);
}
.rai-reports .ac-quick-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.rai-reports .ac-quick-btn svg { opacity: 0.7; }
.rai-reports .ac-quick-btn:hover:not(:disabled) svg { color: var(--brand); opacity: 1; }
.rai-reports .ac-input-form {
  padding: 12px 28px 20px;
  background: var(--surface-page);
}
.rai-reports .ac-input-wrap {
  display: flex; align-items: flex-end; gap: 10px;
  padding: 10px 14px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-input-wrap:focus-within {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(251,95,44,.12);
}
.rai-reports .ac-input-wrap > svg {
  color: var(--brand);
  flex-shrink: 0;
  margin-bottom: 6px;
}
.rai-reports .ac-input-wrap textarea {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  resize: none;
  color: var(--fg-1);
  font: 400 13.5px var(--font-ui);
  line-height: 1.55;
  max-height: 200px;
  padding: 4px 0;
  font-family: var(--font-ui);
}
.rai-reports .ac-input-wrap textarea::placeholder { color: var(--fg-3); }
.rai-reports .ac-send {
  width: 32px; height: 32px;
  background: var(--brand);
  border: 0;
  border-radius: 8px;
  color: var(--fg-onbrand);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .ac-send:hover:not(:disabled) { background: var(--brand-press); transform: scale(1.05); }
.rai-reports .ac-send:disabled { opacity: 0.4; cursor: not-allowed; }
.rai-reports .ac-spin {
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: white;
  border-radius: 50%;
  animation: ac-spin 0.7s linear infinite;
}
@keyframes ac-spin { to { transform: rotate(360deg); } }
.rai-reports .ac-input-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 4px 0;
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
}
.rai-reports .ac-input-foot kbd {
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  padding: 1px 5px;
  border-radius: 4px;
  font: 500 10px var(--font-mono);
}
.rai-reports .ac-model {
  display: inline-flex; align-items: center; gap: 6px;
}
.rai-reports .ac-model-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 6px var(--success);
}
.rai-reports .agent-context-rail {
  background: var(--surface-1);
  border-left: 1px solid var(--border-default);
  overflow-y: auto;
  min-height: 0;
  padding: 16px 14px;
}
.rai-reports .acr-head {
  display: flex; flex-direction: column; gap: 2px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 14px;
}
.rai-reports .acr-eyebrow {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--brand);
}
.rai-reports .acr-meta {
  font: 500 11px var(--font-mono);
  color: var(--fg-muted);
}
.rai-reports .acr-scope {
  background: var(--brand-soft);
  border: 1px solid rgba(251,95,44,.18);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 16px;
}
.rai-reports .acr-scope-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--brand);
}
.rai-reports .acr-scope-val {
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
  margin-top: 2px;
}
.rai-reports .acr-scope-period {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  text-transform: capitalize;
  margin-top: 2px;
}
.rai-reports .acr-section { margin-bottom: 18px; }
.rai-reports .acr-section-lbl {
  display: flex; align-items: center; justify-content: space-between;
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-muted);
  margin-bottom: 10px;
}
.rai-reports .acr-section-cnt {
  font: 600 9px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 1px 6px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .acr-kpis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.rai-reports .acr-kpi {
  display: flex; flex-direction: column; gap: 1px;
  padding: 8px 10px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
}
.rai-reports .acr-kpi-lbl {
  font: 600 9px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-muted);
}
.rai-reports .acr-kpi-val {
  font: 600 16px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.rai-reports .acr-kpi-d {
  font: 500 9.5px var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .acr-kpi-d.up { color: var(--success); }
.rai-reports .acr-kpi-d.down { color: var(--danger); }
.rai-reports .acr-memory {
  display: flex; flex-direction: column; gap: 8px;
}
.rai-reports .acr-mem-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: 8px 10px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
}
.rai-reports .acr-mem-item.is-decision {
  border-color: rgba(108,169,242,.3);
  background: rgba(108,169,242,.06);
}
.rai-reports .acr-mem-item.is-contract {
  border-color: rgba(244,169,58,.3);
  background: var(--warning-bg);
}
.rai-reports .acr-mem-date {
  font: 700 9px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-muted);
}
.rai-reports .acr-mem-text {
  font: 400 11.5px var(--font-ui);
  color: var(--fg-1);
  line-height: 1.5;
}
.rai-reports .acr-sources { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .acr-source {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 8px 10px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
}
.rai-reports .acr-source .statusdot { margin-top: 5px; flex-shrink: 0; }
.rai-reports .acrs-name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .acrs-meta { font: 500 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; margin-top: 1px; }
.rai-reports .page:has(.agent-shell) {
  padding: 0;
  max-width: none;
  overflow: hidden;
  height: calc(100vh - 56px);
}
.rai-reports .rcs-donut-card {
  margin-top: 14px; margin-bottom: 14px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--surface-page);
  overflow: hidden;
}
.rai-reports .rcs-donut-head {
  padding: 11px 14px;
  background: var(--surface-1);
  border-bottom: 1px solid var(--divider);
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-3);
}
.rai-reports .rcs-donut-body {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  padding: 18px 22px;
  align-items: center;
}
.rai-reports .rcs-donut-legend { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .rcs-dl-row {
  display: grid;
  grid-template-columns: 14px 1fr auto auto;
  gap: 10px; align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rcs-dl-row:last-child { border-bottom: 0; }
.rai-reports .rcs-dl-dot { width: 10px; height: 10px; border-radius: 3px; }
.rai-reports .rcs-dl-name { font: 500 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .rcs-dl-val { font: 600 12.5px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .rcs-dl-pct { font: 500 11px var(--font-mono); color: var(--fg-muted); min-width: 44px; text-align: right; font-variant-numeric: tabular-nums; }
.rai-reports .rrk-sales-cell {
  display: flex; align-items: center; gap: 8px;
  justify-content: flex-end;
}
.rai-reports .rrk-sales-bar {
  flex: 1;
  height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
  display: block;
}
.rai-reports .rrk-sales-fill {
  display: block;
  height: 100%;
  background: var(--brand);
  opacity: 0.78;
  border-radius: 999px;
}
.rai-reports .rrk-sales-val {
  font: 500 12px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  min-width: 56px;
  text-align: right;
}
.rai-reports .rpareto-callout {
  display: flex; gap: 28px;
  padding: 10px 14px 6px;
}
.rai-reports .rpc-cell { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .rpc-val {
  font: 600 22px var(--font-mono);
  color: var(--brand);
  letter-spacing: -.015em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rpc-lbl {
  font: 600 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
}
.rai-reports .rrev-trend {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--divider);
  width: 100%;
}
.rai-reports .rrev-trend-head {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.rai-reports .reh-spark {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rsec-eyebrow {
  display: flex; align-items: center; gap: 10px;
}
.rai-reports .rsec-eyebrow-pending {
  font: 600 9px var(--font-mono);
  text-transform: lowercase;
  letter-spacing: .04em;
  padding: 1px 7px;
  background: var(--surface-2);
  border: 1px dashed var(--border-default);
  color: var(--fg-muted);
  border-radius: 999px;
}
.rai-reports .rrail-loc-list { display: flex; flex-direction: column; gap: 3px; }
.rai-reports .rrail-loc {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--fg-2);
  font: 500 12px var(--font-ui);
  cursor: pointer;
  text-align: left;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rrail-loc:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rrail-loc.on { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.2); }
.rai-reports .rrail-loc svg { opacity: 0.6; }
.rai-reports .rrail-loc.on svg { opacity: 1; }
.rai-reports .rrail-toggle {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 4px;
  font: 500 11.5px var(--font-ui);
  color: var(--fg-2);
  cursor: pointer;
  margin-top: 4px;
}
.rai-reports .rrail-toggle input { accent-color: var(--brand); }
.rai-reports .rrail-pending {
  font: 600 9px var(--font-mono);
  text-transform: lowercase;
  letter-spacing: .04em;
  color: var(--fg-muted);
  background: var(--surface-2);
  padding: 1px 6px;
  border-radius: 4px;
  margin-left: 4px;
}
.rai-reports .rsec-cover2 {
  min-height: 480px;
  padding: 36px 44px;
  display: flex; flex-direction: column; justify-content: space-between;
  border: 1px solid var(--border-default);
}
.rai-reports .cov2-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}
.rai-reports .cov2-brand { display: flex; align-items: center; gap: 14px; }
.rai-reports .cov2-mark {
  width: 54px; height: 54px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font: 700 24px var(--font-ui);
  color: white;
  box-shadow: 0 12px 28px -10px rgba(0,0,0,.5);
}
.rai-reports .cov2-overline {
  font: 700 12px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-2);
  text-transform: uppercase;
}
.rai-reports .cov2-overline-right {
  font: 500 11.5px var(--font-mono);
  color: var(--fg-3);
  letter-spacing: .04em;
}
.rai-reports .cov2-overline-right strong { color: var(--fg-1); font-weight: 700; }
.rai-reports .cov2-title { padding: 18px 0 24px; }
.rai-reports .cov2-title-eyebrow {
  font: 700 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.rai-reports .cov2-name {
  font: 600 60px var(--font-ui);
  font-style: italic;
  letter-spacing: -.028em;
  line-height: 1.0;
  color: var(--fg-1);
  margin: 0;
}
.rai-reports .cov2-sub {
  font: 500 14px var(--font-ui);
  color: var(--fg-3);
  margin-top: 14px;
  letter-spacing: .01em;
}
.rai-reports .cov2-heroes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding-top: 24px;
  border-top: 1px solid var(--border-subtle);
}
.rai-reports .cov2-hero { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .ch-lbl {
  font: 700 10px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-3);
}
.rai-reports .ch-val {
  font: 600 38px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.03em;
  line-height: 1.0;
  font-variant-numeric: tabular-nums;
}
.rai-reports .ch-delta {
  font: 600 12px var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .ch-delta.up { color: var(--success); }
.rai-reports .ch-delta.down { color: var(--danger); }
.rai-reports .ch-delta.flat { color: var(--fg-3); }
.rai-reports .rsec-perf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 20px;
}
.rai-reports .rperf {
  padding: 18px 18px 16px;
  background: var(--surface-page);
  border-right: 1px solid var(--divider);
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .rperf:last-child { border-right: 0; }
.rai-reports .rp-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
}
.rai-reports .rp-val {
  font: 600 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rp-delta {
  font: 600 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .rp-delta.up { color: var(--success); }
.rai-reports .rp-delta.down { color: var(--danger); }
.rai-reports .rsec-chart-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 14px 18px 16px;
  margin-bottom: 20px;
}
.rai-reports .rsc-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.rai-reports .rsc-title {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .rsc-legend {
  display: flex; gap: 14px;
  font: 500 11px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .rsc-legend > span { display: inline-flex; align-items: center; gap: 6px; }
.rai-reports .rsec-mini-table {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .rmt-head, .rai-reports .rmt-row { display: contents; }
.rai-reports .rmt-head > div {
  padding: 9px 14px;
  background: var(--surface-page);
  border-bottom: 1px solid var(--divider);
  font: 700 9.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-muted);
}
.rai-reports .rmt-row > div {
  padding: 9px 14px;
  border-bottom: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .rmt-row:last-child > div { border-bottom: 0; }
.rai-reports .rmt-head > div.num, .rai-reports .rmt-row > div.num {
  text-align: right;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  justify-self: end;
}
.rai-reports .rpnl-matrix {
  display: grid;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--surface-page);
}
.rai-reports .rpnl-cell {
  padding: 8px 12px;
  border-bottom: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .rpnl-head {
  font: 700 9.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-muted);
  background: var(--surface-1);
  padding-top: 11px; padding-bottom: 11px;
}
.rai-reports .rpnl-lbl { color: var(--fg-2); }
.rai-reports .rpnl-indent { padding-left: 24px; color: var(--fg-3); font-size: 11.5px; }
.rai-reports .rpnl-cell.num {
  text-align: right;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rpnl-divider { border-top: 1px solid var(--border-default); }
.rai-reports .rpnl-bold { font-weight: 700; color: var(--fg-1); }
.rai-reports .rpnl-final {
  background: rgba(79,180,119,.08);
  color: var(--success);
  font-weight: 700;
}
.rai-reports .rpnl-current { background: var(--brand-soft); font-weight: 600; }
.rai-reports .rsec-rank-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 18px;
}
.rai-reports .rsec-rank-list {
  display: grid;
  grid-template-columns: 36px 1.6fr 70px 150px 70px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .rrk-head, .rai-reports .rrk-row { display: contents; }
.rai-reports .rrk-head > div {
  padding: 9px 10px;
  background: var(--surface-1);
  font: 700 9.5px var(--font-mono);
  letter-spacing: .1em;
  color: var(--fg-muted);
}
.rai-reports .rrk-head > div.num { text-align: right; justify-self: end; }
.rai-reports .rrk-row > div {
  padding: 9px 10px;
  border-top: 1px solid var(--divider);
  font: 500 12.5px var(--font-ui);
  color: var(--fg-1);
  display: flex; align-items: center;
}
.rai-reports .rrk-pos {
  font: 700 11px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rrk-name { gap: 8px; }
.rai-reports .rrk-badge.popular {
  font: 700 8.5px var(--font-mono);
  letter-spacing: .08em;
  background: var(--brand-soft);
  color: var(--brand);
  padding: 1px 6px;
  border-radius: 4px;
}
.rai-reports .rrk-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rrk-delta.up { color: var(--success); font-weight: 600; }
.rai-reports .rrk-delta.down { color: var(--danger); font-weight: 600; }
.rai-reports .rsec-rank-side { display: flex; flex-direction: column; gap: 12px; }
.rai-reports .rmover-block {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}
.rai-reports .rmv-head {
  display: flex; align-items: center; gap: 6px;
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-2);
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rmv-arrow {
  width: 18px; height: 18px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 13px var(--font-mono);
}
.rai-reports .rmv-arrow.up { background: var(--success-bg); color: var(--success); }
.rai-reports .rmv-arrow.down { background: var(--danger-bg);  color: var(--danger); }
.rai-reports .rmv-row { padding: 6px 0; }
.rai-reports .rmv-name { font: 600 12.5px var(--font-ui); color: var(--fg-1); }
.rai-reports .rmv-delta { font: 500 11px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .rmv-delta.up { color: var(--success); }
.rai-reports .rmv-delta.down { color: var(--danger); }
.rai-reports .rsec-segments {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.rai-reports .rseg-card {
  padding: 18px 18px 16px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-top-width: 3px;
  border-radius: var(--radius-md);
  display: flex; flex-direction: column; gap: 8px;
}
.rai-reports .rseg-head {
  display: flex; align-items: baseline; justify-content: space-between;
}
.rai-reports .rseg-lbl {
  font: 700 11px var(--font-mono);
  letter-spacing: .14em;
}
.rai-reports .rseg-count {
  font: 600 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rseg-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .rseg-hero {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rseg-sales {
  font: 600 22px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rseg-pct {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
}
.rai-reports .rseg-delta {
  font: 600 11px var(--font-mono);
  margin-left: auto;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rseg-delta.up { color: var(--success); }
.rai-reports .rseg-delta.down { color: var(--danger); }
.rai-reports .rseg-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rseg-stats > div { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .rss-lbl {
  font: 700 9px var(--font-mono);
  letter-spacing: .08em;
  color: var(--fg-muted);
}
.rai-reports .rss-val {
  font: 600 14px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rseg-takeaway {
  display: flex; gap: 10px;
  padding: 12px 14px;
  background: var(--brand-soft);
  border: 1px solid rgba(251,95,44,.18);
  border-radius: var(--radius-md);
  font: 400 12px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.55;
}
.rai-reports .rseg-takeaway svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.rai-reports .rseg-takeaway strong { color: var(--brand); font-weight: 700; }
.rai-reports .rsec-reviews-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  grid-template-rows: auto auto;
  gap: 14px;
}
.rai-reports .rrev-rating-card {
  grid-row: 1 / 3;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 24px 20px;
  display: flex; flex-direction: column; gap: 8px; align-items: flex-start;
}
.rai-reports .rrev-stars {
  font: 600 38px var(--font-mono);
  color: #F4A93A;
  letter-spacing: -.01em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rrev-total {
  font: 500 12px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .rrev-30 {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--divider);
  width: 100%;
}
.rai-reports .r30-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
  margin-bottom: 10px;
}
.rai-reports .r30-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.rai-reports .r30-cell { display: flex; flex-direction: column; gap: 2px; }
.rai-reports .r30-num {
  font: 600 24px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.rai-reports .r30-lbl-sm {
  font: 700 9px var(--font-mono);
  letter-spacing: .1em;
  color: var(--fg-muted);
}
.rai-reports .rrev-summary {
  background: linear-gradient(135deg, rgba(251,95,44,.06) 0%, var(--surface-page) 60%);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.rai-reports .rrev-summary-head {
  display: flex; align-items: center; gap: 6px;
  font: 700 10px var(--font-mono);
  letter-spacing: .14em;
  color: var(--brand);
  margin-bottom: 8px;
}
.rai-reports .rrev-summary-head svg { color: var(--brand); }
.rai-reports .rrev-summary-text {
  font: 400 13px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.55;
  margin: 0;
}
.rai-reports .rrev-tags {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.rai-reports .rrev-tag-head {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  margin-bottom: 8px;
}
.rai-reports .rrev-tag-pills { display: flex; flex-wrap: wrap; gap: 5px; }
.rai-reports .rrev-pill {
  font: 500 11px var(--font-ui);
  padding: 3px 9px;
  border-radius: 999px;
}
.rai-reports .rrev-pill.good { background: var(--success-bg); color: var(--success); }
.rai-reports .rrev-pill.bad { background: var(--danger-bg);  color: var(--danger); }
.rai-reports .rrev-watch {
  grid-column: 1 / 3;
  background: var(--warning-bg);
  border: 1px solid rgba(244,169,58,.3);
  border-radius: var(--radius-md);
  padding: 12px 16px;
}
.rai-reports .rrev-watch-head {
  display: flex; align-items: center; gap: 6px;
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--warning);
  margin-bottom: 8px;
}
.rai-reports .rrev-watch-head svg { color: var(--warning); }
.rai-reports .rrev-watch-list { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rrev-watch-row {
  display: flex; justify-content: space-between;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .rrev-watch-count { font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--fg-3); }
.rai-reports .rmkt-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 18px;
}
.rai-reports .rmkt-cell {
  padding: 16px 18px;
  background: var(--surface-page);
  border-right: 1px solid var(--divider);
  display: flex; flex-direction: column; gap: 3px;
}
.rai-reports .rmkt-cell:last-child { border-right: 0; }
.rai-reports .rmkt-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-muted);
}
.rai-reports .rmkt-val {
  font: 600 22px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.018em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rmkt-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .rsec-promos2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.rai-reports .rpromo2 {
  position: relative;
  padding: 14px 14px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .rpromo2.is-star {
  border-color: rgba(244,169,58,.3);
  background: linear-gradient(135deg, rgba(244,169,58,.06) 0%, var(--surface-page) 60%);
}
.rai-reports .rpromo2-star {
  position: absolute; top: -8px; right: 14px;
  font: 700 9px var(--font-mono);
  letter-spacing: .1em;
  background: #F4A93A;
  color: var(--ink-0);
  padding: 2px 8px;
  border-radius: 999px;
}
.rai-reports .rpromo2-head {
  display: flex; align-items: center; justify-content: space-between; gap: 6px;
}
.rai-reports .rpromo2-loc {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rpromo2-title { font: 600 13px var(--font-ui); color: var(--fg-1); letter-spacing: -.005em; }
.rai-reports .rpromo2-target { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .rpromo2-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 10px 0;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  margin-top: 4px;
}
.rai-reports .rpromo2-stats > div { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .rps-lbl { font: 700 8.5px var(--font-mono); letter-spacing: .08em; color: var(--fg-muted); }
.rai-reports .rps-val { font: 600 14px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .rpromo2-ai {
  display: flex; gap: 6px;
  padding-top: 6px;
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.5;
}
.rai-reports .rpromo2-ai svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.rai-reports .rops-table {
  display: grid;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .rops-cell {
  padding: 12px;
  border-bottom: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .rops-head {
  background: var(--surface-1);
  font: 700 9.5px var(--font-mono);
  letter-spacing: .1em;
  color: var(--fg-muted);
  text-align: center;
  display: flex; flex-direction: column; gap: 3px;
  align-items: center;
}
.rai-reports .rops-bench {
  font: 500 9.5px var(--font-mono);
  color: var(--fg-3);
  text-transform: none;
  letter-spacing: 0;
}
.rai-reports .rops-loc {
  background: var(--surface-page);
}
.rai-reports .rops-loc-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .rops-loc-city { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .rops-data {
  text-align: center;
  background: var(--surface-page);
}
.rai-reports .rops-pending {
  font: 500 18px var(--font-mono);
  color: var(--fg-muted);
}
.rai-reports .rops-deepdive {
  margin-top: 18px;
}
.rai-reports .rops-dd-head {
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-3);
  margin-bottom: 10px;
}
.rai-reports .rops-dd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.rai-reports .rops-dd-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}
.rai-reports .rops-dd-title {
  font: 600 13px var(--font-ui);
  color: var(--fg-1);
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rops-dd-items { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .rops-dd-item { display: flex; justify-content: space-between; font: 500 11.5px var(--font-ui); }
.rai-reports .rops-dd-lbl { color: var(--fg-3); }
.rai-reports .rops-dd-val { color: var(--fg-muted); font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .rsec-whatif {
  background: linear-gradient(135deg, var(--surface-1) 0%, rgba(251,95,44,.04) 100%);
}
.rai-reports .rwi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 10px;
}
.rai-reports .rwi-controls {
  display: flex; flex-direction: column; gap: 14px;
  padding: 18px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .rwi-slider { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .rws-head {
  display: flex; align-items: baseline; justify-content: space-between;
}
.rai-reports .rws-lbl { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .rws-val {
  font: 600 18px var(--font-mono);
  color: var(--brand);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
}
.rai-reports .rwi-slider input[type="range"] {
  width: 100%; accent-color: var(--brand);
  height: 4px;
}
.rai-reports .rws-help { font: 400 10.5px var(--font-ui); color: var(--fg-muted); font-style: italic; }
.rai-reports .rwi-reset {
  margin-top: 6px;
  align-self: flex-start;
  padding: 5px 10px;
}
.rai-reports .rwi-result {
  padding: 18px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  display: flex; flex-direction: column; gap: 14px;
}
.rai-reports .rwi-impact {
  text-align: center;
  padding: 14px 16px;
  background: linear-gradient(135deg, var(--brand-soft) 0%, transparent 100%);
  border: 1px solid rgba(251,95,44,.18);
  border-radius: var(--radius-md);
}
.rai-reports .rwi-imp-lbl {
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-3);
}
.rai-reports .rwi-imp-val {
  font: 600 34px var(--font-mono);
  letter-spacing: -.025em;
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
}
.rai-reports .rwi-imp-val.up { color: var(--success); }
.rai-reports .rwi-imp-val.down { color: var(--danger); }
.rai-reports .rwi-imp-pct {
  font: 500 12px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rwi-compare {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.rai-reports .rwi-col { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rwic-head {
  font: 700 10px var(--font-mono);
  letter-spacing: .12em;
  color: var(--fg-3);
  padding-bottom: 6px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rwic-row {
  display: flex; justify-content: space-between;
  font: 500 11.5px var(--font-mono);
  font-variant-numeric: tabular-nums;
  padding: 4px 0;
}
.rai-reports .rwic-row > span:first-child { color: var(--fg-3); font-family: var(--font-ui); font-weight: 500; }
.rai-reports .rwic-row > span:last-child { color: var(--fg-1); }
.rai-reports .rwic-final { padding-top: 8px; border-top: 1px solid var(--divider); font-weight: 700; }
.rai-reports .rwi-col-new .rwic-row > span:last-child { color: var(--fg-1); }
.rai-reports .rsec-exec {
  background: linear-gradient(135deg, var(--surface-1) 0%, rgba(108,169,242,.04) 100%);
}
.rai-reports .rexec-heroes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 18px 0;
  padding: 18px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .rexec-hero { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .reh-val {
  font: 600 30px var(--font-mono);
  letter-spacing: -.022em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .reh-lbl {
  font: 700 9.5px var(--font-mono);
  letter-spacing: .14em;
  color: var(--fg-muted);
}
.rai-reports .reh-delta {
  font: 600 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .reh-delta.up { color: var(--success); }
.rai-reports .reh-delta.down { color: var(--danger); }
.rai-reports .rexec-wins {
  padding: 18px 22px;
  background: var(--success-bg);
  border: 1px solid rgba(79,180,119,.3);
  border-radius: var(--radius-md);
}
.rai-reports .rexec-wins-head {
  display: flex; align-items: center; gap: 8px;
  font: 700 11px var(--font-mono);
  letter-spacing: .12em;
  color: var(--success);
  margin-bottom: 10px;
}
.rai-reports .rexec-wins-list {
  margin: 0; padding: 0;
  list-style: none;
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .rexec-wins-list li {
  font: 400 13px var(--font-ui);
  color: var(--fg-1);
  line-height: 1.55;
}
.rai-reports .rexec-wins-list li strong { color: var(--success); margin-right: 4px; font-weight: 700; }
.rai-reports .reports-shell {
  display: flex; flex-direction: column;
  min-height: calc(100vh - 56px);
  margin: 0;
  padding: 0;
}
.rai-reports .reports-actionbar {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 22px 28px 18px;
  gap: 20px;
  border-bottom: 1px solid var(--border-default);
  background: var(--surface-page);
}
.rai-reports .reports-actionbar h1 {
  font: 600 24px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.014em;
  margin: 0;
}
.rai-reports .reports-actionbar .sub {
  font: 400 12.5px var(--font-ui);
  color: var(--fg-3);
  margin: 0;
}
.rai-reports .reports-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.rai-reports .reports-body {
  display: grid;
  grid-template-columns: 300px 1fr;
  flex: 1;
  min-height: 0;
}
.rai-reports .reports-rail {
  background: var(--surface-1);
  border-right: 1px solid var(--border-default);
  padding: 18px 16px 22px;
  overflow-y: auto;
}
.rai-reports .rrail-section {
  display: flex; flex-direction: column; gap: 8px;
  padding-bottom: 18px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rrail-section:last-of-type { border-bottom: 0; }
.rai-reports .rrail-label {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .rrail-clients { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rrail-client {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  color: var(--fg-2);
  transition: all var(--dur-fast) var(--ease-out);
  text-align: left;
  width: 100%;
}
.rai-reports .rrail-client:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rrail-client.on {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.2);
}
.rai-reports .rrail-client svg { color: var(--brand); flex-shrink: 0; }
.rai-reports .rrail-client .client-mark {
  width: 28px; height: 28px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .rc-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .rc-on .rc-name { color: var(--brand); }
.rai-reports .rc-meta { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .rrail-select {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: 8px;
  color: var(--fg-1);
  padding: 8px 12px;
  font: 500 12.5px var(--font-ui);
  cursor: pointer;
  outline: none;
}
.rai-reports .rrail-select:focus { border-color: var(--brand); }
.rai-reports .rrail-sections { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rrail-checkbox {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .rrail-checkbox:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rrail-checkbox.locked { opacity: 0.7; cursor: default; }
.rai-reports .rrail-checkbox.locked:hover { background: transparent; }
.rai-reports .rrail-checkbox input { margin: 0; accent-color: var(--brand); }
.rai-reports .rrail-checkbox > span { flex: 1; }
.rai-reports .rrail-locked {
  font: 600 9px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--fg-muted);
}
.rai-reports .rrail-seg.seg { width: 100%; }
.rai-reports .rrail-seg.seg button { flex: 1; }
.rai-reports .rrail-tip {
  display: flex; gap: 8px;
  padding: 10px 12px;
  background: var(--brand-soft);
  border: 1px solid rgba(251,95,44,.18);
  border-radius: 8px;
  font: 400 11px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.45;
}
.rai-reports .rrail-tip svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.rai-reports .reports-preview {
  background: var(--ink-50);
  padding: 24px 32px 60px;
  overflow-y: auto;
}
.rai-reports .rprev-meta {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 14px;
  padding: 0 4px;
}
.rai-reports .rprev-meta-lbl {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-muted);
}
.rai-reports .rprev-meta-pages {
  font: 500 11px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rdoc {
  max-width: 820px;
  margin: 0 auto;
  display: flex; flex-direction: column;
  gap: 16px;
}
.rai-reports .rsec {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  padding: 34px 38px;
  position: relative;
}
.rai-reports .rsec-eyebrow {
  position: absolute; top: 24px; right: 28px;
  font: 700 9.5px var(--font-mono);
  color: var(--fg-muted);
  letter-spacing: .12em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rsec-title {
  font: 600 22px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.018em;
  margin: 0 0 12px;
}
.rai-reports .rsec-lead {
  font: 400 14px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.6;
  margin: 0 0 20px;
  max-width: 720px;
}
.rai-reports .rsec-cover {
  min-height: 360px;
  display: flex; flex-direction: column; justify-content: space-between;
  border: 1px solid var(--border-default);
}
.rai-reports .cov-brand {
  display: flex; align-items: center; gap: 14px;
}
.rai-reports .cov-mark {
  width: 56px; height: 56px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font: 700 24px var(--font-ui);
  color: white;
  letter-spacing: -.01em;
  box-shadow: 0 12px 28px -10px rgba(0,0,0,.5);
}
.rai-reports .cov-overline {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--fg-2);
}
.rai-reports .cov-title-block { padding: 60px 0 30px; }
.rai-reports .cov-title-eyebrow {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
  margin-bottom: 12px;
}
.rai-reports .cov-title {
  font: 600 64px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.028em;
  line-height: 1.0;
  margin: 0;
  font-style: italic;
}
.rai-reports .cov-subtitle {
  font: 400 16px var(--font-ui);
  color: var(--fg-2);
  margin-top: 16px;
}
.rai-reports .cov-foot {
  display: flex; gap: 60px;
  padding-top: 24px;
  border-top: 1px solid var(--border-subtle);
}
.rai-reports .cov-foot-block { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .cov-foot-lbl {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .cov-foot-val {
  font: 500 13px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rsec-headline-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rsec-hk { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rsec-hk-dot { width: 10px; height: 10px; border-radius: 3px; }
.rai-reports .rsec-hk-lbl {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
}
.rai-reports .rsec-hk-val {
  font: 600 22px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.018em;
}
.rai-reports .rsec-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .rkpi {
  padding: 18px 18px 16px;
  background: var(--surface-page);
  border-right: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .rkpi:nth-child(3n) { border-right: 0; }
.rai-reports .rkpi:nth-last-child(-n+3) { border-bottom: 0; }
.rai-reports .rkpi-lbl {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
  display: flex; align-items: center; gap: 6px;
}
.rai-reports .rkpi-dot { width: 7px; height: 7px; border-radius: 50%; }
.rai-reports .rkpi-val {
  font: 600 26px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rkpi-foot {
  display: flex; gap: 6px; align-items: baseline;
  font: 500 10.5px var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rkpi-delta.up { color: var(--success); font-weight: 600; }
.rai-reports .rkpi-delta.down { color: var(--danger); font-weight: 600; }
.rai-reports .rkpi-delta.neutral { color: var(--fg-3); }
.rai-reports .rkpi-vs { color: var(--fg-muted); }
.rai-reports .rkpi-spark { margin-top: 4px; }
.rai-reports .rsec-chart-legend {
  display: flex; gap: 16px;
  padding-top: 12px;
  font: 500 11.5px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .rsec-chart-legend > span { display: inline-flex; align-items: center; gap: 6px; }
.rai-reports .rcl-dot { width: 10px; height: 10px; border-radius: 2px; }
.rai-reports .rcl-line {
  display: inline-block; width: 16px; height: 2px;
  border-radius: 999px;
}
.rai-reports .rpnl-table {
  display: grid;
  grid-template-columns: 1.8fr 110px 70px 1fr;
  gap: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .rpnl-row { display: contents; }
.rai-reports .rpnl-row > div {
  padding: 10px 14px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .rpnl-row.is-sub > div { background: var(--surface-page); color: var(--fg-1); }
.rai-reports .rpnl-row.is-final > div { background: rgba(79,180,119,.08); color: var(--fg-1); }
.rai-reports .rpnl-row:first-child > div { border-top: 0; }
.rai-reports .rpnl-val, .rai-reports .rpnl-pct {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.rai-reports .rpnl-bar { padding: 10px 14px; }
.rai-reports .rpnl-bar-fill {
  display: block;
  height: 6px;
  border-radius: 999px;
}
.rai-reports .rsec-mkt-grid {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 20px;
  align-items: center;
}
.rai-reports .rsec-mkt-hero {
  display: flex; flex-direction: column; gap: 18px;
}
.rai-reports .rmh-lbl {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .rmh-val {
  font: 600 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.rai-reports .rmh-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 3px; }
.rai-reports .rsec-promos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.rai-reports .rpromo {
  padding: 14px 14px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .rpromo-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  margin-bottom: 8px;
}
.rai-reports .rpromo-loc {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .rpromo-title {
  font: 600 13.5px var(--font-ui);
  color: var(--fg-1);
  margin-bottom: 8px;
}
.rai-reports .rpromo-ai {
  display: flex; gap: 6px;
  padding-top: 8px;
  border-top: 1px dashed var(--border-default);
  font: 400 11.5px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
}
.rai-reports .rpromo-ai svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.rai-reports .rsec-twoup {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.rai-reports .rwlist { display: flex; flex-direction: column; gap: 12px; }
.rai-reports .rwitem {
  display: flex; gap: 10px;
  padding: 10px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .rwi-check, .rai-reports .rwi-flag {
  width: 22px; height: 22px;
  border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .rwi-check { background: var(--success-bg); color: var(--success); }
.rai-reports .rwi-flag { background: var(--warning-bg); color: var(--warning); }
.rai-reports .rwi-title { font: 600 13px var(--font-ui); color: var(--fg-1); margin-bottom: 2px; }
.rai-reports .rwi-desc { font: 400 12px var(--font-ui); color: var(--fg-3); line-height: 1.5; }
.rai-reports .rplan-list { display: flex; flex-direction: column; gap: 10px; }
.rai-reports .rplan-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  padding: 14px 16px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .rplan-item.tag-priority { border-left: 3px solid var(--danger); }
.rai-reports .rplan-item.tag-opportunity { border-left: 3px solid var(--brand); }
.rai-reports .rplan-item.tag-standard { border-left: 3px solid var(--ink-400); }
.rai-reports .rplan-num {
  font: 700 13px var(--font-mono);
  color: var(--fg-3);
  background: var(--surface-2);
  border-radius: 6px;
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rplan-head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 4px;
}
.rai-reports .rplan-title { font: 600 13.5px var(--font-ui); color: var(--fg-1); }
.rai-reports .rplan-tag {
  font: 700 9px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 2px 7px;
  border-radius: 999px;
}
.rai-reports .rplan-tag.tag-priority { background: var(--danger-bg); color: var(--danger); }
.rai-reports .rplan-tag.tag-opportunity { background: var(--brand-soft); color: var(--brand); }
.rai-reports .rplan-tag.tag-standard { background: var(--surface-2); color: var(--fg-3); }
.rai-reports .rplan-desc { font: 400 12px var(--font-ui); color: var(--fg-3); line-height: 1.5; }
.rai-reports .rsec-footer {
  background: linear-gradient(135deg, var(--surface-1) 0%, var(--ink-150) 100%);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 28px;
  align-items: center;
  padding: 24px 38px;
}
.rai-reports .rfoot-mark { display: flex; align-items: center; gap: 12px; }
.rai-reports .rfoot-mark img { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; }
.rai-reports .rfoot-brand { font: 700 14px var(--font-ui); color: var(--fg-1); letter-spacing: -.01em; }
.rai-reports .rfoot-sub { font: 500 10.5px var(--font-mono); color: var(--fg-3); margin-top: 1px; }
.rai-reports .rfoot-contact { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rfoot-contact-row {
  display: flex; gap: 10px;
  font: 500 11px var(--font-ui);
  font-variant-numeric: tabular-nums;
  font-family: var(--font-mono);
}
.rai-reports .rfc-lbl {
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 9.5px;
  width: 100px;
}
.rai-reports .rfc-val { color: var(--fg-1); }
.rai-reports .rfoot-note {
  font: 400 10.5px var(--font-ui);
  color: var(--fg-muted);
  font-style: italic;
  line-height: 1.5;
  max-width: 280px;
  text-align: right;
}
.rai-reports .rsec-empty {
  display: flex; align-items: center; gap: 10px;
  padding: 20px 0;
  font: 500 12.5px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .rsec-empty svg { color: var(--fg-muted); flex-shrink: 0; }
.rai-reports .page:has(.reports-shell) { padding: 0; max-width: none; }
.rai-reports .cust-controls {
  display: flex; align-items: center; gap: 14px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.rai-reports .cust-search {
  position: relative;
  flex: 1; min-width: 280px;
  max-width: 460px;
}
.rai-reports .cust-search svg {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--fg-muted);
}
.rai-reports .cust-search input {
  width: 100%; box-sizing: border-box;
  padding: 10px 32px 10px 34px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 8px;
  color: var(--fg-1);
  font: 400 13px var(--font-ui);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.rai-reports .cust-search input:focus { border-color: var(--brand); }
.rai-reports .cust-search input::placeholder { color: var(--fg-3); }
.rai-reports .cust-search-clear {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  background: var(--surface-3);
  border: 0;
  color: var(--fg-2);
  width: 20px; height: 20px;
  border-radius: 50%;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.rai-reports .cust-search-clear:hover { background: var(--surface-hover); color: var(--fg-1); }
.rai-reports .cust2-table {
  display: grid;
  grid-template-columns: 36px 1.8fr 90px 60px 90px 110px 90px 110px 130px;
  width: 100%;
}
.rai-reports .cust2-row { display: contents; }
.rai-reports .cust2-row > div {
  padding: 14px 12px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .cust2-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.rai-reports .cust2-row.cust2-head > div {
  border-top: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding-top: 12px; padding-bottom: 12px;
}
.rai-reports .cust2-row.cust2-data { cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.rai-reports .cust2-row.cust2-data:hover > div { background: var(--surface-2); }
.rai-reports .cust2-row.cust2-data.expanded > div {
  background: var(--brand-soft);
  border-bottom: 1px solid rgba(251,95,44,.18);
}
.rai-reports .cust2-chev { color: var(--fg-3); justify-content: center; transition: transform var(--dur-fast) var(--ease-out); }
.rai-reports .cust2-row.cust2-data.expanded .cust2-chev { color: var(--brand); }
.rai-reports .cust2-row.cust2-data:not(.expanded) .cust2-chev svg { transform: rotate(-90deg); }
.rai-reports .cust2-client { display: flex; align-items: center; gap: 12px; }
.rai-reports .cust2-client .client-mark {
  width: 30px; height: 30px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .cust2-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .cust2-sub { font: 400 10.5px var(--font-mono); color: var(--fg-3); margin-top: 1px; font-variant-numeric: tabular-nums; }
.rai-reports .health-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 9px 4px 8px;
  border-radius: 999px;
  font: 600 11px var(--font-ui);
  letter-spacing: -.005em;
}
.rai-reports .health-badge .hb-dot { width: 6px; height: 6px; border-radius: 50%; }
.rai-reports .health-badge .hb-score {
  font: 600 10px var(--font-mono);
  font-variant-numeric: tabular-nums;
  background: rgba(255,255,255,.08);
  padding: 1px 6px;
  border-radius: 999px;
  margin-left: 2px;
  opacity: 0.85;
}
.rai-reports .cust2-detail {
  grid-column: 1 / -1;
  background: var(--surface-page);
  padding: 20px 22px 22px;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.rai-reports .cdetail-card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .cdetail-card-head {
  padding: 11px 16px;
  border-bottom: 1px solid var(--divider);
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px;
  background: var(--surface-page);
}
.rai-reports .cdetail-eyebrow {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .cdetail-meta {
  font: 500 11px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .cdetail-padded { padding: 14px 16px 16px; }
.rai-reports .loc-mini-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  padding: 12px 14px 14px;
}
.rai-reports .loc-mini {
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 12px 12px 10px;
}
.rai-reports .lmini-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 10px; }
.rai-reports .lmini-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .lmini-city { font: 400 10.5px var(--font-mono); color: var(--fg-3); margin-top: 1px; }
.rai-reports .lmini-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px 12px;
}
.rai-reports .lmini-stat { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .ls-lbl {
  font: 600 8.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-muted);
}
.rai-reports .ls-val {
  font: 500 17px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  letter-spacing: -.01em;
}
.rai-reports .ls-delta {
  font: 500 10px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .ls-delta.up { color: var(--success); }
.rai-reports .ls-delta.down { color: var(--danger); }
.rai-reports .ls-delta.muted { color: var(--fg-muted); }
.rai-reports .cdetail-bignum {
  display: flex; flex-direction: column; gap: 2px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .cb-val {
  font: 600 30px var(--font-mono);
  color: var(--success);
  letter-spacing: -.02em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rai-reports .cb-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .cdetail-grid2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--divider);
}
.rai-reports .cdetail-grid2 > div { display: flex; flex-direction: column; gap: 2px; }
.rai-reports .health-hero {
  display: flex; align-items: center; gap: 16px;
  padding-bottom: 14px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .health-drivers { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .health-driver {
  display: grid; grid-template-columns: 78px 1fr 50px;
  align-items: center; gap: 10px;
}
.rai-reports .hd-lbl { font: 500 11px var(--font-ui); color: var(--fg-2); }
.rai-reports .hd-bar {
  height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
}
.rai-reports .hd-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand) 0%, var(--brand) 100%);
  border-radius: 999px;
}
.rai-reports .hd-val {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.rai-reports .campaign-mini-list { display: flex; flex-direction: column; gap: 0; }
.rai-reports .cmini-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--divider);
  font: 400 12px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .cmini-row:last-child { border-bottom: 0; }
.rai-reports .cmini-title { flex: 1; color: var(--fg-1); font-weight: 500; }
.rai-reports .cmini-loc {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .cmini-more {
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  padding: 8px 0 4px;
  font-style: italic;
}
.rai-reports .cmini-cta {
  margin-top: 8px;
  padding: 6px 10px;
  font: 500 12px var(--font-ui);
  color: var(--brand);
}
.rai-reports .cmini-cta:hover { background: var(--brand-soft); }
.rai-reports .cmini-cta svg { color: var(--brand); }
.rai-reports .activity-list { display: flex; flex-direction: column; gap: 0; }
.rai-reports .activity-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  gap: 12px;
}
.rai-reports .activity-item:last-child { border-bottom: 0; }
.rai-reports .ai-lbl { color: var(--fg-3); }
.rai-reports .ai-val { color: var(--fg-1); font-weight: 500; text-align: right; }
.rai-reports .ai-val.muted {
  color: var(--fg-muted);
  font-style: italic;
  font-weight: 400;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 11.5px;
}
.rai-reports .cdetail-empty {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 8px 0;
}
.rai-reports .cdetail-empty svg { color: var(--fg-muted); flex-shrink: 0; margin-top: 2px; }
.rai-reports .cdetail-actions .cdetail-padded { padding: 12px 14px 14px; }
.rai-reports .qa-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  color: var(--fg-2);
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .qa-btn:hover {
  background: var(--surface-2);
  border-color: var(--border-default);
  color: var(--fg-1);
}
.rai-reports .qa-btn.qa-primary {
  background: var(--brand-soft);
  border-color: rgba(251,95,44,.18);
}
.rai-reports .qa-btn.qa-primary svg { color: var(--brand); }
.rai-reports .qa-btn.qa-primary:hover { background: rgba(251,95,44,.16); }
.rai-reports .qa-btn > span:nth-child(2) {
  flex: 1;
  display: flex; flex-direction: column; gap: 1px;
}
.rai-reports .qa-title { font: 600 12.5px var(--font-ui); color: var(--fg-1); }
.rai-reports .qa-sub { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .qa-btn.qa-primary .qa-title { color: var(--brand); }
.rai-reports .qa-btn svg:first-child { color: var(--fg-muted); }
.rai-reports .qa-btn.qa-primary svg:first-child { color: var(--brand); }
.rai-reports .qa-btn > svg:last-child { color: var(--fg-muted); opacity: 0.6; }
.rai-reports .promo-group {
  border-top: 1px solid var(--divider);
}
.rai-reports .promo-group:first-of-type { border-top: 0; }
.rai-reports .promo-group-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  background: var(--surface-page);
  border-bottom: 1px solid var(--divider);
}
.rai-reports .pgh-name { display: flex; align-items: center; gap: 12px; }
.rai-reports .pgh-name .client-mark {
  width: 30px; height: 30px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-ui);
}
.rai-reports .pgh-name .pgh-title {
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .pgh-name .pgh-sub {
  font: 400 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .promo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  padding: 14px 20px 20px;
}
.rai-reports .promo-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 14px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}
.rai-reports .promo-card .promo-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  margin-bottom: 2px;
}
.rai-reports .promo-card .promo-type {
  font: 700 9.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 7px;
  border-radius: 4px;
  background: var(--surface-3);
  color: var(--fg-2);
}
.rai-reports .promo-card .promo-type.type-bogo {
  background: rgba(108,169,242,.14);
  color: #6CA9F2;
}
.rai-reports .promo-card .promo-type.type-spend {
  background: rgba(244,169,58,.14);
  color: #F4A93A;
}
.rai-reports .promo-card .promo-loc {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .promo-card .promo-title {
  font: 600 13.5px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .promo-card .promo-meta {
  font: 400 11.5px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .promo-card .promo-meta .promo-target {
  color: var(--fg-muted);
  margin-left: 2px;
}
.rai-reports .promo-card .promo-ai {
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px dashed var(--border-default);
}
.rai-reports .promo-card .promo-ai-head {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 4px;
}
.rai-reports .promo-card .promo-ai-head svg { color: var(--brand); }
.rai-reports .promo-card .promo-ai-text {
  font: 400 11.5px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
}
.rai-reports .promo-tag {
  font: 700 9.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 2px 8px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .promo-tag.tg-ok { background: var(--success-bg); color: var(--success); }
.rai-reports .promo-tag.tg-info { background: rgba(108,169,242,.14); color: #6CA9F2; }
.rai-reports .promo-tag.tg-warn { background: var(--warning-bg); color: var(--warning); }
.rai-reports .promo-tag.tg-crit { background: var(--danger-bg);  color: var(--danger); }
.rai-reports .promo-empty {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px;
  background: var(--surface-page);
  border-top: 1px solid var(--divider);
  font: 500 12.5px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .promo-empty svg { color: var(--warning); flex-shrink: 0; }
.rai-reports .promo-empty strong { color: var(--fg-1); }
.rai-reports .promo-empty > span { flex: 1; }
.rai-reports .adrec-row {
  padding: 16px 22px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .adrec-row:last-child { border-bottom: 0; }
.rai-reports .adrec-name { margin-bottom: 12px; }
.rai-reports .adrec-loc {
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .adrec-cli {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rai-reports .adrec-figs {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 12px;
}
.rai-reports .adrec-figs svg { color: var(--fg-muted); flex-shrink: 0; }
.rai-reports .adrec-fig {
  display: flex; flex-direction: column; gap: 1px;
}
.rai-reports .adrec-fig .af-lbl {
  font: 600 9px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
}
.rai-reports .adrec-fig .af-val {
  font: 600 18px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
  display: flex; align-items: baseline; gap: 4px;
}
.rai-reports .adrec-fig .af-val.af-lift { color: var(--success); }
.rai-reports .adrec-fig .af-val .af-unit {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  font-weight: 400;
}
.rai-reports .adrec-fig:last-child {
  margin-left: auto;
  text-align: right;
  align-items: flex-end;
}
.rai-reports .adrec-fig:last-child .af-val { font-weight: 600; }
.rai-reports .adrec-ai {
  padding-top: 10px;
  border-top: 1px dashed var(--border-default);
}
.rai-reports .adrec-ai-head { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.rai-reports .adrec-ai-head svg { color: var(--brand); }
.rai-reports .adrec-ai-text {
  font: 400 12px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
}
.rai-reports .q2-row {
  padding: 16px 22px;
  border-top: 1px solid var(--divider);
}
.rai-reports .q2-row:first-of-type { border-top: 0; }
.rai-reports .q2-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.rai-reports .q2-title {
  font: 600 14px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .q2-timing {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.rai-reports .q2-tag {
  flex-shrink: 0;
  font: 700 9.5px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--brand-soft);
  color: var(--brand);
}
.rai-reports .q2-sum {
  font: 400 12px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
  margin-bottom: 8px;
}
.rai-reports .q2-perks {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin-bottom: 10px;
}
.rai-reports .q2-perk {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-2);
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  padding: 2px 8px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .q2-ai {
  display: flex; align-items: flex-start; gap: 6px;
  padding-top: 8px;
  border-top: 1px dashed var(--border-default);
  font: 400 11.5px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
}
.rai-reports .q2-ai svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.rai-reports .q2-ai strong { color: var(--brand); font-weight: 600; }
.rai-reports .mkt-legend {
  display: flex; flex-wrap: wrap; gap: 18px;
  padding-top: 14px; margin-top: 6px;
  border-top: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .ml-item { display: inline-flex; align-items: center; gap: 8px; }
.rai-reports .ml-dot { width: 10px; height: 10px; border-radius: 2px; }
.rai-reports .ml-line {
  display: inline-block; width: 18px; height: 0;
  border-top: 2px dashed #4FB477;
}
.rai-reports .ml-val {
  font: 600 12px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  margin-left: 2px;
}
.rai-reports .mkteff-table {
  display: grid;
  grid-template-columns: 1.6fr 90px 100px 70px 80px 100px 110px 1fr;
  width: 100%;
}
.rai-reports .me-row { display: contents; }
.rai-reports .me-row > div {
  padding: 12px 12px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .me-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.rai-reports .me-row.me-head > div {
  border-top: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding-top: 12px; padding-bottom: 12px;
}
.rai-reports .me-name { display: flex; align-items: center; gap: 10px; }
.rai-reports .me-name .mk-dot {
  width: 10px; height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.rai-reports .me-name .mn { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .me-name .ms { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .me-band {
  width: 100%;
  height: 8px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
}
.rai-reports .me-band-fill {
  height: 100%;
  border-radius: 999px;
  transition: width var(--dur-base) var(--ease-out);
}
.rai-reports .me-band-fill.ok { background: linear-gradient(90deg, #4FB477, #2F9D5F); }
.rai-reports .me-band-fill.warn { background: linear-gradient(90deg, #F4A93A, #DC8E1C); }
.rai-reports .me-band-fill.crit { background: linear-gradient(90deg, #F26B5C, #E04A38); }
.rai-reports .dp-legend {
  display: flex; gap: 16px;
  padding-bottom: 14px;
  margin-bottom: 6px;
  border-bottom: 1px solid var(--divider);
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .dp-le { display: inline-flex; align-items: center; gap: 6px; }
.rai-reports .dp-sw { width: 10px; height: 8px; border-radius: 2px; }
.rai-reports .dp-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--divider);
  align-items: center;
}
.rai-reports .dp-row:last-child { border-bottom: none; }
.rai-reports .dp-name .dp-n { font: 500 12.5px var(--font-ui); color: var(--fg-1); }
.rai-reports .dp-name .dp-s { font: 400 10.5px var(--font-mono); color: var(--fg-3); margin-top: 1px; }
.rai-reports .dp-bar {
  position: relative;
  height: 28px;
  background: var(--surface-3);
  border-radius: 6px;
  overflow: hidden;
  display: flex;
}
.rai-reports .dp-bar-del { background: var(--brand); height: 100%; }
.rai-reports .dp-bar-pick { background: #998973; height: 100%; opacity: 0.7; }
.rai-reports .dp-bar-val {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  font: 600 11px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 1px 4px rgba(0,0,0,.4);
  letter-spacing: -.005em;
}
.rai-reports .ops-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 6px;
}
@media (max-width: 1100px) {
.rai-reports .ops-grid { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .ops-card { opacity: 0.92; }
.rai-reports .ops-card h3 { color: var(--fg-2); font-weight: 500; }
.rai-reports .ops-badge {
  font: 600 9px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--fg-muted);
  background: var(--surface-2);
  border: 1px dashed var(--border-default);
  padding: 2px 7px;
  border-radius: 999px;
  margin-left: 4px;
}
.rai-reports .ops-big {
  display: flex; align-items: baseline; gap: 4px;
  padding-top: 8px;
}
.rai-reports .ops-val {
  font: 500 38px var(--font-mono);
  color: var(--fg-3);
  letter-spacing: -.02em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rai-reports .ops-unit {
  font: 500 14px var(--font-mono);
  color: var(--fg-muted);
}
.rai-reports .ops-sub {
  font: 400 11.5px var(--font-ui);
  color: var(--fg-3);
  margin-top: 6px;
}
.rai-reports .ops-bench {
  margin-top: 10px;
  font: 500 10.5px var(--font-mono);
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .ops-breakdown { display: flex; flex-direction: column; gap: 10px; padding-top: 8px; }
.rai-reports .ops-br-row { display: grid; grid-template-columns: 130px 1fr 40px; align-items: center; gap: 10px; }
.rai-reports .ops-br-lbl { font: 500 11.5px var(--font-ui); color: var(--fg-3); }
.rai-reports .ops-br-bar { height: 6px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .ops-br-fill.ghost {
  height: 100%;
  width: 30%;
  background: repeating-linear-gradient(
    -45deg,
    var(--surface-3),
    var(--surface-3) 3px,
    var(--ink-300) 3px,
    var(--ink-300) 6px
  );
  border-radius: 999px;
}
.rai-reports .ops-br-val { font: 500 11px var(--font-mono); color: var(--fg-muted); font-variant-numeric: tabular-nums; text-align: right; }
.rai-reports .ops-list { display: flex; flex-direction: column; gap: 0; padding-top: 4px; }
.rai-reports .ops-li {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--divider);
  font: 500 12px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .ops-li:last-child { border-bottom: 0; }
.rai-reports .ops-li-v {
  font: 500 12px var(--font-mono);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}
.rai-reports .ops-cta {
  margin-top: 18px;
  padding: 16px 22px;
  background: var(--surface-1);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px;
}
.rai-reports .minfo { position: relative; display: inline-flex; align-items: center; margin-left: 6px; vertical-align: middle; }
.rai-reports .minfo-trigger {
  background: transparent;
  border: 0;
  padding: 2px;
  cursor: pointer;
  color: var(--fg-muted);
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .minfo-trigger:hover { color: var(--brand); background: var(--brand-soft); }
.rai-reports .minfo-trigger svg { display: block; }
.rai-reports .minfo-pop {
  /* position:fixed → JS positions it from the trigger rect; no card overflow clips it. */
  position: fixed;
  top: 0; left: 0;
  width: 320px;
  /* Never run past the viewport on narrow screens / triggers near an edge. */
  max-width: min(320px, calc(100vw - 24px));
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  box-shadow: 0 18px 44px rgba(0,0,0,.38), 0 2px 8px rgba(0,0,0,.2);
  padding: 0;
  /* Sit above sibling cards / sticky section headers when un-clipped. */
  z-index: 600;
  /* Wrap long definitions instead of forcing the box wider than its max. */
  overflow-wrap: anywhere;
  word-break: break-word;
  animation: minfo-in 140ms cubic-bezier(.2,.8,.2,1);
}
/* alignment is now driven by JS (position:fixed sets inline left/top) — keep
   left/right auto so the stylesheet never fights the JS-computed left. */
.rai-reports .minfo-pop.align-left,
.rai-reports .minfo-pop.align-right { left: auto; right: auto; }
@keyframes minfo-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* (The old :has() overflow-relaxation hack is gone — the popover is now
   position:fixed + JS-positioned, so no ancestor's overflow:hidden can clip it,
   and cards keep their normal clipping with no layout side-effects.) */
.rai-reports .minfo-head {
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--divider);
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.rai-reports .minfo-title {
  font: 600 13.5px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .minfo-close {
  background: transparent;
  border: 0;
  color: var(--fg-muted);
  cursor: pointer;
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 5px;
  padding: 0;
}
.rai-reports .minfo-close:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .minfo-body { padding: 12px 16px 14px; }
.rai-reports .minfo-def {
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
  margin: 0 0 12px;
  line-height: 1.5;
}
.rai-reports .minfo-formula {
  display: flex; flex-direction: column; gap: 4px;
  margin-bottom: 12px;
}
.rai-reports .minfo-formula-lbl {
  font: 600 9px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-muted);
}
.rai-reports .minfo-formula code {
  font: 500 11.5px var(--font-mono);
  color: var(--fg-1);
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 6px 10px;
  font-variant-numeric: tabular-nums;
  display: inline-block;
  align-self: flex-start;
}
.rai-reports .minfo-bench {
  display: flex; flex-wrap: wrap; gap: 6px;
  align-items: center;
}
.rai-reports .minfo-bench .mb {
  font: 600 10px var(--font-mono);
  padding: 2px 8px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .minfo-bench .mb-ok { color: var(--success); background: var(--success-bg); }
.rai-reports .minfo-bench .mb-warn { color: var(--warning); background: var(--warning-bg); }
.rai-reports .minfo-bench .mb-crit { color: var(--danger);  background: var(--danger-bg); }
.rai-reports .minfo-bench .mb-label {
  font: 500 10.5px var(--font-ui);
  color: var(--fg-muted);
  font-style: italic;
}
.rai-reports .minfo-ai {
  display: flex; align-items: center; gap: 8px;
  width: calc(100% - 16px);
  margin: 0 8px 8px;
  padding: 9px 12px;
  background: var(--brand-soft);
  border: 1px solid rgba(251,95,44,.18);
  color: var(--brand);
  font: 600 12px var(--font-ui);
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .minfo-ai:hover { background: var(--brand); color: var(--fg-onbrand); border-color: var(--brand); }
.rai-reports .minfo-ai svg { flex-shrink: 0; }
.rai-reports .minfo-ai-arrow {
  margin-left: auto;
  font: 500 14px var(--font-mono);
  transition: transform var(--dur-fast) var(--ease-out);
}
.rai-reports .minfo-ai:hover .minfo-ai-arrow { transform: translateX(2px); }
.rai-reports .card-head h3 .minfo { font-weight: 400; }
.rai-reports .kpi .lbl .minfo { margin-left: 4px; }
.rai-reports .location-chips-row {
  display: flex; align-items: center; gap: 14px;
  margin-top: 10px;
  padding: 10px 14px;
  background: var(--surface-page);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .loc-chips-label {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
  white-space: nowrap;
}
.rai-reports .loc-chips-label svg { opacity: .6; }
.rai-reports .location-chips {
  display: flex; flex-wrap: wrap; gap: 5px;
  flex: 1;
}
.rai-reports .loc-chip-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--fg-2);
  font: 500 11.5px var(--font-ui);
  padding: 4px 10px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .loc-chip-btn:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .loc-chip-btn.on {
  background: var(--brand);
  border-color: var(--brand);
  color: var(--fg-onbrand);
}
.rai-reports .loc-chip-btn.clear {
  color: var(--fg-3);
  border-style: dashed;
}
.rai-reports .loc-chip-btn.clear:hover { color: var(--danger); border-color: var(--danger); }
.rai-reports .waterfall-wrap { width: 100%; }
.rai-reports .waterfall-foot {
  display: flex; flex-wrap: wrap; gap: 16px;
  padding-top: 16px; margin-top: 6px;
  border-top: 1px solid var(--divider);
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .wf-foot-item { display: inline-flex; align-items: center; gap: 7px; }
.rai-reports .wf-foot-dot { width: 10px; height: 10px; border-radius: 3px; }
.rai-reports .cascade-table {
  display: grid;
  grid-template-columns: 2fr 110px 90px 200px 80px;
  width: 100%;
}
.rai-reports .cascade-table.no-compare, .rai-reports .cas-row:not(.cas-head):has(:nth-child(5):empty) ~ * {}
.rai-reports .cas-row { display: contents; }
.rai-reports .cas-row > div {
  padding: 11px 14px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 13px var(--font-ui);
  color: var(--fg-1);
}
.rai-reports .cas-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .cas-row.cas-head > div {
  border-top: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding-top: 12px; padding-bottom: 12px;
}
.rai-reports .cas-row.is-final > div {
  background: linear-gradient(90deg, rgba(79,180,119,.06) 0%, transparent 80%);
  font-weight: 600;
}
.rai-reports .cas-row.is-subtotal > div {
  background: var(--surface-page);
}
.rai-reports .cas-bar {
  width: 100%; height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
}
.rai-reports .cas-bar-fill {
  height: 100%;
  border-radius: 999px;
}
.rai-reports .pnl-table {
  display: grid;
  grid-template-columns: 2fr 80px 80px 80px 70px 80px 80px 80px 80px 80px;
  width: 100%;
}
.rai-reports .pnl-row { display: contents; }
.rai-reports .pnl-row > div {
  padding: 12px 12px;
  border-top: 1px solid var(--divider);
  display: flex; align-items: center;
  font: 400 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .pnl-row > div.num {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.rai-reports .pnl-row.pnl-head > div {
  border-top: 0;
  border-bottom: 1px solid var(--divider);
  background: var(--surface-page);
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  padding-top: 12px; padding-bottom: 12px;
}
.rai-reports .pnl-row.pnl-client { cursor: pointer; }
.rai-reports .pnl-row.pnl-client:hover > div { background: var(--surface-2); }
.rai-reports .pnl-row.pnl-client.expanded > div { background: var(--brand-soft); }
.rai-reports .pnl-row.pnl-client.expanded > div.num { color: var(--fg-1); }
.rai-reports .pnl-row.pnl-loc > div {
  background: var(--surface-page);
  font-size: 12px;
}
.rai-reports .pnl-row.pnl-loc:hover > div { background: var(--surface-1); }
.rai-reports .client-cell {
  display: flex; align-items: center; gap: 10px;
}
.rai-reports .client-cell .chev {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px;
  color: var(--fg-3);
  transition: transform var(--dur-fast) var(--ease-out);
}
.rai-reports .pnl-row.pnl-client.expanded .chev { transform: rotate(0deg); color: var(--brand); }
.rai-reports .pnl-row.pnl-client:not(.expanded) .chev { transform: rotate(-90deg); }
.rai-reports .client-cell .client-mark {
  width: 26px; height: 26px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font: 700 11px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .client-cell .loc-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  color: var(--fg-muted);
  background: var(--surface-2);
  border-radius: 5px;
  flex-shrink: 0;
}
.rai-reports .client-cell .cn { font: 500 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .client-cell .cs { font: 400 10.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .takerate-hero {
  display: flex; flex-direction: column; gap: 4px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 16px;
}
.rai-reports .tr-val {
  font: 600 38px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--brand);
  letter-spacing: -.025em;
  line-height: 1;
}
.rai-reports .tr-sub { font: 400 12px var(--font-ui); color: var(--fg-3); }
.rai-reports .tr-breakdown { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.rai-reports .tr-row { display: flex; align-items: center; justify-content: space-between; }
.rai-reports .tr-label { display: inline-flex; align-items: center; gap: 8px; font: 500 12px var(--font-ui); color: var(--fg-2); }
.rai-reports .tr-dot { width: 8px; height: 8px; border-radius: 2px; }
.rai-reports .tr-pct { font: 500 12px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .tr-table { padding-top: 12px; border-top: 1px solid var(--divider); }
.rai-reports .tr-tbl-head {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
  margin-bottom: 10px;
}
.rai-reports .tr-tbl-row {
  display: grid;
  grid-template-columns: 1fr 70px 50px;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
}
.rai-reports .tr-tbl-name { display: inline-flex; align-items: center; gap: 8px; font: 500 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .tr-tbl-dot { width: 7px; height: 7px; border-radius: 2px; }
.rai-reports .tr-tbl-bar { height: 5px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .tr-tbl-fill { height: 100%; border-radius: 999px; }
.rai-reports .tr-tbl-val { font: 500 11.5px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; text-align: right; }
.rai-reports .cofund-hero { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .cf-val {
  font: 600 32px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--success);
  letter-spacing: -.02em;
  line-height: 1;
}
.rai-reports .cf-sub { font: 400 12px var(--font-ui); color: var(--fg-3); }
.rai-reports .cf-spark {
  margin: 16px 0;
  padding: 8px 0;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.rai-reports .cf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rai-reports .cf-cell { display: flex; flex-direction: column; gap: 3px; }
.rai-reports .cf-lbl { font: 600 9.5px var(--font-ui); text-transform: uppercase; letter-spacing: .08em; color: var(--fg-3); }
.rai-reports .cf-num { font: 500 18px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .cf-note {
  margin-top: 14px;
  font: 400 11px var(--font-ui);
  color: var(--fg-muted);
  font-style: italic;
}
.rai-reports .mc-stack {
  display: flex;
  height: 36px;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 18px;
}
.rai-reports .mc-seg { transition: opacity var(--dur-fast) var(--ease-out); }
.rai-reports .mc-seg:hover { opacity: 0.85; }
.rai-reports .mc-list { display: flex; flex-direction: column; gap: 0; }
.rai-reports .mc-row {
  display: grid;
  grid-template-columns: 1fr 90px 60px;
  align-items: center;
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .mc-row:last-child { border-bottom: 0; }
.rai-reports .mc-name { display: inline-flex; align-items: center; gap: 8px; font: 500 12.5px var(--font-ui); color: var(--fg-1); }
.rai-reports .mc-dot { width: 9px; height: 9px; border-radius: 2px; }
.rai-reports .mc-val { font: 500 12.5px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; text-align: right; }
.rai-reports .mc-pct { font: 600 11px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; text-align: right; }
[data-theme="light"] .rai-reports { background: var(--surface-page); }
[data-theme="light"] .rai-reports .topbar { background: rgba(248, 242, 231, 0.85); }
[data-theme="light"] .rai-reports .ai-strip { background: radial-gradient(800px 200px at 12% 0%, rgba(251,95,44,.06) 0%, transparent 60%), var(--surface-1); }

/* ===== reports.css (scoped) ===== */
.rai-reports .filter-band {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  margin-bottom: 14px;
}
@media (max-width: 1100px) {
.rai-reports .filter-band { grid-template-columns: 1fr; }
}
.rai-reports .fb-search {
  position: relative;
  display: flex; align-items: center;
}
.rai-reports .fb-search svg { position: absolute; left: 12px; color: var(--fg-muted); }
.rai-reports .fb-search input {
  width: 100%;
  padding: 10px 12px 10px 36px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  color: var(--fg-1);
  font: 500 13px var(--font-ui);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.rai-reports .fb-search input:focus { border-color: var(--brand); }
.rai-reports .fb-filters { display: flex; gap: 10px; }
.rai-reports .fb-sel {
  display: flex; align-items: center; gap: 8px;
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .fb-sel select {
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  padding: 7px 28px 7px 10px;
  color: var(--fg-1);
  font: 500 12px var(--font-ui);
  text-transform: none;
  letter-spacing: 0;
  outline: none;
  cursor: pointer;
  color-scheme: dark;
}
.rai-reports .fb-sel select:hover { border-color: var(--border-strong); }
.rai-reports .fb-sort { display: flex; align-items: center; gap: 10px; }
.rai-reports .results-meta {
  display: flex; align-items: center; gap: 12px;
  font: 500 12px var(--font-ui);
  color: var(--fg-3);
  margin-bottom: 12px;
  padding: 0 4px;
}
.rai-reports .results-clear {
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  font: 500 11px var(--font-ui);
  padding: 3px 9px;
  border-radius: 999px;
  cursor: pointer;
}
.rai-reports .results-clear:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .client-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
}
.rai-reports .cl-card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: 18px 18px 14px;
  cursor: pointer;
  display: flex; flex-direction: column;
  gap: 14px;
  transition: all var(--dur-fast) var(--ease-out);
  position: relative;
  overflow: hidden;
}
.rai-reports .cl-card:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px -14px rgba(251,95,44,.28), var(--shadow-md);
}
.rai-reports .cl-card-top {
  display: flex; align-items: center; gap: 12px;
}
.rai-reports .cl-mark {
  width: 38px; height: 38px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font: 600 16px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .cl-id { flex: 1; min-width: 0; }
.rai-reports .cl-name {
  font: 600 15px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.008em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rai-reports .cl-sub {
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  margin-top: 1px;
}
.rai-reports .cl-health {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--fg-2);
}
.rai-reports .cl-health-dot { width: 6px; height: 6px; border-radius: 50%; }
.rai-reports .cl-chips {
  display: flex; flex-wrap: wrap; gap: 5px;
}
.rai-reports .cl-chip {
  display: inline-flex; align-items: center; gap: 4px;
  font: 500 10px var(--font-ui);
  padding: 2px 8px;
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  letter-spacing: -.005em;
  white-space: nowrap;
}
.rai-reports .cl-chip-dot {
  width: 5px; height: 5px; border-radius: 50%;
  display: inline-block;
}
.rai-reports .cl-chip-more {
  background: var(--surface-2);
  color: var(--fg-3);
  border: 1px dashed var(--border-default);
}
.rai-reports .cl-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--divider);
}
.rai-reports .cl-m { display: flex; flex-direction: column; gap: 2px; }
.rai-reports .cl-m-l {
  font: 600 9px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--fg-3);
}
.rai-reports .cl-m-v {
  font: 500 17px var(--font-mono);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.rai-reports .cl-m-d {
  font: 500 10.5px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  display: inline-flex; align-items: center; gap: 3px;
}
.rai-reports .cl-m-d.up { color: var(--success); }
.rai-reports .cl-m-d.down { color: var(--danger); }
.rai-reports .cl-spark { height: 36px; }
.rai-reports .cl-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 10px;
  border-top: 1px solid var(--divider);
}
.rai-reports .cl-status {
  display: inline-flex; align-items: center; gap: 5px;
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .cl-status svg { color: inherit; }
.rai-reports .cl-status-sent { color: var(--success); }
.rai-reports .cl-status-scheduled { color: var(--info); }
.rai-reports .cl-status-pending { color: var(--warning); }
.rai-reports .cl-actions { display: flex; gap: 4px; }
.rai-reports .cl-btn {
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  color: var(--fg-2);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .cl-btn:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .report-page {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.rai-reports .rep-toolbar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  padding: 14px 28px;
  background: var(--surface-1);
  border-bottom: 1px solid var(--divider);
  position: sticky; top: 56px; z-index: 4;
  backdrop-filter: blur(12px);
  background: rgba(20, 17, 13, 0.92);
}
.rai-reports .rep-tb-left { display: flex; align-items: center; gap: 14px; }
.rai-reports .rep-tb-id { display: flex; align-items: center; gap: 10px; }
.rai-reports .rep-tb-mono {
  width: 34px; height: 34px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font: 600 14px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .rep-tb-name { font: 600 14px var(--font-ui); color: var(--fg-1); letter-spacing: -.008em; }
.rai-reports .rep-tb-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .rep-tb-mid { display: flex; gap: 8px; align-items: center; }
.rai-reports .rep-sel {
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 7px 26px 7px 12px;
  color: var(--fg-1);
  font: 500 12px var(--font-ui);
  outline: none;
  cursor: pointer;
  color-scheme: dark;
}
.rai-reports .rep-sel:hover { border-color: var(--border-strong); }
.rai-reports .rep-seg { padding: 2px; }
.rai-reports .rep-tb-right { display: flex; gap: 8px; justify-content: flex-end; align-items: center; }
.rai-reports .rep-live-strip {
  background: var(--surface-page);
  border-bottom: 1px solid var(--divider);
  position: sticky; top: 119px; z-index: 3;
}
.rai-reports .live-strip-inner {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 28px;
  font: 500 11.5px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 8px var(--success);
  animation: live-pulse 2s ease-in-out infinite;
}
@keyframes live-pulse { 0%, 100% { opacity: 1 } 50% { opacity: 0.5 } }
.rai-reports .live-lbl { font-weight: 600; color: var(--success); text-transform: uppercase; letter-spacing: .08em; font-size: 10px; }
.rai-reports .live-sep { color: var(--ink-300); }
.rai-reports .live-srcs { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.rai-reports .live-src {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  padding: 2px 8px 2px 6px;
  font: 500 10.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .live-src-dot { width: 5px; height: 5px; border-radius: 50%; }
.rai-reports .live-src-more {
  color: var(--fg-3);
  background: transparent;
  border: 1px dashed var(--border-default);
}
.rai-reports .live-btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  padding: 4px 9px;
  font: 600 10.5px var(--font-ui);
  color: var(--fg-2);
  cursor: pointer;
}
.rai-reports .live-btn:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .rep-doc {
  padding: 0 28px 80px;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}
.rai-reports .rep-doc.is-present {
  padding-top: 40px;
}
.rai-reports .rep-doc.is-present .rsec-wrap {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 60px;
}
.rai-reports .present-exit {
  position: fixed; top: 18px; right: 18px;
  z-index: 100;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 8px;
  padding: 8px 12px;
  font: 600 12px var(--font-ui);
  color: var(--fg-1);
  cursor: pointer;
  box-shadow: var(--shadow-lg);
}
.rai-reports .rcover {
  padding: 80px 0 60px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rcover-grid {
  max-width: 1100px;
  margin: 0 auto;
}
.rai-reports .rcover-eyebrow {
  display: flex; align-items: center; gap: 10px;
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
}
.rai-reports .rcover-sep { color: var(--ink-300); }
.rai-reports .rcover-internal {
  font: 600 10px var(--font-mono);
  background: var(--brand-soft);
  color: var(--brand);
  padding: 2px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.rai-reports .rcover-title {
  margin: 24px 0 16px;
  display: flex;
  align-items: baseline;
  gap: 16px;
  font-family: var(--font-ui);
  letter-spacing: -.04em;
  line-height: 0.92;
}
.rai-reports .rcover-month {
  font: 700 180px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.05em;
  line-height: 0.9;
}
.rai-reports .rcover-year {
  font: 200 180px var(--font-ui);
  color: var(--brand);
  font-style: italic;
  letter-spacing: -.04em;
  line-height: 0.9;
}
.rai-reports .rcover-tagline {
  font: 400 24px var(--font-ui);
  color: var(--fg-2);
  letter-spacing: -.015em;
  line-height: 1.35;
  max-width: 820px;
  margin: 20px 0 50px;
  text-wrap: pretty;
}
.rai-reports .rcover-tagline em {
  font-style: italic;
  color: var(--fg-1);
  font-weight: 500;
}
.rai-reports .rcover-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding: 28px 0;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rcover-meta-col { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .rc-k {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
}
.rai-reports .rc-v {
  font: 600 18px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.012em;
  margin-top: 2px;
}
.rai-reports .rc-s {
  font: 400 12px var(--font-ui);
  color: var(--fg-3);
  margin-top: 2px;
}
.rai-reports .rcover-stack {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 32px;
}
.rai-reports .rcover-loc {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 14px 16px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .rcover-loc-tag {
  font: 600 10px var(--font-mono);
  background: var(--brand-soft);
  color: var(--brand);
  padding: 3px 7px;
  border-radius: 5px;
  flex-shrink: 0;
}
.rai-reports .rcover-loc-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .rcover-loc-addr { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 2px; }
.rai-reports .rcover-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px solid var(--divider);
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .rcover-foot-l { display: flex; align-items: center; gap: 8px; }
.rai-reports .rcover-foot-r { display: inline-flex; align-items: center; gap: 6px; color: var(--fg-2); }
@media (max-width: 1100px) {
.rai-reports .rcover-month, .rai-reports .rcover-year { font-size: 120px; }
.rai-reports .rcover-meta { grid-template-columns: repeat(2, 1fr); }
.rai-reports .rcover-stack { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .rsec {
  padding: 60px 22px 44px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .anom-vs {
  margin-left: 6px;
  font-weight: 500;
  opacity: 0.62;
}
.rai-reports .rsh {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 24px;
  align-items: flex-start;
  margin-bottom: 8px;
}
.rai-reports .rsh-left .rsh-num {
  font: 700 60px var(--font-ui);
  color: var(--brand);
  letter-spacing: -.04em;
  line-height: 0.85;
}
.rai-reports .rsh-right { padding-top: 4px; }
.rai-reports .rsh-eyebrow {
  font: 600 10.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
  margin-bottom: 6px;
}
.rai-reports .rsh-title {
  font: 600 36px var(--font-ui);
  letter-spacing: -.025em;
  line-height: 1.05;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
  max-width: 920px;
}
.rai-reports .rsh-title em {
  font-style: italic;
  color: var(--brand);
  font-weight: 600;
}
.rai-reports .rsh-tag {
  display: flex; align-items: flex-start; gap: 8px;
  margin-top: 14px;
  padding: 12px 14px;
  background: linear-gradient(90deg, var(--brand-soft) 0%, transparent 80%);
  border-left: 2px solid var(--brand);
  border-radius: 0 8px 8px 0;
  font: 400 13.5px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
  max-width: 820px;
}
.rai-reports .rsh-tag-mark { flex-shrink: 0; margin-top: 1px; display: inline-flex; }
.rai-reports .rsh-anom {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 12px;
}
.rai-reports .anom {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 10.5px var(--font-ui);
  padding: 3px 9px 3px 7px;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: var(--surface-1);
}
.rai-reports .anom-up { color: var(--success); border-color: rgba(79,180,119,.25); background: rgba(79,180,119,.07); }
.rai-reports .anom-down { color: var(--danger);  border-color: rgba(242,107,92,.25); background: rgba(242,107,92,.07); }
.rai-reports .anom-flat { color: var(--fg-2); }
.rai-reports .hero-metric { display: flex; flex-direction: column; }
.rai-reports .hero-metric.xl .hm-value { font-size: 92px; }
.rai-reports .hero-metric.lg .hm-value { font-size: 60px; }
.rai-reports .hero-metric.md .hm-value { font-size: 44px; }
.rai-reports .hm-value {
  font: 500 60px var(--font-mono);
  letter-spacing: -.035em;
  line-height: 0.95;
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.rai-reports .hm-label {
  font: 500 13px var(--font-ui);
  color: var(--fg-3);
  margin-top: 12px;
  display: inline-flex; align-items: center; gap: 6px;
}
.rai-reports .hm-meta {
  display: flex; align-items: center; gap: 10px;
  margin-top: 10px;
  font: 500 12px var(--font-mono);
}
.rai-reports .hm-delta { display: inline-flex; align-items: center; gap: 3px; font-weight: 600; }
.rai-reports .hm-delta.up { color: var(--success); }
.rai-reports .hm-delta.down { color: var(--danger); }
.rai-reports .hm-vs { color: var(--fg-muted); font-size: 11px; }
.rai-reports .hm-sub { color: var(--fg-3); font: 400 12px var(--font-ui); }
.rai-reports .metric-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border-subtle);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .mr-cell {
  padding: 18px 20px;
  background: var(--surface-1);
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .mr-lbl {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--fg-3);
  display: inline-flex; align-items: center; gap: 4px;
}
.rai-reports .mr-val {
  font: 500 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.022em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  display: inline-flex;
  align-items: baseline;
}
.rai-reports .mr-unit { font: 400 14px var(--font-ui); color: var(--fg-3); margin-left: 3px; }
.rai-reports .mr-delta {
  font: 500 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.rai-reports .mr-delta.up { color: var(--success); }
.rai-reports .mr-delta.down { color: var(--danger); }
.rai-reports .mr-vs { color: var(--fg-muted); margin-left: 3px; }
.rai-reports .mr-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .mr-note {
  display: inline-block;
  margin-left: 4px;
  font: 500 9.5px var(--font-ui);
  color: var(--fg-3);
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
}
.rai-reports .internal-drawer {
  margin-top: 22px;
  background: linear-gradient(180deg, rgba(251,95,44,.04) 0%, transparent 100%);
  border: 1px dashed rgba(251,95,44,.3);
  border-radius: var(--radius-md);
  padding: 16px 18px;
}
.rai-reports .id-head {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
  margin-bottom: 14px;
}
.rai-reports .id-body { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.rai-reports .id-col { display: flex; flex-direction: column; gap: 3px; }
.rai-reports .id-k { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .id-v { font: 600 18px var(--font-ui); color: var(--fg-1); letter-spacing: -.014em; }
.rai-reports .id-s { font: 400 11.5px var(--font-ui); color: var(--fg-3); }
.rai-reports .id-d { font: 600 10px var(--font-mono); padding: 1px 6px; border-radius: 999px; margin-left: 4px; vertical-align: middle; }
.rai-reports .id-d.up { background: rgba(79,180,119,.15); color: var(--success); }
.rai-reports .id-d.down { background: rgba(242,107,92,.15); color: var(--danger); }

/* ===== reports-sections.css (scoped) ===== */
.rai-reports .exec-grid {
  display: grid;
  grid-template-columns: 1.55fr 1fr;
  gap: 24px;
  margin-top: 28px;
}
@media (max-width: 1100px) {
.rai-reports .exec-grid { grid-template-columns: 1fr; }
}
.rai-reports .exec-hero { display: flex; flex-direction: column; gap: 20px; }
.rai-reports .exec-narrative {
  font: 400 16px var(--font-ui);
  line-height: 1.6;
  color: var(--fg-2);
  margin: 8px 0 0;
  max-width: 720px;
  text-wrap: pretty;
}
.rai-reports .exec-narrative strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .exec-actions {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 12px;
}
.rai-reports .exec-action {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border-radius: 8px;
  font: 500 12.5px var(--font-ui);
  align-self: flex-start;
  border: 1px solid var(--border-subtle);
  background: var(--surface-1);
}
.rai-reports .exec-action-up { color: var(--success); border-color: rgba(79,180,119,.25); background: rgba(79,180,119,.06); }
.rai-reports .exec-action-down { color: var(--danger);  border-color: rgba(242,107,92,.25); background: rgba(242,107,92,.06); }
.rai-reports .exec-action-flat { color: var(--fg-2); }
.rai-reports .exec-side {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.rai-reports .exec-kpi {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .exec-kpi-l { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .exec-kpi-v {
  font: 500 28px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.025em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: 2px;
}
.rai-reports .exec-kpi-u { font: 400 14px var(--font-ui); color: var(--fg-3); margin-left: 3px; }
.rai-reports .exec-kpi-s { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 2px; }
.rai-reports .legend-strip {
  display: flex; flex-wrap: wrap; gap: 16px;
  padding-top: 14px;
  margin-top: 14px;
  border-top: 1px solid var(--divider);
}
.rai-reports .legend-item {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .legend-dot { width: 9px; height: 9px; border-radius: 2px; display: inline-block; }
.rai-reports .legend-dash { width: 14px; height: 2px; display: inline-block; border-radius: 1px; }
.rai-reports .legend-name { color: var(--fg-1); font-weight: 500; }
.rai-reports .legend-num { color: var(--fg-3); font-family: var(--font-mono); font-variant-numeric: tabular-nums; margin-left: 4px; }
.rai-reports .chart-legend-row {
  display: flex; gap: 18px;
  margin-top: 12px;
  font: 500 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .chart-legend-row span { display: inline-flex; align-items: center; gap: 6px; }
.rai-reports .chart-sub-label {
  font: 400 12px var(--font-ui);
  color: var(--fg-3);
  margin-top: 10px;
  text-align: center;
}
.rai-reports .yoy-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .yoy-row:last-child { border-bottom: none; }
.rai-reports .yoy-name {
  font: 600 13px var(--font-ui);
  color: var(--fg-1);
  display: flex; align-items: center; gap: 8px;
}
.rai-reports .loc-dot {
  width: 8px; height: 8px; border-radius: 2px;
  display: inline-block;
}
.rai-reports .yoy-bars { display: flex; gap: 14px; }
.rai-reports .yoy-bar { display: flex; flex-direction: column; gap: 1px; text-align: right; }
.rai-reports .yoy-bar-l { font: 600 10.5px var(--font-mono); color: var(--fg-3); text-transform: uppercase; letter-spacing: .08em; }
.rai-reports .yoy-bar-v { font: 500 13px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .yoy-pct {
  font: 600 12px var(--font-mono);
  font-variant-numeric: tabular-nums;
  padding: 4px 9px;
  border-radius: 999px;
  background: var(--surface-2);
}
.rai-reports .yoy-pct.up { color: var(--success); background: rgba(79,180,119,.12); }
.rai-reports .yoy-pct.down { color: var(--danger);  background: rgba(242,107,92,.12); }
.rai-reports .yoy-pct.new { color: var(--brand);   background: var(--brand-soft); }
.rai-reports .loc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 14px;
}
.rai-reports .loc-rev-card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  border-left: 3px solid var(--loc-color, var(--brand));
  display: flex; flex-direction: column; gap: 8px;
}
.rai-reports .loc-rev-head { display: flex; align-items: center; gap: 8px; }
.rai-reports .loc-rev-tag {
  font: 600 9px var(--font-mono);
  background: var(--loc-color);
  color: white;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: .04em;
}
.rai-reports .loc-rev-name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .loc-rev-val { font: 500 24px var(--font-mono); color: var(--fg-1); letter-spacing: -.022em; font-variant-numeric: tabular-nums; line-height: 1; }
.rai-reports .loc-rev-sub { font: 500 11px var(--font-mono); color: var(--fg-3); display: flex; align-items: center; gap: 4px; font-variant-numeric: tabular-nums; flex-wrap: wrap; }
.rai-reports .loc-rev-sub .up { color: var(--success); }
.rai-reports .loc-rev-sub .down { color: var(--danger); }
.rai-reports .new-pill { color: var(--brand); background: var(--brand-soft); padding: 1px 6px; border-radius: 999px; font-weight: 600; }
.rai-reports .loc-rev-spark { height: 28px; }
@media (max-width: 1100px) {
.rai-reports .loc-grid { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .rh-wrap {
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .rh-hours, .rai-reports .rh-row {
  display: grid;
  grid-template-columns: 36px repeat(24, 1fr);
  gap: 3px;
  align-items: center;
}
.rai-reports .rh-hours { margin-bottom: 4px; }
.rai-reports .rh-hour {
  font: 600 10.5px var(--font-mono);
  color: transparent;
  text-align: left;
}
.rai-reports .rh-hour.show { color: var(--chart-axis, var(--fg-3)); }
.rai-reports .rh-day {
  font: 600 11px var(--font-ui);
  color: var(--chart-axis, var(--fg-3));
  text-transform: uppercase;
  letter-spacing: .08em;
}
.rai-reports .rh-cell {
  aspect-ratio: 1;
  border-radius: 3px;
  background: var(--surface-2);
  transition: transform var(--dur-fast) var(--ease-out);
}
.rai-reports .rh-cell:hover { transform: scale(1.2); }
.rai-reports .rh-cell.rh-l1 { background: rgba(167,139,250,.14); }
.rai-reports .rh-cell.rh-l2 { background: rgba(167,139,250,.32); }
.rai-reports .rh-cell.rh-l3 { background: rgba(167,139,250,.54); }
.rai-reports .rh-cell.rh-l4 { background: rgba(167,139,250,.78); }
.rai-reports .rh-cell.rh-l5 { background: rgba(167,139,250,1); }
.rai-reports .rh-legend {
  display: flex; align-items: center; gap: 6px;
  margin-top: 14px;
  font: 500 11.5px var(--font-ui);
  color: var(--fg-2);
  justify-content: flex-end;
}
.rai-reports .rh-legend .rh-cell { width: 12px; aspect-ratio: 1; }
.rai-reports .funnel { display: flex; flex-direction: column; gap: 10px; }
.rai-reports .funnel-row { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .funnel-meta { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.rai-reports .funnel-label { font: 500 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .funnel-num { font: 500 14px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .funnel-bar-wrap { position: relative; height: 28px; background: var(--surface-2); border-radius: 6px; overflow: visible; }
.rai-reports .funnel-bar {
  height: 100%; border-radius: 6px;
  transition: width var(--dur-base) var(--ease-out);
  min-width: 4px;
}
.rai-reports .funnel-conv {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  font: 600 11px var(--font-mono);
  color: rgba(255,255,255,.92);
  font-variant-numeric: tabular-nums;
}
.rai-reports .delivery-link-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: 24px;
  gap: 14px;
}
.rai-reports .dlc-l { display: flex; align-items: flex-start; gap: 14px; }
.rai-reports .dlc-h { font: 600 15px var(--font-ui); color: var(--fg-1); letter-spacing: -.01em; }
.rai-reports .dlc-s { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 4px; line-height: 1.45; max-width: 360px; }
.rai-reports .lollipop { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .lol-row {
  display: grid;
  grid-template-columns: 144px 1fr 108px;
  gap: 12px;
  align-items: center;
}
/* min-width:0 + ellipsis so long @handles truncate inside their column instead
   of overflowing onto the track (e.g. @marymatheustraveler). */
.rai-reports .lol-label {
  font: 500 13px var(--font-ui);
  color: var(--fg-1);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rai-reports .lol-track {
  position: relative;
  height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
}
.rai-reports .lol-bar { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 999px; }
.rai-reports .lol-dot {
  position: absolute;
  width: 12px; height: 12px;
  border-radius: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.rai-reports .lol-val {
  font: 600 12.5px var(--font-mono);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}
.rai-reports .sms-card-body { padding: 24px 20px; }
.rai-reports .sms-num { display: flex; gap: 24px; align-items: center; }
.rai-reports .sms-num-meta { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.rai-reports .sms-k { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.rai-reports .sms-k-l { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .sms-k-v { font: 500 16px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .ch-mark {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 6px;
  font: 700 12px var(--font-ui);
  margin-right: 6px;
  vertical-align: middle;
}
.rai-reports .ch-mark.mt-meta { background: linear-gradient(135deg, #1877F2, #0a5cc7); color: white; }
.rai-reports .ch-mark.mt-google { background: white; color: #4285F4; border: 1px solid #4285F4; }
.rai-reports .cost-objectives {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border-subtle);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--border-default);
}
.rai-reports .co-card {
  background: var(--surface-1);
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 8px;
}
.rai-reports .co-head { display: flex; align-items: center; gap: 8px; }
.rai-reports .co-ico {
  width: 28px; height: 28px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
}
.rai-reports .co-name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .co-val { font: 500 26px var(--font-mono); color: var(--fg-1); letter-spacing: -.022em; font-variant-numeric: tabular-nums; }
.rai-reports .co-meta { display: flex; justify-content: space-between; gap: 8px; font: 500 11px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .co-count { color: var(--fg-3); }
.rai-reports .co-bench { font-weight: 600; }
.rai-reports .co-bench.good { color: var(--success); }
.rai-reports .co-bench.bad { color: var(--danger); }
.rai-reports .cmp-triple {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border-subtle);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .cmp-cell {
  background: var(--surface-1);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .cmp-cell.is-accent { background: linear-gradient(180deg, rgba(251,95,44,.08) 0%, var(--surface-1) 80%); }
.rai-reports .cmp-lbl { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .cmp-val { font: 500 24px var(--font-mono); color: var(--fg-1); letter-spacing: -.022em; font-variant-numeric: tabular-nums; }
.rai-reports .cmp-cell.is-accent .cmp-val { color: var(--brand); }
.rai-reports .cmp-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }

/* ── Paid Ads — "Where your budget went" goal breakdown (centerpiece) ──
   Donut (left) + legend (right). Balanced two-column layout; collapses to a
   stacked, centered donut-over-legend on narrow viewports. */
.rai-reports .bgoal-split {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 32px;
}
.rai-reports .bgoal-donut {
  position: relative;
  width: 188px; height: 188px;
  flex-shrink: 0;
  justify-self: center;
}
.rai-reports .bgoal-donut svg { display: block; }
/* Dim-focus: hover the donut → all slices dim, hovered slice stays bright
   (mirrors the .rc-focusable pattern used by every other report chart). */
.rai-reports .bgoal-donut .bgoal-slice { transition: opacity .12s var(--ease-out); cursor: crosshair; }
.rai-reports .bgoal-donut svg.rc-focusable:hover .bgoal-slice { opacity: .3; }
.rai-reports .bgoal-donut svg.rc-focusable .bgoal-slice:hover { opacity: 1; }
.rai-reports .bgoal-donut-center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; pointer-events: none;
}
.rai-reports .bgoal-donut-total { font: 500 24px var(--font-mono); color: var(--fg-1); letter-spacing: -.025em; font-variant-numeric: tabular-nums; line-height: 1; }
.rai-reports .bgoal-donut-cap { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .08em; color: var(--fg-3); margin-top: 5px; }
.rai-reports .bgoal-legend { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .bgoal-leg-row {
  display: flex; align-items: flex-start; gap: 11px;
  padding: 12px 4px;
  border-bottom: 1px solid var(--border-subtle);
}
.rai-reports .bgoal-leg-row:last-child { border-bottom: 0; }
.rai-reports .bgoal-leg-dot { width: 11px; height: 11px; border-radius: 3px; flex-shrink: 0; margin-top: 4px; }
.rai-reports .bgoal-leg-main { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.rai-reports .bgoal-leg-top { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.rai-reports .bgoal-leg-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .bgoal-leg-pct { font: 600 13px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .bgoal-leg-meta { display: flex; align-items: baseline; gap: 10px; font: 500 11.5px var(--font-mono); font-variant-numeric: tabular-nums; color: var(--fg-3); flex-wrap: wrap; }
.rai-reports .bgoal-leg-spend { color: var(--fg-2); font-weight: 600; }
.rai-reports .bgoal-cpr { color: var(--fg-2); font-weight: 600; }
.rai-reports .bgoal-est { font: 400 10.5px var(--font-ui); color: var(--fg-muted); text-transform: none; letter-spacing: 0; }
@media (max-width: 720px) {
  .rai-reports .bgoal-split { grid-template-columns: 1fr; gap: 18px; }
}

/* ── Paid Ads — plain-English one-liner + muted technical footer + footnote ── */
.rai-reports .paid-oneliner {
  font: 400 13px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.5;
  padding: 12px 14px;
  background: var(--surface-2);
  border-radius: var(--radius-md);
}
.rai-reports .paid-tech-footer {
  margin-top: 14px;
  font: 400 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-muted);
  letter-spacing: .01em;
}
.rai-reports .paid-footnote {
  margin-top: 16px;
  padding: 14px 16px;
  border-top: 1px solid var(--border-subtle);
}
.rai-reports .paid-footnote-head {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-muted);
  margin-bottom: 8px;
}
.rai-reports .paid-footnote-list {
  margin: 0; padding: 0; list-style: none;
  display: flex; flex-direction: column; gap: 5px;
}
.rai-reports .paid-footnote-list li {
  font: 400 11.5px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.45;
  padding-left: 14px;
  position: relative;
}
.rai-reports .paid-footnote-list li::before {
  content: '·';
  position: absolute; left: 4px; top: -1px;
  color: var(--fg-muted);
}
.rai-reports .paid-footnote-note {
  margin-top: 9px;
  font: 400 10.5px var(--font-ui);
  font-style: italic;
  color: var(--fg-muted);
}

.rai-reports .demo-bar-wrap { display: flex; flex-direction: column; gap: 14px; }
.rai-reports .demo-bar {
  display: flex;
  border-radius: 8px;
  overflow: hidden;
  background: var(--surface-2);
}
.rai-reports .demo-seg { transition: opacity var(--dur-fast); }
.rai-reports .demo-seg:hover { opacity: 0.85; }
.rai-reports .demo-legend { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .demo-l-item { display: flex; align-items: center; gap: 8px; font: 500 12px var(--font-ui); }
.rai-reports .demo-l-dot { width: 8px; height: 8px; border-radius: 2px; }
.rai-reports .demo-l-label { color: var(--fg-1); flex: 1; }
.rai-reports .demo-l-val { color: var(--fg-1); font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .top-post {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 20px;
  border-bottom: 1px solid var(--divider);
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: background .12s ease;
}
.rai-reports .top-post:last-child { border-bottom: none; }
.rai-reports .top-post:hover { background: var(--surface-2); }
.rai-reports .top-post-go { display: inline-flex; align-items: center; opacity: .4; margin-left: 4px; color: var(--fg-3); transition: opacity .12s ease, color .12s ease; }
.rai-reports .top-post:hover .top-post-go { opacity: 1; color: var(--brand); }
.rai-reports .top-post-kind {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 8px;
  border-radius: 6px;
  text-align: center;
  background: var(--surface-3);
  color: var(--fg-2);
}
.rai-reports .tp-reel { background: rgba(225,48,108,.15); color: #E1306C; }
.rai-reports .tp-carousel { background: rgba(167,139,250,.15); color: #A78BFA; }
.rai-reports .tp-photo { background: rgba(108,169,242,.15); color: #6CA9F2; }
.rai-reports .top-post-title { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .top-post-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 2px; }
.rai-reports .top-post-stats { display: flex; flex-wrap: wrap; gap: 3px 10px; margin-top: 5px; }
.rai-reports .tp-stat { font: 400 11px var(--font-ui); color: var(--fg-3); white-space: nowrap; }
.rai-reports .tp-stat em { font-style: normal; font-weight: 600; color: var(--fg-2); font-variant-numeric: tabular-nums; }
.rai-reports .top-post-eng {
  font: 500 18px var(--font-mono);
  color: var(--success);
  font-variant-numeric: tabular-nums;
}
.rai-reports .influencer-cell { display: flex; align-items: center; gap: 8px; }
.rai-reports .influencer-mark {
  width: 26px; height: 26px;
  border-radius: 7px;
  background: linear-gradient(135deg, #F4A93A, #E1306C, #833AB4);
  color: white;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .reel-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px;
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--fg-2);
}
.rai-reports .reel-link:hover { background: var(--brand-soft); color: var(--brand); }
.rai-reports .kw-table th, .rai-reports .kw-table td { padding: 11px 14px; }
.rai-reports .kw-pos {
  display: inline-block;
  font: 600 11px var(--font-mono);
  padding: 3px 8px;
  border-radius: 6px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .kw-ptop { background: rgba(79,180,119,.15); color: var(--success); }
.rai-reports .kw-pmid { background: rgba(244,169,58,.15); color: var(--warning); }
.rai-reports .kw-plow { background: var(--surface-3); color: var(--fg-3); }
/* TARGET keyword (not ranking yet) — a tracked opportunity, distinct from a
   real low position. Outlined accent pill so it reads as "goal", not "rank". */
.rai-reports .kw-ptarget {
  background: rgba(99,102,241,.12);
  color: var(--accent, #6366F1);
  border: 1px dashed rgba(99,102,241,.45);
  letter-spacing: .02em;
  text-transform: uppercase;
  font-size: 10px;
  cursor: help;
}
.rai-reports .kw-target-row td:first-child strong { opacity: .92; }
.rai-reports .kw-bar-wrap { width: 80px; height: 6px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .kw-bar { height: 100%; background: var(--success); border-radius: 999px; }
/* Keyword groups (Company + per location) + native CSS "View all" toggle */
.rai-reports .kw-group { margin-bottom: 18px; }
.rai-reports .kw-group:last-child { margin-bottom: 0; }
.rai-reports .kw-group .kw-table { margin-top: 2px; }
.rai-reports .kw-extra { display: none; }
.rai-reports .kw-toggle:checked ~ .kw-table .kw-extra { display: table-row; }
.rai-reports .kw-more-sum {
  display: inline-flex; align-items: center; cursor: pointer;
  font: 600 12px var(--font-ui); color: var(--brand-orange, #FB5F2C);
  padding: 8px 14px 2px; user-select: none;
}
.rai-reports .kw-more-sum::before { content: '▸ '; margin-right: 4px; }
.rai-reports .kw-toggle:checked ~ .kw-more-sum::before { content: '▾ '; }
.rai-reports .kw-more-sum .kw-more-hide { display: none; }
.rai-reports .kw-toggle:checked ~ .kw-more-sum .kw-more-show { display: none; }
.rai-reports .kw-toggle:checked ~ .kw-more-sum .kw-more-hide { display: inline; }
.rai-reports .seo-side { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.rai-reports .seo-side-k { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .seo-side-l { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .seo-side-v { font: 600 18px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
/* Backlink-profile side delta chip (movement vs prior period). */
.rai-reports .seo-side-d { font: 700 11px var(--font-ui); margin-left: 6px; white-space: nowrap; }
.rai-reports .seo-side-d.up { color: var(--success); }
.rai-reports .seo-side-d.down { color: var(--danger); }
/* Local SEO keyword selector chips — separated from the card header (top border
   + breathing room) and far more legible than the old 11px cramped pills. */
.rai-reports .lsm-kw-chips {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  margin: 14px 16px 6px; padding-top: 13px;
  border-top: 1px solid var(--ink-100, rgba(0,0,0,.06));
}
.rai-reports .lsm-kw-lead {
  font: 700 10px var(--font-ui); text-transform: uppercase; letter-spacing: .12em;
  color: var(--fg-3); margin-right: 2px;
}
.rai-reports .lsm-kw-chip {
  display: inline-flex; align-items: center; gap: 7px; line-height: 1; cursor: pointer;
  font: 600 12.5px var(--font-ui); padding: 7px 12px; border-radius: 999px;
  border: 1px solid var(--ink-200, rgba(0,0,0,.12)); background: var(--surface-1);
  color: var(--fg-1); transition: background .12s, border-color .12s, color .12s;
}
.rai-reports .lsm-kw-chip:hover { border-color: var(--brand-orange, #FB5F2C); color: var(--brand-orange, #FB5F2C); }
.rai-reports .lsm-kw-chip .lsm-kw-chip-v { font: 700 11.5px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .lsm-kw-chip.on { background: var(--brand-orange, #FB5F2C); border-color: transparent; color: #fff; }
.rai-reports .lsm-kw-chip.on .lsm-kw-chip-v { color: rgba(255,255,255,.85); }
.rai-reports .rep-hero-card {
  background: linear-gradient(180deg, rgba(244,169,58,.06) 0%, var(--surface-1) 60%);
  padding: 28px 24px;
  display: flex; align-items: center; justify-content: center;
}
.rai-reports .rep-hero-stars { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.rai-reports .rep-hero-num {
  font: 700 80px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.04em;
  line-height: 0.9;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rep-hero-stars-row { display: flex; gap: 2px; }
.rai-reports .rep-hero-meta { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 6px; }
.rai-reports .rep-hero-foot {
  display: flex; align-items: center; gap: 8px;
  margin-top: 6px;
}
.rai-reports .rep-hero-delta {
  display: inline-flex; align-items: center; gap: 4px;
  font: 600 11px var(--font-mono);
  color: var(--success);
  background: rgba(79,180,119,.12);
  padding: 3px 8px;
  border-radius: 999px;
}
.rai-reports .rep-mini-meta {
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rating-chip {
  background: rgba(244,169,58,.12);
  color: #F4A93A;
  padding: 2px 7px;
  border-radius: 5px;
  font: 600 11px var(--font-mono);
}
.rai-reports .rpb { display: flex; align-items: center; gap: 10px; min-width: 140px; }
.rai-reports .rpb-bar { flex: 1; height: 6px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .rpb-fill { height: 100%; border-radius: 999px; }
.rai-reports .rpb-val { font: 600 11px var(--font-mono); font-variant-numeric: tabular-nums; min-width: 44px; text-align: right; }
.rai-reports .sunday-adoption {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  padding: 20px 24px;
}
@media (max-width: 1100px) {
.rai-reports .sunday-adoption { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .sun-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.rai-reports .sun-head {
  display: flex; align-items: baseline; justify-content: space-between;
  width: 100%;
}
.rai-reports .sun-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .sun-rate { font: 500 16px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .sun-bars { display: flex; flex-direction: column; gap: 6px; width: 100%; margin-top: 6px; }
.rai-reports .sun-bar {
  display: grid;
  grid-template-columns: 28px 1fr 36px;
  gap: 8px;
  align-items: center;
}
.rai-reports .sun-bar-l { font: 600 11px var(--font-mono); color: var(--fg-3); text-transform: uppercase; letter-spacing: .06em; }
.rai-reports .sun-bar-track { height: 5px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .sun-bar-fill { height: 100%; border-radius: 999px; }
.rai-reports .sun-bar-v { font: 500 12px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; text-align: right; }
.rai-reports .callout {
  display: flex; gap: 10px;
  padding: 12px 14px;
  border-radius: 8px;
  font: 400 12.5px var(--font-ui);
  line-height: 1.5;
  align-items: flex-start;
}
.rai-reports .callout-info {
  background: rgba(108,169,242,.08);
  border: 1px solid rgba(108,169,242,.2);
  color: var(--fg-2);
}
.rai-reports .callout-info svg { color: var(--info); flex-shrink: 0; margin-top: 2px; }
.rai-reports .callout strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .staff-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--divider); }
.rai-reports .staff-tab {
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--fg-3);
  font: 600 12px var(--font-ui);
  padding: 8px 14px;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: -1px;
}
.rai-reports .staff-tab:hover { color: var(--fg-1); }
.rai-reports .staff-tab.on { color: var(--fg-1); border-bottom-color: var(--brand); }
.rai-reports .staff-tab-count {
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 1px 7px;
  border-radius: 999px;
  font: 600 10px var(--font-mono);
}
.rai-reports .staff-tab.on .staff-tab-count { background: var(--brand-soft); color: var(--brand); }
.rai-reports .staff-table th, .rai-reports .staff-table td { padding: 10px 14px; vertical-align: middle; }
.rai-reports .staff-su {
  display: inline-flex; align-items: center; gap: 8px;
  min-width: 130px;
}
.rai-reports .staff-su-bar { flex: 1; height: 4px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .staff-su-fill { height: 100%; background: var(--brand); border-radius: 999px; }
.rai-reports .staff-su span { font: 500 11px var(--font-mono); color: var(--fg-2); font-variant-numeric: tabular-nums; min-width: 28px; }
.rai-reports .bad-review-row {
  display: grid;
  grid-template-columns: 120px 1fr 180px;
  gap: 14px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--divider);
  align-items: flex-start;
}
.rai-reports .bad-review-row:last-of-type { border-bottom: none; }
.rai-reports .brr-meta { display: flex; flex-direction: column; gap: 4px; }
.rai-reports .brr-stars { color: var(--warning); font: 500 13px var(--font-ui); letter-spacing: 1.5px; }
.rai-reports .brr-loc { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .brr-date { font: 500 10.5px var(--font-mono); color: var(--fg-3); }
.rai-reports .brr-author { font: 600 12px var(--font-ui); color: var(--fg-2); margin-bottom: 4px; }
.rai-reports .brr-summary { font: 400 13px var(--font-ui); color: var(--fg-1); line-height: 1.5; }
.rai-reports .brr-summary--clamp { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rai-reports .brr-summary--empty { color: var(--fg-3); font-style: italic; }
.rai-reports .brr-more { margin-top: 4px; font: 600 11px var(--font-ui); color: var(--fg-3); background: none; border: none; padding: 0; cursor: pointer; }
.rai-reports .brr-more:hover { color: var(--brand); }
.rai-reports .brr-side { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.rai-reports .brr-theme {
  font: 500 10px var(--font-mono);
  background: var(--surface-3);
  color: var(--fg-2);
  padding: 2px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rai-reports .bad-review-foot {
  display: flex; align-items: center; gap: 6px;
  padding: 12px 20px;
  font: 500 12px var(--font-ui);
  color: var(--fg-3);
  background: var(--surface-page);
}
.rai-reports .underline-link { color: var(--brand); text-decoration: underline; text-underline-offset: 2px; }
.rai-reports .hiring-process {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 20px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .hp-step { display: flex; align-items: center; gap: 10px; }
.rai-reports .hp-num {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-mono);
  flex-shrink: 0;
}
.rai-reports .hp-title { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .hp-val { font: 600 14px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .qr-locations { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .qr-loc {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: 8px;
}
.rai-reports .qr-mark {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .qr-l-name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .qr-l-num { font: 500 11px var(--font-mono); color: var(--fg-3); margin-top: 2px; font-variant-numeric: tabular-nums; }
.rai-reports .next-grid {
  display: flex; flex-direction: column;
  gap: 14px;
  margin-top: 28px;
}
.rai-reports .next-card {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 24px;
  padding: 24px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-left: 4px solid var(--accent, var(--brand));
  border-radius: var(--radius-lg);
}
.rai-reports .next-num {
  font: 700 56px var(--font-ui);
  color: var(--accent, var(--brand));
  letter-spacing: -.04em;
  line-height: 0.9;
}
.rai-reports .next-content { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .next-meta-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.rai-reports .next-cat {
  font: 600 10px var(--font-ui);
  padding: 3px 10px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.rai-reports .next-impact, .rai-reports .next-effort {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
}
.rai-reports .next-h {
  font: 600 20px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.015em;
  line-height: 1.3;
  text-wrap: pretty;
}
.rai-reports .next-s {
  font: 400 13.5px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.55;
  max-width: 760px;
  text-wrap: pretty;
}
.rai-reports .next-metric {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11.5px var(--font-mono);
  color: var(--accent, var(--brand));
  background: var(--brand-soft);
  padding: 4px 10px;
  border-radius: 999px;
  align-self: flex-start;
  font-variant-numeric: tabular-nums;
}
.rai-reports .next-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 18px;
  padding: 14px 18px;
  background: var(--surface-2);
  border-radius: var(--radius-md);
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
  gap: 16px;
}
.rai-reports .next-foot-l { display: flex; align-items: center; gap: 10px; }
.rai-reports .rfooter {
  padding: 50px 0 30px;
  margin-top: 40px;
  border-top: 1px solid var(--divider);
}
.rai-reports .rfooter-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rfooter-mark { display: flex; align-items: center; gap: 12px; }
.rai-reports .mark-sq {
  width: 40px; height: 40px;
  border-radius: 9px;
  background: linear-gradient(135deg, #FB5F2C 0%, #E54E1E 100%);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 16px -8px rgba(251,95,44,.5);
  overflow: hidden;
}
.rai-reports .mark-sq img { width: 40px; height: 40px; object-fit: cover; }
.rai-reports .rfooter-name { font: 600 14px var(--font-ui); color: var(--fg-1); }
.rai-reports .rfooter-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 1px; }
.rai-reports .rfooter-lbl { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-3); }
.rai-reports .rfooter-val { font: 600 13px var(--font-ui); color: var(--fg-1); margin-top: 4px; }
.rai-reports .rfooter-fineprint {
  margin-top: 18px;
  font: 400 11px var(--font-ui);
  color: var(--fg-muted);
  line-height: 1.5;
  max-width: 920px;
}

/* ===== reports-overlays.css (scoped) ===== */
.rai-reports .resty-dock {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 420px;
  background: var(--surface-1);
  border-left: 1px solid var(--border-default);
  box-shadow: -10px 0 32px rgba(0,0,0,.35);
  display: flex; flex-direction: column;
  z-index: 50;
  animation: dock-in 240ms cubic-bezier(.2,.8,.2,1);
}
@keyframes dock-in {
  from { transform: translateX(40px); opacity: 0; }
  to   { transform: translateX(0);   opacity: 1; }
}
.rai-reports .resty-dock-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--divider);
  background: linear-gradient(180deg, rgba(251,95,44,.08) 0%, transparent 100%);
}
.rai-reports .resty-dock-id { display: flex; align-items: center; gap: 10px; }
.rai-reports .resty-dock-title { font: 600 14px var(--font-ui); color: var(--fg-1); }
.rai-reports .resty-dock-sub { font: 400 11px var(--font-mono); color: var(--fg-3); margin-top: 2px; font-variant-numeric: tabular-nums; }
.rai-reports .resty-dock-actions { display: flex; gap: 4px; }
.rai-reports .resty-dock-thread {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex; flex-direction: column; gap: 14px;
}
.rai-reports .resty-dock-empty { display: flex; flex-direction: column; }
.rai-reports .resty-dock-empty-h {
  font: 600 19px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.015em;
  margin-bottom: 6px;
}
.rai-reports .resty-dock-empty-s {
  font: 400 13px var(--font-ui);
  color: var(--fg-3);
  line-height: 1.55;
  margin-bottom: 20px;
}
.rai-reports .resty-dock-suggest-h {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.rai-reports .resty-dock-suggest-l { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .resty-dock-sug {
  display: flex; align-items: center; gap: 8px;
  text-align: left;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 9px 12px;
  color: var(--fg-2);
  font: 500 12.5px var(--font-ui);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .resty-dock-sug:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .resty-dock-sug svg { color: var(--brand); flex-shrink: 0; }
.rai-reports .resty-dock-sug-int svg { color: var(--info); }
.rai-reports .resty-msg { display: flex; gap: 10px; }
.rai-reports .resty-msg-user { justify-content: flex-end; }
.rai-reports .resty-msg-user .resty-msg-bub {
  background: var(--brand);
  color: var(--fg-onbrand);
  border-color: var(--brand);
}
.rai-reports .resty-msg-av {
  width: 28px; height: 28px;
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
}
.rai-reports .resty-msg-bub {
  max-width: 320px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 12px;
  padding: 10px 12px;
}
.rai-reports .resty-msg-text {
  font: 400 13px var(--font-ui);
  line-height: 1.5;
  color: var(--fg-1);
  white-space: pre-wrap;
}
.rai-reports .resty-msg-user .resty-msg-text { color: var(--fg-onbrand); }
.rai-reports .resty-msg-cite {
  display: flex; flex-wrap: wrap; gap: 4px;
  margin-top: 8px;
}
.rai-reports .resty-cite-chip {
  display: inline-flex; align-items: center; gap: 3px;
  font: 600 9.5px var(--font-mono);
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  color: var(--fg-3);
  padding: 1px 6px;
  border-radius: 999px;
  letter-spacing: .02em;
}
.rai-reports .resty-typing { display: flex; gap: 4px; padding: 4px 0; }
.rai-reports .resty-typing span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--fg-muted);
  animation: rtdot 1s ease-in-out infinite;
}
.rai-reports .resty-typing span:nth-child(2) { animation-delay: .2s; }
.rai-reports .resty-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes rtdot { 0%, 80%, 100% { opacity: .3; transform: translateY(0) } 40% { opacity: 1; transform: translateY(-3px) } }
.rai-reports .resty-dock-input {
  position: relative;
  padding: 10px 14px;
  border-top: 1px solid var(--divider);
  background: var(--surface-page);
  display: flex; align-items: center; gap: 8px;
}
.rai-reports .resty-dock-input textarea {
  flex: 1;
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: 9px;
  padding: 10px 12px;
  font: 400 13px var(--font-ui);
  color: var(--fg-1);
  resize: none;
  outline: none;
  min-height: 22px;
  max-height: 120px;
  line-height: 1.4;
}
.rai-reports .resty-dock-input textarea:focus { border-color: var(--brand); }
.rai-reports .resty-send {
  width: 32px; height: 32px;
  border-radius: 9px;
  background: var(--brand);
  border: none;
  color: var(--fg-onbrand);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rai-reports .resty-send:hover:not(:disabled) { background: var(--brand-hover); }
.rai-reports .resty-send:disabled { background: var(--surface-3); color: var(--fg-muted); cursor: default; }
.rai-reports .resty-dock-disclaimer {
  padding: 6px 14px 10px;
  font: 400 10px var(--font-ui);
  color: var(--fg-muted);
  text-align: center;
  border-top: 1px solid transparent;
  background: var(--surface-page);
}
.rai-reports .modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(8, 6, 4, .65);
  backdrop-filter: blur(6px);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 40px 20px;
  overflow-y: auto;
  animation: backdrop-in 180ms ease-out;
}
@keyframes backdrop-in { from { opacity: 0; } to { opacity: 1; } }
.rai-reports .modal {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 4px 16px rgba(0,0,0,.3);
  max-width: 820px;
  width: 100%;
  max-height: calc(100vh - 80px);
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: modal-in 220ms cubic-bezier(.2,.8,.2,1);
}
@keyframes modal-in {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.rai-reports .modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .modal-head-l { display: flex; align-items: center; gap: 12px; }
.rai-reports .modal-head-l > svg:first-child { color: var(--brand); }
.rai-reports .modal-title { font: 600 16px var(--font-ui); color: var(--fg-1); letter-spacing: -.012em; }
.rai-reports .modal-sub { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 2px; }
.rai-reports .modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 22px;
  display: flex; flex-direction: column; gap: 16px;
}
.rai-reports .modal-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 22px;
  border-top: 1px solid var(--divider);
  background: var(--surface-page);
  gap: 12px;
}
.rai-reports .email-modal { max-width: 880px; }
.rai-reports .ec-rows { display: flex; flex-direction: column; gap: 4px; padding-bottom: 8px; border-bottom: 1px solid var(--divider); }
.rai-reports .ec-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  padding: 8px 0;
  align-items: center;
}
.rai-reports .ec-row label {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
}
.rai-reports .ec-row.ec-row-input {
  grid-template-columns: 72px 1fr;
  align-items: flex-start;
}
.rai-reports .ec-row.ec-row-input label { padding-top: 10px; }
.rai-reports .ec-val { display: flex; align-items: center; gap: 8px; }
.rai-reports .ec-val .avatar-sm { width: 24px; height: 24px; }
.rai-reports .ec-val-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .ec-val-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 1px; }
.rai-reports .ec-recip { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.rai-reports .ec-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  padding: 3px 10px 3px 4px;
  font: 500 11.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .ec-chip-mark {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--surface-3);
  color: var(--fg-1);
  display: flex; align-items: center; justify-content: center;
  font: 600 9px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .ec-chip-add { background: transparent; cursor: pointer; color: var(--fg-3); border-style: dashed; padding: 3px 10px; }
.rai-reports .ec-chip-add:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .ec-chip-internal { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .ec-ai-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: linear-gradient(90deg, rgba(251,95,44,.08), transparent);
  border: 1px solid rgba(251,95,44,.18);
  border-radius: 9px;
  flex-wrap: wrap;
}
.rai-reports .ec-ai-left {
  display: flex; align-items: center; gap: 8px;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .ec-ai-right { display: flex; gap: 6px; align-items: center; }
.rai-reports .ec-seg { padding: 2px; }
.rai-reports .ec-regen { padding: 6px 12px; }
.rai-reports .ec-input, .rai-reports .ec-textarea {
  width: 100%;
  box-sizing: border-box;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 10px 12px;
  font: 400 13px var(--font-ui);
  color: var(--fg-1);
  outline: none;
  resize: vertical;
}
.rai-reports .ec-input:focus, .rai-reports .ec-textarea:focus { border-color: var(--brand); }
.rai-reports .ec-textarea { line-height: 1.55; font-family: var(--font-ui); white-space: pre-wrap; }
.rai-reports .ec-attach-row {
  display: flex; gap: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--divider);
  align-items: flex-start;
}
.rai-reports .ec-attach-lbl {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
  padding-top: 12px;
  width: 60px;
  flex-shrink: 0;
}
.rai-reports .ec-attach-list { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.rai-reports .ec-attach {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .ec-attach > svg { color: var(--brand); flex-shrink: 0; }
.rai-reports .ec-attach-n { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .ec-attach-s { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 1px; }
.rai-reports .ec-attach-x {
  width: 22px; height: 22px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3);
  cursor: pointer;
  margin-left: auto;
}
.rai-reports .ec-attach-x:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .ec-check {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 12px var(--font-ui);
  color: var(--fg-2);
  cursor: pointer;
}
.rai-reports .ec-check input { accent-color: var(--brand); }
.rai-reports .ec-foot-l { display: flex; align-items: center; gap: 14px; }
.rai-reports .ec-foot-r { display: flex; gap: 8px; }
.rai-reports .minfo { position: relative; display: inline-flex; align-items: center; margin-left: 4px; }
.rai-reports .minfo-trigger {
  background: transparent;
  border: none;
  cursor: pointer;
  display: inline-flex; align-items: center;
  color: var(--fg-muted);
  padding: 0;
}
.rai-reports .minfo-trigger:hover { color: var(--brand); }
.rai-reports .minfo-pop {
  /* position:fixed → JS positions it from the trigger rect; no card overflow clips it. */
  position: fixed;
  top: 0; left: 0;
  width: 320px;
  /* Never run past the viewport on narrow screens / triggers near an edge. */
  max-width: min(320px, calc(100vw - 24px));
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.2);
  /* Sit above sibling cards / sticky section headers when un-clipped. */
  z-index: 600;
  /* Wrap long definitions instead of forcing the box wider than its max. */
  overflow-wrap: anywhere;
  word-break: break-word;
  font-family: var(--font-ui);
  letter-spacing: 0;
  text-transform: none;
  font-weight: 400;
  font-style: normal;
}
.rai-reports .minfo-pop.align-right { right: 0; left: auto; }
.rai-reports .minfo-pop.align-left { left: 0; right: auto; }
.rai-reports .minfo-head {
  padding: 12px 14px 4px;
  display: flex; align-items: center; justify-content: space-between;
}
.rai-reports .minfo-title { font: 600 13px var(--font-ui); color: var(--fg-1); letter-spacing: -.005em; }
.rai-reports .minfo-close {
  width: 22px; height: 22px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  color: var(--fg-3);
  cursor: pointer;
}
.rai-reports .minfo-body { padding: 4px 14px 12px; }
.rai-reports .minfo-def { font: 400 12px var(--font-ui); color: var(--fg-2); line-height: 1.55; margin: 0 0 10px; text-wrap: pretty; }
.rai-reports .minfo-formula {
  display: flex; flex-direction: column; gap: 3px;
  padding: 8px 10px;
  background: var(--surface-page);
  border-radius: 6px;
  margin-bottom: 10px;
}
.rai-reports .minfo-formula-lbl { font: 600 9px var(--font-ui); text-transform: uppercase; letter-spacing: .12em; color: var(--fg-3); }
.rai-reports .minfo-formula code { font: 500 11.5px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .minfo-bench { display: flex; gap: 5px; flex-wrap: wrap; font: 500 10px var(--font-mono); }
.rai-reports .mb { padding: 2px 7px; border-radius: 999px; }
.rai-reports .mb-ok { background: rgba(79,180,119,.15);  color: var(--success); }
.rai-reports .mb-warn { background: rgba(244,169,58,.15);  color: var(--warning); }
.rai-reports .mb-crit { background: rgba(242,107,92,.15);  color: var(--danger); }
.rai-reports .mb-label { color: var(--fg-3); padding: 2px 0; }
.rai-reports .minfo-ai {
  display: flex; align-items: center; gap: 8px;
  box-sizing: border-box;   /* padding stays INSIDE the 100% width */
  width: 100%;
  margin: 0;                /* kill the leftover `margin:0 8px 8px` from the
                               duplicate .minfo-ai block above — that 8px left
                               margin is what pushed the footer past the box edge */
  background: var(--brand-soft);
  border: 0;
  border-top: 1px solid rgba(251,95,44,.2);
  color: var(--brand);
  font: 600 12px var(--font-ui);
  padding: 11px 16px;
  text-align: left;
  cursor: pointer;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}
.rai-reports .minfo-ai svg { flex-shrink: 0; }
.rai-reports .minfo-ai:hover { background: var(--brand); color: var(--fg-onbrand); }
.rai-reports .minfo-ai-arrow { margin-left: auto; font: 600 13px var(--font-mono); }
.rai-reports .sidebar-resty-icon { display: inline-flex; align-items: center; }
@media (min-width: 1400px) {
.rai-reports body:has(.resty-dock) .rep-doc { max-width: calc(1400px - 360px); }
}
.rai-reports .rep-doc.is-present {
  scroll-snap-type: y mandatory;
  height: calc(100vh - 56px - 119px);
  overflow-y: auto;
}
.rai-reports .rep-doc.is-present .rsec-wrap {
  padding: 60px 24px;
  scroll-snap-align: start;
}
.rai-reports .rep-doc.is-present .rcover {
  scroll-snap-align: start;
  min-height: 100vh;
  display: flex; align-items: center;
}
.rai-reports .tone-internal .internal-drawer { animation: none; }

/* ===== reports-patch.css (scoped) ===== */
.rai-reports .grqr-block {
  flex: 1;
  display: flex; flex-direction: column; gap: 6px;
  min-width: 0;
}
.rai-reports .grqr-l {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .grqr-v {
  font: 500 36px var(--font-mono);
  letter-spacing: -.025em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rai-reports .grqr-bar {
  height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 4px;
}
.rai-reports .grqr-fill {
  height: 100%;
  border-radius: 999px;
  transition: width var(--dur-base) var(--ease-out);
}
.rai-reports .grqr-s {
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  margin-top: 2px;
}
.rai-reports .grqr-vs {
  font: 600 28px var(--font-ui);
  color: var(--fg-3);
  letter-spacing: -.02em;
  flex-shrink: 0;
}
.rai-reports .seo-sub-divider {
  display: flex; align-items: center; gap: 10px;
  margin: 30px 0 14px;
  padding-top: 22px;
  border-top: 1px dashed var(--border-default);
}
.rai-reports .seo-sub-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  border-radius: 8px;
  background: linear-gradient(135deg, #4285F4, #34A853);
  color: white;
  font: 700 11px var(--font-ui);
  letter-spacing: .02em;
}
.rai-reports .seo-sub-title {
  font: 600 15px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.01em;
}
.rai-reports .seo-sub-sub {
  font: 400 12px var(--font-ui);
  color: var(--fg-3);
  margin-left: auto;
}
.rai-reports .yoy-hero {
  display: flex; flex-direction: column; justify-content: center;
  padding: 24px;
  gap: 8px;
  position: relative;
}
.rai-reports .yoy-hero-l {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
}
.rai-reports .yoy-hero-v {
  font: 500 48px var(--font-mono);
  letter-spacing: -.03em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rai-reports .yoy-hero-s {
  font: 400 12px var(--font-ui);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .yoybar {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 140px;
}
.rai-reports .yoybar-row {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 6px;
  align-items: center;
}
.rai-reports .yoybar-l {
  font: 500 9px var(--font-mono);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rai-reports .yoybar-track {
  height: 6px;
  background: var(--surface-3);
  border-radius: 999px;
  overflow: hidden;
}
.rai-reports .yoybar-fill {
  height: 100%;
  border-radius: 999px;
  transition: width var(--dur-base) var(--ease-out);
}
.rai-reports .yoybar-fill-prior { background: var(--ink-400); opacity: 0.55; }
.rai-reports .yoybar-fill-cur { background: var(--brand);   box-shadow: 0 0 6px rgba(251,95,44,.25); }
.rai-reports .rcover-services {
  margin-top: 40px;
  padding: 28px 0;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.rai-reports .rcover-services-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 22px;
}
.rai-reports .rcover-services-eyebrow {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.rai-reports .rcover-services-title {
  font: 600 22px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.018em;
}
.rai-reports .rcover-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.rai-reports .rcover-cat {
  padding: 14px 16px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--cat-color, var(--brand));
  display: flex; flex-direction: column; gap: 10px;
}
.rai-reports .rcover-cat-head {
  display: flex; align-items: center; gap: 8px;
}
.rai-reports .rcover-cat-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0;
}
.rai-reports .rcover-cat-name {
  font: 600 12px var(--font-ui);
  color: var(--fg-1);
  flex: 1;
  letter-spacing: -.005em;
}
.rai-reports .rcover-cat-count {
  font: 600 10px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-2);
  padding: 1px 7px;
  border-radius: 999px;
}
.rai-reports .rcover-cat-services {
  display: flex; flex-wrap: wrap; gap: 5px;
}
.rai-reports .rcover-cat-chip {
  display: inline-flex; align-items: center;
  font: 500 11px var(--font-ui);
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  padding: 3px 9px;
  border-radius: 999px;
  white-space: nowrap;
}
.rai-reports .rsec {
  padding-top: 80px;
  padding-bottom: 56px;
}
.rai-reports .rsec-wrap + .rsec-wrap {
  
  margin-top: 18px;
}
.rai-reports .rsec .g-12 { gap: 18px; }
.rai-reports .rsec .card .card-body { padding: 22px; }
.rai-reports .rsec .card .card-head { padding: 18px 22px; }
.rai-reports .rsec .metric-row .mr-cell { padding: 20px 22px; }
.rai-reports .top-post-kind {
  white-space: nowrap;
  width: auto;
  min-width: 56px;
  padding: 4px 9px;
  font-size: 9.5px;
  letter-spacing: .06em;
  display: inline-flex;
  justify-content: center;
}
.rai-reports .top-post {
  grid-template-columns: 72px 1fr auto;
  gap: 16px;
}
.rai-reports .top-post-title {
  word-break: break-word;
}
.rai-reports .influencer-cell { min-width: 140px; }
.rai-reports .rsec-influencers .table th, .rai-reports .rsec-influencers .table td {
  padding: 11px 12px;
}
.rai-reports .rsec-influencers .table {
  table-layout: auto;
}
@media (max-width: 1400px) {
.rai-reports .rsec-influencers .card-body {
    overflow-x: auto;
  }
.rai-reports .rsec-influencers .table {
    min-width: 980px;
  }
}
.rai-reports .rcover-internal {
  background: var(--brand-soft);
  color: var(--brand);
}
.rai-reports .rrs-feature {
  margin-top: 22px;
  padding: 22px 24px;
  background: linear-gradient(135deg, rgba(251,95,44,.14) 0%, rgba(251,95,44,.04) 60%, var(--surface-1) 100%);
  border: 1px solid rgba(251,95,44,.35);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 18px -10px rgba(251,95,44,.4);
}
.rai-reports .rrs-feature::before {
  content: "";
  position: absolute; left: -40px; top: -40px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(251,95,44,.18) 0%, transparent 60%);
  pointer-events: none;
}
.rai-reports .rrs-feature-l { display: flex; align-items: center; gap: 16px; position: relative; z-index: 2; }
.rai-reports .rrs-pulse {
  position: absolute; left: 12px; top: 50%;
  transform: translateY(-50%);
  width: 50px; height: 50px;
  border-radius: 50%;
  background: rgba(251,95,44,.3);
  animation: rrs-pulse 2.4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes rrs-pulse {
  0%, 100% { transform: translateY(-50%) scale(1); opacity: 0.7; }
  50%      { transform: translateY(-50%) scale(1.35); opacity: 0; }
}
.rai-reports .rrs-mark {
  width: 50px; height: 50px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand), #E54E1E);
  color: white;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  position: relative; z-index: 2;
  box-shadow: 0 6px 14px -4px rgba(251,95,44,.55);
}
.rai-reports .rrs-eyebrow {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--brand);
  margin-bottom: 2px;
}
.rai-reports .rrs-name {
  font: 700 22px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.02em;
  line-height: 1.1;
}
.rai-reports .rrs-tag {
  font: 400 12.5px var(--font-ui);
  color: var(--fg-3);
  margin-top: 4px;
  max-width: 380px;
}
.rai-reports .rrs-feature-r {
  display: flex; gap: 28px;
  position: relative; z-index: 2;
}
.rai-reports .rrs-stat { display: flex; flex-direction: column; gap: 2px; }
.rai-reports .rrs-stat-l { font: 600 9px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .rrs-stat-v {
  font: 500 22px var(--font-mono);
  color: var(--fg-1);
  letter-spacing: -.022em;
  font-variant-numeric: tabular-nums;
}
.rai-reports .rrs-stat-s { font: 500 10.5px var(--font-mono); color: var(--success); font-variant-numeric: tabular-nums; }
.rai-reports .google-only-chip {
  display: inline-flex; align-items: center; gap: 7px;
  font: 600 13px var(--font-ui);
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  padding: 6px 14px 6px 11px;
  color: var(--fg-1);
}
.rai-reports .dualbar { display: flex; flex-direction: column; gap: 3px; min-width: 130px; }
.rai-reports .dualbar-track { height: 5px; background: var(--surface-3); border-radius: 999px; overflow: hidden; }
.rai-reports .dualbar-fill { height: 100%; border-radius: 999px; }
.rai-reports .card-foot-row {
  display: flex; gap: 18px;
  padding: 12px 22px;
  border-top: 1px solid var(--divider);
  background: var(--surface-page);
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .brr-extended .brr-responder {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 6px;
  font: 500 11px var(--font-mono);
  color: var(--success);
  font-variant-numeric: tabular-nums;
}
.rai-reports .brr-extended .brr-responder svg { opacity: 0.7; }
.rai-reports .ai-summary-card {
  background: linear-gradient(135deg, rgba(251,95,44,.06), transparent 50%), var(--surface-1);
  border: 1px solid var(--border-default);
}
.rai-reports .ai-summary-head {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--divider);
}
.rai-reports .ai-summary-mark { flex-shrink: 0; }
.rai-reports .ai-summary-eyebrow {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--brand);
}
.rai-reports .ai-summary-title { font: 600 14px var(--font-ui); color: var(--fg-1); letter-spacing: -.008em; margin-top: 2px; }
.rai-reports .ai-summary-body {
  padding: 18px 22px 22px;
  font: 400 14px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.6;
  max-height: 130px;
  overflow: hidden;
  position: relative;
  transition: max-height var(--dur-base) var(--ease-out);
}
.rai-reports .ai-summary-body.is-open { max-height: 1200px; }
.rai-reports .ai-summary-body:not(.is-open)::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 60px;
  background: linear-gradient(180deg, transparent, var(--surface-1));
  pointer-events: none;
}
.rai-reports .ai-summary-body p { margin: 0 0 12px; }
.rai-reports .ai-summary-body p strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .ai-summary-toggle {
  display: inline-flex; align-items: center; gap: 5px;
  background: transparent;
  border: 1px solid var(--brand);
  color: var(--brand);
  font: 600 12px var(--font-ui);
  padding: 6px 14px;
  border-radius: 7px;
  cursor: pointer;
  margin-top: 4px;
  position: relative; z-index: 1;
}
.rai-reports .ai-summary-toggle:hover { background: var(--brand-soft); }

/* ── Full-report modal (AI Review Summary "View full report") ──────────── */
/* Mounted when state.repAiSummaryOpen is true. Fixed overlay + backdrop +
   centered scrollable panel. Backdrop and ✕ carry data-rep-ai-summary-toggle
   so either click closes; the panel body does not, so inner scroll/clicks
   stay open. */
.rai-reports .rep-fullreport-overlay {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 4vh 16px;
}
.rai-reports .rep-fullreport-backdrop {
  position: absolute; inset: 0;
  background: rgba(8, 10, 14, .62);
  backdrop-filter: blur(2px);
  cursor: pointer;
  animation: repFrFade var(--dur-base, .18s) var(--ease-out, ease);
}
.rai-reports .rep-fullreport-panel {
  position: relative;
  display: flex; flex-direction: column;
  width: min(760px, 100%);
  max-height: 92vh;
  background: linear-gradient(135deg, rgba(251,95,44,.06), transparent 42%), var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, .42);
  overflow: hidden;
  animation: repFrRise var(--dur-base, .18s) var(--ease-out, ease);
}
.rai-reports .rep-fullreport-head {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--divider);
  flex-shrink: 0;
}
.rai-reports .rep-fullreport-head-txt { flex: 1; min-width: 0; }
.rai-reports .rep-fullreport-close {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  background: transparent;
  border: 1px solid var(--border-default);
  border-radius: 8px;
  color: var(--fg-2);
  cursor: pointer;
  transition: background var(--dur-fast, .12s) ease, color var(--dur-fast, .12s) ease;
}
.rai-reports .rep-fullreport-close:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rep-fullreport-body {
  padding: 20px 22px 26px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  font: 400 14px var(--font-ui);
  color: var(--fg-2);
  line-height: 1.62;
}
.rai-reports .rep-fullreport-body p { margin: 0 0 12px; }
.rai-reports .rep-fullreport-body p strong { color: var(--fg-1); font-weight: 600; }
@keyframes repFrFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes repFrRise { from { opacity: 0; transform: translateY(10px) scale(.985); } to { opacity: 1; transform: none; } }

.rai-reports .coming-soon-card {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 18px 22px;
  background: linear-gradient(90deg, var(--surface-1), var(--surface-page));
  border: 1px dashed var(--border-default);
}
.rai-reports .cs-mark {
  width: 50px; height: 50px;
  border-radius: 12px;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
}
.rai-reports .cs-eyebrow {
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
}
.rai-reports .cs-title { font: 600 15px var(--font-ui); color: var(--fg-1); margin-top: 2px; }
.rai-reports .cs-sub { font: 400 12px var(--font-ui); color: var(--fg-3); line-height: 1.5; margin-top: 4px; }
.rai-reports .cs-pill {
  font: 600 10px var(--font-mono);
  background: var(--brand-soft);
  color: var(--brand);
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
/* Section-level "Integration coming soon" panel — same chrome as the inline
   coming-soon-card but a touch more presence (it stands in for a whole report
   section: Reservations, Email & SMS, blended-ROAS). Used by RepComingSoon /
   RepComingSoonCard in reportShell.js. Honest placeholder — never any number. */
.rai-reports .coming-soon-card.cs-section { padding: 22px 24px; }
.rai-reports .rsec-coming-soon .coming-soon-card { align-items: flex-start; }
.rai-reports .rsec-coming-soon .cs-mark { align-self: center; }
.rai-reports .sunday-trend-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1100px) {
.rai-reports .sunday-trend-grid { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .sun-trend-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.rai-reports .stc-head { display: flex; align-items: center; justify-content: space-between; }
.rai-reports .stc-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .stc-trend {
  font: 600 11px var(--font-mono);
  font-variant-numeric: tabular-nums;
  padding: 2px 8px;
  border-radius: 999px;
}
.rai-reports .stc-trend.up { color: var(--success); background: rgba(79,180,119,.12); }
.rai-reports .stc-trend.down { color: var(--danger);  background: rgba(242,107,92,.12); }
.rai-reports .stc-chart { padding: 0; }
.rai-reports .stc-foot {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  padding-top: 6px;
  border-top: 1px solid var(--divider);
}
.rai-reports .stc-month { display: flex; flex-direction: column; gap: 1px; }
.rai-reports .stc-m-l { font: 500 9px var(--font-mono); color: var(--fg-3); text-transform: uppercase; letter-spacing: .06em; }
.rai-reports .stc-m-v { font: 500 13px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .stc-feb .stc-m-l { color: var(--brand); }
.rai-reports .stc-feb .stc-m-v { color: var(--brand); font-weight: 600; }
.rai-reports .db-card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 18px 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .db-head { display: flex; align-items: center; justify-content: space-between; }
.rai-reports .db-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .db-delta { font: 600 11px var(--font-mono); padding: 2px 8px; border-radius: 999px; font-variant-numeric: tabular-nums; }
.rai-reports .db-delta.up { color: var(--success); background: rgba(79,180,119,.12); }
.rai-reports .db-val { font: 500 36px var(--font-mono); color: var(--fg-1); letter-spacing: -.025em; line-height: 1; font-variant-numeric: tabular-nums; }
.rai-reports .db-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-bottom: 8px; }
.rai-reports .hp-flow {
  display: flex; align-items: center;
  gap: 14px;
  padding: 16px;
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  flex-wrap: wrap;
}
.rai-reports .hp-step.is-accent .hp-num {
  background: var(--success);
  color: white;
}
.rai-reports .is-accent-cell {
  background: linear-gradient(180deg, rgba(79,180,119,.06) 0%, var(--surface-1) 80%) !important;
}
.rai-reports .ns-controls {
  display: flex; align-items: center; gap: 10px;
  margin-top: 16px;
}
.rai-reports .ns-meta { font: 500 11px var(--font-mono); color: var(--fg-3); margin-left: auto; font-variant-numeric: tabular-nums; }
.rai-reports .next-card-actionable {
  grid-template-columns: 80px 1fr auto !important;
  position: relative;
}
.rai-reports .next-card-actionable .next-content { padding-right: 8px; }
.rai-reports .next-actions {
  display: flex; flex-direction: column; gap: 6px;
  align-self: flex-start;
}
.rai-reports .next-act {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .next-act:hover { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .next-act:disabled { opacity: 0.55; cursor: default; }
.rai-reports .next-act-remove:hover { background: var(--danger-bg); color: var(--danger); border-color: rgba(242,107,92,.35); }
.rai-reports .ns-empty {
  margin-top: 24px;
  padding: 36px;
  text-align: center;
  background: var(--surface-page);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .ns-empty-h { font: 600 16px var(--font-ui); color: var(--fg-1); }
.rai-reports .ns-empty-s { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 4px; }
.rai-reports .cl-card-tags {
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
}
.rai-reports .cl-squad {
  display: inline-flex; align-items: center; gap: 4px;
  font: 600 10px var(--font-ui);
  padding: 2px 8px;
  border: 1px solid;
  border-radius: 999px;
  letter-spacing: -.005em;
  white-space: nowrap;
}
.rai-reports .period-seg {
  display: inline-flex;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 3px;
  gap: 1px;
}
.rai-reports .period-btn {
  background: transparent;
  border: none;
  color: var(--fg-3);
  font: 600 11px var(--font-ui);
  padding: 5px 9px;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  letter-spacing: -.004em;
}
.rai-reports .period-btn:hover { color: var(--fg-1); }
.rai-reports .period-btn.on { background: var(--brand-soft); color: var(--brand); }

/* ── Custom date-range picker (calendar popover) ───────────────────────── */
.rai-reports .rep-tb-mid { position: relative; }
.rai-reports .period-btn-custom { display: inline-flex; align-items: center; gap: 5px; max-width: 210px; }
.rai-reports .period-btn-custom svg { flex-shrink: 0; }
.rai-reports .period-btn-custom .pb-custom-lbl { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rai-reports .period-btn-custom.open { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .rep-cal-pop {
  position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%);
  z-index: 60; width: 540px; max-width: calc(100vw - 40px);
  background: var(--surface-1); border: 1px solid var(--border-subtle);
  border-radius: 14px; padding: 14px;
  box-shadow: 0 24px 60px -16px rgba(0,0,0,.55), 0 4px 14px rgba(0,0,0,.3);
  animation: repCalIn .14s var(--ease-out);
}
@keyframes repCalIn { from { opacity: 0; transform: translateX(-50%) translateY(-6px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }
.rai-reports .rep-cal-pop::before {
  content: ''; position: absolute; top: -7px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 12px; height: 12px; background: var(--surface-1);
  border-left: 1px solid var(--border-subtle); border-top: 1px solid var(--border-subtle);
}
.rai-reports .rep-cal-presets { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.rai-reports .rep-cal-preset {
  background: var(--surface-2); border: 1px solid var(--border-subtle); color: var(--fg-2);
  font: 600 11px var(--font-ui); padding: 6px 10px; border-radius: 7px; cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rep-cal-preset:hover { color: var(--brand); border-color: var(--brand); background: var(--brand-soft); }
.rai-reports .rep-cal-body { position: relative; }
.rai-reports .rep-cal-arrow {
  position: absolute; top: 0; width: 28px; height: 28px; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-2); border: 1px solid var(--border-subtle); border-radius: 7px;
  color: var(--fg-2); cursor: pointer; transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .rep-cal-arrow:hover { color: var(--fg-1); border-color: var(--brand); }
.rai-reports .rep-cal-arrow.prev { left: 0; }
.rai-reports .rep-cal-arrow.next { right: 0; }
.rai-reports .rep-cal-months { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.rai-reports .rep-cal-mhead { text-align: center; font: 600 12px var(--font-ui); color: var(--fg-1); margin-bottom: 10px; letter-spacing: -.004em; }
.rai-reports .rep-cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); margin-bottom: 4px; }
.rai-reports .rep-cal-dow span { text-align: center; font: 600 9.5px var(--font-ui); text-transform: uppercase; letter-spacing: .04em; color: var(--fg-3); }
.rai-reports .rep-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.rai-reports .rep-cal-day {
  aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; color: var(--fg-2); font: 500 11.5px var(--font-mono);
  border-radius: 7px; cursor: pointer; padding: 0;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.rai-reports button.rep-cal-day:hover { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .rep-cal-day.is-empty { cursor: default; }
.rai-reports .rep-cal-day.is-disabled { cursor: default; color: var(--fg-3); opacity: .3; }
.rai-reports .rep-cal-day.is-today { box-shadow: inset 0 0 0 1px var(--border-subtle); }
.rai-reports .rep-cal-day.in-range { background: var(--brand-soft); color: var(--brand); border-radius: 0; }
.rai-reports .rep-cal-day.range-edge,
.rai-reports button.rep-cal-day.range-edge:hover { background: var(--brand); color: #fff; box-shadow: none; }
.rai-reports .rep-cal-day.range-start { border-radius: 7px 0 0 7px; }
.rai-reports .rep-cal-day.range-end { border-radius: 0 7px 7px 0; }
.rai-reports .rep-cal-day.range-start.range-end { border-radius: 7px; }
.rai-reports .rep-cal-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--divider);
}
.rai-reports .rep-cal-range { font: 500 12px var(--font-ui); color: var(--fg-2); }
.rai-reports .rep-cal-actions { display: flex; gap: 8px; }
.rai-reports .rep-cal-btn { font: 600 12px var(--font-ui); padding: 8px 14px; border-radius: 8px; cursor: pointer; border: 1px solid transparent; transition: all var(--dur-fast) var(--ease-out); }
.rai-reports .rep-cal-btn.ghost { background: transparent; border-color: var(--border-subtle); color: var(--fg-2); }
.rai-reports .rep-cal-btn.ghost:hover { color: var(--fg-1); border-color: var(--fg-3); }
.rai-reports .rep-cal-btn.primary { background: var(--brand); color: #fff; }
.rai-reports .rep-cal-btn.primary:hover { filter: brightness(1.06); }
.rai-reports .rep-cal-btn.primary.is-disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }

/* ── Chart hover focus — spotlight the hovered metric, dim the rest.
   Opt-in via .rc-focusable (charts pass opts.tip → Social only for now). ── */
.rai-reports .rc-focusable .rc-grp { transition: opacity .12s var(--ease-out); }
.rai-reports svg.rc-focusable:hover .rc-grp { opacity: .28; }
.rai-reports svg.rc-focusable .rc-grp:hover { opacity: 1; }
.rai-reports .demo-bar.rc-focusable .demo-seg { transition: opacity .12s var(--ease-out); }
.rai-reports .demo-bar.rc-focusable:hover .demo-seg { opacity: .35; }
.rai-reports .demo-bar.rc-focusable .demo-seg:hover { opacity: 1; }
.rai-reports .lollipop.rc-focusable .lol-row { transition: opacity .12s var(--ease-out); }
.rai-reports .lollipop.rc-focusable:hover .lol-row { opacity: .4; }
.rai-reports .lollipop.rc-focusable .lol-row:hover { opacity: 1; }
/* Review-breakdown distribution focus-dim (horizontal HTML bars) — spotlight the
   hovered star row, dim the rest, like the SVG charts above. */
.rai-reports .rep-dist.rc-focusable .rep-star-row { transition: opacity .12s var(--ease-out); }
.rai-reports .rep-dist.rc-focusable:hover .rep-star-row { opacity: .35; }
.rai-reports .rep-dist.rc-focusable .rep-star-row:hover { opacity: 1; }
/* Area chart: focus dot + vertical guide line appear on hover of each point */
.rai-reports .rc-pt .pt-dot, .rai-reports .rc-pt .pt-line { opacity: 0; transition: opacity .12s var(--ease-out); }
.rai-reports .rc-pt:hover .pt-dot, .rai-reports .rc-pt:hover .pt-line { opacity: 1; }
/* Funnel: spotlight the hovered stage, dim the rest (opts.tip → .rc-focusable) */
.rai-reports .funnel.rc-focusable .funnel-row { transition: opacity .12s var(--ease-out); }
.rai-reports .funnel.rc-focusable:hover .funnel-row { opacity: .4; }
.rai-reports .funnel.rc-focusable .funnel-row:hover { opacity: 1; }
/* Reservation heatmap: spotlight the hovered hour-cell, dim the grid (legend
   swatches live outside .rh-row so they keep full opacity). */
.rai-reports .rh-wrap.rc-focusable .rh-row .rh-cell { transition: opacity .12s var(--ease-out); }
.rai-reports .rh-wrap.rc-focusable:hover .rh-row .rh-cell { opacity: .45; }
.rai-reports .rh-wrap.rc-focusable .rh-row .rh-cell:hover { opacity: 1; }

/* ── Top posts: green total + caption + external-link, "View full list" link ── */
.rai-reports .top-post-right { display: flex; align-items: center; gap: 10px; }
.rai-reports .tpe-wrap { text-align: right; }
.rai-reports .tpe-cap { font: 500 9px var(--font-ui); text-transform: uppercase; letter-spacing: .06em; color: var(--fg-3); margin-top: 1px; }
.rai-reports .card-link-btn { background: transparent; border: 1px solid var(--border-subtle); color: var(--fg-2); font: 600 11px var(--font-ui); padding: 5px 10px; border-radius: 7px; cursor: pointer; white-space: nowrap; transition: all .12s var(--ease-out); }
.rai-reports .card-link-btn:hover { color: var(--brand); border-color: var(--brand); background: var(--brand-soft); }

/* ── City full-list modal (sibling backdrop + transform-centered modal) ── */
.rai-reports .rep-modal-backdrop { position: fixed; inset: 0; background: rgba(8,6,4,.6); backdrop-filter: blur(5px); z-index: 200; animation: backdrop-in 160ms ease-out; }
.rai-reports .rep-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 201;
  width: 560px; max-width: calc(100vw - 40px); max-height: calc(100vh - 100px);
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--surface-1); border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 4px 16px rgba(0,0,0,.3);
  animation: repCityIn .2s cubic-bezier(.2,.8,.2,1);
}
@keyframes repCityIn { from { opacity: 0; transform: translate(-50%, calc(-50% + 12px)); } to { opacity: 1; transform: translate(-50%, -50%); } }
.rai-reports .rep-modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 18px 20px; border-bottom: 1px solid var(--divider); }
.rai-reports .rep-modal-head h3 { margin: 0; font: 600 15px var(--font-ui); color: var(--fg-1); letter-spacing: -.01em; }
.rai-reports .rep-modal-head .sub { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 3px; }
.rai-reports .rep-modal-close { width: 30px; height: 30px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: var(--surface-2); border: 1px solid var(--border-subtle); border-radius: 8px; color: var(--fg-2); cursor: pointer; transition: all .12s var(--ease-out); }
.rai-reports .rep-modal-close:hover { color: var(--fg-1); border-color: var(--fg-3); }
.rai-reports .rep-modal-body { flex: 1; overflow-y: auto; padding: 8px 12px 14px; }
.rai-reports .city-row { display: grid; grid-template-columns: 22px 1fr 80px 64px 52px; align-items: center; gap: 10px; padding: 8px; border-radius: 8px; }
.rai-reports .city-row:hover { background: var(--surface-2); }
.rai-reports .city-rank { font: 600 11px var(--font-mono); color: var(--fg-3); text-align: center; }
.rai-reports .city-name { font: 500 13px var(--font-ui); color: var(--fg-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rai-reports .city-track { height: 6px; background: var(--surface-3); border-radius: 3px; overflow: hidden; }
.rai-reports .city-fill { display: block; height: 100%; background: #E1306C; border-radius: 3px; }
.rai-reports .city-count { font: 600 12px var(--font-mono); color: var(--fg-1); text-align: right; font-variant-numeric: tabular-nums; }
.rai-reports .city-pct { font: 500 12px var(--font-mono); color: var(--fg-3); text-align: right; font-variant-numeric: tabular-nums; }

/* ── Data-availability notice (amber) — e.g. demographics only current, not historical ── */
.rai-reports .data-notice {
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(245, 180, 60, 0.10);
  border: 1px solid rgba(245, 180, 60, 0.28);
  border-radius: 9px; padding: 9px 12px; margin-bottom: 14px;
  font: 400 12px var(--font-ui); color: var(--fg-2); line-height: 1.45;
}
.rai-reports .data-notice svg { color: #F5B43C; flex-shrink: 0; margin-top: 1px; }
.rai-reports .data-notice strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .live-warn {
  display: inline-flex; align-items: center; gap: 4px;
  font: 500 10.5px var(--font-ui);
  color: var(--warning);
  background: rgba(244,169,58,.1);
  border: 1px solid rgba(244,169,58,.25);
  padding: 2px 9px;
  border-radius: 999px;
}
.rai-reports .live-warn svg { flex-shrink: 0; }
.rai-reports .no-data-box {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 36px 18px;
  text-align: center;
  background: var(--surface-page);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-md);
}
.rai-reports .no-data-box .nd-mark {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--surface-2);
  color: var(--fg-3);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.rai-reports .no-data-box .nd-h { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .no-data-box .nd-s { font: 400 11.5px var(--font-ui); color: var(--fg-3); max-width: 320px; line-height: 1.5; }
.rai-reports .rvs-stack { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.rai-reports .rvs-row {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
}
.rai-reports .rvs-dot { width: 10px; height: 10px; border-radius: 50%; }
.rai-reports .rvs-l { font: 500 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .rvs-v { font: 500 16px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .rvs-row-meta { background: transparent; border-color: transparent; }
.rai-reports .rvs-row-meta .rvs-l { color: var(--fg-3); font-weight: 400; }
.rai-reports .rvs-row-meta .rvs-v { color: var(--success); font-weight: 600; }
/* Total Reviews vs QR Scans — donut + legend layout (agency-report design) */
.rai-reports .rvs-wrap { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.rai-reports .rvs-donut { position: relative; width: 150px; height: 150px; flex-shrink: 0; }
.rai-reports .rvs-donut-c { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.rai-reports .rvs-donut-num { font: 700 26px var(--font-ui); color: var(--fg-1); letter-spacing: -.02em; line-height: 1; }
.rai-reports .rvs-donut-lbl { font: 600 9px var(--font-ui); letter-spacing: .14em; color: var(--fg-3); text-transform: uppercase; margin-top: 4px; }
.rai-reports .rvs-donut + .rvs-stack, .rai-reports .rvs-wrap .rvs-stack { flex: 1; min-width: 240px; }
/* Google Reviews vs QR Scans · by location — dual-bar VISUAL cell */
.rai-reports .qr-bars { display: flex; flex-direction: column; gap: 5px; min-width: 150px; }
.rai-reports .qr-bar-track { height: 7px; background: var(--surface-3); border-radius: 4px; overflow: hidden; }
.rai-reports .qr-bar { height: 100%; border-radius: 4px; }
.rai-reports .qr-bar-g { background: #4285F4; }
.rai-reports .qr-bar-q { background: var(--brand); }
/* ── Reviews vs QR Scans (unified) — gauge + totals + per-location ranking ── */
.rai-reports .qr-top { display: flex; align-items: center; gap: 26px; padding: 2px 4px 8px; flex-wrap: wrap; }
.rai-reports .qr-gauge { position: relative; width: 124px; height: 124px; flex-shrink: 0; }
.rai-reports .qr-gauge-c { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; pointer-events: none; }
.rai-reports .qr-gauge-num { font: 600 24px var(--font-mono); color: var(--fg-1); letter-spacing: -.02em; line-height: 1; font-variant-numeric: tabular-nums; }
.rai-reports .qr-gauge-lbl { font: 600 10.5px var(--font-ui); text-transform: uppercase; letter-spacing: .07em; color: var(--fg-3); margin-top: 5px; white-space: nowrap; }
.rai-reports .qr-nums { display: flex; flex-direction: column; gap: 12px; flex-shrink: 0; }
.rai-reports .qr-stat { display: flex; align-items: baseline; gap: 12px; }
.rai-reports .qr-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; align-self: center; }
.rai-reports .qr-stat-l { font: 500 13px var(--font-ui); color: var(--fg-2); width: 132px; flex-shrink: 0; white-space: nowrap; }
.rai-reports .qr-stat-v { font: 600 17px var(--font-mono); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.rai-reports .qr-note { flex: 1; min-width: 200px; align-self: stretch; display: flex; align-items: center; padding-left: 24px; border-left: 1px solid var(--divider); font: 400 13px var(--font-ui); color: var(--fg-3); line-height: 1.55; }
.rai-reports .qr-loc-head { font: 600 11px var(--font-ui); text-transform: uppercase; letter-spacing: .08em; color: var(--fg-3); padding: 14px 6px 10px; margin-top: 2px; border-top: 1px solid var(--divider); }
.rai-reports .qr-loc-hint { text-transform: none; letter-spacing: 0; font-weight: 400; opacity: .85; }
.rai-reports .qr-loc-list { display: flex; flex-direction: column; gap: 10px; padding: 0 6px 4px; }
.rai-reports .qr-loc-row { display: flex; align-items: center; gap: 14px; }
.rai-reports .qr-loc-name { font: 600 13px var(--font-ui); color: var(--fg-1); width: 88px; flex-shrink: 0; }
.rai-reports .qr-loc-raw { font: 500 12px var(--font-mono); color: var(--fg-3); width: 168px; flex-shrink: 0; font-variant-numeric: tabular-nums; white-space: nowrap; }
.rai-reports .qr-loc-bar-track { flex: 1; height: 10px; background: var(--surface-3); border-radius: 5px; overflow: hidden; min-width: 50px; }
.rai-reports .qr-loc-bar { height: 100%; background: var(--brand); border-radius: 5px; transition: width .3s var(--ease-out); }
.rai-reports .qr-loc-pct { font: 600 13px var(--font-mono); color: var(--brand); width: 50px; text-align: right; flex-shrink: 0; font-variant-numeric: tabular-nums; }
.rai-reports .qr-loc-list.rc-focusable .qr-loc-row { transition: opacity .12s var(--ease-out); }
.rai-reports .qr-loc-list.rc-focusable:hover .qr-loc-row { opacity: .35; }
.rai-reports .qr-loc-list.rc-focusable .qr-loc-row:hover { opacity: 1; }
/* Priority response queue — subtle reply link (declutter: no badge, no fill) */
.rai-reports .rep-reply-link {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11px var(--font-ui); color: var(--fg-3);
  text-decoration: none; padding: 4px 9px; border-radius: 6px;
  border: none; background: transparent; cursor: pointer;
  transition: color var(--dur-fast, .12s) ease, background var(--dur-fast, .12s) ease;
}
.rai-reports .rep-reply-link:hover { color: var(--brand); background: var(--brand-soft); }
/* Expanded response inside a 1-2★ review row */
.rai-reports .brr-response { margin-top: 10px; padding: 10px 12px; border-left: 2px solid var(--brand); background: var(--surface-2); border-radius: 0 6px 6px 0; }
.rai-reports .brr-response-lbl { display: flex; align-items: center; gap: 5px; font: 600 10px var(--font-ui); letter-spacing: .06em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 5px; }
.rai-reports .brr-response-text { font: 400 13px var(--font-ui); line-height: 1.55; color: var(--fg-1); white-space: pre-wrap; }
/* Respond-from-report modal */
.rai-reports .rep-respond-text { width: 100%; box-sizing: border-box; resize: vertical; min-height: 120px; padding: 10px 12px; border: 1px solid var(--border-default); border-radius: 8px; background: var(--surface-1); color: var(--fg-1); font: 400 14px var(--font-ui); line-height: 1.5; }
.rai-reports .rep-respond-text:focus { outline: none; border-color: var(--brand); }
.rai-reports .rep-respond-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 14px; }
.rai-reports .rep-respond-cancel { font: 600 12px var(--font-ui); padding: 8px 14px; border-radius: 8px; border: 1px solid var(--border-default); background: transparent; color: var(--fg-2); cursor: pointer; }
.rai-reports .rep-respond-cancel:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .rep-respond-improve { display: inline-flex; align-items: center; gap: 6px; margin-right: auto; font: 600 12px var(--font-ui); padding: 8px 14px; border-radius: 8px; border: 1px solid var(--border-default); background: transparent; color: var(--brand); cursor: pointer; }
.rai-reports .rep-respond-improve:hover { background: color-mix(in srgb, var(--brand) 10%, transparent); border-color: var(--brand); }
.rai-reports .rep-respond-improve:disabled { opacity: .55; cursor: default; }
.rai-reports .rep-respond-submit { display: inline-flex; align-items: center; gap: 6px; font: 600 12px var(--font-ui); padding: 8px 16px; border-radius: 8px; border: 1px solid var(--brand); background: var(--brand); color: #fff; cursor: pointer; }
.rai-reports .rep-respond-submit:hover { filter: brightness(1.06); }
.rai-reports .rep-respond-submit:disabled { opacity: .6; cursor: default; }
.rai-reports .ai-sum-lead { font: 400 14px var(--font-ui); line-height: 1.6; color: var(--fg-2); margin: 0 0 14px; }
.rai-reports .ai-sum-h {
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
  margin: 18px 0 8px;
}
.rai-reports .ai-sum-list {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .ai-sum-list li {
  font: 400 13px var(--font-ui);
  color: var(--fg-2);
  padding: 6px 12px;
  background: var(--surface-page);
  border-left: 2px solid var(--brand-soft-hi, rgba(251,95,44,.2));
  border-radius: 0 6px 6px 0;
  line-height: 1.55;
}
.rai-reports .ai-sum-list li strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .ai-sum-list li em { color: var(--brand); font-style: normal; font-weight: 600; }
.rai-reports .roas-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.rai-reports .roas-head { display: flex; align-items: center; gap: 10px; }
.rai-reports .roas-name { font: 600 14px var(--font-ui); color: var(--fg-1); letter-spacing: -.008em; }
.rai-reports .roas-sub { font: 500 11px var(--font-mono); color: var(--fg-3); font-variant-numeric: tabular-nums; }
.rai-reports .roas-pill {
  font: 600 11px var(--font-mono);
  padding: 4px 10px;
  border-radius: 999px;
  margin-left: auto;
  letter-spacing: .02em;
}
.rai-reports .roas-bar {
  display: flex;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface-3);
}
.rai-reports .roas-spend, .rai-reports .roas-return { transition: width var(--dur-base) var(--ease-out); }
.rai-reports .roas-legend {
  display: flex; gap: 14px;
  font: 500 12.5px var(--font-ui);
  color: var(--fg-2);
}
.rai-reports .roas-legend span { display: inline-flex; align-items: center; gap: 5px; }
.rai-reports .local-grid-wrap {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 24px;
  align-items: stretch;
}
@media (max-width: 900px) {
.rai-reports .local-grid-wrap { grid-template-columns: 1fr; }
}
.rai-reports .local-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  padding: 18px;
  background:
    radial-gradient(circle at 50% 50%, rgba(251,95,44,.06), transparent 60%),
    repeating-linear-gradient(0deg,  rgba(255,255,255,.025) 0 1px, transparent 1px 24px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0 1px, transparent 1px 24px),
    var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  position: relative;
  aspect-ratio: 1;
}
.rai-reports .local-cell {
  aspect-ratio: 1;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font: 700 11px var(--font-mono);
  color: rgba(20,17,13,.85);
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out);
}
.rai-reports .local-cell:hover { transform: scale(1.08); z-index: 2; }
.rai-reports .local-pin {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-size: 26px;
  filter: drop-shadow(0 4px 8px rgba(251,95,44,.6));
  pointer-events: none;
  z-index: 3;
}
.rai-reports .local-side {
  display: flex; flex-direction: column; gap: 14px;
  justify-content: space-between;
}
.rai-reports .local-stat {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 2px;
}
.rai-reports .local-stat-l { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .local-stat-v { font: 500 22px var(--font-mono); color: var(--fg-1); letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.rai-reports .local-stat-s { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .local-comp {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .local-comp-h { font: 600 10px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); margin-bottom: 2px; }
.rai-reports .local-comp-row { display: flex; align-items: center; justify-content: space-between; }
.rai-reports .local-comp-n { font: 500 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .local-comp-p {
  font: 600 10px var(--font-mono);
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid;
  font-variant-numeric: tabular-nums;
}
.rai-reports .local-legend {
  display: flex; align-items: center; gap: 6px;
  font: 500 10px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .local-leg-dot { width: 8px; height: 8px; border-radius: 2px; display: inline-block; }
.rai-reports .local-leg-dot + .local-leg-dot { margin-left: 8px; }
.rai-reports .rsh-eyebrow em {
  font-style: normal;
  font-weight: 700;
  color: var(--brand);
  letter-spacing: -.005em;
  text-transform: uppercase;
}
.rai-reports .lsm-wrap {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 18px;
  align-items: stretch;
}
@media (max-width: 900px) {
.rai-reports .lsm-wrap { grid-template-columns: 1fr; }
}
.rai-reports .lsm-list { display: flex; flex-direction: column; gap: 8px; }
.rai-reports .lsm-entry {
  display: grid;
  grid-template-columns: 28px 1fr;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  transition: all var(--dur-fast) var(--ease-out);
}
.rai-reports .lsm-entry:hover { border-color: var(--border-strong); }
.rai-reports .lsm-entry.is-you {
  background: linear-gradient(90deg, rgba(34,197,94,.08), transparent 80%);
  border-color: rgba(34,197,94,.35);
}
.rai-reports .lsm-rank {
  font: 600 14px var(--font-mono);
  color: var(--fg-3);
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.rai-reports .lsm-entry.is-you .lsm-rank { color: var(--success); }
.rai-reports .lsm-meta { display: flex; flex-direction: column; gap: 3px; }
.rai-reports .lsm-name {
  font: 600 13px var(--font-ui);
  color: var(--fg-1);
  display: inline-flex; align-items: center; gap: 5px;
  letter-spacing: -.005em;
}
.rai-reports .lsm-name svg { color: var(--fg-3); flex-shrink: 0; }
.rai-reports .lsm-you-pill {
  font: 600 9.5px var(--font-ui);
  background: var(--success);
  color: white;
  padding: 1px 7px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-left: 4px;
}
.rai-reports .lsm-addr { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .lsm-rating { display: inline-flex; align-items: center; gap: 5px; margin-top: 1px; font: 500 11px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .lsm-r-num { color: var(--fg-1); font-weight: 600; }
.rai-reports .lsm-r-stars { letter-spacing: 1px; font-size: 11px; }
.rai-reports .lsm-r-count { color: var(--fg-3); }
.rai-reports .lsm-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 6px;
}
.rai-reports .lsm-stat {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 10px 14px;
}
.rai-reports .lsm-stat-l { font: 600 9.5px var(--font-ui); text-transform: uppercase; letter-spacing: .1em; color: var(--fg-3); }
.rai-reports .lsm-stat-v { font: 500 22px var(--font-mono); color: var(--fg-1); letter-spacing: -.02em; line-height: 1.1; font-variant-numeric: tabular-nums; }
/* Interactive Mapbox geo-grid container (replaces the old synthetic beige map). */
.rai-reports .lsm-map {
  position: relative;
  background: var(--surface-2, #15161a);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-height: 380px;
  height: 380px;
  border: 1px solid var(--border-default);
}
.rai-reports .lsm-map .mapboxgl-ctrl-logo,
.rai-reports .lsm-map .mapboxgl-ctrl-attrib,
.rai-reports .lsm-map .mapboxgl-ctrl-bottom-left { display: none !important; }
.rai-reports .lsm-map .slm-empty {
  display: flex; align-items: center; justify-content: center; height: 100%;
  color: var(--fg-3); font: 400 13px var(--font-ui); text-align: center; padding: 24px;
}
/* Per-point marker: colored disc with the rank number. */
.rai-reports .slm-dot {
  width: 30px; height: 30px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px var(--font-ui);
  color: #fff;
  border: 2px solid rgba(255,255,255,.85);
  box-shadow: 0 2px 6px rgba(0,0,0,.35);
  cursor: pointer;
  transition: transform .12s ease-out;
}
.rai-reports .slm-dot:hover { transform: scale(1.18); z-index: 3; }
/* Popup: who ranks at this point. */
.rai-reports .slm-popup .mapboxgl-popup-content {
  background: var(--surface-1, #1c1d22); border: 1px solid var(--border-default);
  border-radius: 12px; padding: 10px 12px; box-shadow: var(--shadow-md, 0 8px 24px rgba(0,0,0,.4));
}
.rai-reports .slm-popup .mapboxgl-popup-tip { display: none; }
.rai-reports .slm-pop-head { margin-bottom: 6px; }
.rai-reports .slm-pop-rank { display: inline-block; padding: 2px 9px; border-radius: 9px; color: #fff; font: 700 11px var(--font-ui); }
.rai-reports .slm-pop-list-lbl { font: 600 9px var(--font-ui); letter-spacing: .06em; text-transform: uppercase; color: var(--fg-3); margin: 4px 0 4px; }
.rai-reports .slm-pop-row { display: block; padding: 4px 0; font: 400 12px var(--font-ui); color: var(--fg-2); }
.rai-reports .slm-pop-row + .slm-pop-row { border-top: 1px solid rgba(255,255,255,.05); }
.rai-reports .slm-pop-rowtop { display: flex; align-items: center; gap: 7px; }
.rai-reports .slm-pop-row.is-you { color: var(--brand-orange, #FB5F2C); font-weight: 600; }
.rai-reports .slm-pop-pos { flex: 0 0 16px; text-align: center; font-weight: 700; color: var(--fg-3); }
.rai-reports .slm-pop-row.is-you .slm-pop-pos { color: var(--brand-orange, #FB5F2C); }
.rai-reports .slm-pop-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rai-reports .slm-pop-meta { font: 500 10.5px var(--font-ui); color: var(--fg-3); margin: 2px 0 0 23px; }
.rai-reports .slm-pop-cats { display: flex; flex-wrap: wrap; gap: 3px; margin: 4px 0 0 23px; }
.rai-reports .slm-pop-cat { font: 600 9.5px var(--font-ui); color: var(--fg-2); background: rgba(255,255,255,.06); border: 1px solid var(--ink-200); border-radius: 4px; padding: 1px 5px; }
.rai-reports .lsm-legend {
  display: flex; gap: 16px;
  margin-top: 14px;
  font: 500 12.5px var(--font-ui);
  color: var(--fg-2);
  justify-content: center;
}
.rai-reports .lsm-legend span { display: inline-flex; align-items: center; gap: 5px; }
.rai-reports .lsm-leg-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  display: inline-block;
}

/* ── Category chips + address on each competitor entry ── */
.rai-reports .lsm-cats { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.rai-reports .lsm-cat {
  font: 600 11px var(--font-ui);
  color: var(--fg-2);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--ink-200);
  border-radius: 5px;
  padding: 2px 6px;
  white-space: nowrap;
}
.rai-reports .lsm-entry.is-you .lsm-cat { border-color: rgba(34,197,94,.4); color: var(--fg-1); }
.rai-reports .lsm-addr {
  margin-top: 5px;
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .lsm-gmaps {
  color: var(--brand-orange, #FB5F2C);
  text-decoration: none; font-weight: 600;
  display: inline-flex; align-items: center; gap: 2px;
}
.rai-reports .lsm-gmaps:hover { text-decoration: underline; }
.rai-reports .lsm-more { margin-top: 2px; }
.rai-reports .lsm-more-sum {
  cursor: pointer; list-style: none;
  font: 600 11.5px var(--font-ui); color: var(--brand-orange, #FB5F2C);
  padding: 7px 0 3px; user-select: none;
}
.rai-reports .lsm-more-sum::-webkit-details-marker { display: none; }
.rai-reports .lsm-more-sum::before { content: '▸ '; }
.rai-reports .lsm-more[open] > .lsm-more-sum::before { content: '▾ '; }
.rai-reports .lsm-more[open] > .lsm-more-sum { color: var(--fg-3); }

/* ── Optimization recommendations panel ── */
.rai-reports .lsm-recs {
  margin-top: 18px;
  border-top: 1px solid var(--ink-200);
  padding-top: 16px;
}
.rai-reports .lsm-recs-head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.rai-reports .lsm-recs-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 7px;
  background: linear-gradient(135deg, #FB5F2C, #F4A93A); color: #fff;
}
.rai-reports .lsm-recs-title { font: 700 14px var(--font-ui); color: var(--fg-1); }
.rai-reports .lsm-recs-sub { font: 500 11.5px var(--font-ui); color: var(--fg-3); }
.rai-reports .lsm-rec {
  display: flex;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--ink-200);
  border-radius: 10px;
  margin-bottom: 8px;
  overflow: hidden;
}
.rai-reports .lsm-rec-bar { width: 3px; flex: none; align-self: stretch; }
.rai-reports .lsm-rec-main { padding: 11px 13px; flex: 1; min-width: 0; }
.rai-reports .lsm-rec-title {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
  font: 700 13px var(--font-ui); color: var(--fg-1);
}
.rai-reports .lsm-rec-ic { display: inline-flex; }
.rai-reports .lsm-rec-sev {
  font: 700 9.5px var(--font-ui); text-transform: uppercase; letter-spacing: .04em;
  border: 1px solid currentColor; border-radius: 5px; padding: 1px 5px; margin-left: auto;
}
.rai-reports .lsm-rec-text { font: 500 12px/1.5 var(--font-ui); color: var(--fg-2); margin-top: 5px; }
.rai-reports .lsm-rec-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 9px; }
.rai-reports .lsm-rec-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11px var(--font-ui); color: var(--fg-1);
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.35);
  border-radius: 6px; padding: 3px 8px;
}
.rai-reports .lsm-rec-chip-n { font-weight: 500; font-size: 9.5px; color: var(--fg-3); }
.rai-reports .ins-brief {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 18px;
  padding: 22px 24px;
  background: linear-gradient(135deg, rgba(251,95,44,.1), rgba(251,95,44,.02) 60%, var(--surface-1)) ;
  border: 1px solid rgba(251,95,44,.3);
  border-radius: var(--radius-lg);
  margin-bottom: 14px;
}
.rai-reports .ins-brief-mark { display: flex; align-items: flex-start; padding-top: 4px; }
.rai-reports .ins-brief-eyebrow {
  display: flex; align-items: center; gap: 8px;
  font: 600 11px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--brand);
  margin-bottom: 6px;
}
.rai-reports .ins-brief-sep { color: var(--ink-300); }
.rai-reports .ins-brief-text {
  font: 400 16px var(--font-ui);
  line-height: 1.6;
  color: var(--fg-2);
  margin: 0 0 14px;
  max-width: 880px;
}
.rai-reports .ins-brief-text strong { color: var(--fg-1); font-weight: 600; }
.rai-reports .ins-brief-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.rai-reports .ins-tag {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 11px var(--font-ui);
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
}
.rai-reports .ins-tag-up { color: var(--success); border-color: rgba(79,180,119,.3); background: rgba(79,180,119,.08); }
.rai-reports .ins-tag-down { color: var(--danger); border-color: rgba(242,107,92,.3); background: rgba(242,107,92,.08); }
.rai-reports .anom-row {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--divider);
  align-items: flex-start;
  cursor: pointer;
  transition: background var(--dur-fast);
}
.rai-reports .anom-row:hover { background: var(--surface-2); }
.rai-reports .anom-row:last-child { border-bottom: none; }
.rai-reports .anom-row-ico {
  width: 26px; height: 26px;
  border-radius: 8px;
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--fg-3);
}
.rai-reports .anom-row-up .anom-row-ico { background: rgba(79,180,119,.12); color: var(--success); }
.rai-reports .anom-row-down .anom-row-ico { background: rgba(242,107,92,.12); color: var(--danger); }
.rai-reports .anom-row-flat .anom-row-ico { background: var(--surface-3); color: var(--fg-2); }
.rai-reports .anom-row-head {
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.rai-reports .anom-row-client {
  font: 600 13px var(--font-ui);
  color: var(--fg-1);
  letter-spacing: -.005em;
}
.rai-reports .anom-row-client:hover { color: var(--brand); text-decoration: underline; }
.rai-reports .anom-row-area {
  font: 600 9.5px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 1px 7px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.rai-reports .anom-row-time { font: 500 11px var(--font-mono); color: var(--fg-muted); margin-left: auto; }
.rai-reports .anom-row-text { font: 400 12.5px var(--font-ui); color: var(--fg-2); line-height: 1.5; }
.rai-reports .watch-row {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px 18px;
  border-bottom: 1px solid var(--divider);
  cursor: pointer;
  transition: background var(--dur-fast);
}
.rai-reports .watch-row:hover { background: var(--surface-2); }
.rai-reports .watch-row:last-child { border-bottom: none; }
.rai-reports .watch-mark {
  width: 30px; height: 30px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font: 600 13px var(--font-ui);
}
.rai-reports .watch-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .watch-sub { font: 400 11px var(--font-ui); color: var(--fg-3); }
.rai-reports .watch-mom { font: 600 12px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .mover-list { display: flex; flex-direction: column; gap: 2px; }
.rai-reports .mover-head {
  font: 600 10px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--success);
  padding: 8px 0 4px;
}
.rai-reports .mover-head-d { color: var(--danger); margin-top: 6px; }
.rai-reports .mover-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0;
  cursor: pointer;
}
.rai-reports .mover-row:hover .mover-name { color: var(--brand); }
.rai-reports .mover-name { font: 500 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .mover-mom { font: 600 12px var(--font-mono); font-variant-numeric: tabular-nums; }
.rai-reports .mover-mom.up { color: var(--success); }
.rai-reports .mover-mom.down { color: var(--danger); }
.rai-reports .squad-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
@media (max-width: 900px) {
.rai-reports .squad-grid { grid-template-columns: repeat(2, 1fr); }
}
.rai-reports .squad-card {
  background: var(--surface-page);
  border: 1px solid var(--border-default);
  border-left: 3px solid var(--sq-color, var(--brand));
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 6px;
}
.rai-reports .squad-head { display: flex; align-items: center; gap: 8px; }
.rai-reports .squad-emoji { font-size: 16px; }
.rai-reports .squad-name { font: 600 12px var(--font-ui); color: var(--fg-1); }
.rai-reports .squad-count {
  margin-left: auto;
  font: 600 10px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 1px 7px;
  border-radius: 999px;
}
.rai-reports .squad-mom { font: 500 26px var(--font-mono); letter-spacing: -.025em; line-height: 1; font-variant-numeric: tabular-nums; }
.rai-reports .squad-meta {
  display: flex; justify-content: space-between;
  font: 500 10px var(--font-mono);
  color: var(--fg-3);
}
.rai-reports .squad-warn { color: var(--warning); }
.rai-reports .resty-portfolio {
  max-width: 720px;
  margin: 40px auto;
  text-align: center;
  padding: 60px 32px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
}
.rai-reports .resty-portfolio-mark { display: inline-flex; margin-bottom: 18px; }
.rai-reports .resty-portfolio-h { font: 600 24px var(--font-ui); color: var(--fg-1); letter-spacing: -.02em; margin-bottom: 6px; }
.rai-reports .resty-portfolio-s { font: 400 13px var(--font-ui); color: var(--fg-3); margin-bottom: 24px; }
.rai-reports .resty-portfolio-list { display: flex; flex-direction: column; gap: 6px; }
.rai-reports .resty-port-q {
  display: inline-flex; align-items: center; gap: 8px;
  text-align: left;
  background: var(--surface-page);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 10px 14px;
  color: var(--fg-2);
  font: 500 13px var(--font-ui);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.rai-reports .resty-port-q:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .resty-port-q svg { color: var(--brand); flex-shrink: 0; }
.rai-reports .sends-toolbar {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
  padding: 14px 16px;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  margin-bottom: 12px;
}
.rai-reports .sends-period {
  display: flex; align-items: center; gap: 8px;
  padding-right: 16px;
  border-right: 1px solid var(--divider);
}
.rai-reports .period-nav {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 7px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.rai-reports .period-nav:hover { background: var(--surface-3); color: var(--fg-1); }
.rai-reports .sends-period-label { padding: 0 8px; min-width: 220px; }
.rai-reports .sp-month { font: 600 16px var(--font-ui); color: var(--fg-1); letter-spacing: -.015em; }
.rai-reports .sp-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 1px; }
.rai-reports .period-today {
  font: 600 11px var(--font-ui);
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  padding: 6px 11px;
  border-radius: 7px;
  cursor: pointer;
}
.rai-reports .period-today:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .sends-filters { display: flex; gap: 8px; align-items: center; justify-content: flex-end; }
.rai-reports .sends-search {
  position: relative;
  display: flex; align-items: center;
  flex: 0 1 280px;
}
.rai-reports .sends-search svg { position: absolute; left: 10px; color: var(--fg-muted); }
.rai-reports .sends-search input {
  width: 100%;
  padding: 7px 10px 7px 30px;
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  color: var(--fg-1);
  font: 500 12px var(--font-ui);
  outline: none;
}
.rai-reports .sends-search input:focus { border-color: var(--brand); }
.rai-reports .sends-tabs {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 0;
  margin-bottom: 8px;
}
.rai-reports .sends-tab {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 12px var(--font-ui);
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--fg-2);
  padding: 6px 12px 6px 11px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast);
}
.rai-reports .sends-tab:hover { background: var(--surface-2); color: var(--fg-1); }
.rai-reports .sends-tab.on { background: var(--surface-2); }
.rai-reports .sends-tab-count {
  font: 600 10px var(--font-mono);
  background: var(--surface-3);
  color: var(--fg-3);
  padding: 1px 7px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .sends-result-meta {
  font: 500 11px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
}
.rai-reports .sends-list-card { padding: 0; overflow: hidden; }
.rai-reports .sends-table { width: 100%; }
.rai-reports .sends-table th { padding: 10px 14px; font-size: 9.5px; }
.rai-reports .sends-table td { padding: 11px 14px; vertical-align: middle; }
.rai-reports .sends-row.is-sel { background: var(--brand-soft); }
.rai-reports .sends-row:hover { background: var(--surface-2); }
.rai-reports .sends-check { accent-color: var(--brand); cursor: pointer; }
.rai-reports .sends-client { display: flex; align-items: center; gap: 10px; }
.rai-reports .sends-client-mark {
  width: 30px; height: 30px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font: 600 13px var(--font-ui);
  flex-shrink: 0;
}
.rai-reports .sends-client-name { font: 600 13px var(--font-ui); color: var(--fg-1); }
.rai-reports .sends-client-sub { font: 400 11px var(--font-ui); color: var(--fg-3); margin-top: 1px; }
.rai-reports .sends-squad {
  display: inline-flex; align-items: center; gap: 5px;
  font: 600 10.5px var(--font-ui);
  padding: 2px 9px;
  border: 1px solid;
  border-radius: 999px;
}
.rai-reports .sends-status {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 11px var(--font-ui);
  padding: 3px 9px 3px 8px;
  border-radius: 999px;
}
.rai-reports .sends-status .ss-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.rai-reports .sends-status-sent { color: var(--success); background: rgba(79,180,119,.12); }
.rai-reports .sends-status-sent    .ss-dot { background: var(--success); box-shadow: 0 0 6px var(--success); }
.rai-reports .sends-status-pending { color: var(--warning); background: rgba(244,169,58,.12); }
.rai-reports .sends-status-pending .ss-dot { background: var(--warning); }
.rai-reports .sends-status-failed { color: var(--danger); background: rgba(242,107,92,.12); }
.rai-reports .sends-status-failed  .ss-dot { background: var(--danger); }
.rai-reports .sends-actions { display: inline-flex; gap: 4px; justify-content: flex-end; }
.rai-reports .sends-act {
  width: 26px; height: 26px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--fg-3);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--dur-fast);
}
.rai-reports .sends-act:hover { background: var(--brand-soft); color: var(--brand); border-color: rgba(251,95,44,.3); }
.rai-reports .sends-empty { padding: 40px 20px; text-align: center; }
.rai-reports .sends-empty-h { font: 600 14px var(--font-ui); color: var(--fg-1); }
.rai-reports .sends-empty-s { font: 400 12px var(--font-ui); color: var(--fg-3); margin-top: 4px; }
.rai-reports .sends-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--border-subtle);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.rai-reports .sends-cal-dow {
  background: var(--surface-page);
  padding: 8px 10px;
  font: 600 9.5px var(--font-ui);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--fg-3);
}
.rai-reports .sends-cal-cell {
  background: var(--surface-1);
  min-height: 110px;
  padding: 6px 8px;
  display: flex; flex-direction: column; gap: 4px;
}
.rai-reports .sends-cal-cell.is-empty { background: var(--surface-page); opacity: .6; }
.rai-reports .sends-cal-num {
  font: 500 12px var(--font-mono);
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
}
.rai-reports .sends-cal-chips { display: flex; flex-direction: column; gap: 3px; }
.rai-reports .sends-cal-chip {
  display: flex; align-items: center; gap: 5px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--surface-2);
  font: 500 10.5px var(--font-ui);
  color: var(--fg-1);
  cursor: pointer;
  transition: background var(--dur-fast);
  overflow: hidden;
}
.rai-reports .sends-cal-chip:hover { background: var(--brand-soft); color: var(--brand); }
.rai-reports .sends-cal-chip.ss-sent { border-left: 2px solid var(--success); }
.rai-reports .sends-cal-chip.ss-pending { border-left: 2px solid var(--warning); }
.rai-reports .sends-cal-chip.ss-failed { border-left: 2px solid var(--danger); }
.rai-reports .sends-cal-chip .ss-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.rai-reports .sends-cal-chip-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 10.5px; }
.rai-reports .sends-cal-more {
  font: 500 10px var(--font-mono);
  color: var(--fg-3);
  padding: 2px 6px;
}
.rai-reports .sends-cal-legend {
  display: flex; gap: 14px;
  font: 500 11px var(--font-ui);
  color: var(--fg-3);
}
.rai-reports .sends-cal-legend span { display: inline-flex; align-items: center; gap: 5px; }
.rai-reports .ss-dot-sent { background: var(--success); }
.rai-reports .ss-dot-pending { background: var(--warning); }
.rai-reports .ss-dot-failed { background: var(--danger); }
.rai-reports .ss-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.rai-reports .sidebar-section-label {
  display: flex; align-items: baseline;
}
.rai-reports .sidebar-section-label > .count {
  margin-left: auto;
}
.rai-reports .sidebar-health-filter {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding: 2px 8px 10px;
}
.rai-reports .shf-chip {
  display: inline-flex; align-items: center; gap: 4px;
  font: 600 10px var(--font-ui);
  background: transparent;
  border: 1px solid var(--border-subtle);
  color: var(--fg-3);
  padding: 3px 7px;
  border-radius: 999px;
  cursor: pointer;
  transition: all var(--dur-fast);
}
.rai-reports .shf-chip:hover { color: var(--fg-1); background: var(--surface-2); }
.rai-reports .shf-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  display: inline-block;
}
.rai-reports .shf-count {
  font: 600 9px var(--font-mono);
  background: var(--surface-2);
  color: var(--fg-3);
  padding: 0 5px;
  border-radius: 999px;
  margin-left: 2px;
  font-variant-numeric: tabular-nums;
}
.rai-reports .shf-chip.on .shf-count { background: rgba(255,255,255,.12); color: inherit; }
.rai-reports .sidebar-clients-scroll {
  flex: 1 1 auto;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 2px;
  padding: 0 4px;
  margin: 0 -4px;
  max-height: calc(100vh - 460px);
  min-height: 200px;
}
.rai-reports .sidebar-clients-scroll::-webkit-scrollbar { width: 6px; }
.rai-reports .sidebar-client {
  position: relative;
  padding-left: 14px !important;
  border-left: 2px solid transparent;
}
.rai-reports .sidebar-client.sb-cli-risk { border-left-color: rgba(242,107,92,.6); }
.rai-reports .sidebar-client.sb-cli-watch { border-left-color: rgba(244,169,58,.6); }
.rai-reports .sidebar-client.sb-cli-good { border-left-color: rgba(108,169,242,.55); }
.rai-reports .sidebar-client.sb-cli-great { border-left-color: rgba(79,180,119,.55); }
.rai-reports .sidebar-client.sb-cli-risk.active { border-left-color: #F26B5C; background: rgba(242,107,92,.08); color: #F26B5C; }
.rai-reports .sidebar-client.sb-cli-risk.active .cn { color: #F26B5C; }
.rai-reports .client-meta .cs { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rai-reports .client-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.rai-reports .sb-empty {
  padding: 18px 12px;
  text-align: center;
  font: 400 11px var(--font-ui);
  color: var(--fg-3);
  font-style: italic;
}
.rai-reports .cl-squad svg {
  display: inline-block;
  vertical-align: middle;
}
.rai-reports .squad-emoji {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 7px;
  background: var(--surface-2);
}
.rai-reports .sidebar {
  display: flex; flex-direction: column;
  min-height: 0;
}
/* ════════════════════════════════════════════════════════════════════════
   CHART AXIS LABELS (template-wide readability pass · 2026-06-12)
   Every SVG axis tick rendered by public/reports/charts.js carries
   .chart-axis-lbl with font-size 13.5 viewBox units (≈12px+ effective) and
   fill var(--chart-axis) — readable in dark AND light mode. This rule only
   adds the numeric niceties; size/weight live on the SVG attributes so the
   text scales with the chart.
   ════════════════════════════════════════════════════════════════════════ */
.rai-reports .chart-axis-lbl {
  font-variant-numeric: tabular-nums;
  letter-spacing: .01em;
}

/* ════════════════════════════════════════════════════════════════════════
   PRESENTATION MODE — meeting-friendly layer on top of the legacy
   is-present scroll-snap shell. Toggled by the "Present" button
   (data-rep-present) which adds `is-present presentation-mode` to .rep-doc.
   Goals: larger typography, one section per viewport (snap, from is-present),
   no edit/internal-only controls on screen.
   ════════════════════════════════════════════════════════════════════════ */
/* Hide operator-only / interactive controls while presenting */
.rai-reports .rep-doc.presentation-mode .seg,
.rai-reports .rep-doc.presentation-mode .card-link-btn,
.rai-reports .rep-doc.presentation-mode .minfo,
.rai-reports .rep-doc.presentation-mode .internal-drawer,
.rai-reports .rep-doc.presentation-mode .btn {
  display: none !important;
}
/* Typography bumps — back-row readable */
.rai-reports .rep-doc.presentation-mode .rsh-eyebrow { font-size: 12px; }
.rai-reports .rep-doc.presentation-mode .rsh-title { font-size: 42px; max-width: 1040px; }
.rai-reports .rep-doc.presentation-mode .rsh-tag { font-size: 15px; max-width: 920px; }
.rai-reports .rep-doc.presentation-mode .card-head h3 { font-size: 16px; }
.rai-reports .rep-doc.presentation-mode .card-head .sub { font-size: 13.5px; }
.rai-reports .rep-doc.presentation-mode .mr-lbl { font-size: 12px; }
.rai-reports .rep-doc.presentation-mode .mr-val { font-size: 32px; }
.rai-reports .rep-doc.presentation-mode .mr-sub,
.rai-reports .rep-doc.presentation-mode .mr-delta { font-size: 12.5px; }
.rai-reports .rep-doc.presentation-mode .legend-item,
.rai-reports .rep-doc.presentation-mode .chart-legend-row,
.rai-reports .rep-doc.presentation-mode .lsm-legend { font-size: 13.5px; }
.rai-reports .rep-doc.presentation-mode .funnel-label { font-size: 14px; }
.rai-reports .rep-doc.presentation-mode .lol-label { font-size: 14px; }
.rai-reports .rep-doc.presentation-mode .lol-val { font-size: 13.5px; }
.rai-reports .rep-doc.presentation-mode table { font-size: 13.5px; }

/* ════════════════════════════════════════════════════════════════════════
   PRINT / SAVE AS PDF (Cmd+P or the Download PDF button)
   • Each report section starts on a fresh page; cards/charts never split.
   • White background + light tokens so charts stay legible on paper.
   • Dashboard chrome (rail, sidebars, toolbars, controls) hidden.
   • A fixed running header repeats the client + period on every page.
   ════════════════════════════════════════════════════════════════════════ */
.rai-reports .rep-print-header { display: none; }

@media print {
  /* ── Force the light palette regardless of the on-screen theme. CSS vars
     re-declared with !important out-rank the [data-theme="dark"] block. ── */
  .rai-reports, [data-theme="dark"] .rai-reports, [data-theme="light"] .rai-reports {
    --surface-page:    #ffffff !important;
    --surface-rail:    #ffffff !important;
    --surface-1:       #ffffff !important;
    --surface-2:       #f7f3ec !important;
    --surface-3:       #efe8dc !important;
    --surface-hover:   #f1ece2 !important;
    --fg-1:            #1a1612 !important;
    --fg-2:            #4a4136 !important;
    --fg-3:            #6f655b !important;
    --fg-muted:        #8a8077 !important;
    --border-subtle:   rgba(60, 45, 30, 0.12) !important;
    --border-default:  rgba(60, 45, 30, 0.18) !important;
    --border-strong:   rgba(60, 45, 30, 0.32) !important;
    --divider:         rgba(60, 45, 30, 0.14) !important;
    --chart-grid:      rgba(60, 45, 30, 0.14) !important;
    --chart-axis:      #57504a !important;
    --shadow-sm: none !important; --shadow-md: none !important;
    --shadow-lg: none !important; --shadow-xl: none !important;
    background: #ffffff !important;
    color: #1a1612 !important;
  }
  .rai-reports * {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* ── Hide the production dashboard chrome around the report (only when the
     Reports section is the visible one — gated on its inline display). ── */
  body:has(#reportsSection:not([style*="none"]) .report-page) .rail,
  body:has(#reportsSection:not([style*="none"]) .report-page) .secondary-sidebar,
  body:has(#reportsSection:not([style*="none"]) .report-page) .mobile-header,
  body:has(#reportsSection:not([style*="none"]) .report-page) .main > .top-header {
    display: none !important;
  }
  body:has(#reportsSection:not([style*="none"]) .report-page) .app {
    display: block !important;
    height: auto !important;
  }
  body:has(#reportsSection:not([style*="none"]) .report-page) .main {
    display: block !important;
    height: auto !important;
    overflow: visible !important;
  }

  /* ── Hide in-report controls / interactive chrome ── */
  .rai-reports .rep-toolbar,
  .rai-reports .rep-live-strip,
  .rai-reports .present-exit,
  .rai-reports .resty-dock,
  .rai-reports .seg,
  .rai-reports .btn,
  .rai-reports .card-link-btn,
  .rai-reports .minfo,
  .rai-reports .period-seg,
  .rai-reports .internal-drawer {
    display: none !important;
  }

  /* ── Free the scroll containers so EVERY page prints (not just the first
     viewport), and neutralize presentation/scroll-snap state. ── */
  #raiReportsRoot.rai-reports { overflow: visible !important; }
  .rai-reports .rep-doc,
  .rai-reports .rep-doc.is-present {
    height: auto !important;
    overflow: visible !important;
    scroll-snap-type: none !important;
    max-width: none !important;
    padding: 26px 14px 0 !important;
  }
  .rai-reports .rep-doc.is-present .rsec-wrap { min-height: 0 !important; padding: 0 !important; }
  .rai-reports .rep-doc.is-present .rcover { min-height: 0 !important; display: block; }

  /* ── Running header: client + period repeat on every printed page ── */
  .rai-reports .rep-print-header {
    display: flex !important;
    position: fixed;
    top: 0; left: 0; right: 0;
    justify-content: space-between;
    align-items: center;
    padding: 4px 2px 6px;
    font: 600 9.5px var(--font-ui);
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #6f655b;
    border-bottom: 1px solid rgba(60, 45, 30, 0.18);
    background: #ffffff;
  }

  /* ── Pagination: one major section per page, nothing cut mid-chart ── */
  .rai-reports .rcover {
    break-after: page;
    page-break-after: always;
    padding: 40px 0 30px;
  }
  .rai-reports .rcover-month, .rai-reports .rcover-year { font-size: 120px; }
  .rai-reports .rsec-wrap {
    break-before: page;
    page-break-before: always;
  }
  /* The section right after the cover already starts on a new page via the
     cover's break-after — avoid a double (blank) page. */
  .rai-reports .rcover + .rsec-wrap { break-before: auto; page-break-before: auto; }
  .rai-reports .rsh { break-inside: avoid; page-break-inside: avoid; break-after: avoid; }
  .rai-reports .card,
  .rai-reports .metric-row,
  .rai-reports .hero-metric,
  .rai-reports .funnel,
  .rai-reports .lollipop,
  .rai-reports .cmp-triple,
  .rai-reports .demo-bar-wrap,
  .rai-reports .qr-top,
  .rai-reports .rh-wrap,
  .rai-reports .loc-rev-card,
  .rai-reports .sun-card,
  .rai-reports svg {
    break-inside: avoid;
    page-break-inside: avoid;
  }
  /* Long tables may flow across pages — header repeats, rows stay whole. */
  .rai-reports table { break-inside: auto; page-break-inside: auto; }
  .rai-reports thead { display: table-header-group; }
  .rai-reports tr { break-inside: avoid; page-break-inside: avoid; }
  .rai-reports .rfooter { break-before: page; page-break-before: always; }
}
