/* ═══════════════════════════════════════════════════════════════
   CNTCT Core Styles — Extracted from index.html
   V13.0 Design System
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600;700&display=swap');

/* ═══════════════════════════════════════════════════════════════
   CNTCT V13.0 — Design System Upgrade, Auth, Error Logger, Login Revamp
   Design principles: readable, restrained, spacious, hierarchical
   ═══════════════════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  /* V31.0: FULL DARK — Bloomberg Terminal / Palantir Gotham aesthetic */
  --bg:#09090D;--bg2:#0F0F15;--bg3:#15151E;--bg4:#1A1A25;
  /* Card system — SOLID layered surfaces, not transparent glass */
  --card:#12121A;--card-hover:#16161F;--card-raised:#181822;
  /* Borders — subtle glow edges */
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);--border-glow:rgba(201,169,110,0.25);
  /* Text — white hierarchy on dark */
  --text:rgba(255,255,255,0.92);--text2:rgba(255,255,255,0.65);--muted:rgba(255,255,255,0.4);--dim:rgba(255,255,255,0.22);
  /* Primary accent — gold (the brand) */
  --accent:#c9a96e;--accent-bright:#D4A843;--accent-soft:rgba(201,169,110,0.12);--accent-glow:0 0 20px rgba(201,169,110,0.15);
  /* Semantic colors — vibrant for dark bg */
  --green:#10B981;--green-soft:rgba(16,185,129,0.12);
  --red:#EF4444;--red-soft:rgba(239,68,68,0.12);
  --cyan:#4FACFE;--cyan-soft:rgba(79,172,254,0.1);
  --orange:#F59E0B;--orange-soft:rgba(245,158,11,0.1);
  --purple:#7C3AED;--purple-soft:rgba(124,58,237,0.1);
  --pink:#EC4899;--rose:#F43F5E;--sage:#10B981;
  --gold:#c9a96e;--gold-bright:#FBBF24;--gold-deep:#B8860B;
  --champagne:rgba(255,255,255,0.15);
  /* Shadows — deep for dark mode with subtle color */
  --shadow-sm:0 1px 3px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.03);
  --shadow-md:0 4px 16px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03);
  --shadow-lg:0 8px 30px rgba(0,0,0,0.6),0 0 0 1px rgba(255,255,255,0.04);
  --shadow-xl:0 20px 60px rgba(0,0,0,0.7);
  /* Radii */
  --radius:8px;--radius-sm:6px;--radius-lg:12px;
  /* Gold accent system */
  --aman-gold:#c9a96e;
  --aman-gold-soft:rgba(201,169,110,0.1);
  --aman-gold-glow:0 0 20px rgba(201,169,110,0.15);
  --aman-cream:#09090D;
  --aman-cream-soft:rgba(255,255,255,0.03);
  /* Brain deep tones */
  --brain-dark:#07070B;
  --brain-darker:#040408;
  --brain-grid:rgba(201,169,110,0.03);
  --brain-glow:rgba(201,169,110,0.06);
  /* Glass layers — 5-level elevation for rich backgrounds */
  --glass-1:rgba(255,255,255,0.03);--glass-2:rgba(255,255,255,0.06);--glass-3:rgba(255,255,255,0.10);--glass-4:rgba(255,255,255,0.14);--glass-5:rgba(255,255,255,0.18);
  --glass-border:rgba(255,255,255,0.08);--glass-blur:blur(20px);
  /* Gold hierarchy — dim to white */
  --gold-dim:#8B7340;--gold-base:#B8944F;--gold-primary:#C9A96E;--gold-bright:#D4A843;--gold-light:#FBBF24;--gold-white:#FDE68A;
  /* Spacing tokens */
  --space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;
}
html,body{background:var(--bg)!important;color:var(--text);font-family: var(--font-body);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.6}
/* V31.0: Ambient breathing gradients — cranked for depth */
body::before,body::after{content:'';position:fixed;border-radius:50%;pointer-events:none;z-index:0}
body::before{width:900px;height:900px;background:radial-gradient(circle,rgba(201,169,110,0.08) 0%,rgba(201,169,110,0.02) 40%,transparent 70%);filter:blur(120px);top:-300px;left:-200px;animation:ambientDrift 30s ease-in-out infinite}
body::after{width:700px;height:700px;background:radial-gradient(circle,rgba(124,58,237,0.06) 0%,rgba(124,58,237,0.015) 40%,transparent 70%);filter:blur(100px);bottom:-200px;right:-150px;animation:ambientDrift 25s ease-in-out infinite reverse}
@keyframes ambientDrift{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,20px)}66%{transform:translate(-20px,-10px)}}
.mono{font-family: var(--font-mono)}
.serif{font-family: var(--font-body)}
.luxury{font-family: var(--font-display)}

/* ═══ SCROLLBAR ═══ */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--dim)}

/* ═══ V31.0 CARDS — solid layered surfaces with depth ═══ */
.glass-card{background:var(--card);border:1px solid var(--border);border-radius: 2px;overflow:hidden;box-shadow:var(--shadow-md);position:relative}
.glass-card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,0.06) 50%,transparent 90%)}
.glass-card-glow{box-shadow:0 0 30px rgba(201,169,110,0.08),inset 0 1px 0 rgba(255,255,255,0.05)}

/* ═══ V13.0 GOLD ACCENT ═══ */
.gold-accent{color:var(--aman-gold)}
.gold-border{border-color:var(--aman-gold)!important}
.gold-glow{box-shadow:var(--aman-gold-glow)}

/* ═══ V16.5 LUXURY DIVIDER ═══ */
.luxury-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.2),transparent);margin:32px 0}

/* ═══ V13.0 ANIMATIONS ═══ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseGlow{0%,100%{opacity:0.5}50%{opacity:1}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes floatParticle{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-20px) scale(1.1)}50%{transform:translate(-20px,30px) scale(0.95)}75%{transform:translate(15px,15px) scale(1.05)}}
.anim-fade-in{animation:fadeInUp 0.5s ease-out forwards}
.anim-pulse{animation:pulseGlow 2s ease-in-out infinite}

/* ═══ LAYOUT ═══ */
.app{max-width:1280px;margin:0 auto;padding:52px 40px 0;overflow-x:clip}
.hidden{display:none!important}

/* ═══ HEADER — hidden, brand moved to nav ═══ */
.header{display:none!important}
.cost-badge{font-family: var(--font-body);font-size:10px;padding:5px 12px;border-radius:2px;background:rgba(139,158,107,0.1);border:1px solid rgba(139,158,107,0.15);color:rgba(139,158,107,0.7);letter-spacing:0.5px;display:none}

/* ═══ V28.4 NAVIGATION — Clean, Commanding, Premium ═══ */
.top-nav{position:fixed;top:0;left:0;right:0;width:100%;background:rgba(9,9,13,0.85);border-bottom:1px solid rgba(201,169,110,0.08);padding:0;z-index:1000;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-sizing:border-box}
.top-nav.hidden{display:none!important}
.nav-container{max-width:1400px;margin:0 auto;padding:0 48px;display:flex;align-items:center;height:52px}
.nav-brand{display:flex;align-items:center;margin-right:48px;text-decoration:none;flex-shrink:0}
.nav-brand-mark{font-family: var(--font-display);font-size:18px;font-weight:600;letter-spacing:4px;color:var(--aman-gold)}
.nav-items{display:flex;gap:2px;align-items:center;height:52px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1}
.nav-items::-webkit-scrollbar{display:none}
.nav-item{display:flex;align-items:center;padding:0 16px;font-family: var(--font-body);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:2.5px;color:rgba(255,255,255,0.5);text-decoration:none;transition:all 0.25s ease;height:100%;border-bottom:2px solid transparent;white-space:nowrap;position:relative}
.nav-item:hover{color:rgba(255,255,255,0.9)}
.nav-item.active{color:var(--aman-gold);border-bottom-color:var(--aman-gold)}
.nav-icon{display:none}
.nav-hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px}
.nav-hamburger span{width:18px;height:1.5px;background:rgba(255,255,255,0.05);border-radius:1px;transition:all 0.3s}

/* Mobile Navigation */

/* V41: Outreach Hub Tabs */
.outreach-hub-tabs{display:flex;gap:2px;padding:20px 24px 0;background:var(--brain-dark,#0a0a0f);border-bottom:1px solid rgba(201,169,110,0.1)}
.oh-tab{padding:10px 24px;background:transparent;border:none;color:var(--dim,#6a6a6a);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;letter-spacing:0.5px}
.oh-tab:hover{color:var(--text,#e8e6e3)}
.oh-tab.active{color:var(--gold,#c9a96e);border-bottom-color:var(--gold,#c9a96e)}

@media (max-width: 768px) {
  .nav-container{padding:0 20px}
  .nav-brand{margin-right:auto}
  .nav-items{flex-direction:column;gap:0;position:absolute;top:100%;left:0;right:0;height:auto;background:#0C0B0A;border-bottom:1px solid rgba(201,169,110,0.08);padding:16px 20px;display:none;z-index:100}
  .nav-items.open{display:flex}
  .nav-item{height:auto;padding:12px 0;border-bottom:none;font-size:11px}
  .nav-item.active{border-bottom:1px solid var(--aman-gold);padding-bottom:11px}
  .nav-hamburger{display:flex}

  /* Mobile layout priority — V28.6: noir hero is first child now */
  #runView{display:flex;flex-direction:column}
  #runView > *{order:10}
  .rv-noir{order:1!important}
  .rv-content{order:2!important;padding:0 20px!important}
  .rv-noir-inner{padding:0 20px!important}
  .rv-title{font-size:28px!important}
  #forensicLedger{order:5!important}
  #channelProfiles{order:6!important}
  #dossierPanel{order:7!important}
  #lateralPanel{order:8!important}
  #docsPanel{order:9!important}
  #mapSection{order:10!important}
  #pathwaySection{order:11!important}
}

/* ═══ V28.0 STANDALONE PAGE CONTAINER — Premium dark hero + light content ═══ */
#standaloneView{min-height:100vh}
.sa-hero{width:100vw;margin-left:calc(-50vw + 50%);background:linear-gradient(180deg,#07070B 0%,#0A0A10 50%,#0D0D14 80%,var(--bg) 100%);padding:56px 0 48px;position:relative;overflow:hidden}
.sa-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.015) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.015) 1px,transparent 1px);background-size:80px 80px;opacity:0.4;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 10%,transparent 70%);pointer-events:none}
.sa-hero-inner{max-width:900px;margin:0 auto;padding:0 48px;position:relative;z-index:1}
.sa-hero-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:6px;font-family: var(--font-body);font-weight:600;margin-bottom:16px;opacity:0.7}
.sa-hero-title{font-family: var(--font-display);font-size:48px;font-weight:500;color:#FAFAF8;letter-spacing:-0.5px;line-height:1.08;margin-bottom:14px}
.sa-hero-subtitle{font-size:14px;color:rgba(255,252,248,0.42);font-weight:400;max-width:520px;line-height:1.7;letter-spacing:0.3px;font-family: var(--font-body)}
.sa-content{max-width:1100px;margin:0 auto;padding:0 48px 60px}
@media(max-width:768px){
  .sa-hero{padding:36px 0 32px}
  .sa-hero-inner{padding:0 20px}
  .sa-hero-title{font-size:32px}
  .sa-hero-subtitle{font-size:13px}
  .sa-content{padding:0 20px 40px}
}
@media(max-width:480px){
  .sa-hero-title{font-size:26px}
  .sa-hero-label{font-size:9px;letter-spacing:4px}
}

/* V28.0 Standalone stat cards */
.sa-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:32px}
.sa-stat{text-align:center;padding:22px 12px 18px;background:var(--card);border:1px solid var(--border);border-radius: 2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.sa-stat::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.35),transparent);border-radius:1px}
.sa-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px rgba(201,169,110,0.04);border-color:rgba(201,169,110,0.12);background:var(--card-hover)}
.sa-stat-num{font-size:30px;font-weight:600;font-family: var(--font-display);color:var(--text);line-height:1;margin-bottom:4px}
.sa-stat-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:500}
@media(max-width:768px){.sa-stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}.sa-stat{padding:16px 8px 14px}.sa-stat-num{font-size:24px}}
@media(max-width:480px){.sa-stat-grid{grid-template-columns:repeat(2,1fr)}}

/* V28.0 Standalone section label */
.sa-section-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600;margin:0 0 12px;display:flex;align-items:center;gap:12px}
.sa-section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(201,169,110,0.12),transparent)}

/* V28.0 Standalone white card */
.sa-card{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:20px;margin-bottom:10px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm)}
.sa-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px rgba(201,169,110,0.04);border-color:rgba(201,169,110,0.15);background:var(--card-hover)}
.sa-card.sa-expanded{border-color:rgba(201,169,110,0.2);box-shadow:var(--shadow-md);transform:none;background:var(--card-hover)}
.sa-card.sa-expanded:hover{transform:none}
.sa-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:10px;margin-bottom:24px}
@media(max-width:768px){.sa-card-grid{grid-template-columns:1fr}}

/* V28.0 Standalone table */
.sa-table-wrap{background:var(--card);border:1px solid var(--border);border-radius: 2px;overflow:hidden;box-shadow:var(--shadow-sm)}
.sa-table{width:100%;border-collapse:collapse;font-size:13px}
.sa-table thead th{background:#0B0B10;color:rgba(201,169,110,0.7);font-family: var(--font-body);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:14px 16px;border-bottom:2px solid rgba(201,169,110,0.15);text-align:left;position:sticky;top:0;z-index:2}
.sa-sort-arrow{font-size:8px;opacity:0.4;margin-left:4px}
.sa-table tbody tr{transition:background 0.15s;border-bottom:1px solid rgba(255,255,255,0.04)}
.sa-table tbody tr:nth-child(even){background:rgba(255,255,255,0.015)}
.sa-table tbody tr:hover{background:rgba(201,169,110,0.08)}
.sa-table tbody td{padding:13px 16px;color:var(--text2);vertical-align:middle}

/* ═══ V28.0 SETTINGS VIEW — Premium dark hero + white cards ═══ */
.settings-view{min-height:100vh;padding:0;background:transparent}
.settings-view.hidden{display:none!important}
.settings-hero{width:100vw;margin-left:calc(-50vw + 50%);background:linear-gradient(180deg,#07070B 0%,#0A0A10 50%,#0D0D14 80%,var(--bg) 100%);padding:56px 0 48px;position:relative;overflow:hidden}
.settings-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.015) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.015) 1px,transparent 1px);background-size:80px 80px;opacity:0.4;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 10%,transparent 70%);pointer-events:none}
.settings-hero-inner{max-width:680px;margin:0 auto;padding:0 48px;position:relative;z-index:1}
.settings-hero-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:6px;font-family: var(--font-body);font-weight:600;margin-bottom:16px;opacity:0.7}
.settings-hero-title{font-family: var(--font-display);font-size:48px;font-weight:500;color:#FAFAF8;letter-spacing:-0.5px;line-height:1.08;margin-bottom:10px}
.settings-hero-subtitle{font-size:14px;color:rgba(255,252,248,0.42);font-weight:400;line-height:1.7;letter-spacing:0.3px;font-family: var(--font-body)}
.settings-container{max-width:680px;margin:0 auto;padding:0 48px 60px}
.settings-section{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:28px;margin-bottom:12px;box-shadow:0 4px 16px rgba(0,0,0,0.2);transition:all 0.3s}
.settings-section:hover{box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.settings-section h3{font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--aman-gold);margin-bottom:20px;font-family: var(--font-body)}
.settings-field{margin-bottom:16px}
.settings-field:last-child{margin-bottom:0}
.settings-field label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-weight:500;font-family: var(--font-body)}
.settings-input{width:100%;padding:12px 16px;background:var(--bg2);border:1px solid rgba(255,255,255,0.1);border-radius:2px;color:var(--text);font-size:13px;font-family: var(--font-body);outline:none;transition:all 0.2s}
input.settings-input[type="password"],input.settings-input[type="text"]{font-family: var(--font-mono);font-size:13px}
.settings-input:focus{border-color:var(--aman-gold);box-shadow:0 0 0 3px var(--aman-gold-soft);background:rgba(255,255,255,0.05)}
.api-key-display{display:flex;gap:8px;align-items:center}
.api-key-display .settings-input{flex:1;margin:0}
.settings-btn-small{padding:10px 14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:2px;color:var(--text);font-size:11px;cursor:pointer;transition:all 0.2s;white-space:nowrap;font-family: var(--font-body);font-weight:500}
.settings-btn-small:hover{border-color:rgba(201,169,110,0.3);color:var(--aman-gold);box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.settings-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.settings-stat{background:var(--card);border:1px solid var(--border);padding:18px 16px;border-radius: 2px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 16px rgba(0,0,0,0.2);position:relative;overflow:hidden}
.settings-stat::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:20px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.2),transparent)}
.settings-stat .stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:500;font-family: var(--font-body)}
.settings-stat .stat-value{font-family: var(--font-display);font-size:30px;font-weight:600;color:var(--text);line-height:1}
.settings-btn-primary{width:100%;padding:14px;background:var(--aman-gold);color:#fff;font-weight:600;font-size:11px;border:none;border-radius:2px;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body)}
.settings-btn-primary:hover{opacity:0.92;transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,169,110,0.3)}
.settings-btn-secondary{width:100%;padding:14px;background:rgba(255,255,255,0.05);color:var(--text);font-weight:600;font-size:11px;border:1px solid rgba(255,255,255,0.1);border-radius:2px;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body)}
.settings-btn-secondary:hover{border-color:rgba(201,169,110,0.3);color:var(--aman-gold);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.settings-error-log{max-height:300px;overflow-y:auto;background:#0C0B0A;border:1px solid rgba(201,169,110,0.08);border-radius: 2px;padding:16px;font-family: var(--font-mono);font-size:10px;color:rgba(201,169,110,0.5);line-height:1.8}
.settings-error-log::-webkit-scrollbar{width:4px}
.settings-error-log::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.15);border-radius:2px}
.settings-footer{margin-top:32px}
@media(max-width:768px){
  .settings-hero{padding:36px 0 32px}
  .settings-hero-inner{padding:0 20px}
  .settings-hero-title{font-size:32px}
  .settings-container{padding:0 20px 40px}
  .settings-stats{grid-template-columns:1fr}
}

/* ═══ CONFIG PANEL ═══ */
.config-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(12px)}
.config-box{background:#111118;border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius-lg);padding:48px 40px;width:480px;max-width:90vw;box-shadow:var(--shadow-xl)}
.config-box h2{font-size:24px;font-weight:600;letter-spacing:3px;margin-bottom:8px;font-family: var(--font-body);text-transform:uppercase;color:var(--text)}
.config-box .desc{font-size:14px;color:var(--muted);margin-bottom:32px;line-height:1.7}
.config-box label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:8px;font-weight:500}
.config-box input,.config-box select{width:100%;padding:12px 16px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:2px;color:var(--text);font-size:14px;font-family: var(--font-body);margin-bottom:20px;outline:none;transition:all 0.2s}
.config-box input:focus,.config-box select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.config-box .row{display:flex;gap:16px}
.config-box .row>*{flex:1}
.btn-primary{width:100%;padding:14px;background:var(--accent);color:#fff;font-weight:600;font-size:14px;border:none;border-radius:var(--radius);cursor:pointer;transition:all 0.2s;margin-top:12px;letter-spacing:1px;text-transform:uppercase;font-family: var(--font-body)}
.btn-primary:hover{opacity:0.9;transform:translateY(-1px);box-shadow:var(--accent-glow)}
.btn-primary:disabled{opacity:0.3;cursor:not-allowed;transform:none;box-shadow:none}
.config-error{color:var(--red);font-size:13px;margin-top:12px;font-family: var(--font-mono);padding:10px 14px;background:var(--red-soft);border-radius:var(--radius-sm);border:1px solid rgba(192,112,96,0.2)}

/* ═══ V13.0 LOGIN PAGE ═══ */
.login-bg{position:fixed;inset:0;background:var(--brain-dark);z-index:-1;overflow:hidden}
.login-grid{position:absolute;inset:0;background-image:linear-gradient(var(--brain-grid) 1px,transparent 1px),linear-gradient(90deg,var(--brain-grid) 1px,transparent 1px);background-size:60px 60px;opacity:0.5}
.login-particles{position:absolute;inset:0;pointer-events:none}
.login-particles::before,.login-particles::after{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,0.04) 0%,transparent 70%);animation:floatParticle 20s ease-in-out infinite}
.login-particles::before{top:10%;left:20%;animation-delay:0s}
.login-particles::after{bottom:15%;right:15%;animation-delay:-10s;width:400px;height:400px;background:radial-gradient(circle,rgba(201,169,110,0.03) 0%,transparent 70%)}
.login-card{position:relative;width:440px;max-width:92vw;padding:48px 40px;z-index:1;animation:fadeInUp 0.6s ease-out}
.login-logo-wrap{text-align:center;margin-bottom:36px}
.login-logo{width:56px;height:56px;border-radius: 2px;background:linear-gradient(135deg,var(--aman-gold),var(--gold-deep));display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;color:#fff;font-family: var(--font-body);letter-spacing:1px;margin-bottom:16px;box-shadow:0 0 30px rgba(201,169,110,0.2)}
.login-title{font-family: var(--font-display);font-size:32px;font-weight:600;letter-spacing:6px;color:var(--text);margin-bottom:4px}
.login-subtitle{font-size:12px;color:var(--dim);letter-spacing:2px;text-transform:uppercase;font-weight:400}
.login-social-btn{width:100%;padding:13px 20px;border-radius:var(--radius);font-size:13px;font-weight:500;border:1px solid var(--border2);background:var(--bg3);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all 0.2s;margin-bottom:8px;font-family: var(--font-body);position:relative}
.login-social-btn:hover{background:var(--bg4);border-color:var(--dim);transform:translateY(-1px)}
.login-social-btn.google:hover{border-color:rgba(66,133,244,0.4);box-shadow:0 0 15px rgba(66,133,244,0.1)}
.login-social-btn.apple:hover{border-color:rgba(255,255,255,0.2);box-shadow:0 0 15px rgba(255,255,255,0.05)}
.login-social-btn.microsoft:hover{border-color:rgba(0,120,215,0.4);box-shadow:0 0 15px rgba(0,120,215,0.1)}
.login-social-btn.github:hover{border-color:rgba(255,255,255,0.2);box-shadow:0 0 15px rgba(255,255,255,0.05)}
.login-social-btn.amazon:hover{border-color:rgba(255,153,0,0.4);box-shadow:0 0 15px rgba(255,153,0,0.1)}
.login-social-btn .coming-soon-tag{position:absolute;right:14px;font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:600}
.login-social-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.login-social-grid .login-social-btn{margin-bottom:0;padding:11px 14px;font-size:12px}
/* V13.11: Toast notification */
.cntct-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--bg3);border:1px solid var(--aman-gold);border-radius:var(--radius);padding:12px 24px;color:var(--aman-gold);font-size:12px;font-family: var(--font-body);z-index:1000;opacity:0;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);pointer-events:none;box-shadow:0 8px 32px rgba(0,0,0,0.4);letter-spacing:0.5px}
.cntct-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}
.login-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:var(--dim);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.login-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;display:block;margin-bottom:6px;font-weight:500}
.login-input{width:100%;padding:12px 16px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:2px;color:var(--text);font-size:14px;font-family: var(--font-body);margin-bottom:16px;outline:none;transition:all 0.2s}
.login-input:focus{border-color:var(--aman-gold);box-shadow:0 0 0 3px var(--aman-gold-soft)}
.login-remember{display:flex;align-items:center;gap:8px;margin:-8px 0 16px;cursor:pointer;font-size:12px;color:var(--muted)}
.login-remember input{accent-color:var(--aman-gold)}
.login-models-row{display:flex;gap:12px;margin-bottom:8px}
.login-models-row>div{flex:1}
.login-models-row select{margin-bottom:8px}
.login-connect-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--aman-gold),var(--gold-deep));color:#fff;font-weight:600;font-size:14px;border:none;border-radius:var(--radius);cursor:pointer;transition:all 0.2s;letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body);margin-top:8px}
.login-connect-btn:hover{opacity:0.92;transform:translateY(-1px);box-shadow:var(--aman-gold-glow)}
.login-connect-btn:disabled{opacity:0.3;cursor:not-allowed;transform:none;box-shadow:none}
.login-footer{text-align:center;font-size:10px;color:var(--dim);margin-top:20px;letter-spacing:0.5px}

/* ═══ V27.0 DASHBOARD — NOIR HERO, WHITE DATA, COMMANDING ═══ */
.dashboard{position:relative;padding:0;display:flex;flex-direction:column;align-items:center;min-height:100vh;background:var(--bg)}

/* V31.0: Noir hero — no gradient to cream, stays dark */
.dash-noir{width:100vw;margin-left:calc(-50vw + 50%);background:linear-gradient(180deg,#06060A 0%,#08080E 40%,var(--bg) 100%);display:flex;flex-direction:column;align-items:center;position:relative;padding-bottom:40px}

/* V29.0: Ambient background — animated particle network + gold orbs */
.dash-bg{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.dash-particle-canvas{position:absolute;inset:0;width:100%;height:100%;opacity:0.6}
.dash-glow-orb{position:absolute;border-radius:50%;filter:blur(150px);opacity:0.06;animation:dashOrbFloat 25s ease-in-out infinite}
.dash-orb-1{width:600px;height:600px;background:var(--aman-gold);top:-250px;left:-150px}
.dash-orb-2{width:400px;height:400px;background:rgba(201,169,110,0.3);bottom:-100px;right:-50px;animation-delay:-12s}
.dash-orb-3{width:300px;height:300px;background:rgba(201,169,110,0.15);top:50%;left:60%;animation-delay:-8s;opacity:0.04}
@keyframes dashOrbFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(40px,20px)}66%{transform:translate(-30px,-15px)}}

/* Hero text on dark */
.dash-hero{position:relative;z-index:1;text-align:center;padding:52px 40px 22px;max-width:860px}
.dash-hero-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:6px;font-family: var(--font-body);font-weight:600;margin-bottom:18px;opacity:0.7}
.dash-hero h2{font-family: var(--font-display);font-size:52px;font-weight:500;letter-spacing:-0.5px;color:#FAFAF8;margin-bottom:14px;line-height:1.08}
.dash-hero h2 .gold{color:var(--aman-gold)}
.dash-hero p{font-size:14px;color:rgba(255,252,248,0.45);font-weight:400;max-width:480px;line-height:1.7;margin:0 auto;letter-spacing:0.3px;font-family: var(--font-body)}

/* Search bar on dark */
.dash-search-wrap{position:relative;z-index:1;width:100%;max-width:620px;padding:0 40px;margin-bottom:8px}
.brand-input-row{display:flex;align-items:center;gap:0;width:100%;background:rgba(255,255,255,0.03);border:1px solid rgba(201,169,110,0.1);border-radius: 2px;overflow:hidden;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);backdrop-filter:blur(20px)}
.brand-input-row:focus-within{border-color:rgba(201,169,110,0.3);box-shadow:0 0 0 3px rgba(201,169,110,0.06),0 8px 32px rgba(0,0,0,0.3)}
.dash-input-icon{padding:0 0 0 20px;color:rgba(201,169,110,0.3);display:flex;align-items:center;flex-shrink:0}
.dash-input-divider{width:1px;height:24px;background:rgba(201,169,110,0.08);flex-shrink:0;margin:0 4px}
.brand-input{flex:1;padding:16px 16px;background:transparent;border:none;color:#FAFAF8;font-size:15px;font-family: var(--font-body);font-weight:400;outline:none;letter-spacing:0.2px}
.brand-input:focus{background:transparent}
.brand-input::placeholder{color:rgba(201,169,110,0.35);font-weight:300;letter-spacing:0.5px;font-size:14px}
.input-hint{text-align:center;font-size:10px;color:rgba(201,169,110,0.3);margin-top:8px;margin-bottom:0;font-family: var(--font-body);font-weight:400;letter-spacing:0.5px}
.btn-investigate{padding:16px 24px;background:var(--aman-gold);color:#0C0B0A;font-weight:700;font-size:9px;border:none;border-radius:0 11px 11px 0;cursor:pointer;letter-spacing:2.5px;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);white-space:nowrap;text-transform:uppercase;font-family: var(--font-body);flex-shrink:0;position:relative;overflow:hidden;min-width:fit-content}
.btn-investigate::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,0.2) 50%,transparent 60%);transform:translateX(-100%);transition:transform 0.6s}
.btn-investigate:hover{box-shadow:0 0 30px rgba(201,169,110,0.3);letter-spacing:3.5px}
.btn-investigate:hover::after{transform:translateX(100%)}
.btn-investigate:disabled{opacity:0.2;cursor:not-allowed;box-shadow:none}
.btn-investigate:disabled::after{display:none}

/* Command bar on dark */
.dash-actions-row{position:relative;z-index:1;display:flex;gap:6px;max-width:620px;width:100%;margin:14px auto 0;padding:0 40px;flex-wrap:wrap;justify-content:center}
.dash-action-btn{display:flex;align-items:center;gap:5px;padding:7px 13px;font-size:9px;color:rgba(255,252,248,0.4);background:transparent;border:1px solid rgba(201,169,110,0.1);border-radius: 2px;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);font-family: var(--font-body);font-weight:500;letter-spacing:1px;text-transform:uppercase}
.dash-action-btn:hover{border-color:rgba(201,169,110,0.2);color:var(--aman-gold);background:rgba(201,169,110,0.04)}
.dash-action-icon{color:rgba(201,169,110,0.35);font-size:10px;transition:color 0.3s}
.dash-action-btn:hover .dash-action-icon{color:var(--aman-gold)}

/* Vault section — light area below noir gradient */
.dash-vault-section{position:relative;z-index:1;max-width:780px;width:100%;margin:32px auto 0;padding:0 40px}
.dash-vault-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dash-vault-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600}
.dash-vault-reset{font-size:10px;color:var(--muted);cursor:pointer;transition:color 0.2s;font-family: var(--font-body);letter-spacing:1px;font-weight:500;opacity:0.4}
.dash-vault-reset:hover{color:var(--red);opacity:1}
.dash-vault-counters{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.dash-vault-counter{text-align:center;padding:20px 10px 16px;background:var(--glass-2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius: 2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.dash-vault-counter::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.4),transparent);border-radius:1px}
.dash-vault-counter:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px rgba(201,169,110,0.06);border-color:rgba(201,169,110,0.2)}
.dash-vault-num{font-size:30px;font-weight:600;font-family: var(--font-display);color:var(--gold-light);line-height:1;margin-bottom:4px}
.dash-vault-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:500}

/* Previous Runs */
.dash-prev-runs{position:relative;z-index:1;max-width:780px;width:100%;margin:28px auto 0;padding:0 40px}
.dash-prev-runs .dash-section-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:12px}
.dash-prev-runs .dash-section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(201,169,110,0.12),transparent)}
.dash-run-card{position:relative;background:var(--glass-2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius: 2px;padding:20px 24px;margin-bottom:8px;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);display:grid;grid-template-columns:1fr auto;align-items:center;gap:20px;overflow:hidden;box-shadow:var(--shadow-sm)}
.dash-run-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--aman-gold),rgba(201,169,110,0.3));opacity:0;transition:opacity 0.3s}
.dash-run-card:hover{border-color:rgba(201,169,110,0.2);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px rgba(201,169,110,0.06);background:var(--glass-3)}
.dash-run-card:hover::before{opacity:1}
.dash-run-brand{font-weight:600;font-size:22px;font-family: var(--font-display);color:var(--text);letter-spacing:-0.5px}
.dash-run-meta{font-size:10px;color:var(--muted);font-family: var(--font-body);margin-top:3px;letter-spacing:0.5px;font-weight:400}
.dash-run-breakdown{display:flex;height:5px;border-radius:2px;overflow:hidden;margin-top:8px;background:rgba(255,255,255,0.04)}
.dash-run-breakdown span{height:100%;transition:width 0.5s cubic-bezier(0.4,0,0.2,1)}
.dash-run-chain{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px;max-height:56px;overflow:hidden;position:relative}
.dash-run-stats{display:flex;gap:16px}
.dash-run-stat{text-align:center}
.dash-run-stat .val{font-size:18px;font-weight:600;font-family: var(--font-display);color:var(--gold-bright);line-height:1}
.dash-run-stat .lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:500;margin-top:2px;font-family: var(--font-body)}
.dash-run-card .run-delete-btn{position:absolute;top:8px;right:8px;background:none;border:none;color:rgba(255,255,255,0.15);cursor:pointer;font-size:12px;opacity:0;transition:opacity 0.2s;padding:4px 8px}
.dash-run-card:hover .run-delete-btn{opacity:1}
.dash-run-card .run-delete-btn:hover{color:var(--red)}

/* Chain tags */
.dash-chain-tag{font-size:8.5px;padding:2px 7px;border-radius:2px;font-family: var(--font-body);font-weight:500;letter-spacing:0.3px}
.dash-chain-tag.agency{background:rgba(201,169,110,0.07);color:var(--aman-gold);border:1px solid rgba(201,169,110,0.1)}
.dash-chain-tag.dist{background:rgba(100,170,130,0.05);color:var(--sage);border:1px solid rgba(100,170,130,0.1)}

/* Section headers */
.dash-section-header{display:flex;justify-content:space-between;align-items:center;padding:16px 0;cursor:pointer}
.dash-section-header h4{font-family: var(--font-display);font-size:22px;font-weight:600;color:var(--text)}
.dash-section-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600;margin-bottom:8px}

/* Dashboard Mobile */
@media(max-width:768px){
  .dash-noir{padding-bottom:28px}
  .dash-hero{padding:36px 20px 18px}
  .dash-hero h2{font-size:34px}
  .dash-hero p{font-size:13px}
  .dash-hero-label{font-size:9px;letter-spacing:4px}
  .dash-search-wrap{padding:0 16px;max-width:100%}
  .brand-input-row{flex-wrap:wrap;border-radius:2px}
  .dash-input-icon{padding:0 0 0 14px}
  .brand-input{padding:14px;font-size:14px}
  .dash-input-divider{display:none}
  .btn-investigate{width:100%;border-radius:0 0 8px 8px;padding:14px;letter-spacing:2px}
  .dash-vault-section{padding:0 16px;margin-top:24px}
  .dash-vault-counters{grid-template-columns:repeat(3,1fr);gap:6px}
  .dash-vault-counter{padding:14px 6px 10px}
  .dash-vault-num{font-size:22px}
  .dash-intel-grid{grid-template-columns:repeat(2,1fr);padding:0 16px;gap:6px}
  .dash-actions-row{padding:0 16px;gap:5px;margin-top:12px}
  .dash-action-btn{padding:6px 10px;font-size:8.5px;flex:1;min-width:0;justify-content:center}
  .dash-prev-runs{padding:0 16px;margin-top:24px}
  .dash-run-card{grid-template-columns:1fr;gap:10px;padding:14px 16px}
  .dash-run-stats{justify-content:flex-start;gap:14px}
  .dash-run-brand{font-size:16px}
  .dash-run-stat .val{font-size:16px}
  .dash-intel-graph{margin-top:24px}
}
@media(max-width:480px){
  .dash-hero h2{font-size:26px}
  .dash-hero{padding:32px 16px 16px}
  .dash-vault-counters{grid-template-columns:repeat(3,1fr)}
  .dash-vault-num{font-size:20px}
  .dash-intel-grid{grid-template-columns:1fr 1fr}
  .dash-actions-row{flex-wrap:wrap}
  .dash-action-btn{flex:0 0 calc(50% - 3px);padding:6px;font-size:8px}
  .dash-action-icon{display:none}
  .dash-run-stats{flex-wrap:wrap;gap:10px}
}

/* ═══ V30.0 DASHBOARD OVERHAUL — Intelligence Command Center ═══ */

/* Enhanced hero particles/network — CRANKED for glass-over-ambient */
.dash-particle-canvas{position:absolute;inset:0;width:100%;height:100%;opacity:1}
.dash-glow-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:0.18;animation:dashOrbFloat 25s ease-in-out infinite}

/* Hero data ticker — Bloomberg-style stats in hero */
.dash-hero-ticker{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding:0 20px;margin-top:2px}
.dash-hero-ticker .ticker-stat{font-family: var(--font-display);font-size:14px;color:rgba(255,252,248,0.5);font-weight:600}
.dash-hero-ticker .ticker-label{font-family: var(--font-body);font-size:10px;color:rgba(255,252,248,0.3);text-transform:uppercase;letter-spacing:1px;margin-left:2px}
.dash-hero-ticker .ticker-dot{color:rgba(201,169,110,0.35);font-size:8px;margin:0 4px}

/* Gold bridge divider */
.dash-gold-bridge{width:60px;height:1.5px;background:linear-gradient(90deg,transparent,var(--aman-gold),transparent);margin:0 auto;opacity:0.3}

/* Intelligence Signals card */
.dash-signal-card{position:relative;z-index:1;max-width:780px;width:100%;margin:24px auto 0;padding:0 40px}
.dash-signal-inner{background:var(--glass-3);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(201,169,110,0.1);border-radius: 2px;padding:20px 24px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.dash-signal-inner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--aman-gold),rgba(201,169,110,0.3))}
.dash-signal-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600;margin-bottom:12px}
.dash-signal-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.dash-signal-item:last-child{border-bottom:none;padding-bottom:0}
.dash-signal-pill{font-size:8px;padding:2px 8px;border-radius: 2px;font-family: var(--font-body);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;white-space:nowrap;flex-shrink:0;margin-top:2px}
.dash-signal-pill.personnel{background:rgba(139,158,107,0.1);color:var(--sage);border:1px solid rgba(139,158,107,0.15)}
.dash-signal-pill.cross-brand{background:rgba(201,169,110,0.08);color:var(--aman-gold);border:1px solid rgba(201,169,110,0.12)}
.dash-signal-pill.channels{background:rgba(155,139,180,0.1);color:#9b8bb4;border:1px solid rgba(155,139,180,0.15)}
.dash-signal-pill.confidence{background:rgba(100,170,130,0.08);color:var(--sage);border:1px solid rgba(100,170,130,0.12)}
.dash-signal-text{font-size:13px;color:var(--text);font-family: var(--font-body);line-height:1.6}

/* Vault — horizontal Bloomberg stats bar */
.dash-vault-bar{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;background:var(--glass-3);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);border-radius: 2px;padding:20px 28px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.dash-vault-bar::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.3),transparent)}
.dash-vault-stat{text-align:center;padding:0 20px;position:relative}
.dash-vault-stat:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:28px;background:linear-gradient(180deg,transparent,rgba(201,169,110,0.15),transparent)}
.dash-vault-stat .vault-num{font-size:28px;font-weight:600;font-family: var(--font-display);color:var(--gold-light);line-height:1}
.dash-vault-stat .vault-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:500;margin-top:4px}

/* Learning insight card */
.dash-learning-card{position:relative;z-index:1;max-width:780px;width:100%;margin:16px auto 0;padding:0 40px}
.dash-learning-inner{background:var(--glass-2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius: 2px;padding:18px 24px;box-shadow:var(--shadow-sm)}
.dash-learning-label{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;font-family: var(--font-body);font-weight:600;margin-bottom:10px}
.dash-learning-stats{display:flex;gap:28px;flex-wrap:wrap}
.dash-learning-stat .learn-num{font-size:22px;font-weight:600;font-family: var(--font-display);color:var(--gold-bright);line-height:1}
.dash-learning-stat .learn-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:500;margin-top:3px}

/* Run grid for 3+ investigations */
.dash-run-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:10px}

/* Empty state — dark weapon card */
.dash-empty-weapon{background:linear-gradient(160deg,rgba(13,15,22,0.8),rgba(17,20,32,0.8),rgba(11,14,23,0.8));backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(201,169,110,0.12);border-radius: 2px;padding:56px 40px;text-align:center;max-width:640px;margin:0 auto;animation:weaponPulse 4s ease-in-out infinite}
@keyframes weaponPulse{0%,100%{box-shadow:0 0 30px rgba(201,169,110,0.06),inset 0 0 30px rgba(201,169,110,0.02)}50%{box-shadow:0 0 50px rgba(201,169,110,0.12),inset 0 0 40px rgba(201,169,110,0.04)}}
.dash-empty-weapon .weapon-ready{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:4px;font-family: var(--font-body);font-weight:600;opacity:0.5;margin-bottom:20px}
.dash-empty-weapon h3{font-family: var(--font-display);font-size:36px;font-weight:500;color:#FAFAF8;margin-bottom:16px;line-height:1.15;letter-spacing:-0.3px}
.dash-empty-weapon p{font-size:13px;color:rgba(255,252,248,0.35);font-family: var(--font-body);line-height:1.8;max-width:420px;margin:0 auto 28px}
.dash-empty-weapon .weapon-cta{display:inline-block;padding:14px 36px;background:var(--aman-gold);color:#0C0B0A;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;border:none;border-radius:2px;cursor:pointer;font-family: var(--font-body);transition:all 0.4s cubic-bezier(0.4,0,0.2,1);box-shadow:0 0 30px rgba(201,169,110,0.15)}
.dash-empty-weapon .weapon-cta:hover{box-shadow:0 0 50px rgba(201,169,110,0.25);letter-spacing:3.5px;transform:translateY(-1px)}

/* Section entrance animations */
@keyframes dashFadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.dash-vault-section,.dash-signal-card,.dash-learning-card,.dash-prev-runs,.dash-intel-grid{animation:dashFadeUp 0.6s ease-out both}
.dash-signal-card{animation-delay:0.1s}
.dash-learning-card{animation-delay:0.15s}
.dash-prev-runs{animation-delay:0.2s}
.dash-intel-grid{animation-delay:0.25s}

/* Footer */
.dash-footer{text-align:center;padding:40px 0;font-size:9px;color:var(--muted);font-family: var(--font-body);letter-spacing:2px;text-transform:uppercase;opacity:0.4}

/* V30.0 Mobile overrides */
@media(max-width:768px){
  .dash-vault-bar{padding:16px 12px;flex-wrap:wrap}
  .dash-vault-stat{padding:8px 14px}
  .dash-vault-stat .vault-num{font-size:22px}
  .dash-signal-card{padding:0 16px}
  .dash-learning-card{padding:0 16px}
  .dash-run-grid{grid-template-columns:1fr}
  .dash-empty-weapon{padding:40px 24px;margin:0 16px}
  .dash-empty-weapon h3{font-size:28px}
  .dash-hero-ticker .ticker-stat{font-size:12px}
}
@media(max-width:480px){
  .dash-vault-stat{padding:6px 10px}
  .dash-vault-stat .vault-num{font-size:18px}
  .dash-learning-stats{gap:16px}
  .dash-empty-weapon h3{font-size:24px}
}

/* ═══ V23.2: BRAND DOSSIER — Magazine-Quality Intelligence Brief ═══ */
/* V24.0: Dossier — magazine-quality Vogue-level brand profile */
.dossier-v18{font-family: var(--font-body);max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:4px}
.dossier-v18 .dossier-hero{position:relative;padding:64px 52px 52px;background:linear-gradient(160deg,#1a1814 0%,#2c2620 100%);border:1px solid rgba(201,169,110,0.12);border-radius: 2px;overflow:hidden}
.dossier-v18 .dossier-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 5%,rgba(201,169,110,0.4) 50%,transparent 95%)}
.dossier-v18 .dossier-hero::after{content:'';position:absolute;top:-100px;right:-60px;width:500px;height:500px;background:radial-gradient(circle,rgba(201,169,110,0.08) 0%,transparent 65%);pointer-events:none}
.dossier-v18 .dossier-brand-name{font-family: var(--font-display);font-size:58px;font-weight:600;color:#FFFDF5;letter-spacing:-1.5px;line-height:1.05;position:relative;z-index:1}
.dossier-v18 .dossier-hero-meta{margin-top:18px;font-size:11px;color:rgba(201,169,110,0.55);font-family: var(--font-body);letter-spacing:4px;text-transform:uppercase;display:flex;align-items:center;gap:14px;position:relative;z-index:1;font-weight:500}
.dossier-v18 .dossier-origin{color:rgba(201,169,110,0.75);font-weight:600}
.dossier-v18 .dossier-section{margin-bottom:0}
.dossier-v18 .dossier-card{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:36px 40px;position:relative;box-shadow:var(--shadow-sm)}
.dossier-v18 .dossier-card-accent{position:absolute;left:0;top:24px;bottom:24px;width:2px;background:linear-gradient(180deg,transparent,rgba(201,169,110,0.3),transparent);border-radius:1px}
.dossier-v18 .dossier-section-title{font-family: var(--font-display);font-size:24px;font-weight:600;color:var(--text);margin-bottom:26px;padding-left:18px;position:relative;letter-spacing:0.2px}
.dossier-v18 .dossier-section-title::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:5px;height:5px;background:var(--aman-gold);border-radius:50%;box-shadow:0 0 8px rgba(201,169,110,0.3)}
.dossier-v18 .dossier-dna-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding-left:18px}
.dossier-v18 .dossier-dna-item{padding:18px 20px;border-left:2px solid rgba(201,169,110,0.18);background:transparent;transition:all 0.25s;border-radius:0 8px 8px 0}
.dossier-v18 .dossier-dna-item:hover{background:rgba(201,169,110,0.04);border-left-color:rgba(201,169,110,0.35)}
.dossier-v18 .dossier-dna-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:2.5px;font-family: var(--font-body);margin-bottom:8px;font-weight:600}
.dossier-v18 .dossier-dna-value{font-size:15px;color:var(--text);font-weight:500;line-height:1.5}
.dossier-v18 .dossier-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-left:18px}
.dossier-v18 .dossier-stat-box{text-align:center;padding:26px 14px;background:rgba(201,169,110,0.03);border:1px solid rgba(201,169,110,0.08);border-radius: 2px;transition:all 0.25s}
.dossier-v18 .dossier-stat-box:hover{border-color:rgba(201,169,110,0.2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.dossier-v18 .dossier-stat-value{font-size:34px;font-weight:600;font-family: var(--font-display);color:var(--text);line-height:1}
.dossier-v18 .dossier-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-top:10px;font-family: var(--font-body);font-weight:600}
.dossier-v18 .dossier-partners-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding-left:18px}
.dossier-v18 .dossier-partner-card{padding:22px 24px;background:var(--card);border:1px solid var(--border);border-radius: 2px;transition:all 0.25s}
.dossier-v18 .dossier-partner-card:hover{border-color:rgba(201,169,110,0.12);background:rgba(201,169,110,0.04);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.dossier-v18 .dossier-partner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dossier-v18 .dossier-partner-name{font-weight:600;font-size:15px;color:var(--text);font-family: var(--font-body)}
.dossier-v18 .dossier-partner-type{font-size:9px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body);font-weight:600;padding:4px 10px;background:rgba(201,169,110,0.06);border-radius:2px}
.dossier-v18 .dossier-partner-detail{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.6}
.dossier-v18 .dossier-detail-label{color:var(--aman-gold);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;margin-right:6px;font-weight:600}
.dossier-v18 .dossier-signals{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding-left:18px}
.dossier-v18 .dossier-signal{display:flex;gap:16px;padding:22px;background:var(--card);border:1px solid var(--border);border-radius: 2px;transition:all 0.25s;align-items:flex-start}
.dossier-v18 .dossier-signal:hover{border-color:rgba(201,169,110,0.12);background:rgba(201,169,110,0.04);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.dossier-v18 .dossier-signal-icon{font-size:22px;line-height:1;flex-shrink:0;opacity:0.8}
.dossier-v18 .dossier-signal-title{font-weight:600;font-size:14px;color:var(--text)}
.dossier-v18 .dossier-signal-detail{font-size:12px;color:var(--muted);margin-top:5px;line-height:1.6}
.dossier-v18 .dossier-contact-tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-left:18px}
.dossier-v18 .dossier-tier-box{text-align:center;padding:26px 14px;background:rgba(201,169,110,0.03);border:1px solid rgba(201,169,110,0.08);border-radius: 2px;transition:all 0.25s}
.dossier-v18 .dossier-tier-box:hover{border-color:rgba(201,169,110,0.2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.dossier-v18 .dossier-tier-icon{font-size:24px;margin-bottom:8px;opacity:0.8}
.dossier-v18 .dossier-tier-label{font-size:10px;color:var(--aman-gold);font-weight:600;text-transform:uppercase;letter-spacing:2px;font-family: var(--font-body)}
.dossier-v18 .dossier-tier-count{font-size:30px;font-weight:600;color:var(--text);font-family: var(--font-display);margin:6px 0;line-height:1}
.dossier-v18 .dossier-tier-desc{font-size:11px;color:var(--muted);line-height:1.4}
/* V24.0: dossier mobile */
@media(max-width:768px){
  .dossier-v18 .dossier-hero{padding:40px 24px 36px}
  .dossier-v18 .dossier-brand-name{font-size:38px}
  .dossier-v18 .dossier-hero-meta{font-size:10px;letter-spacing:3px}
  .dossier-v18 .dossier-card{padding:26px 22px}
  .dossier-v18 .dossier-section-title{font-size:21px}
  .dossier-v18 .dossier-dna-grid{grid-template-columns:1fr}
  .dossier-v18 .dossier-stats-row{grid-template-columns:repeat(2,1fr)}
  .dossier-v18 .dossier-partners-grid{grid-template-columns:1fr}
  .dossier-v18 .dossier-signals{grid-template-columns:1fr}
  .dossier-v18 .dossier-contact-tiers{grid-template-columns:repeat(2,1fr)}
}

/* ═══ V28.6: COMMAND CENTER — Run View — Dark Noir Hero + Premium Layout ═══ */
#runView{min-height:100vh}
.rv-noir{width:100vw;margin-left:calc(-50vw + 50%);background:linear-gradient(180deg,#0C0B0A 0%,#0F0E0C 40%,#1A1816 80%,var(--bg) 100%);padding:0 0 40px;position:relative}
.rv-noir::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.015) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.015) 1px,transparent 1px);background-size:80px 80px;opacity:0.3;mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black 10%,transparent 70%);pointer-events:none}
.rv-noir-inner{max-width:1100px;margin:0 auto;padding:0 48px;position:relative;z-index:1}
.rv-content{max-width:1100px;margin:0 auto;padding:0 48px}
.command-center{margin-bottom:28px}
.rv-nav{display:flex;gap:10px;align-items:center;padding-top:20px;margin-bottom:4px}
.rv-pause{border-color:rgba(251,146,60,0.25)!important;color:rgba(251,146,60,0.7)!important;font-weight:600!important}
.rv-pause:hover{border-color:rgba(251,146,60,0.5)!important;color:#FB923C!important;background:rgba(251,146,60,0.08)!important;box-shadow:0 0 16px rgba(251,146,60,0.15)!important}
.rv-title{font-family: var(--font-display);font-size:42px;font-weight:500;letter-spacing:-0.5px;color:#FAFAF8;margin:14px 0 6px;line-height:1.1}
.rv-subtitle{font-size:11px;color:rgba(201,169,110,0.5);letter-spacing:3px;text-transform:uppercase;margin-bottom:28px;font-weight:500;font-family: var(--font-body)}
/* ═══ V28.6: PHASE PIPELINE — Connected steps on dark ═══ */
.phase-bar{display:flex;gap:0;padding:8px 0;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:relative;margin-bottom:4px}
.phase-bar::-webkit-scrollbar{display:none}
.phase-pill{position:relative;z-index:1;padding:10px 18px;font-size:10px;font-family: var(--font-body);font-weight:600;letter-spacing:1.2px;text-transform:uppercase;border-radius:0;border:1px solid rgba(201,169,110,0.08);border-right:none;background:rgba(201,169,110,0.03);color:rgba(201,169,110,0.3);cursor:default;transition:all 0.4s ease;flex-shrink:0;display:flex;align-items:center;gap:7px}
.phase-pill:first-child{border-radius: 2px 0 0 10px}
.phase-pill:last-child{border-radius:0 10px 10px 0;border-right:1px solid rgba(201,169,110,0.08)}
.phase-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:rgba(201,169,110,0.12);transition:all 0.4s;flex-shrink:0}
.phase-pill.active{color:var(--aman-gold);background:rgba(201,169,110,0.1);border-color:rgba(201,169,110,0.2);box-shadow:inset 0 0 20px rgba(201,169,110,0.06)}
.phase-pill.active::before{background:var(--aman-gold);box-shadow:0 0 10px var(--aman-gold);animation:pillPulse 1.5s ease-in-out infinite}
.phase-pill.complete{color:rgba(139,158,107,0.8);background:rgba(139,158,107,0.08);border-color:rgba(139,158,107,0.18)}
.phase-pill.complete::before{background:rgba(139,158,107,0.7);box-shadow:0 0 4px rgba(139,158,107,0.3);width:6px;height:6px}
.phase-pill.error{color:rgba(192,112,96,0.8);background:rgba(192,112,96,0.06);border-color:rgba(192,112,96,0.18)}
.phase-pill.error::before{background:rgba(192,112,96,0.7);box-shadow:0 0 4px rgba(192,112,96,0.3)}
@keyframes pillPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.4)}}

/* V28.6: Stats — white cards on dark noir, commanding numbers */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.stat-box{background:var(--card);padding:20px 16px;text-align:center;border-radius: 2px;border:1px solid var(--border);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat-box::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.35),transparent);border-radius:1px}
.stat-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px rgba(201,169,110,0.04);border-color:rgba(201,169,110,0.12)}
.stat-box .value{font-size:30px;font-weight:600;font-family: var(--font-display);line-height:1;color:var(--text);letter-spacing:-0.5px;margin-bottom:2px}
.stat-box .label{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-top:6px;font-family: var(--font-body);font-weight:500}
.stats-bar-secondary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}
.stats-bar-secondary .stat-box{padding:14px 12px}
.stats-bar-secondary .stat-box .value{font-size:22px}

/* V24.0: Progress bar — premium with glow */
.search-progress{margin-bottom:20px;position:relative}
.search-progress-track{height:4px;background:rgba(201,169,110,0.08);border-radius:2px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,0.3)}
.search-progress-fill{height:100%;background:linear-gradient(90deg,rgba(201,169,110,0.4),var(--aman-gold),rgba(255,200,120,0.8),var(--aman-gold));background-size:300% 100%;border-radius:2px;transition:width 0.8s cubic-bezier(0.4,0,0.2,1);width:0%;animation:gradientFlow 2.5s ease infinite;box-shadow:0 0 12px rgba(201,169,110,0.3),0 0 4px rgba(201,169,110,0.5)}
@keyframes gradientFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.search-progress-label{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:rgba(201,169,110,0.45);font-family: var(--font-body);font-weight:500;letter-spacing:1px}
.search-progress-pulse{position:absolute;right:0;top:0;height:4px;width:30px;background:rgba(201,169,110,0.6);border-radius:2px;animation:progressPulse 1.5s ease-in-out infinite;box-shadow:0 0 8px rgba(201,169,110,0.4)}
@keyframes progressPulse{0%,100%{opacity:0}50%{opacity:1}}

/* ═══ V12.6: CNTCT Brain Intelligence Network — Redesigned Gotham Visualization ═══ */
.intel-split{display:block;margin-bottom:16px}
/* V12.6: Expandable CNTCT Brain — enhanced fullscreen */
/* V24.0: Brain Map Canvas — sleeker, premium dark canvas */
.spider-canvas-wrap{background:linear-gradient(160deg,#0d0f16 0%,#111420 40%,#0b0e17 100%);border:1px solid rgba(201,169,110,0.15);border-radius: 2px;height:640px;position:relative;overflow:hidden;box-shadow:inset 0 0 100px rgba(0,0,0,0.7),0 2px 24px rgba(0,0,0,0.3),0 0 1px rgba(201,169,110,0.2);transition:all 0.4s cubic-bezier(0.4,0,0.2,1)}
.spider-canvas-wrap.brain-expanded{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;z-index:500!important;border-radius:0!important;border:none!important;margin:0!important;background:linear-gradient(160deg,#010306 0%,#040a10 40%,#020508 100%)}
.brain-expand-btn{position:absolute;top:14px;right:14px;z-index:8;cursor:pointer;background:rgba(201,169,110,0.06);border:1px solid rgba(201,169,110,0.2);border-radius:2px;padding:8px 16px;font-size:10px;font-family: var(--font-body);color:rgba(201,169,110,0.7);letter-spacing:2.5px;text-transform:uppercase;transition:all 0.3s;display:flex;align-items:center;gap:8px;font-weight:600}
.brain-expand-btn::before{content:'⛶';font-size:12px}
.brain-expanded .brain-expand-btn::before{content:'✕'}
.brain-expand-btn:hover{background:rgba(201,169,110,0.1);color:rgba(201,169,110,0.95);border-color:rgba(201,169,110,0.4);box-shadow:0 0 16px rgba(201,169,110,0.12)}
.brain-parent-badge{position:absolute;top:16px;left:50%;transform:translateX(-50%);z-index:7;font-size:12px;font-family: var(--font-body);color:rgba(201,169,110,0.85);letter-spacing:3px;text-transform:uppercase;padding:8px 20px;background:rgba(6,8,14,0.85);border:1px solid rgba(201,169,110,0.2);border-radius: 2px;display:none;backdrop-filter:blur(16px);font-weight:600}
.brain-parent-badge.visible{display:block}
/* V29.1: Distribution Channel Profiles — Slide-out drawer from right */
.channel-profiles{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:90vw;z-index:1000;background:#111118;box-shadow:-8px 0 40px rgba(0,0,0,0.4);transform:translateX(100%);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;overflow:hidden}
.channel-profiles.visible{transform:translateX(0)}
.cp-backdrop{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,0.3);opacity:0;pointer-events:none;transition:opacity 0.3s}
.cp-backdrop.visible{opacity:1;pointer-events:auto}
.cp-drawer-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:all 0.2s;font-size:16px;color:var(--muted)}
.cp-drawer-close:hover{border-color:var(--aman-gold);color:var(--aman-gold);transform:scale(1.05)}
.cp-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px;padding:24px 24px 0;flex-shrink:0}
.cp-header-left{display:flex;flex-direction:column;gap:6px}
.cp-header-title{font-family: var(--font-display);font-size:28px;font-weight:600;color:var(--text);letter-spacing:-0.5px}
.cp-header-sub{font-size:11px;color:var(--muted);letter-spacing:3px;text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.cp-header-stats{display:flex;gap:24px}
.cp-hstat{display:flex;flex-direction:column;align-items:flex-end}
.cp-hstat-val{font-family: var(--font-display);font-size:24px;font-weight:600;color:var(--text)}
.cp-hstat-label{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.channel-tabs{display:flex;overflow-x:auto;gap:8px;padding:4px 24px;margin-bottom:12px;scrollbar-width:none;flex-shrink:0}
.channel-tabs::-webkit-scrollbar{display:none}
.channel-tab{padding:8px 16px;font-size:10px;font-family: var(--font-body);font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;border:1px solid rgba(201,169,110,0.12);border-radius: 2px;white-space:nowrap;transition:all 0.25s;background:rgba(201,169,110,0.03);display:flex;align-items:center;gap:8px}
.channel-tab:hover{color:var(--text2);background:rgba(201,169,110,0.07);border-color:rgba(201,169,110,0.2)}
.channel-tab.active{color:var(--text);background:rgba(201,169,110,0.1);border-color:rgba(201,169,110,0.25);font-weight:600}
.channel-tab .tab-count{font-size:10px;font-family: var(--font-display);font-weight:600;opacity:0.5}
.channel-tab.active .tab-count{opacity:0.8}
.channel-tab-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}
.channel-profile-content{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.2) transparent;display:flex;flex-direction:column;gap:8px;padding:0 24px 24px}
.channel-profile-content::-webkit-scrollbar{width:6px}
.channel-profile-content::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:3px}
.cp-company-card{padding:18px 22px 18px 24px;background:var(--card);border:1px solid var(--border);border-left:3px solid transparent;border-radius: 2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);cursor:pointer;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.cp-company-card:hover{border-color:rgba(201,169,110,0.15);border-left-color:var(--aman-gold);background:var(--bg4);box-shadow:0 8px 24px rgba(0,0,0,0.3);transform:translateY(-2px)}
.cp-company-card.expanded{border-color:rgba(201,169,110,0.15);border-left-color:var(--aman-gold);background:var(--bg4);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.cp-card-header{display:flex;justify-content:space-between;align-items:center;gap:14px;cursor:pointer}
.cp-card-left{flex:1;min-width:0}
.cp-company-name{font-family: var(--font-display);font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.3px}
.cp-website-link{font-size:11px;color:var(--muted);text-decoration:none;margin-left:10px;font-family: var(--font-body);font-weight:400;transition:color 0.2s}
.cp-website-link:hover{color:var(--aman-gold)}
.cp-company-meta{display:flex;gap:12px;margin-top:6px;flex-wrap:wrap;align-items:center}
.cp-stat{font-size:12px;color:var(--muted);font-family: var(--font-body);letter-spacing:0.3px}
.cp-stat-email{color:#8B9E6B}
.cp-card-right{display:flex;align-items:center;gap:12px}
.cp-company-count{font-family: var(--font-display);font-size:24px;font-weight:600;color:var(--text);opacity:0.25;line-height:1}
.cp-expand-icon{font-size:10px;color:var(--muted);transition:transform 0.3s ease,color 0.2s}
.cp-company-card.expanded .cp-expand-icon{transform:rotate(90deg);color:var(--aman-gold)}
.cp-card-expanded-content{padding-top:18px;margin-top:18px;border-top:1px solid rgba(201,169,110,0.08);animation:cpReveal 0.3s ease}
@keyframes cpReveal{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.cp-section-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--aman-gold);font-family: var(--font-body);font-weight:600;display:block;margin-bottom:10px}
.cp-brand-chips{display:flex;flex-wrap:wrap;gap:6px}
.cp-brand-chip{font-size:11px;padding:5px 12px;background:rgba(201,169,110,0.04);color:var(--text2);border:1px solid rgba(201,169,110,0.12);border-radius:2px;font-family: var(--font-body);font-weight:500;white-space:nowrap;transition:all 0.2s}
.cp-brand-chip:hover{background:rgba(201,169,110,0.08);border-color:rgba(201,169,110,0.2);color:var(--text)}
.cp-region-tags{display:flex;flex-wrap:wrap;gap:6px}
.cp-region-tag{font-size:10px;padding:4px 10px;background:rgba(201,169,110,0.03);color:var(--muted);border:1px solid rgba(201,169,110,0.08);border-radius:2px;font-family: var(--font-body);letter-spacing:0.5px}
.cp-spec{font-size:12px;color:var(--muted);font-family: var(--font-body);line-height:1.6;padding:10px 14px;background:rgba(201,169,110,0.02);border-radius:2px;border-left:2px solid rgba(201,169,110,0.15)}
.cp-contacts-heading{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:2.5px;font-family: var(--font-body);font-weight:600;margin-bottom:10px}
.cp-contact-card{padding:12px 16px;background:rgba(201,169,110,0.02);border:1px solid rgba(201,169,110,0.06);border-radius: 2px;transition:all 0.2s}
.cp-contact-card:hover{background:rgba(201,169,110,0.04);border-color:rgba(201,169,110,0.12)}
.cp-contact-header{display:flex;align-items:baseline;gap:10px;margin-bottom:4px}
.cp-contact-name-link{font-family: var(--font-body);font-size:13px;font-weight:600;color:var(--text);text-decoration:none;transition:color 0.2s}
.cp-contact-name-link:hover{color:var(--aman-gold)}
.cp-contact-title-link{color:var(--muted);flex:1;font-size:12px;font-family: var(--font-body);text-decoration:none}
.cp-contact-title-link:hover{color:var(--text2)}
.cp-diamond-badge{display:inline-flex;align-items:center;font-size:10px;margin-left:6px;color:var(--aman-gold);font-weight:600;background:rgba(201,169,110,0.08);padding:2px 8px;border-radius:2px;letter-spacing:0.5px;font-family: var(--font-body)}
.cp-source-tag{display:inline-block;font-size:9px;padding:3px 7px;background:rgba(201,169,110,0.04);color:var(--muted);border-radius:2px;margin-left:6px;font-family: var(--font-body);text-transform:uppercase;letter-spacing:0.5px;font-weight:500}
.cp-contact-methods{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap;align-items:center}
.cp-contact-method{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(201,169,110,0.03);border:1px solid rgba(201,169,110,0.1);border-radius:2px;cursor:pointer;transition:all 0.2s;color:var(--muted);text-decoration:none;font-family: var(--font-body);font-size:11px}
.cp-contact-method:hover{background:rgba(201,169,110,0.07);border-color:rgba(201,169,110,0.2);color:var(--text2)}
.channel-empty{text-align:center;padding:48px;color:var(--muted);font-size:13px;font-family: var(--font-body);letter-spacing:1px}
/* V24.0: CNTCT Brain legend — right-side collapsible drawer with stats */
.brain-legend-wrap{position:absolute;top:14px;bottom:14px;right:14px;z-index:6;width:200px;display:flex;flex-direction:column;pointer-events:none}
.brain-legend-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:10px;font-family: var(--font-body);color:rgba(201,169,110,0.6);letter-spacing:2px;text-transform:uppercase;cursor:pointer;background:rgba(6,8,14,0.85);border:1px solid rgba(201,169,110,0.12);border-radius: 2px;width:fit-content;transition:all 0.3s;backdrop-filter:blur(16px);pointer-events:all;font-weight:600;margin-left:auto}
.brain-legend-toggle:hover{color:rgba(201,169,110,0.9);background:rgba(6,8,14,0.95);border-color:rgba(201,169,110,0.25)}
.brain-legend-toggle .bl-arrow{transition:transform 0.3s;display:inline-block;font-size:8px}
.brain-legend-wrap.bl-open .bl-arrow{transform:rotate(180deg)}
.brain-legend-wrap.bl-open{pointer-events:all}
.brain-legend{display:flex;flex-direction:column;gap:3px;padding:14px 16px;background:rgba(6,8,14,0.92);border:1px solid rgba(201,169,110,0.15);border-radius: 2px;backdrop-filter:blur(20px);max-height:calc(100% - 50px);overflow-y:auto;transition:max-height 0.4s ease,padding 0.4s ease,opacity 0.3s;opacity:1;margin-top:8px;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.2) transparent}
.brain-legend::-webkit-scrollbar{width:5px}
.brain-legend::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:3px}
.brain-legend-wrap:not(.bl-open) .brain-legend{max-height:0;padding:0 16px;opacity:0;overflow:hidden}
.brain-legend-stats{font-size:9px;color:rgba(201,169,110,0.6);letter-spacing:2px;text-transform:uppercase;padding:8px 0 10px;border-bottom:1px solid rgba(201,169,110,0.1);margin-bottom:6px;font-family: var(--font-body);font-weight:600;line-height:1.8}
.brain-legend-stats .bls-num{color:rgba(201,169,110,0.85);font-family: var(--font-display);font-size:14px;letter-spacing:0;font-weight:600}
.brain-legend-item{display:flex;align-items:center;gap:8px;font-size:10px;font-family: var(--font-body);color:rgba(255,255,255,0.6);letter-spacing:0.5px;text-transform:uppercase;white-space:nowrap;padding:5px 0;transition:color 0.2s;cursor:default}
.brain-legend-item:hover{color:rgba(255,255,255,0.9)}
.brain-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 0 4px currentColor}
.spider-canvas-wrap svg{width:100%;height:100%;position:relative;z-index:2}
.spider-canvas-wrap canvas{display:none}
/* V18: Network node hover z-index fix */
.spider-canvas-wrap svg .node-group:hover{z-index:10}
/* V12.6: Enhanced label and stats bar */
/* V28.4: Spider label — subtle, non-intrusive */
.spider-label{position:absolute;top:12px;left:14px;font-size:9px;color:rgba(201,169,110,0.35);font-family: var(--font-body);letter-spacing:3px;text-transform:uppercase;z-index:6;display:flex;align-items:center;gap:8px;font-weight:600}
.spider-label::before{content:'';width:6px;height:6px;background:rgba(201,169,110,0.4);border-radius:50%;flex-shrink:0}
/* V28.0: Spider stats — bottom-right system readout */
.spider-stats{position:absolute;bottom:12px;right:14px;font-size:9px;color:rgba(201,169,110,0.4);font-family: var(--font-body);z-index:6;text-align:right;letter-spacing:1px;background:rgba(6,8,14,0.7);padding:6px 12px;border-radius:2px;border:1px solid rgba(201,169,110,0.08);backdrop-filter:blur(8px);font-weight:500}
.brain-expanded .spider-label{font-size:11px;color:rgba(201,169,110,0.85);left:20px;top:18px}
.brain-expanded .spider-stats{font-size:11px;color:rgba(201,169,110,0.55)}
/* V12.6: CNTCT Brain Gotham grid — enhanced topographic feel */
/* V28.4: Clean, minimal grid — network graph aesthetic */
.brain-grid{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.brain-grid::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(201,169,110,0.02) 0%,transparent 100%)}
.brain-grid::after{display:none}
.brain-rings{position:absolute;inset:0;pointer-events:none;z-index:1}
/* Legend styles moved to V12.6 block above */
/* V12.6: Tier labels — enhanced visibility with glow markers */
/* V28.4: Tier labels — whisper-quiet, only visible on expand */
.brain-tier-label{position:absolute;left:12px;font-size:7px;font-family: var(--font-body);color:rgba(201,169,110,0.15);letter-spacing:3px;text-transform:uppercase;z-index:3;pointer-events:none;padding-left:10px;border-left:1px solid rgba(201,169,110,0.08);font-weight:600}
.brain-expanded .brain-tier-label{font-size:9px;color:rgba(201,169,110,0.3);padding-left:14px;left:20px}
/* V28.2: Node animations — enhanced glow, brighter pulses, more dramatic discovery */
@keyframes brainPulse{0%{opacity:0;transform:scale(0)}30%{opacity:1;transform:scale(1.2)}60%{transform:scale(0.92)}100%{transform:scale(1)}}
@keyframes brainGlow{0%,100%{filter:drop-shadow(0 0 6px currentColor)}50%{filter:drop-shadow(0 0 14px currentColor) drop-shadow(0 0 28px currentColor)}}
@keyframes brainLinkDraw{from{stroke-dashoffset:200;opacity:0}to{stroke-dashoffset:0;opacity:0.6}}
@keyframes brainDataFlow{0%{stroke-dashoffset:16}100%{stroke-dashoffset:0}}
.brain-link-flow{stroke-dasharray:8 4;animation:brainDataFlow 1.5s linear infinite}
@keyframes nodeDiscover{0%{r:0;opacity:0;filter:brightness(3)}40%{opacity:1;filter:brightness(1.5)}100%{filter:brightness(1)}}
@keyframes hexRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes brandPulse{0%,100%{filter:drop-shadow(0 0 8px #c9a96e) drop-shadow(0 0 16px rgba(201,169,110,0.3))}50%{filter:drop-shadow(0 0 16px #c9a96e) drop-shadow(0 0 32px rgba(201,169,110,0.5)) drop-shadow(0 0 48px rgba(201,169,110,0.15))}}
.brain-node{animation:brainPulse 0.8s cubic-bezier(0.34,1.56,0.64,1) forwards}
.brain-node-brand{animation:brandPulse 4s ease-in-out infinite}
.brain-node-channel{animation:brainGlow 5s ease-in-out infinite 0.5s}
.brain-link{stroke-dasharray:200;animation:brainLinkDraw 1.2s ease forwards}
.brain-link-flow{stroke-dasharray:6 3;animation:brainDataFlow 0.8s linear infinite}
/* V28.4: Scan lines + crosshair + HUD corners HIDDEN — clean network graph */
.brain-scan,.brain-scan-h,.brain-crosshair,.brain-hud-corner{display:none!important}
@keyframes scanLine{0%{transform:translateY(-100%)}100%{transform:translateY(calc(100vh + 100%))}}
@keyframes scanLineH{0%{transform:translateX(-100%)}100%{transform:translateX(calc(100vw + 100%))}}
/* V28.4: HUD corners + crosshair removed for clean network graph */
/* V28.4: HUD readout — compact, non-intrusive node/link counter */
.brain-hud-readout{position:absolute;bottom:12px;left:14px;font-family: var(--font-body);font-size:9px;color:rgba(201,169,110,0.35);letter-spacing:1px;z-index:6;text-align:left;line-height:1.6;background:rgba(6,8,14,0.7);padding:6px 12px;border-radius:2px;backdrop-filter:blur(8px);font-weight:500;border:1px solid rgba(201,169,110,0.08);text-transform:uppercase}
.brain-hud-readout span{display:inline;margin-right:8px}
.brain-hud-readout .hud-val{color:rgba(201,169,110,0.6);font-family: var(--font-display);font-size:13px;letter-spacing:0;text-transform:none;font-weight:600;line-height:1}
/* V28.2: Tooltip — premium intelligence card with enhanced depth */
.brain-tooltip{position:absolute;pointer-events:none;z-index:10;background:rgba(6,8,14,0.97);border:1px solid rgba(201,169,110,0.25);border-radius: 2px;padding:18px 22px;font-family: var(--font-body);font-size:12px;color:rgba(255,255,255,0.9);max-width:360px;box-shadow:0 16px 48px rgba(0,0,0,0.85),0 0 1px rgba(201,169,110,0.4),inset 0 1px 0 rgba(201,169,110,0.06);display:none;backdrop-filter:blur(24px)}
.brain-tooltip::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 5%,rgba(201,169,110,0.6) 30%,var(--aman-gold) 50%,rgba(201,169,110,0.6) 70%,transparent 95%);border-radius: 2px 14px 0 0}
.brain-tooltip .tt-type{font-size:9px;color:rgba(201,169,110,0.7);letter-spacing:3px;text-transform:uppercase;margin-bottom:8px;font-weight:600}
.brain-tooltip .tt-label{font-size:18px;font-weight:600;margin-bottom:6px;color:#fff;font-family: var(--font-display);letter-spacing:0.5px}
.brain-tooltip .tt-detail{font-size:11px;color:rgba(255,255,255,0.6);letter-spacing:0.3px;line-height:1.7}
.brain-tooltip .tt-meta{font-size:10px;color:rgba(201,169,110,0.5);margin-top:10px;padding-top:10px;border-top:1px solid rgba(201,169,110,0.12);font-weight:500;letter-spacing:1px}

/* ═══ V24.0: THINKING STREAM — Premium live feed ═══ */
.thinking-stream{max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.15) transparent;padding:14px 16px;background:linear-gradient(180deg,rgba(0,4,10,0.3) 0%,rgba(0,4,10,0.5) 100%);border:1px solid rgba(201,169,110,0.12);border-radius: 2px;position:relative;font-family: var(--font-mono);box-shadow:inset 0 2px 8px rgba(0,0,0,0.2)}
.thinking-stream::-webkit-scrollbar{width:3px}
.thinking-stream::-webkit-scrollbar-track{background:transparent}
.thinking-stream::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:2px}
.ts-line{font-size:11.5px;line-height:1.8;padding:2px 0;animation:plfSlideIn 0.3s ease-out;white-space:normal;word-break:break-word}
.ts-line.ts-latest{text-shadow:0 0 10px currentColor}
.ts-line.plf-agent{color:#d4af37}
.ts-line.plf-genome{color:#c9a96e}
.ts-line.plf-vacuum{color:#a8977a}
.ts-line.plf-peer{color:#b8a898}
.ts-line.plf-error{color:#ff5555}
.ts-line.plf-complete{color:#c9a96e;font-weight:600}
.ts-line.plf-system{color:#8a8072}
.ts-line.plf-extract{color:#a8977a}
.ts-line.plf-dork{color:#d4af37}
.ts-line.plf-email{color:#d4af37}
.ts-line.plf-tribunal{color:#c9a96e}
.ts-line.plf-default{color:#8a8072}
.ts-fade-1{opacity:0.9}
.ts-fade-2{opacity:0.8}
.ts-fade-3{opacity:0.65}
.ts-fade-4{opacity:0.5}
.ts-fade-5{opacity:0.4}
.thinking-stream-header{font-family: var(--font-body);font-size:10px;letter-spacing:2.5px;color:rgba(201,169,110,0.6);text-transform:uppercase;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(201,169,110,0.1);font-weight:600}
/* Legacy support */
.think-line{opacity:0;animation:fadeIn 0.3s ease forwards}
.think-genome{color:var(--gold-bright)}
.think-peer{color:var(--orange)}
.think-swarm{color:var(--orange)}
.think-vacuum{color:var(--orange)}
.think-dork{color:var(--gold)}
.think-extract{color:var(--purple)}
.think-tribunal{color:var(--green)}
.think-verify{color:var(--green)}
.think-email{color:var(--cyan)}
.think-kill{color:var(--red)}
.think-filter{color:var(--red)}
.think-lateral{color:var(--pink)}
.think-error{color:var(--red);font-weight:600}
.think-complete{color:var(--green);font-weight:600}
.think-system{color:var(--dim);font-style:italic}
.think-retry{color:var(--orange);font-style:italic}
.think-vault{color:var(--purple)}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ═══ Thread Grid ═══ */
.thread-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;max-height:90px;overflow-y:auto}
.thread-card{background:var(--card);border:1px solid var(--border);border-radius:2px;padding:6px 12px;font-size:11px;font-family: var(--font-body);display:inline-flex;align-items:center;gap:8px;transition:all 0.2s;box-shadow:var(--shadow-sm)}
.thread-card.active{border-color:var(--accent);background:var(--accent-soft);animation:pulse 1.5s infinite}
.thread-card.complete{border-color:rgba(139,158,107,0.2);opacity:0.5}
.thread-card.error{border-color:var(--red);opacity:0.5}
.thread-card .vector{font-weight:500;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.thread-card .query{display:none}
.thread-card .results{color:var(--green);font-weight:600;font-size:11px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ═══ Lateral Panel ═══ */
.lateral-panel{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.lateral-panel h4{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;margin-bottom:12px;font-weight:600;font-family: var(--font-body)}
.lateral-brand{display:inline-block;padding:6px 14px;background:transparent;border:1px solid rgba(196,136,154,0.2);border-radius:var(--radius-sm);font-size:13px;font-family: var(--font-body);color:var(--pink);margin:3px;cursor:pointer;transition:all 0.2s}
.lateral-brand:hover{background:rgba(196,136,154,0.08);border-color:var(--pink)}

/* ═══ V23.0: PREMIUM INTELLIGENCE LEDGER ═══ */
.forensic-ledger{margin-top:24px;background:transparent;padding:0;border:none}
/* V24.0: Intelligence Ledger — premium header redesign */
.il-top{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:24px 28px 18px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.il-title-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.il-title-left{display:flex;align-items:baseline;gap:16px}
.il-title{font-family: var(--font-display);font-size:30px;font-weight:700;letter-spacing:-0.5px;color:var(--text);margin:0;line-height:1}
.il-count{font-size:14px;color:var(--aman-gold);font-family: var(--font-display);font-weight:600;padding:3px 10px;background:rgba(201,169,110,0.06);border-radius:2px}
.il-actions{display:flex;gap:8px;flex-wrap:wrap}
.il-act-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius: 2px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.25s;font-family: var(--font-body);border:1px solid;letter-spacing:0.2px}
.il-act-icon{font-size:13px;opacity:0.8}
.il-act-export{background:rgba(201,169,110,0.08);color:var(--aman-gold);border-color:rgba(201,169,110,0.2)}
.il-act-export:hover{background:rgba(201,169,110,0.15);border-color:rgba(201,169,110,0.4);box-shadow:0 2px 12px rgba(201,169,110,0.1)}
.il-act-logs{background:rgba(139,158,107,0.08);color:var(--green);border-color:rgba(139,158,107,0.2)}
.il-act-logs:hover{background:rgba(139,158,107,0.15);border-color:rgba(139,158,107,0.4);box-shadow:0 2px 12px rgba(139,158,107,0.1)}
.il-act-email{background:rgba(155,139,180,0.08);color:var(--accent);border-color:rgba(155,139,180,0.2)}
.il-act-email:hover{background:rgba(155,139,180,0.15);border-color:rgba(155,139,180,0.4);box-shadow:0 2px 12px rgba(155,139,180,0.1)}
.il-act-remove{background:rgba(192,112,96,0.08);color:var(--red);border-color:rgba(192,112,96,0.2)}
.il-act-remove:hover{background:rgba(192,112,96,0.15);border-color:rgba(192,112,96,0.4);box-shadow:0 2px 12px rgba(192,112,96,0.1)}
.il-controls{display:flex;gap:14px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.il-search-wrap{position:relative;flex:1;min-width:260px}
.il-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:rgba(201,169,110,0.4);font-size:17px;pointer-events:none}
.il-search{width:100%;padding:12px 18px 12px 42px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius: 2px;color:var(--text);font-size:14px;font-family: var(--font-body);outline:none;transition:all 0.3s}
.il-search:focus{border-color:rgba(201,169,110,0.35);box-shadow:0 0 0 3px rgba(201,169,110,0.06);background:rgba(255,255,255,0.05)}
.il-search::placeholder{color:var(--dim);font-weight:400;font-size:13px}
.il-view-group{display:flex;gap:0;border:1px solid rgba(255,255,255,0.08);border-radius: 2px;overflow:hidden;background:rgba(255,255,255,0.03)}
.il-view{padding:10px 22px;font-size:12px;font-family: var(--font-body);font-weight:600;letter-spacing:0.5px;cursor:pointer;border:none;background:transparent;color:rgba(201,169,110,0.4);transition:all 0.25s}
.il-view:hover{color:rgba(201,169,110,0.7);background:rgba(201,169,110,0.05)}
.il-view.active{background:rgba(201,169,110,0.12);color:var(--aman-gold);box-shadow:inset 0 -2px 0 var(--aman-gold)}
.il-filters{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.filter-pills{display:flex;gap:5px;flex-wrap:wrap}
.filter-pill{padding:7px 16px;border-radius: 2px;font-size:12px;font-family: var(--font-body);cursor:pointer;border:1px solid rgba(201,169,110,0.1);color:rgba(201,169,110,0.5);background:transparent;transition:all 0.25s;font-weight:500;letter-spacing:0.2px}
.filter-pill:hover{border-color:rgba(201,169,110,0.3);color:rgba(201,169,110,0.75);background:rgba(201,169,110,0.04)}
.filter-pill.active{border-color:var(--aman-gold);color:var(--aman-gold);background:rgba(201,169,110,0.1);box-shadow:0 0 8px rgba(201,169,110,0.1)}
.il-bulk{display:flex;gap:4px}
.il-bulk-btn{padding:5px 12px;border-radius:2px;font-size:10px;font-family: var(--font-body);cursor:pointer;border:1px solid rgba(201,169,110,0.1);color:rgba(201,169,110,0.4);background:transparent;transition:all 0.2s;font-weight:500;letter-spacing:0.3px;text-transform:uppercase}
.il-bulk-btn:hover{border-color:rgba(201,169,110,0.25);color:rgba(201,169,110,0.7)}
.btn-back{padding:8px 18px;border-radius:2px;font-size:12px;background:rgba(255,252,248,0.04);border:1px solid rgba(201,169,110,0.12);color:rgba(201,169,110,0.55);cursor:pointer;transition:all 0.3s;font-family: var(--font-body);font-weight:500;letter-spacing:0.5px;backdrop-filter:blur(8px)}
.btn-back:hover{border-color:rgba(201,169,110,0.3);color:var(--aman-gold);background:rgba(201,169,110,0.08);box-shadow:0 2px 12px rgba(201,169,110,0.1)}

/* ═══ V24.0: PREMIUM TABLE — clean, readable, professional ═══ */
.contacts-grid{width:100%}
.contacts-count{font-size:12px;color:var(--muted);font-family: var(--font-body);padding:6px 0;letter-spacing:0.3px}
.il-table-wrap{max-height:74vh;overflow-y:auto;border:1px solid var(--border);border-radius: 2px;background:var(--card);scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.15) transparent;box-shadow:var(--shadow-sm)}
.il-table-wrap::-webkit-scrollbar{width:6px}
.il-table-wrap::-webkit-scrollbar-track{background:transparent}
.il-table-wrap::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.18);border-radius:3px}
.il-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.il-table thead{position:sticky;top:0;z-index:10}
.il-table thead th{position:sticky;top:0;z-index:10;background:rgba(255,255,255,0.72);backdrop-filter:blur(20px);color:rgba(100,100,105,0.8);font-family: var(--font-body);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:14px 16px;border-bottom:2px solid rgba(201,169,110,0.12);white-space:nowrap;cursor:pointer;user-select:none;transition:all 0.2s}
.il-table thead th:hover{color:var(--aman-gold);background:rgba(201,169,110,0.05)}
.il-table th.sorted-asc::after{content:' ↑';color:var(--aman-gold);font-size:11px}
.il-table th.sorted-desc::after{content:' ↓';color:var(--aman-gold);font-size:11px}
.il-table th:first-child{padding-left:16px;width:38px}
.il-table tbody tr{transition:all 0.15s ease;border-bottom:1px solid rgba(201,169,110,0.04)}
.il-table tbody tr:nth-child(even){background:rgba(201,169,110,0.02)}
.il-table tbody tr:hover{background:rgba(201,169,110,0.07)}
.il-table tbody td{padding:13px 16px;font-size:13.5px;vertical-align:middle;border-bottom:1px solid rgba(201,169,110,0.04);color:var(--text2);line-height:1.5}
.il-table td:first-child{padding-left:16px;width:38px}
.il-table tr.selected{background:rgba(201,169,110,0.1)}
.il-table tbody tr.diamond-row{background:linear-gradient(90deg,rgba(201,169,110,0.07),rgba(201,169,110,0.015),transparent)}
.il-table tbody tr.diamond-row:hover{background:linear-gradient(90deg,rgba(201,169,110,0.12),rgba(201,169,110,0.04),transparent)}
.il-table tbody tr.golden-row{background:linear-gradient(90deg,rgba(201,169,110,0.05),transparent)}
.il-table tbody tr.rejected-row{opacity:0.3}
.tbl-check{width:16px;height:16px;accent-color:var(--aman-gold);cursor:pointer;opacity:0.5;transition:opacity 0.2s}
.il-table tbody tr:hover .tbl-check{opacity:1}
.tbl-name{font-weight:600;color:var(--text);font-size:14px;font-family: var(--font-body);letter-spacing:-0.2px}
.tbl-company{font-family: var(--font-display);font-size:15px;color:rgba(201,169,110,0.8);font-weight:500}
.tbl-email a{color:rgba(201,169,110,0.75);text-decoration:none;font-family: var(--font-mono);font-size:12px;transition:color 0.2s;letter-spacing:-0.2px}
.tbl-email a:hover{color:var(--aman-gold);text-decoration:underline}
.tbl-email .inferred{color:var(--orange)}
.tbl-email .bounce-risk{color:var(--red);text-decoration:line-through}
.tbl-status{display:inline-block;padding:4px 10px;border-radius:2px;font-size:11px;font-weight:600;font-family: var(--font-body);letter-spacing:0.3px}
.tbl-status.verified{background:rgba(139,158,107,0.1);color:var(--green);border:1px solid rgba(139,158,107,0.15)}
.tbl-status.unverified{background:rgba(251,146,60,0.1);color:var(--orange);border:1px solid rgba(251,146,60,0.15)}
.tbl-confidence{display:flex;align-items:center;gap:8px}
.tbl-conf-bar{width:56px;height:4px;background:rgba(201,169,110,0.08);border-radius:3px;overflow:hidden}
.tbl-conf-fill{height:100%;border-radius:3px}
.tbl-conf-fill.high{background:var(--green)}
.tbl-conf-fill.med{background:var(--orange)}
.tbl-conf-fill.low{background:var(--red)}
.tbl-conf-text{font-size:12px;color:var(--muted);font-family: var(--font-mono);min-width:32px}
.tbl-mx{font-size:11px;font-family: var(--font-mono)}
.tbl-mx.valid{color:var(--green)}
.tbl-mx.invalid{color:var(--red)}
.tbl-mx.unknown{color:var(--dim)}
.tbl-source{font-size:9px;padding:3px 8px;border-radius:2px;font-family: var(--font-body);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;background:var(--purple-soft);color:var(--purple)}
.tbl-tags{display:flex;gap:3px;flex-wrap:wrap}
.tbl-tag{font-size:9px;padding:2px 7px;border-radius:3px;font-family: var(--font-body);font-weight:600;letter-spacing:0.3px}
.tbl-tag.golden{background:rgba(201,169,110,0.08);color:var(--gold);border:1px solid rgba(201,169,110,0.15)}
.tbl-tag.vault{background:var(--purple-soft);color:var(--purple);border:1px solid rgba(155,139,180,0.15)}
.tbl-tag.inferred{background:var(--orange-soft);color:var(--orange);border:1px solid rgba(251,146,60,0.15)}
.contacts-table-wrap{max-height:650px;overflow-y:auto;border:1px solid var(--border);border-radius: 2px;background:var(--card);box-shadow:var(--shadow-sm)}
.row-detail{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#111118;border:1px solid rgba(255,255,255,0.1);border-radius: 2px;padding:32px;width:560px;max-width:90vw;max-height:85vh;overflow-y:auto;z-index:100;box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.row-detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:99;backdrop-filter:blur(8px)}
.row-detail h3{font-size:20px;margin-bottom:8px;font-family: var(--font-body);font-weight:700;color:var(--text)}
.row-detail .detail-row{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:13px}
.row-detail .detail-label{color:var(--dim);min-width:100px;font-size:11px;text-transform:uppercase;letter-spacing:0.8px;font-weight:600;padding-top:2px}
.row-detail .detail-value{color:var(--text2);flex:1;word-break:break-word;line-height:1.7}
.row-detail .close-btn{position:absolute;top:16px;right:16px;background:#12121A;border:1px solid rgba(255,255,255,0.07);color:var(--muted);width:32px;height:32px;border-radius:2px;font-size:16px;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center}
.row-detail .close-btn:hover{color:var(--text);border-color:rgba(255,255,255,0.15)}

/* ═══ V15.2: CONTACTS INTELLIGENCE CARDS ═══ */
/* V23.0: Legacy compat — old view-toggle classes redirect */
.view-toggle-group{display:none}
.view-toggle{display:none}
.contacts-view-bar{display:none}
.ledger-title-row{display:none}
.ledger-actions-row{display:none}
.ledger-section-label{display:none}
/* V24.0: Cards container — magazine-quality enriched grid */
.contacts-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:16px;max-height:75vh;overflow-y:auto;padding:6px 4px;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.2) transparent}
.contacts-cards::-webkit-scrollbar{width:6px}
.contacts-cards::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:3px}
.contact-card{display:flex;flex-direction:column;gap:12px;padding:20px 22px;background:var(--card);border:1px solid var(--border);border-radius: 2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);cursor:pointer;position:relative;border-left:4px solid transparent;box-shadow:var(--shadow-sm)}
.contact-card:hover{border-color:rgba(201,169,110,0.12);background:var(--bg4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.contact-card.diamond{border-left-color:var(--aman-gold);background:linear-gradient(135deg,rgba(201,169,110,0.08),rgba(201,169,110,0.03));box-shadow:0 2px 12px rgba(201,169,110,0.1),inset 0 1px 0 rgba(201,169,110,0.08),0 0 20px rgba(201,169,110,0.04)}
.contact-card.diamond:hover{background:linear-gradient(135deg,rgba(201,169,110,0.12),rgba(201,169,110,0.05));box-shadow:0 6px 20px rgba(201,169,110,0.15),0 0 30px rgba(201,169,110,0.06);transform:translateY(-2px)}
.contact-card.golden{border-left-color:rgba(201,169,110,0.6);background:rgba(201,169,110,0.04);box-shadow:0 2px 16px rgba(201,169,110,0.06)}
.contact-card.rejected{opacity:0.35;border-left-color:var(--red);filter:grayscale(0.8)}
.contact-card.imported{border-left-color:#5b8a72;border-left-width:4px;background:rgba(91,138,114,0.04);box-shadow:0 1px 8px rgba(91,138,114,0.08)}
.contact-card.imported:hover{background:rgba(91,138,114,0.07);border-color:rgba(91,138,114,0.2)}
.cp-contact-card.imported{border-left:3px solid #5b8a72;background:rgba(91,138,114,0.03)}
tr.imported-row{border-left:3px solid #5b8a72;background:rgba(91,138,114,0.03)}
tr.imported-row:hover{background:rgba(91,138,114,0.06)}
.contact-card.selected{background:rgba(201,169,110,0.08);border-color:var(--aman-gold);box-shadow:0 0 0 3px rgba(201,169,110,0.1),0 4px 16px rgba(201,169,110,0.12)}
.cc-main{display:flex;flex-direction:column;gap:8px;min-width:0}
.cc-name{font-weight:600;font-size:18px;color:var(--text);font-family: var(--font-display);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-0.3px;line-height:1.2}
.cc-title{font-size:13.5px;color:var(--muted);font-family: var(--font-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400;line-height:1.4}
.cc-company-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:4px}
.cc-company{font-size:13px;color:var(--text2);font-weight:500;font-family: var(--font-body);display:flex;align-items:center;gap:6px}
.cc-company::before{content:'';display:inline-block;width:18px;height:18px;border-radius:2px;background-size:contain;background-position:center;background-repeat:no-repeat}
.cc-pillar{display:inline-block;padding:5px 10px;border-radius:2px;font-size:10px;font-weight:600;letter-spacing:1px;font-family: var(--font-body);white-space:nowrap;border:1px solid rgba(201,169,110,0.12);text-transform:uppercase}
.cc-territory{font-size:11px;color:var(--dim);font-family: var(--font-body);text-transform:uppercase;letter-spacing:0.8px;font-weight:500}
.cc-actions{display:flex;flex-direction:row;align-items:center;gap:8px;justify-content:flex-start;flex-wrap:wrap;margin-top:2px}
.cc-action-row{display:flex;gap:8px;align-items:center}
.cc-email-btn,.cc-phone-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:2px;font-size:11.5px;font-family: var(--font-body);text-decoration:none;transition:all 0.25s;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);font-weight:500}
.cc-email-btn{color:var(--accent-bright);border-color:rgba(201,169,110,0.18)}
.cc-email-btn:hover{background:rgba(201,169,110,0.08);border-color:rgba(201,169,110,0.3);box-shadow:0 2px 10px rgba(201,169,110,0.1)}
.cc-phone-btn{color:var(--green);border-color:rgba(139,158,107,0.2)}
.cc-phone-btn:hover{background:rgba(139,158,107,0.06);border-color:rgba(139,158,107,0.3);box-shadow:0 2px 10px rgba(139,158,107,0.1)}
.cc-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.cc-status{font-size:11px;font-weight:600;padding:5px 10px;border-radius:2px;letter-spacing:0.5px;font-family: var(--font-body);border:1px solid}
.cc-status.verified{background:rgba(139,158,107,0.1);color:#8B9E6B;border-color:rgba(139,158,107,0.2)}
.cc-status.unverified{background:rgba(251,146,60,0.1);color:var(--orange);border-color:rgba(251,146,60,0.2)}
.cc-status.rejected{background:rgba(192,112,96,0.1);color:var(--red);border-color:rgba(192,112,96,0.2)}
.cc-trust{font-size:11px;color:var(--muted);font-family: var(--font-body);font-weight:600;padding:3px 6px;background:rgba(201,169,110,0.04);border-radius:2px}
.cc-check{position:absolute;top:14px;right:14px;width:18px;height:18px;accent-color:var(--aman-gold);cursor:pointer;opacity:0.4;transition:opacity 0.25s}
.contact-card:hover .cc-check{opacity:0.7}
.cc-check:checked{opacity:1;accent-color:var(--aman-gold)}
/* V24.0: Grouped/By-Company view — premium accordion with hierarchy */
.contacts-grouped{max-height:75vh;overflow-y:auto;padding:6px 4px;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.2) transparent}
.contacts-grouped::-webkit-scrollbar{width:6px}
.contacts-grouped::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:3px}
.company-group{margin-bottom:12px;border:1px solid var(--border);border-radius: 2px;overflow:hidden;background:var(--card);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm)}
.company-group:hover{border-color:rgba(201,169,110,0.18);box-shadow:0 4px 20px rgba(0,0,0,0.3)}
.company-group.expanded{box-shadow:0 4px 24px rgba(0,0,0,0.4),0 1px 0 rgba(201,169,110,0.08)}
.company-group-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:var(--card);cursor:pointer;transition:all 0.25s;user-select:none;border-left:4px solid var(--aman-gold);position:relative}
.company-group-header::after{content:'›';position:absolute;right:20px;top:50%;transform:translateY(-50%) rotate(0deg);font-size:18px;color:var(--muted);transition:transform 0.3s;font-weight:300}
.company-group.expanded .company-group-header::after{transform:translateY(-50%) rotate(90deg);color:var(--aman-gold)}
.company-group-header:hover{background:var(--card-hover)}
.company-group-name{font-weight:600;font-size:18px;color:var(--text);font-family: var(--font-display);letter-spacing:-0.3px}
.company-group-meta{display:flex;gap:10px;align-items:center;font-size:11px;color:var(--muted);font-family: var(--font-body);letter-spacing:0.3px;font-weight:500}
.company-group-meta span{display:flex;align-items:center;gap:5px;padding:4px 10px;background:rgba(201,169,110,0.04);border-radius:2px;border:1px solid rgba(201,169,110,0.08)}
.company-group-body{display:none;border-top:1px solid rgba(201,169,110,0.08);background:transparent;max-height:0;overflow:hidden;transition:max-height 0.3s ease}
.company-group.expanded .company-group-body{display:block;max-height:1000px}
.company-group-body .contact-card{border-radius:0;border-left:none;border-right:none;border-top:none;margin:0;padding:16px 22px;background:transparent;border-bottom:1px solid rgba(201,169,110,0.06);box-shadow:none}
.company-group-body .contact-card:last-child{border-bottom:none}
.company-group-body .contact-card:hover{background:rgba(201,169,110,0.03);transform:none;box-shadow:none}
/* V24.0: CNTCT Brain section label — numbered ledger header */
.ledger-section-label{font-size:11px;font-weight:600;color:var(--aman-gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;font-family: var(--font-body);display:flex;align-items:center;gap:10px}
.ledger-section-label::before{content:attr(data-number);display:inline-flex;width:22px;height:22px;border-radius:50%;background:rgba(201,169,110,0.08);border:1.5px solid rgba(201,169,110,0.2);align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--aman-gold)}
/* Mobile responsive */
@media(max-width:768px){
.il-top{padding:14px 16px 12px}
.il-title{font-size:20px}
.il-title-row{flex-direction:column;gap:10px}
.il-controls{flex-direction:column;gap:8px}
.il-search-wrap{min-width:100%}
.il-view-group{width:100%}
.il-view{flex:1;text-align:center}
.il-actions{width:100%;justify-content:space-between}
.il-filters{flex-direction:column;gap:8px}
.filter-pills{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.filter-pill{white-space:nowrap;flex-shrink:0}
.contacts-cards{grid-template-columns:1fr}
.contact-card{padding:16px 18px}
.cc-name{font-size:16px}
.cc-actions{flex-direction:row;align-items:center;justify-content:flex-start;gap:6px}
.company-group-header{padding:14px 18px}
.company-group-name{font-size:16px}
.il-bulk{display:none}
}

/* ═══ Drift Cards ═══ */
.drift-card{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius: 2px;margin-bottom:4px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm)}
.drift-card:hover{border-color:rgba(201,169,110,0.12);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.drift-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;font-family: var(--font-body)}
.drift-icon.flip{background:var(--red-soft);color:var(--red)}
.drift-icon.new{background:var(--green-soft);color:var(--green)}
.drift-icon.departed{background:rgba(113,113,122,0.1);color:var(--dim)}
.drift-icon.confirmed{background:var(--accent-soft);color:var(--accent)}
.drift-info{flex:1}
.drift-name{font-weight:500;font-size:14px;font-family: var(--font-body);color:var(--text)}
.drift-detail{font-size:12px;color:var(--muted);font-family: var(--font-mono);margin-top:2px}
.drift-type{font-size:11px;font-weight:600;font-family: var(--font-body);letter-spacing:0.5px;text-transform:uppercase;color:var(--dim)}

/* ═══ Principal tier ═══ */
.contacts-table tr.diamond-row:hover{background:rgba(201,169,110,0.08)}
.tbl-tag.diamond{background:linear-gradient(135deg,rgba(201,169,110,0.1),rgba(155,139,180,0.1));color:var(--gold-bright);border:1px solid rgba(201,169,110,0.3);font-weight:700}

/* ═══ Rejected rows ═══ */
.contacts-table tr.rejected-row:hover{opacity:0.6}
.tbl-status.rejected{background:var(--red-soft);color:var(--red);border:1px solid rgba(192,112,96,0.2)}
.tbl-tag.rejected-tag{background:var(--red-soft);color:var(--red);border:1px solid rgba(192,112,96,0.2)}

/* ═══ Reclassify ═══ */
.btn-reclassify{padding:4px 10px;border-radius:var(--radius-sm);font-size:11px;font-family: var(--font-body);cursor:pointer;border:1px solid var(--border);color:var(--dim);background:transparent;transition:all 0.2s;font-weight:500}
.btn-reclassify:hover{border-color:var(--border2);color:var(--text)}

/* ═══ Reclassification modal ═══ */
.reclass-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#111118;border:1px solid rgba(255,255,255,0.1);border-radius: 2px;padding:32px;width:480px;max-width:90vw;z-index:110;box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.reclass-modal h3{font-size:18px;margin-bottom:16px;font-family: var(--font-body);font-weight:700}
.reclass-modal select,.reclass-modal textarea{width:100%;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:2px;color:var(--text);font-size:13px;font-family: var(--font-body);margin:8px 0}
.reclass-modal textarea{height:70px;resize:vertical}
.reclass-modal .btn-row{display:flex;gap:8px;margin-top:16px}

/* ═══ Document discovery ═══ */
.docs-panel{background:var(--card);border:1px solid var(--border);border-radius: 2px;padding:18px 22px;margin:20px 0;box-shadow:var(--shadow-sm)}
.docs-panel h4{font-size:10px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:3px;margin-bottom:12px;font-weight:600;font-family: var(--font-body)}
.doc-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:2px;margin-bottom:4px;font-size:13px;transition:all 0.2s;box-shadow:var(--shadow-sm)}
.doc-card:hover{border-color:var(--border2)}
.doc-card .doc-type{padding:4px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;font-family: var(--font-body);background:var(--accent-soft);color:var(--accent);border:1px solid rgba(155,139,180,0.2);min-width:40px;text-align:center;text-transform:uppercase}
.doc-card .doc-title{flex:1;color:var(--text2);font-family: var(--font-body);font-size:13px}
.doc-card .doc-url{color:var(--muted);font-family: var(--font-mono);font-size:11px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.doc-card a{color:var(--muted);text-decoration:none}
.doc-card a:hover{text-decoration:underline;color:var(--accent)}
.doc-card .btn-save-doc{padding:5px 10px;border-radius:var(--radius-sm);font-size:11px;font-family: var(--font-body);cursor:pointer;border:1px solid var(--border);color:var(--muted);background:transparent;transition:all 0.2s;font-weight:500}
.doc-card .btn-save-doc:hover{border-color:var(--accent);color:var(--accent)}
.doc-card .btn-save-doc.saved{border-color:rgba(139,158,107,0.3);color:var(--green)}

/* ═══ Map ═══ */
#contactMap{height:400px;border-radius:var(--radius);border:1px solid var(--border);margin:20px 0;background:var(--bg3)}
.leaflet-container{background:var(--bg3)!important;font-family: var(--font-body)!important}
/* V13.3: Force dark background on ALL potential white-bg elements */
svg{background:transparent!important}
.leaflet-pane,.leaflet-tile,.leaflet-tile-pane{background:transparent!important}
.map-popup{font-family: var(--font-body);font-size:13px;line-height:1.7}
.map-popup .pop-name{font-family: var(--font-body);font-size:15px;font-weight:600;color:var(--text);margin-bottom:3px}
.map-popup .pop-company{color:var(--accent);font-size:12px}
.map-popup .pop-title{color:var(--muted);font-size:12px}

/* ═══ Brand Pathway ═══ */
.pathway-container{margin:24px 0;padding:24px;background:var(--card);border:1px solid var(--border);border-radius: 2px;overflow-x:auto;box-shadow:var(--shadow-sm)}
.pathway-container h4{font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-weight:600;font-family: var(--font-body)}
.pathway-svg{width:100%;min-height:200px}
.pathway-node{cursor:pointer;transition:all 0.2s}
.pathway-node:hover{filter:brightness(1.2)}
/* V24.0: Distribution Architecture Funnel — Premium Aman redesign */
.dist-arch-funnel{display:flex;flex-direction:column;align-items:center;gap:0;padding:12px 0}
.da-tier{width:100%;display:flex;justify-content:center}
.da-tier-origin{margin-bottom:8px}
.da-brand-node{display:flex;flex-direction:column;align-items:center;padding:20px 36px;border:1px solid rgba(201,169,110,0.15);border-radius: 2px;background:var(--card);box-shadow:var(--shadow-sm)}
.da-brand-name{font-family: var(--font-display);font-size:20px;color:var(--aman-gold);letter-spacing:0.5px;font-weight:600}
.da-brand-stats{font-size:11px;color:var(--muted);letter-spacing:1px;margin-top:6px;text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.da-connector-tier{width:100%;text-align:center}
.da-tier-split{display:flex;gap:28px;justify-content:center;align-items:flex-start;flex-wrap:wrap;padding:0 16px}
.da-split-branch{display:flex;flex-direction:column;align-items:center;gap:10px;min-width:150px}
.da-split-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;margin-bottom:4px;font-family: var(--font-body);color:var(--aman-gold)}
.da-split-external{flex:1;max-width:900px}
.da-external-channels{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.da-channel-branch{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:140px;max-width:220px}
.da-channel-card{display:flex;flex-direction:column;align-items:center;padding:14px 18px;border:1px solid var(--border);border-radius: 2px;min-width:130px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);cursor:default;background:var(--card);box-shadow:var(--shadow-sm)}
.da-channel-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);border-color:rgba(201,169,110,0.12);background:var(--bg4)}
.da-channel-icon{font-size:18px;margin-bottom:6px}
.da-channel-name{font-size:12px;font-weight:600;letter-spacing:0.3px;text-align:center;color:var(--text);font-family: var(--font-body)}
.da-channel-count{font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:0.3px;font-family: var(--font-body)}
.da-company-list{display:flex;flex-direction:column;gap:3px;width:100%;margin-top:6px}
.da-company-chip{display:flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid rgba(255,255,255,0.06);border-radius:2px;font-size:11px;background:rgba(255,255,255,0.03);transition:all 0.2s;cursor:default;font-family: var(--font-body)}
.da-company-chip:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1)}
.da-co-name{flex:1;color:var(--text);letter-spacing:0.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.da-co-count{color:var(--aman-gold);font-weight:600;font-size:12px;min-width:14px;text-align:right}
.da-co-territory{font-size:9px;color:var(--muted);letter-spacing:0.3px;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family: var(--font-body)}
.da-more{justify-content:center;color:var(--muted);border-style:dashed;font-size:11px;border-radius:2px}
/* ═══ V29.1: LIVE SYSTEM LOG — Premium overlay inside brain map ═══ */
.brain-logfeed{display:flex;flex-direction:column;position:absolute;top:0;right:0;bottom:0;width:380px;z-index:5;background:linear-gradient(180deg,rgba(6,8,14,0.97) 0%,rgba(4,6,12,0.98) 100%);border-left:1px solid rgba(201,169,110,0.1);overflow:hidden;pointer-events:auto;padding:0;backdrop-filter:blur(24px);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1),opacity 0.3s;transform:translateX(0)}
.brain-logfeed.plf-collapsed{transform:translateX(100%);opacity:0;pointer-events:none}
.brain-logfeed .plf-lines{pointer-events:auto;flex:1;min-height:0;padding:10px 16px 14px 20px}
.brain-logfeed::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(201,169,110,0.2),transparent)}
.plf-lines{display:flex;flex-direction:column;gap:0;overflow-y:auto;overflow-x:hidden;pointer-events:auto;mask-image:linear-gradient(to bottom,transparent 0%,black 4%,black 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 4%,black 100%);scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.15) transparent;flex:1;min-height:0}
.plf-lines::-webkit-scrollbar{width:3px}
.plf-lines::-webkit-scrollbar-track{background:transparent}
.plf-lines::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:2px}
.plf-line{font-family:var(--font-mono);font-size:12px;line-height:1.7;letter-spacing:0.3px;white-space:normal;word-break:break-word;overflow-wrap:break-word;padding:3px 0;animation:plfSlideIn 0.35s ease-out;text-shadow:0 0 6px currentColor}
.plf-line.plf-agent{color:#d4af37}
.plf-line.plf-genome{color:#c9a96e}
.plf-line.plf-vacuum{color:#a8977a}
.plf-line.plf-peer{color:#b8a898}
.plf-line.plf-error{color:#ff5555}
.plf-line.plf-complete{color:#c9a96e;font-weight:600}
.plf-line.plf-system{color:#8a8072}
.plf-line.plf-default{color:#8a8072}
.plf-ts{color:rgba(201,169,110,0.45);margin-right:8px;font-size:11px}
.plf-line.plf-latest{opacity:1!important;text-shadow:0 0 14px currentColor,0 0 4px currentColor}
.plf-line.plf-fade-1{opacity:0.9}
.plf-line.plf-fade-2{opacity:0.8}
.plf-line.plf-fade-3{opacity:0.7}
.plf-line.plf-fade-4{opacity:0.6}
.plf-line.plf-fade-5{opacity:0.5}
.plf-line.plf-fade-6{opacity:0.4}
.plf-line.plf-fade-7{opacity:0.35}
@keyframes plfSlideIn{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}
/* V24.0: Enhanced typing effect with smooth reveal */
.plf-line.plf-typing{animation:plfTypeReveal 0.6s ease-out forwards}
@keyframes plfTypeReveal{from{clip-path:inset(0 100% 0 0);opacity:0.5}to{clip-path:inset(0 0 0 0);opacity:1}}
.plf-cursor{display:inline-block;width:7px;height:12px;background:#d4af37;margin-left:4px;animation:plfBlink 0.7s step-end infinite;vertical-align:middle;box-shadow:0 0 8px #d4af37;border-radius:1px}
@keyframes plfBlink{0%,100%{opacity:1}50%{opacity:0}}
.plf-header{font-family: var(--font-body);font-size:10px;letter-spacing:3px;color:rgba(201,169,110,0.55);text-transform:uppercase;padding:14px 16px 10px 20px;border-bottom:1px solid rgba(201,169,110,0.1);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;font-weight:600}
.plf-close{cursor:pointer;font-size:16px;color:rgba(201,169,110,0.35);transition:all 0.2s;padding:2px 6px;border-radius:2px}
.plf-close:hover{color:rgba(201,169,110,0.8);background:rgba(201,169,110,0.08)}
.brain-logfeed-toggle{display:block;position:absolute;top:10px;right:90px;z-index:35;font-family: var(--font-body);font-size:10px;letter-spacing:2.5px;color:rgba(201,169,110,0.5);padding:7px 14px;border:1px solid rgba(201,169,110,0.2);border-radius:2px;cursor:pointer;transition:all 0.25s;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);text-transform:uppercase;font-weight:600}
.brain-logfeed-toggle:hover{color:rgba(201,169,110,0.9);border-color:rgba(201,169,110,0.5);background:rgba(201,169,110,0.1);box-shadow:0 0 16px rgba(201,169,110,0.15)}
.brain-logfeed-toggle.active{color:#d4af37;border-color:rgba(201,169,110,0.4);background:rgba(201,169,110,0.12);box-shadow:inset 0 0 10px rgba(201,169,110,0.08),0 0 20px rgba(201,169,110,0.1)}
.brain-channels-btn{position:absolute;top:10px;right:180px;z-index:35;font-family: var(--font-body);font-size:10px;letter-spacing:2.5px;color:rgba(201,169,110,0.5);padding:7px 14px;border:1px solid rgba(201,169,110,0.2);border-radius:2px;cursor:pointer;transition:all 0.25s;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);text-transform:uppercase;font-weight:600;display:none}
.brain-channels-btn.visible{display:block}
.brain-channels-btn:hover{color:rgba(201,169,110,0.9);border-color:rgba(201,169,110,0.5);background:rgba(201,169,110,0.1);box-shadow:0 0 16px rgba(201,169,110,0.15)}
.brain-logfeed.plf-hidden{display:none!important}
.brain-logfeed.plf-collapsed{transform:translateX(100%);opacity:0;pointer-events:none}
.plf-scanline{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.2),transparent);animation:plfScan 4s linear infinite;pointer-events:none}
@keyframes plfScan{0%{bottom:100%;opacity:0}5%{opacity:1}95%{opacity:0.5}100%{bottom:0;opacity:0}}
/* thinkingStream: visible by default */

/* ═══ V23.2: Dossier Panel Container ═══ */
.dossier-panel{margin:24px 0;border:1px solid var(--border);border-radius: 2px;overflow:hidden;background:var(--card);box-shadow:var(--shadow-sm)}
.dossier-header{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-bottom:1px solid rgba(201,169,110,0.05);cursor:pointer;transition:all 0.2s}
.dossier-header:hover{background:rgba(201,169,110,0.02)}
.dossier-header h4{font-family: var(--font-display);font-size:16px;color:var(--text);font-weight:600;letter-spacing:0.3px}
.dossier-toggle{color:rgba(201,169,110,0.3);font-size:10px;transition:transform 0.3s}
.dossier-toggle.open{transform:rotate(180deg)}
.dossier-content{padding:0;line-height:1.8;font-size:13px;color:var(--text2);max-height:none;overflow-y:auto}
.btn-dossier{padding:7px 16px;border-radius:2px;font-size:11px;font-family: var(--font-body);cursor:pointer;border:1px solid rgba(201,169,110,0.08);color:rgba(201,169,110,0.4);background:transparent;transition:all 0.2s;font-weight:500;letter-spacing:0.5px}
.btn-dossier:hover{border-color:rgba(201,169,110,0.2);color:var(--aman-gold);background:rgba(201,169,110,0.03)}

/* ═══ V23.2: DOSSIER GLOBAL OVERRIDES (non-scoped fallbacks) ═══ */
.dossier-v13{display:none}
.dossier-generating{text-align:center;padding:48px;color:rgba(201,169,110,0.35);font-size:12px;letter-spacing:1px;font-family: var(--font-body)}
.dossier-divider{color:rgba(201,169,110,0.2)}
.dossier-tagline{color:rgba(255,253,245,0.3)}
.dossier-team-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;position:relative;z-index:1;padding-left:14px}
.dossier-team-member{padding:16px 18px;background:rgba(201,169,110,0.015);border:1px solid rgba(201,169,110,0.06);border-radius: 2px;transition:all 0.25s}
.dossier-team-member:hover{border-color:rgba(201,169,110,0.15);background:rgba(201,169,110,0.03)}
.dossier-member-name{font-family: var(--font-body);font-size:12px;font-weight:600;color:rgba(255,253,245,0.8);margin-bottom:3px}
.dossier-member-role{font-size:9px;color:rgba(201,169,110,0.45);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;font-family: var(--font-body);font-weight:500}
.dossier-member-company{font-size:10px;color:rgba(255,253,245,0.3);font-family: var(--font-body)}
.dossier-footer{display:flex;justify-content:space-between;align-items:center;padding:18px 36px;border-top:1px solid rgba(201,169,110,0.05);margin-top:4px}
.dossier-footer-text{font-size:9px;color:rgba(201,169,110,0.2);letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.dossier-footer-accent{color:rgba(201,169,110,0.35)}

/* Responsive adjustments */
@media(max-width: 768px){
  .dossier-brand-name{font-size:36px}
  .dossier-section-title{font-size:20px}
  .dossier-card{padding:20px}
  .dossier-dna-grid,.dossier-stats-row,.dossier-partners-grid,.dossier-signals,.dossier-contact-tiers{grid-template-columns:1fr}
  .dossier-footer{flex-direction:column;gap:8px;text-align:center}
}


/* ═══ V29.0: INTELLIGENCE GRAPH — Premium Dark Canvas ═══ */
.dash-intel-graph{position:relative;z-index:1;width:100vw;margin-left:calc(-50vw + 50%);margin-top:40px;padding:0}
.ig-noir{background:linear-gradient(180deg,var(--bg) 0%,#1A1816 4%,#0F0E0C 20%,#0C0B0A 50%,#0F0E0C 80%,#1A1816 96%,var(--bg) 100%);padding:48px 0 56px;position:relative;overflow:hidden}
.ig-noir::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(201,169,110,0.012) 1px,transparent 1px),linear-gradient(90deg,rgba(201,169,110,0.012) 1px,transparent 1px);background-size:60px 60px;opacity:0.3;mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black 10%,transparent 70%);pointer-events:none}
.ig-noir-inner{max-width:780px;margin:0 auto;padding:0 48px;position:relative;z-index:1}
.ig-header{margin-bottom:32px}
.ig-header .dash-section-label{color:rgba(201,169,110,0.5);margin-bottom:8px}
.ig-header h4{font-family: var(--font-display);font-size:32px;font-weight:500;color:#FAFAF8;letter-spacing:-0.3px;margin:0}
.ig-header .dossier-toggle{color:rgba(201,169,110,0.3);font-size:12px;transition:color 0.2s;cursor:pointer}
.ig-header .dossier-toggle:hover{color:rgba(201,169,110,0.6)}
.intel-graph-body{position:relative}
.ig-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:28px}
.ig-stat{background:rgba(255,255,255,0.03);border:1px solid rgba(201,169,110,0.08);padding:20px 12px;text-align:center;border-radius: 2px;transition:all 0.3s;position:relative;overflow:hidden}
.ig-stat::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.15),transparent)}
.ig-stat:hover{background:rgba(201,169,110,0.04);border-color:rgba(201,169,110,0.15);transform:translateY(-2px)}
.ig-stat .ig-val{font-size:26px;font-weight:600;font-family: var(--font-display);color:#FAFAF8;line-height:1}
.ig-stat .ig-lbl{font-size:8px;color:rgba(201,169,110,0.45);text-transform:uppercase;letter-spacing:2px;margin-top:6px;font-weight:500;font-family: var(--font-body)}
.ig-tab-bar{display:flex;gap:4px;margin-bottom:24px}
.ig-tab{padding:8px 18px;font-size:10px;color:rgba(255,252,248,0.35);cursor:pointer;border:1px solid rgba(201,169,110,0.08);border-radius: 2px;transition:all 0.25s;font-family: var(--font-body);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;background:transparent}
.ig-tab:hover{color:rgba(255,252,248,0.6);border-color:rgba(201,169,110,0.15);background:rgba(201,169,110,0.03)}
.ig-tab.active{color:var(--aman-gold);border-color:rgba(201,169,110,0.25);background:rgba(201,169,110,0.08)}
.ig-tab-content{display:none}
.ig-tab-content.active{display:block}
.ig-connections{margin:0}
.ig-connection{display:flex;align-items:center;gap:14px;padding:16px 20px;background:rgba(255,255,255,0.02);border:1px solid rgba(201,169,110,0.06);border-radius: 2px;margin-bottom:6px;transition:all 0.25s;cursor:pointer}
.ig-connection:hover{border-color:rgba(201,169,110,0.15);background:rgba(201,169,110,0.04);transform:translateY(-1px)}
.ig-conn-icon{width:38px;height:38px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ig-conn-icon.shared-rep{background:rgba(201,169,110,0.1);color:var(--aman-gold)}
.ig-conn-icon.shared-agency{background:rgba(139,158,107,0.1);color:var(--sage)}
.ig-conn-icon.shared-dist{background:rgba(196,149,106,0.1);color:#c4956a}
.ig-conn-icon.personnel{background:rgba(155,139,180,0.1);color:#9b8bb4}
.ig-conn-icon.signal{background:rgba(192,112,96,0.1);color:#c07060}
.ig-conn-info{flex:1;min-width:0}
.ig-conn-title{font-size:14px;font-family: var(--font-display);font-weight:600;color:#FAFAF8;letter-spacing:-0.2px}
.ig-conn-detail{font-size:11px;color:rgba(255,252,248,0.35);font-family: var(--font-body);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ig-conn-strength{font-size:9px;font-family: var(--font-body);padding:4px 12px;border-radius: 2px;font-weight:600;letter-spacing:1px;text-transform:uppercase}
.ig-conn-strength.strong{color:var(--aman-gold);border:1px solid rgba(201,169,110,0.25);background:rgba(201,169,110,0.06)}
.ig-conn-strength.medium{color:rgba(255,252,248,0.4);border:1px solid rgba(255,252,248,0.1);background:rgba(255,255,255,0.02)}
.ig-conn-strength.weak{color:rgba(255,252,248,0.25);border:1px solid rgba(255,252,248,0.06)}
.ig-brands-grid{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0}
.ig-brand-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border:1px solid rgba(201,169,110,0.1);border-radius: 2px;font-size:12px;font-family: var(--font-body);color:rgba(255,252,248,0.6);cursor:pointer;transition:all 0.25s;background:rgba(201,169,110,0.03);font-weight:500}
.ig-brand-chip:hover{border-color:rgba(201,169,110,0.25);background:rgba(201,169,110,0.06);color:rgba(255,252,248,0.85)}
.ig-brand-chip .chip-count{font-size:12px;color:var(--aman-gold);font-family: var(--font-display);font-weight:600}
.ig-network-canvas{width:100%;height:500px;border:1px solid rgba(201,169,110,0.1);border-radius: 2px;background:linear-gradient(160deg,#0d0f16 0%,#111420 40%,#0b0e17 100%);position:relative;overflow:hidden;box-shadow:inset 0 0 80px rgba(0,0,0,0.5)}
.ig-insights{margin-top:0;padding:24px;border:1px solid rgba(201,169,110,0.06);border-radius: 2px;background:rgba(255,255,255,0.02);line-height:1.8;font-size:14px;max-height:450px;overflow-y:auto;color:rgba(255,252,248,0.7)}
.ig-insights::-webkit-scrollbar{width:4px}
.ig-insights::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.15);border-radius:2px}
.ig-insights h3{font-family: var(--font-display);font-size:20px;font-weight:500;color:#FAFAF8;margin:20px 0 10px;letter-spacing:-0.2px}
.ig-insights h3:first-child{margin-top:0}
.ig-insights .ig-signal{display:flex;gap:12px;padding:12px 16px;border:1px solid rgba(201,169,110,0.06);border-radius: 2px;margin:8px 0;background:rgba(255,255,255,0.02)}
.ig-insights .ig-signal-icon{font-size:14px;flex-shrink:0;margin-top:2px;color:var(--aman-gold)}
.ig-insights .ig-signal-text{font-size:12px;color:rgba(255,252,248,0.55);line-height:1.7;font-family: var(--font-body)}
@media(max-width:768px){
  .ig-noir{padding:32px 0 40px}
  .ig-noir-inner{padding:0 20px}
  .ig-header h4{font-size:24px}
  .ig-stats-row{grid-template-columns:repeat(3,1fr);gap:6px}
  .ig-tab{padding:6px 12px;font-size:9px}
  .ig-connection{padding:12px 14px;flex-wrap:wrap}
  .dash-intel-graph{margin-top:28px}
}
@media(max-width:480px){
  .ig-stats-row{grid-template-columns:repeat(2,1fr)}
  .ig-tab-bar{flex-wrap:wrap}
}

/* ═══ KNOWLEDGE GRAPH ═══ */
.kg-controls{display:flex;gap:8px;align-items:center;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:wrap}
.kg-search{padding:8px 12px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:2px;color:var(--text);font-size:13px;font-family: var(--font-body);outline:none;width:220px;transition:all 0.2s}
.kg-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.kg-search::placeholder{color:var(--dim)}
.kg-filter{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;letter-spacing:0.5px;text-transform:uppercase;color:var(--dim);background:transparent;cursor:pointer;transition:all 0.2s;font-family: var(--font-body);font-weight:500}
.kg-filter:hover{border-color:var(--border2);color:var(--muted)}
.kg-filter.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.kg-stats{margin-left:auto;font-size:11px;color:var(--muted);font-family: var(--font-body);font-weight:500;letter-spacing:0.3px}
.kg-tooltip{position:absolute;pointer-events:none;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);padding:14px 18px;color:var(--text);font-size:13px;z-index:50;max-width:300px;box-shadow:var(--shadow-lg);opacity:0;transition:opacity 0.2s;backdrop-filter:blur(8px)}
.kg-tooltip.visible{opacity:1}
.kg-tooltip .tt-name{font-family: var(--font-body);font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.kg-tooltip .tt-type{font-size:11px;text-transform:uppercase;color:var(--dim);margin-bottom:6px;font-weight:500}
.kg-tooltip .tt-detail{font-size:12px;color:var(--muted);line-height:1.6;font-family: var(--font-mono)}
.kg-legend{position:absolute;bottom:16px;left:16px;display:flex;gap:12px;z-index:10}
.kg-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--dim);text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.kg-legend-dot{width:8px;height:8px;border-radius:50%}
.kg-zoom-controls{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;gap:2px;z-index:10}
.kg-zoom-btn{width:32px;height:32px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--dim);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.kg-zoom-btn:hover{border-color:var(--accent);color:var(--accent)}
.kg-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--dim);font-size:15px;gap:8px;font-family: var(--font-body)}
.kg-empty .kg-empty-sub{font-size:12px;color:var(--border2);font-family: var(--font-body);font-weight:500}

/* ═══ V26.0 INTELLIGENCE COMMAND CENTER ═══ */
.dash-intel-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:780px;width:100%;margin:20px auto 0;padding:0 40px}
.dash-intel-card{background:var(--glass-2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius: 2px;padding:20px 16px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);cursor:default;text-align:center;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.dash-intel-card::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:30px;height:2px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.3),transparent);border-radius:1px}
.dash-intel-card:hover{border-color:rgba(201,169,110,0.2);background:var(--glass-3);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px rgba(201,169,110,0.06)}
.dash-intel-card h5{font-size:9px;color:var(--aman-gold);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:8px;font-weight:600;font-family: var(--font-body)}
.dash-intel-card .intel-number{font-size:32px;font-weight:600;font-family: var(--font-display);line-height:1;color:var(--gold-light)}
.dash-intel-card .intel-label{font-size:9px;color:var(--muted);margin-top:6px;font-family: var(--font-body);letter-spacing:0.5px;font-weight:500}
.dash-mini-graph{width:100%;height:200px;background:var(--bg2);border-radius: 2px;margin-top:12px;position:relative;overflow:hidden;border:1px solid var(--border)}
.dash-signal-list{margin-top:12px}
.dash-signal{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(201,169,110,0.06);font-size:13px}
.dash-signal:last-child{border-bottom:none}
.dash-signal .sig-icon{font-size:15px;flex-shrink:0}
.dash-signal .sig-text{color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family: var(--font-body);font-weight:500}
.dash-signal .sig-time{font-size:10px;color:var(--muted);font-family: var(--font-body);letter-spacing:1px;font-weight:500}
/* ═══ V13.0 ERROR VAULT ═══ */
.error-vault-badge{position:fixed;bottom:20px;left:20px;width:32px;height:32px;border-radius:50%;background:var(--red);color:#fff;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:100;font-family: var(--font-mono);transition:all 0.2s;box-shadow:0 0 12px rgba(192,112,96,0.3)}
.error-vault-badge:hover{transform:scale(1.15);box-shadow:0 0 20px rgba(192,112,96,0.5)}
.error-vault-panel{position:fixed;bottom:60px;left:20px;width:420px;max-width:90vw;max-height:60vh;z-index:500;display:flex;flex-direction:column;border:1px solid var(--border2);box-shadow:var(--shadow-xl)}
.evp-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}
.evp-title{font-size:13px;font-weight:600;color:var(--text);letter-spacing:1px;text-transform:uppercase}
.evp-count{font-size:10px;color:var(--dim);font-family: var(--font-body);font-weight:500;margin-left:auto}
.evp-close{background:none;border:none;color:var(--dim);cursor:pointer;font-size:16px;padding:0 4px}
.evp-filters{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.evp-filter{padding:3px 8px;font-size:10px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:var(--muted);border-radius:2px;cursor:pointer;text-transform:uppercase;letter-spacing:1px;font-family: var(--font-body);font-weight:600}
.evp-filter.empty{opacity:0.4}
.evp-filter:hover{border-color:var(--dim);color:var(--text)}
.evp-list{overflow-y:auto;flex:1;padding:8px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.evp-entry{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.03);font-size:11px}
.evp-entry-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.evp-cat{padding:2px 6px;border-radius:2px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;font-family: var(--font-body)}
.evp-cat-engine{background:rgba(201,169,110,0.1);color:var(--cyan)}
.evp-cat-visual{background:rgba(155,139,180,0.1);color:var(--purple)}
.evp-cat-design{background:rgba(201,169,110,0.1);color:var(--aman-gold)}
.evp-cat-ui{background:rgba(139,158,107,0.1);color:var(--green)}
.evp-cat-code{background:rgba(192,112,96,0.1);color:var(--red)}
.evp-cat-network{background:rgba(251,146,60,0.1);color:var(--orange)}
.evp-time{font-size:10px;color:var(--dim);font-family: var(--font-body);font-weight:500}
.evp-msg{color:var(--text2);line-height:1.5;word-break:break-word}
.evp-details{color:var(--dim);font-size:10px;margin-top:4px;font-family: var(--font-mono)}
.evp-stack{margin-top:4px}
.evp-stack summary{font-size:11px;color:var(--dim);cursor:pointer}
.evp-stack pre{font-size:11px;color:var(--red);overflow-x:auto;padding:6px;background:var(--bg);border-radius:2px;margin-top:4px;white-space:pre-wrap}

/* V24.0e chain tag color variants removed — now defined in V24.0 dashboard section (line ~320) */

/* ═══════════════════════════════════════════════════════════════
   V13.1 — MOBILE PERFECTION: Comprehensive Responsive Redesign
   Mobile-first CSS rewrite for CNTCT Brain-level mobile experience
   ═══════════════════════════════════════════════════════════════ */

/* ═══ SMALL PHONES (max-width: 480px) ═══ */
@media(max-width:480px){
  .app{padding:52px 12px 0}
  .header{padding:10px 0;gap:8px}
  .header h1{font-size:13px;letter-spacing:1.5px}
  .header .subtitle{font-size:11px}
  .cost-badge{font-size:11px;padding:3px 8px}
  .logo{width:26px;height:26px;font-size:10px;border-radius:2px}
  .login-card{padding:24px 16px}
  .login-title{font-size:22px;letter-spacing:3px}
  .dashboard{padding:32px 0 20px;min-height:auto}
  .dash-hero h2{font-size:24px;letter-spacing:-0.3px}
  .dash-hero p{font-size:12px}
  .brand-input-row{flex-direction:column;border-radius:var(--radius)}
  .brand-input{padding:12px 12px;font-size:14px}
  .btn-investigate{padding:12px;font-size:11px}
  .stats-bar,.stats-bar-secondary{grid-template-columns:1fr 1fr;gap:6px}
  .stat-box{padding:8px 6px}
  .stat-box .value{font-size:16px}
  .stat-box .label{font-size:7px}
  .phase-bar{gap:4px;padding:6px 0;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;border:none;background:transparent}
  .phase-pill{flex-shrink:0;min-width:auto;padding:5px 10px;font-size:11px}
  .intel-split{display:flex!important;flex-direction:column!important;gap:8px}
  .spider-canvas-wrap{width:100%!important;height:360px!important;min-height:360px!important;border-radius:3px}
  .thinking-stream{width:100%!important;max-height:160px}
  .brain-expand-btn{font-size:7px;padding:3px 8px}
  .brain-logfeed-toggle{font-size:7px;padding:2px 6px}
  .spider-label{font-size:6px}
  .forensic-ledger{margin-top:12px}
  .ledger-header{flex-direction:column;align-items:flex-start;gap:8px}
  .ledger-header h3{font-size:14px}
  .filter-pills{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;max-width:100%;padding-bottom:2px;gap:4px}
  .contacts-table-wrap,.il-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}
  .contacts-table,.il-table{min-width:700px;font-size:11px}
  .contacts-table th,.contacts-table td,.il-table th,.il-table td{padding:6px 4px;font-size:11px}
  .contacts-table th:first-child,.contacts-table td:first-child,.il-table th:first-child,.il-table td:first-child{position:sticky;left:0;z-index:2;background:rgba(15,15,21,0.95)}
  .contacts-grid{grid-template-columns:1fr!important}
  .channel-tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:4px}
  .channel-tab{flex-shrink:0;font-size:11px}
  .dossier-panel{padding:8px}
  .dossier-content{padding:8px}
  .dossier-header h4{font-size:12px}
  #contactMap{height:200px!important}
  .pathway-container{overflow-x:auto;-webkit-overflow-scrolling:touch}
  #pathwayDiagram{min-width:500px}
  .row-detail-overlay .row-detail{width:95vw!important;max-width:95vw;padding:12px}
  .config-box{width:95vw!important;padding:20px 16px}
  .btn-back{font-size:10px;padding:5px 10px}
  .btn-export{font-size:11px;padding:5px 10px}
  #runTitle{font-size:14px}
  #runSubtitle{font-size:11px}
  .thread-grid{grid-template-columns:1fr!important}
  .lateral-panel,.docs-panel{padding:8px}
  .command-center{padding:8px 0}
  .search-progress-label{font-size:11px}
  .prev-runs{width:100%}
  .run-card{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ═══ PHONES & SMALL TABLETS (max-width: 768px) ═══ */
@media(max-width:768px){
  .app{padding:52px 16px 0}

  /* Header */
  .header{padding:12px 0;flex-wrap:wrap;gap:10px;flex-direction:row}
  .header h1{font-size:14px;letter-spacing:2px}
  .header .subtitle{font-size:10px}
  .cost-badge{font-size:10px;padding:4px 10px}
  .logo{width:28px;height:28px;font-size:12px;border-radius:2px}

  /* Login */
  .login-card{padding:32px 24px;width:100%;margin:0}
  .login-title{font-size:26px;letter-spacing:4px}
  .login-logo{width:48px;height:48px;font-size:18px}
  .login-models-row{flex-direction:column;gap:0}
  .login-models-row>div{flex:1}

  /* Dashboard */
  .dashboard{padding:40px 0 24px;min-height:auto}
  .dash-hero{margin-bottom:24px}
  .dash-hero h2{font-size:28px;letter-spacing:-0.4px}
  .dash-hero p{font-size:14px}

  /* Brand input row - stack vertically */
  .brand-input-row{flex-direction:column;border-radius:var(--radius);overflow:visible;max-width:100%}
  .brand-input{border-left:none!important;border-bottom:1px solid var(--border);padding:14px 16px;border-radius:0}
  .brand-input:first-child{border-radius:var(--radius) var(--radius) 0 0}
  .brand-input:last-of-type{border-bottom:none}
  .brand-input+.brand-input{border-left:none}
  .btn-investigate{border-radius:0 0 var(--radius) var(--radius);padding:14px;width:100%;margin-top:0;border:1px solid var(--border);border-top:none}
  .input-hint{font-size:11px;margin-bottom:20px}

  /* Stats bars - 2x2 grid */
  .stats-bar,.stats-bar-secondary{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .stat-box{padding:12px 10px}
  .stat-box .value{font-size:18px}
  .stat-box .label{font-size:11px}
  .stat-box{border-radius:2px}

  /* Phase pills - scrollable strip, consistent with desktop */
  .phase-bar{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding:8px 0;gap:6px;scrollbar-width:none;-ms-overflow-style:none;border:none;background:transparent}
  .phase-bar::-webkit-scrollbar{display:none}
  .phase-pill{flex-shrink:0;min-width:auto;padding:8px 12px;font-size:11px;white-space:nowrap}

  /* Intel split - stack vertically */
  .intel-split{display:flex!important;flex-direction:column!important;gap:12px}
  .spider-canvas-wrap{width:100%!important;min-height:440px;height:440px;border-radius:2px}
  .brain-logfeed{width:100%!important;bottom:0;top:auto!important;height:35%;border-top:1px solid rgba(201,169,110,0.1);border-left:none;position:absolute;transform:translateX(0)!important;right:0;left:0}
  .brain-logfeed.plf-collapsed{transform:translateY(100%)!important;opacity:0}

  /* CNTCT Brain on mobile */
  .brain-tier-label{display:none}
  .brain-expand-btn{font-size:11px;padding:5px 12px;right:8px;top:8px}
  .brain-logfeed-toggle{font-size:11px;padding:4px 10px}
  .brain-hud-readout{font-size:9px}
  .brain-zoom-hint{display:none}
  .spider-label{font-size:9px}

  /* Forensic Ledger / Contacts Table */
  .forensic-ledger{margin-top:16px;width:100%}
  .ledger-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:12px}
  .ledger-header h3{font-size:16px;margin-bottom:0}
  .filter-pills{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;max-width:100%;padding-bottom:4px;margin-bottom:12px;gap:6px;flex-wrap:nowrap}
  .filter-pill{flex-shrink:0}
  .contacts-toolbar{flex-direction:column;gap:10px;margin-bottom:12px}
  .contacts-search{width:100%}
  .bulk-actions{width:100%;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .contacts-table-wrap,.il-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px;border-radius:0}
  .contacts-table,.il-table{min-width:800px;font-size:11px}
  .contacts-table th,.contacts-table td,.il-table th,.il-table td{padding:10px 8px;font-size:11px}
  .contacts-table th:first-child,.contacts-table td:first-child,.il-table th:first-child,.il-table td:first-child{position:sticky;left:0;z-index:2;background:rgba(15,15,21,0.95)}
  .contacts-grid{grid-template-columns:1fr!important;width:100%}

  /* Channel profiles drawer — full width on mobile */
  .channel-profiles{width:100vw;max-width:100vw}
  .channel-tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none;margin-bottom:12px;gap:8px;padding:4px 16px}
  .channel-tabs::-webkit-scrollbar{display:none}
  .channel-tab{flex-shrink:0;padding:8px 12px;min-width:auto;font-size:12px}
  .channel-profile-content{width:100%;padding:0 16px 16px}
  .cp-header{padding:20px 16px 0}
  .brain-channels-btn{right:auto!important;left:10px;top:auto!important;bottom:10px}

  /* Map sections */
  #contactMap{height:280px!important;width:100%;border-radius:2px}
  .pathway-container{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;margin-bottom:12px}
  #pathwayDiagram{min-width:700px}

  /* Dossier */
  .dossier-panel{padding:12px;width:100%}
  .dossier-content{padding:12px;width:100%}
  .dossier-header h4{font-size:13px;margin-bottom:10px}
  .dossier-section{margin-bottom:12px}

  /* Tools section */
  .dash-tools{width:100%;max-width:100%;margin:0 auto 20px}
  .dash-tools-body{gap:8px}
  .dash-tools-body>div{width:100%}
  .dash-tools-body .row{flex-direction:column}
  .dash-intel-grid{grid-template-columns:1fr}

  /* Modals & Overlays */
  .row-detail-overlay .row-detail{width:95vw!important;max-width:95vw;max-height:90vh;overflow-y:auto;padding:16px;border-radius:var(--radius)}
  .config-box{width:95vw!important;max-width:95vw;padding:24px 20px;border-radius:var(--radius)}

  /* Previous runs */
  .prev-runs{width:100%;max-width:100%}
  .run-card{flex-direction:column;align-items:flex-start;gap:8px;padding:14px}

  /* Search progress */
  .search-progress-label{font-size:11px}

  /* Lateral panel / docs */
  .lateral-panel,.docs-panel{padding:12px;width:100%}
  .lateral-panel h4,.docs-panel h4{font-size:13px;margin-bottom:10px}

  /* Command center */
  .command-center{padding:16px 0;width:100%}

  /* Buttons */
  .btn-back{font-size:11px;padding:8px 14px;border-radius:2px}
  .btn-export{font-size:10px;padding:8px 14px;border-radius:2px}

  /* Intel Graph */
  .intel-graph-section{width:100%}
  .ig-tab-bar{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:6px;padding-bottom:4px}
  .ig-tab{flex-shrink:0;padding:8px 12px}
  .ig-stats-row{flex-wrap:wrap;gap:8px}
  .ig-network-canvas{height:280px!important;width:100%}

  /* Run title */
  #runTitle{font-size:18px;margin-bottom:8px}
  #runSubtitle{font-size:11px}

  /* Thread grid */
  .thread-grid{grid-template-columns:1fr!important}

  /* Error vault */
  .error-vault-panel{width:90vw;max-width:320px;left:50%;transform:translateX(-50%)}
}

/* ═══ TABLETS (769px to 1024px) ═══ */
@media(min-width:769px) and (max-width:1024px){
  .app{padding:52px 24px 0}
  .dashboard{padding:60px 0 40px}
  .dash-hero h2{font-size:32px;letter-spacing:-0.4px}
  .brand-input-row{max-width:100%;width:100%}
  .stats-bar,.stats-bar-secondary{gap:8px}
  .intel-split{gap:12px}
  .spider-canvas-wrap{height:500px}
  .contacts-table-wrap,.il-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .intel-graph-section{width:100%}
}

/* ═══ EXPANDED CNTCT BRAIN FULLSCREEN (mobile) ═══ */
@media(max-width:768px){
  .brain-expanded .spider-canvas-wrap{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;z-index:100!important;border-radius:0!important;top:0!important;left:0!important;right:auto!important;bottom:auto!important}
  .brain-expanded .brain-logfeed{width:100%!important;bottom:0;top:auto!important;height:40vh;border-left:none;border-top:1px solid rgba(201,169,110,0.1);transform:translateX(0)!important}
  .brain-expanded{background:linear-gradient(160deg,#010306 0%,#040a10 40%,#020508 100%)!important}
}

/* ═══ TOUCH-FRIENDLY HELPERS ═══ */
@media(hover:none) and (pointer:coarse){
  .phase-pill,.channel-tab,.ig-tab,.filter-pill,.bulk-btn,.btn-back,.btn-export,.contact-row{min-height:40px;display:inline-flex;align-items:center}
  .contacts-table td,.contacts-table th,.il-table td,.il-table th{padding:12px 10px}
  button,a[role="button"]{min-height:40px;min-width:40px}
  .run-card,.dash-intel-card,.dash-run-card{padding:16px;margin-bottom:8px}
}

/* ═══ V24.0: DISTRIBUTION ARCHITECTURE — Premium canvas ═══ */
.dist-arch-wrap{position:relative;width:100%;min-height:440px;height:560px;background:linear-gradient(160deg,#0d0f16 0%,#111420 40%,#0b0e17 100%);border-radius: 2px;overflow:hidden;border:1px solid rgba(201,169,110,0.15);box-shadow:inset 0 0 100px rgba(0,0,0,0.7),0 2px 24px rgba(0,0,0,0.3),0 0 1px rgba(201,169,110,0.2)}
.dist-arch-wrap svg{width:100%;height:100%}
.dist-arch-title{position:absolute;top:14px;left:18px;font-size:11px;color:rgba(201,169,110,0.5);letter-spacing:3px;text-transform:uppercase;font-family: var(--font-body);z-index:2;font-weight:600}
.dist-arch-stats{position:absolute;top:14px;right:18px;font-size:11px;color:rgba(201,169,110,0.4);font-family: var(--font-body);z-index:2;font-weight:500;letter-spacing:0.5px}
/* V22.7: Retailer toggle */
.retailer-toggle-wrap{position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:3}
.retailer-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.retailer-toggle-label input{display:none}
.retailer-toggle-slider{width:32px;height:18px;background:rgba(255,255,255,0.1);border:1px solid rgba(201,169,110,0.3);border-radius:2px;position:relative;transition:all 0.3s}
.retailer-toggle-slider::after{content:'';position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:rgba(201,169,110,0.4);transition:all 0.3s}
.retailer-toggle-label input:checked+.retailer-toggle-slider{background:rgba(201,169,110,0.2);border-color:rgba(201,169,110,0.6)}
.retailer-toggle-label input:checked+.retailer-toggle-slider::after{transform:translateX(14px);background:var(--aman-gold)}
.retailer-toggle-text{font-size:10px;color:rgba(201,169,110,0.5);font-family: var(--font-body);letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.dist-arch-controls{position:absolute;bottom:14px;right:14px;display:flex;gap:5px;z-index:2}
.dist-arch-controls button{padding:6px 14px;font-size:10px;font-family: var(--font-body);background:rgba(10,12,20,0.8);border:1px solid rgba(201,169,110,0.15);color:var(--aman-gold);border-radius:2px;cursor:pointer;font-weight:600;letter-spacing:1px;backdrop-filter:blur(12px);transition:all 0.2s}
.dist-arch-controls button:hover{background:rgba(201,169,110,0.08);border-color:rgba(201,169,110,0.3)}

/* V24.0: Architecture tree node styles — premium treatment */
.da-node{cursor:pointer;transition:opacity 0.3s}
.da-node:hover{opacity:0.9}
.da-node-parent rect{fill:rgba(201,169,110,0.05);stroke:var(--aman-gold);stroke-width:2;rx:8;ry:8;filter:drop-shadow(0 0 14px rgba(201,169,110,0.15))}
.da-node-brand rect{fill:rgba(201,169,110,0.08);stroke:var(--aman-gold);stroke-width:2.5;rx:10;ry:10;filter:drop-shadow(0 0 20px rgba(201,169,110,0.2))}
.da-node-category rect{stroke-width:1.2;rx:6;ry:6;transition:all 0.2s}
.da-node-category:hover rect{stroke-width:2;filter:drop-shadow(0 0 10px currentColor)}
.da-node-entity rect{fill:rgba(255,255,255,0.05);stroke:var(--border2);stroke-width:0.8;rx:5;ry:5;transition:all 0.2s}
.da-node-entity:hover rect{fill:rgba(201,169,110,0.04);stroke:var(--aman-gold);stroke-width:1.5;filter:drop-shadow(0 0 8px rgba(201,169,110,0.15))}
.da-label-primary{font-family: var(--font-body);font-size:11px;fill:var(--muted);letter-spacing:2.5px;text-transform:uppercase;font-weight:600}
.da-label-name{font-family: var(--font-display);font-size:16px;fill:var(--text);font-weight:600}
.da-brand-name{fill:var(--aman-gold);font-size:18px}
.da-label-cat{font-family: var(--font-body);font-size:11px;font-weight:600;letter-spacing:0.5px}
.da-badge-text{font-family: var(--font-body);font-size:11px;font-weight:700}
.da-entity-name{font-family: var(--font-body);font-size:11px;fill:var(--text);font-weight:500}
.da-entity-meta{font-family: var(--font-body);font-size:10px;fill:var(--muted)}
.da-link{fill:none;stroke-linecap:round}
.da-link-parent-brand{stroke:var(--aman-gold);stroke-width:2.5;opacity:0.5;stroke-dasharray:8 4;animation:daFlowDash 2s linear infinite}
.da-link-brand-category{stroke:var(--aman-gold);stroke-width:1.5;opacity:0.35}
.da-link-category-entity{stroke:rgba(201,169,110,0.14);stroke-width:0.8}
@keyframes daFlowDash{to{stroke-dashoffset:-24}}
.da-tooltip{position:absolute;display:none;opacity:0;background:rgba(10,12,20,0.96);border:1px solid rgba(201,169,110,0.15);border-radius: 2px;padding:16px 20px;max-width:340px;max-height:320px;overflow-y:auto;z-index:100;pointer-events:none;transition:opacity 0.2s;backdrop-filter:blur(20px);box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.da-tip-header{font-family: var(--font-display);font-size:18px;color:var(--aman-gold);margin-bottom:6px;font-weight:600}
.da-tip-terr{font-family: var(--font-body);font-size:10px;color:var(--muted);margin-bottom:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.da-tip-contact{padding:6px 0;border-bottom:1px solid rgba(201,169,110,0.08)}
.da-tip-contact:last-child{border-bottom:none}
.da-tip-name{font-size:12px;color:var(--text);font-weight:500;display:block;font-family: var(--font-body)}
.da-tip-title{font-size:11px;color:var(--muted);display:block;font-family: var(--font-body)}
.da-tip-email{font-family: var(--font-body);font-size:11px;color:var(--aman-gold);display:block;margin-top:3px;font-weight:500}
.da-stat-sep{color:var(--muted);margin:0 8px}
.dist-arch-wrap{position:relative;min-height:440px;border-radius: 2px;overflow:hidden}
.da-tooltip{position:absolute;background:rgba(10,12,20,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(201,169,110,0.15);border-radius: 2px;padding:14px 18px;font-size:12px;color:var(--text);pointer-events:none;z-index:10;min-width:220px;box-shadow:0 8px 32px rgba(0,0,0,0.5);opacity:0;transition:opacity 0.2s}
.da-tooltip.visible{opacity:1}

/* ═══ V24.0: ENHANCED PATHWAY MAP — Premium controls ═══ */
.da-search-wrap{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:3}
.da-search-input{background:rgba(10,12,20,0.8);border:1px solid rgba(201,169,110,0.2);border-radius: 2px;padding:7px 18px;font-family: var(--font-body);font-size:11px;color:var(--text);width:220px;outline:none;transition:all 0.3s;backdrop-filter:blur(12px);font-weight:500}
.da-search-input:focus{border-color:var(--aman-gold);width:280px;box-shadow:0 0 16px rgba(201,169,110,0.15)}
.da-search-input::placeholder{color:rgba(201,169,110,0.3)}
.da-minimap{position:absolute;bottom:14px;left:14px;width:150px;height:95px;background:rgba(10,12,20,0.8);border:1px solid rgba(201,169,110,0.12);border-radius: 2px;z-index:2;overflow:hidden;cursor:pointer;backdrop-filter:blur(8px)}
.da-minimap svg{width:100%;height:100%}
.da-minimap-viewport{fill:rgba(201,169,110,0.08);stroke:var(--aman-gold);stroke-width:1;opacity:0.6}
.da-context-menu{position:absolute;display:none;background:rgba(10,12,20,0.96);border:1px solid rgba(201,169,110,0.2);border-radius: 2px;padding:6px 0;min-width:220px;z-index:200;backdrop-filter:blur(20px);box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.da-ctx-item{padding:10px 18px;font-family: var(--font-body);font-size:12px;color:var(--text);cursor:pointer;transition:background 0.15s;font-weight:500}
.da-ctx-item:hover{background:rgba(201,169,110,0.1);color:var(--aman-gold)}
.da-ctx-sep{height:1px;margin:4px 8px;background:rgba(201,169,110,0.1)}
.da-ctx-drag-hint{color:var(--dim);font-style:italic;font-size:10px;cursor:default}
.da-ctx-drag-hint:hover{background:transparent;color:var(--dim)}
/* V22.13: Spider Context Menu — Premium Redesign */
/* V23.5: Premium Context Menu — complete redesign */
.spider-ctx{position:absolute;display:none;background:rgba(18,16,14,0.97);border:1px solid rgba(201,169,110,0.18);border-radius: 2px;padding:0;width:320px;max-height:520px;z-index:200;backdrop-filter:blur(24px) saturate(1.2);box-shadow:0 20px 60px rgba(0,0,0,0.7),0 0 0 1px rgba(201,169,110,0.08),inset 0 1px 0 rgba(255,255,255,0.03);font-family: var(--font-body);overflow:hidden}
.spider-ctx::-webkit-scrollbar{width:3px}
.spider-ctx::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.15);border-radius:2px}
.spider-ctx::-webkit-scrollbar-track{background:transparent}
.sctx-header{padding:14px 16px 10px;background:linear-gradient(180deg,rgba(201,169,110,0.06) 0%,transparent 100%);border-bottom:1px solid rgba(201,169,110,0.08)}
.sctx-company-name{display:block;font-size:14px;font-weight:600;color:var(--text);letter-spacing:0.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family: var(--font-display);line-height:1.2}
.sctx-type-badge{display:inline-flex;align-items:center;gap:5px;margin-top:5px;padding:3px 10px;border-radius: 2px;font-size:9px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase}
.sctx-type-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sctx-suggest{padding:10px 14px;margin:8px 10px 4px;background:linear-gradient(135deg,rgba(201,169,110,0.1) 0%,rgba(201,169,110,0.04) 100%);border:1px solid rgba(201,169,110,0.18);border-radius: 2px;position:relative;overflow:hidden}
.sctx-suggest::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.3),transparent)}
.sctx-suggest-label{font-size:8px;text-transform:uppercase;letter-spacing:2.5px;color:var(--aman-gold);opacity:0.7;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.sctx-suggest-label::before{content:'✦';font-size:9px}
.sctx-suggest-btn{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:2px;cursor:pointer;transition:all 0.2s;color:var(--text);font-size:12px;font-weight:500;background:rgba(201,169,110,0.06)}
.sctx-suggest-btn:hover{background:rgba(201,169,110,0.18);transform:translateX(2px)}
.sctx-suggest-arrow{color:var(--aman-gold);font-size:12px;opacity:0.8}
.sctx-sep{height:1px;margin:6px 14px;background:linear-gradient(90deg,transparent,rgba(201,169,110,0.1),transparent)}
.sctx-section-label{padding:8px 16px 4px;font-size:8px;text-transform:uppercase;letter-spacing:2.5px;color:rgba(201,169,110,0.5);font-weight:600}
.sctx-search-wrap{padding:4px 10px 6px;position:relative}
.sctx-search{width:100%;padding:7px 12px 7px 28px;background:rgba(255,255,255,0.04);border:1px solid rgba(201,169,110,0.1);border-radius:2px;font-size:11px;color:var(--text);font-family: var(--font-body);outline:none;transition:border-color 0.2s}
.sctx-search:focus{border-color:rgba(201,169,110,0.3);background:rgba(255,255,255,0.06)}
.sctx-search::placeholder{color:rgba(201,169,110,0.25);font-size:10px}
.sctx-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:10px;color:rgba(201,169,110,0.3);pointer-events:none}
.sctx-reassign-scroll{max-height:200px;overflow-y:auto;padding:0 6px 4px}
.sctx-reassign-scroll::-webkit-scrollbar{width:3px}
.sctx-reassign-scroll::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.15);border-radius:2px}
.sctx-reassign-grid{display:flex;flex-wrap:wrap;gap:5px;padding:2px 4px 4px}
.sctx-reassign-chip{padding:5px 11px;border-radius: 2px;font-size:10px;font-weight:500;cursor:pointer;transition:all 0.15s;border:1px solid transparent;white-space:nowrap;letter-spacing:0.3px;line-height:1.2}
.sctx-reassign-chip:hover{transform:translateY(-1px);box-shadow:0 3px 12px rgba(0,0,0,0.4)}
.sctx-reassign-chip.current{opacity:0.2;cursor:default;pointer-events:none;transform:none}
.sctx-reassign-chip.hidden{display:none}
.sctx-actions-scroll{max-height:160px;overflow-y:auto}
.sctx-item{padding:8px 16px;font-size:11px;color:rgba(255,255,255,0.5);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:10px;border-left:2px solid transparent;margin:0 2px}
.sctx-item:hover{background:rgba(201,169,110,0.06);color:var(--text);border-left-color:rgba(201,169,110,0.3)}
.sctx-icon{font-size:12px;opacity:0.5;width:16px;text-align:center;flex-shrink:0}
.sctx-item-label{flex:1}
.sctx-item-hint{font-size:8px;color:rgba(201,169,110,0.25);letter-spacing:0.5px;text-transform:uppercase}
.sctx-item.sctx-discovery{color:rgba(201,169,110,0.8)}
.sctx-item.sctx-discovery:hover{color:var(--aman-gold);background:rgba(201,169,110,0.04);border-left-color:rgba(201,169,110,0.4)}
.sctx-item.sctx-inactive{color:rgba(192,112,96,0.6)}
.sctx-item.sctx-inactive:hover{color:#C07060;background:rgba(192,112,96,0.04);border-left-color:rgba(192,112,96,0.4)}
.sctx-item.sctx-dicl{color:rgba(155,139,180,0.7)}
.sctx-item.sctx-dicl:hover{color:#9B8BB4;background:rgba(155,139,180,0.04);border-left-color:rgba(155,139,180,0.4)}
.sctx-item.sctx-web{color:rgba(184,148,79,0.7)}
.sctx-item.sctx-web:hover{color:#B8944F;background:rgba(184,148,79,0.04);border-left-color:rgba(184,148,79,0.4)}
.sctx-footer{padding:6px 16px 8px;border-top:1px solid rgba(201,169,110,0.06);display:flex;justify-content:space-between;align-items:center}
.sctx-footer-hint{font-size:8px;color:rgba(201,169,110,0.2);letter-spacing:0.5px}
.da-node-entity.da-dragging rect{stroke:var(--aman-gold)!important;stroke-width:2!important;filter:drop-shadow(0 0 12px rgba(201,169,110,0.4))!important}
.da-node-entity.da-search-match rect{stroke:var(--aman-gold)!important;stroke-width:2!important;filter:drop-shadow(0 0 16px rgba(201,169,110,0.5))!important;animation:daPulseMatch 1.5s ease-in-out infinite}
.da-node-entity.da-search-dim{opacity:0.15!important}
.da-node-category.da-search-dim{opacity:0.15!important}
.da-node-category.da-collapsed rect{stroke-dasharray:4 2}
.da-drop-zone rect{stroke-width:2.5!important;filter:drop-shadow(0 0 12px currentColor)!important;animation:daDropPulse 0.8s ease-in-out infinite}
@keyframes daPulseMatch{0%,100%{filter:drop-shadow(0 0 8px rgba(201,169,110,0.3))}50%{filter:drop-shadow(0 0 20px rgba(201,169,110,0.6))}}
@keyframes daDropPulse{0%,100%{opacity:0.7}50%{opacity:1}}
.da-flow-particle{fill:var(--aman-gold);opacity:0}
.da-ghost-node rect{fill:transparent!important;stroke-dasharray:6 3!important;opacity:0.4}
.da-ghost-node text{opacity:0.5;font-style:italic}
.da-ghost-node:hover{opacity:0.8}
.da-territory-ring{fill:none;stroke-width:2;opacity:0.6}
.da-confidence-high{stroke:var(--aman-gold)!important;stroke-width:1.5!important}
.da-confidence-medium{stroke:rgba(201,169,110,0.5)!important;stroke-dasharray:6 2!important}
.da-confidence-low{stroke:rgba(255,80,80,0.4)!important;stroke-dasharray:3 3!important;animation:daLowPulse 2s ease-in-out infinite}
@keyframes daLowPulse{0%,100%{stroke-opacity:0.3}50%{stroke-opacity:0.8}}
.da-node-size-sm rect{height:26px!important}
.da-node-size-lg rect{height:34px!important}
.da-node-size-xl rect{height:40px!important}

/* ═══ LANDSCAPE MODE (mobile) ═══ */
@media(max-width:768px) and (orientation:landscape){
  .dashboard{padding:20px 0 16px}
  .dash-hero{margin-bottom:12px}
  .dash-hero h2{font-size:20px}
  .spider-canvas-wrap{height:200px}
  .thinking-stream{max-height:150px}
  .intel-split{gap:8px}
}

/* ═══ V17.0: MOBILE-FIRST CONTACTS PAGE ═══ */
@media (max-width: 768px) {
  /* Contacts page mobile layout */
  #forensicLedger {
    padding: 8px !important;
  }

  .forensic-header {
    flex-direction: column;
    gap: 8px;
  }

  .forensic-header h2 {
    font-size: 20px !important;
  }

  .ledger-actions-row {
    flex-wrap: wrap;
    gap: 4px;
  }

  .ledger-actions-row button {
    font-size: 10px !important;
    padding: 4px 8px !important;
  }

  .filter-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 4px;
    padding-bottom: 8px;
  }

  .filter-pills button {
    flex-shrink: 0;
    font-size: 10px !important;
    padding: 4px 8px !important;
    white-space: nowrap;
  }

  /* Mobile table: horizontal scroll */
  #contactsTableWrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .contacts-table {
    min-width: 700px;
  }

  /* Mobile cards: single column */
  #contactsCards {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .contact-card {
    padding: 12px !important;
  }

  /* Company rows on mobile */
  .company-row {
    padding: 8px 12px !important;
  }

  /* Search bar mobile */
  #contactSearch {
    font-size: 14px !important;
    padding: 10px 12px !important;
  }

  /* View toggles mobile */
  .view-toggle-group {
    flex-wrap: wrap;
    gap: 4px;
  }

  .view-toggle {
    font-size: 10px !important;
    padding: 4px 8px !important;
  }

  /* Dashboard mobile improvements */
  .dash-hero h1 {
    font-size: 28px !important;
  }

  .dash-search-bar {
    flex-direction: column;
    gap: 8px;
  }

  .dash-search-bar input {
    width: 100% !important;
    font-size: 14px !important;
  }

  .dash-search-bar button {
    width: 100% !important;
  }

  .dash-vault-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .dash-intel-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .dash-action-btns {
    flex-direction: column;
    gap: 8px;
  }

  .dash-action-btn {
    width: 100% !important;
  }
}

@media (max-width: 480px) {
  .dash-hero h1 {
    font-size: 22px !important;
  }

  .dash-vault-grid {
    grid-template-columns: 1fr !important;
  }

  .dash-intel-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .contacts-table {
    min-width: 600px;
    font-size: 11px;
  }

  .contacts-table thead th {
    padding: 8px 6px;
    font-size: 11px;
  }

  .contacts-table tbody td {
    padding: 8px 6px;
    font-size: 11px;
  }
}

/* ═══ V24.0: DISTRIBUTION GEOGRAPHY — Premium Aman redesign ═══ */
.geo-section{margin:24px 0}
.geo-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px;padding:0 4px}
.geo-header-left{display:flex;align-items:baseline;gap:14px}
.geo-header-title{font-family: var(--font-display);font-size:28px;font-weight:600;color:var(--text);letter-spacing:-0.5px}
.geo-header-sub{font-size:11px;color:var(--muted);letter-spacing:3px;text-transform:uppercase;font-family: var(--font-body);font-weight:500}
.geo-header-stats{display:flex;gap:20px}
.geo-stat{display:flex;flex-direction:column;align-items:flex-end}
.geo-stat-val{font-family: var(--font-display);font-size:24px;font-weight:600;color:var(--text);line-height:1}
.geo-stat-label{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;font-family: var(--font-body);margin-top:3px;font-weight:500}
.geo-map-wrap{position:relative;width:100%;height:620px;background:linear-gradient(160deg,#0d0f16 0%,#111420 40%,#0b0e17 100%);border-radius: 2px;overflow:hidden;border:1px solid rgba(201,169,110,0.15);box-shadow:inset 0 0 100px rgba(0,0,0,0.7),0 2px 24px rgba(0,0,0,0.3),0 0 1px rgba(201,169,110,0.2)}
.geo-map-wrap svg{width:100%;height:100%}
.geo-map-wrap .geo-ocean{fill:rgba(8,10,18,0.9)}
.geo-map-wrap .geo-land{fill:rgba(20,24,38,0.95);stroke:rgba(201,169,110,0.1);stroke-width:0.4;transition:fill 0.3s,stroke 0.3s}
.geo-map-wrap .geo-land:hover{fill:rgba(201,169,110,0.05);stroke:rgba(201,169,110,0.22)}
.geo-map-wrap .geo-land.active{fill:rgba(201,169,110,0.07);stroke:rgba(201,169,110,0.28);stroke-width:0.6}
.geo-map-wrap .geo-graticule{stroke:rgba(201,169,110,0.04);stroke-width:0.3;fill:none}
.geo-arc{fill:none;stroke:url(#geoArcGrad);stroke-width:1.2;opacity:0;stroke-dasharray:5,4}
.geo-arc.animated{animation:arcFadeIn 0.8s ease-out forwards,arcDash 3s linear 0.8s infinite}
@keyframes arcFadeIn{from{opacity:0;stroke-width:0.5}to{opacity:0.5;stroke-width:1.2}}
@keyframes arcDash{to{stroke-dashoffset:-9}}
.geo-marker{cursor:pointer}
.geo-marker .gm-pulse{fill:var(--aman-gold);opacity:0;animation:geoPulse 3s ease-out infinite}
.geo-marker .gm-outer{fill:none;stroke:rgba(201,169,110,0.18);stroke-width:1.2}
.geo-marker .gm-core{fill-opacity:0.75;stroke:rgba(0,0,0,0.3);stroke-width:0.5;filter:drop-shadow(0 0 4px rgba(201,169,110,0.3));transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1)}
.geo-marker:hover .gm-core{fill-opacity:1;filter:drop-shadow(0 0 14px rgba(201,169,110,0.6));transform:scale(1.15)}
.geo-marker:hover .gm-outer{stroke:rgba(201,169,110,0.4);stroke-width:1.5}
.geo-marker .gm-count{fill:rgba(255,253,245,0.95);font-family: var(--font-body);font-size:10px;font-weight:700;text-anchor:middle;pointer-events:none;dominant-baseline:central}
.geo-marker .gm-label{fill:rgba(255,253,245,0.6);font-family: var(--font-body);font-size:9px;font-weight:500;text-anchor:middle;pointer-events:none;letter-spacing:0.5px}
@keyframes geoPulse{0%{r:0;opacity:0.35}100%{r:28;opacity:0}}
.geo-tooltip{position:absolute;background:rgba(10,12,20,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(201,169,110,0.15);border-radius: 2px;padding:16px 20px;font-size:12px;color:var(--text);pointer-events:none;z-index:10;min-width:220px;max-width:320px;box-shadow:0 12px 40px rgba(0,0,0,0.6),0 0 1px rgba(201,169,110,0.2);opacity:0;transition:opacity 0.25s,transform 0.25s;transform:translateY(4px)}
.geo-tooltip.visible{opacity:1;transform:translateY(0)}
.geo-tooltip .tt-city{font-family: var(--font-display);font-weight:600;font-size:18px;color:rgba(255,253,245,0.95);margin-bottom:3px}
.geo-tooltip .tt-count{font-family: var(--font-body);color:rgba(201,169,110,0.6);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(201,169,110,0.1);font-weight:500}
.geo-tooltip .tt-contacts{font-size:11px;color:var(--muted);max-height:240px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(201,169,110,0.15) transparent;display:flex;flex-direction:column;gap:6px}
.geo-tooltip .tt-contacts::-webkit-scrollbar{width:4px}
.geo-tooltip .tt-contacts::-webkit-scrollbar-thumb{background:rgba(201,169,110,0.2);border-radius:2px}
.geo-tooltip .tt-contact-row{padding:5px 0;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid rgba(255,255,255,0.03)}
.geo-tooltip .tt-contact-name{color:rgba(255,253,245,0.8);font-weight:500;font-size:12px;font-family: var(--font-body)}
.geo-tooltip .tt-contact-meta{color:rgba(201,169,110,0.45);font-size:10px;font-family: var(--font-body)}
.geo-legend-wrap{position:absolute;top:14px;left:14px;z-index:6;display:flex;flex-direction:column;gap:6px;pointer-events:none}
.geo-legend{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:rgba(10,12,20,0.85);backdrop-filter:blur(16px);border:1px solid rgba(201,169,110,0.1);border-radius: 2px;font-size:10px;font-family: var(--font-body);color:rgba(255,253,245,0.5);pointer-events:auto}
.geo-legend-item{display:flex;align-items:center;gap:7px;letter-spacing:0.3px;padding:3px 0;font-weight:500}
.geo-legend-dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 6px currentColor;flex-shrink:0}
.geo-zoom-controls{position:absolute;top:14px;right:14px;display:flex;flex-direction:column;gap:5px;z-index:6}
.geo-zoom-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(10,12,20,0.8);border:1px solid rgba(201,169,110,0.1);border-radius:2px;color:rgba(201,169,110,0.5);font-size:15px;cursor:pointer;transition:all 0.2s;backdrop-filter:blur(12px);font-family: var(--font-body);font-weight:500}
.geo-zoom-btn:hover{border-color:rgba(201,169,110,0.25);color:var(--aman-gold);background:rgba(201,169,110,0.06)}
.geo-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:16px}
.geo-summary-card{padding:16px 18px;background:var(--card);border:1px solid var(--border);border-radius: 2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:var(--shadow-sm)}
.geo-summary-card:hover{border-color:rgba(201,169,110,0.12);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.3)}
.geo-summary-card .gs-region{font-family: var(--font-body);font-size:12px;font-weight:500;color:var(--text);letter-spacing:0.3px;margin-bottom:6px}
.geo-summary-card .gs-count{font-family: var(--font-display);font-size:28px;font-weight:600;color:var(--text);line-height:1}
.geo-summary-card .gs-detail{font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;font-family: var(--font-body);font-weight:500}
@media(max-width:600px){.geo-header{flex-direction:column;gap:10px}.geo-header-stats{justify-content:flex-start}.geo-map-wrap{height:400px;border-radius: 2px}.geo-summary{grid-template-columns:repeat(2,1fr);gap:8px}.geo-summary-card{padding:12px 14px}.geo-summary-card .gs-count{font-size:22px}.geo-legend{padding:8px 12px}}

/* ═══ V13.8: FEEDBACK & LEARNING SYSTEM ═══ */
/* Inline editing styles */
.tbl-cell-editable{cursor:pointer;position:relative;padding:4px;border-radius:2px;transition:all 0.15s}
.tbl-cell-editable:hover{background:rgba(201,169,110,0.03);border:1px solid rgba(201,169,110,0.1)}
.tbl-cell-edit-input{padding:4px 6px;background:rgba(255,255,255,0.05);border:1px solid var(--aman-gold);border-radius:2px;color:var(--text);font-family:inherit;font-size:inherit;width:100%;min-width:80px;box-sizing:border-box}
.tbl-cell-edit-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 8px rgba(201,169,110,0.2)}
.tbl-cell-edited{border:2px solid var(--aman-gold) !important;background:rgba(201,169,110,0.05) !important}

/* Feedback buttons */
.tbl-feedback-buttons{display:flex;gap:4px;align-items:center}
.tbl-feedback-btn{padding:3px 7px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:all 0.2s;font-family:inherit}
.tbl-feedback-btn:hover{border-color:var(--cyan);color:var(--text)}
.tbl-feedback-btn.thumbs-up{color:var(--green);border-color:rgba(139,158,107,0.3)}
.tbl-feedback-btn.thumbs-up:hover{background:rgba(139,158,107,0.1);border-color:var(--green)}
.tbl-feedback-btn.thumbs-down{color:var(--red);border-color:rgba(192,112,96,0.3)}
.tbl-feedback-btn.thumbs-down:hover{background:rgba(192,112,96,0.1);border-color:var(--red)}
.tbl-feedback-btn.active{background:rgba(201,169,110,0.1);border-color:var(--cyan);color:var(--cyan)}

/* Correction modal */
.correction-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}
.correction-modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;min-width:400px;max-width:500px;box-shadow:var(--shadow-xl);color:var(--text)}
.correction-modal-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--cyan)}
.correction-modal-subtitle{font-size:12px;color:var(--muted);margin-bottom:16px}
.correction-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.correction-option{padding:12px;border:1px solid var(--border);border-radius:2px;background:transparent;color:var(--text);cursor:pointer;transition:all 0.2s;text-align:left;font-family:inherit;font-size:13px}
.correction-option:hover{border-color:var(--red);background:rgba(192,112,96,0.05)}
.correction-option-label{font-weight:500;margin-bottom:2px}
.correction-option-desc{font-size:11px;color:var(--muted)}
.correction-modal-buttons{display:flex;gap:8px;justify-content:flex-end}
.correction-modal-buttons button{padding:8px 16px;border-radius:2px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:12px;transition:all 0.2s}
.correction-modal-buttons button:hover{background:rgba(201,169,110,0.1);border-color:var(--cyan);color:var(--cyan)}
.correction-modal-buttons .btn-submit{background:var(--red);border-color:var(--red);color:var(--bg)}
.correction-modal-buttons .btn-submit:hover{background:rgba(192,112,96,0.8)}


/* Rep Group Deep Dive — type badges and cards */
.rep-type-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase}
.rep-type-badge.multiline-rep{background:rgba(37,99,235,0.15);color:#60a5fa}
.rep-type-badge.buying-group{background:rgba(124,58,237,0.15);color:#a78bfa}
.rep-type-badge.distributor{background:rgba(5,150,105,0.15);color:#34d399}
.rep-type-badge.manufacturers-rep{background:rgba(217,119,6,0.15);color:#fbbf24}
.rep-type-badge.international-distributor{background:rgba(8,145,178,0.15);color:#22d3ee}
.rep-type-badge.specialty-distributor{background:rgba(190,24,93,0.15);color:#f472b6}
.rep-type-badge.trade-show{background:rgba(234,88,12,0.15);color:#fb923c}
.rep-type-badge.agency{background:rgba(79,70,229,0.15);color:#818cf8}
.rep-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:20px;transition:all 0.2s ease;cursor:pointer}
.rep-card:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.12);transform:translateY(-1px)}
.rep-card.verified{border-left:3px solid #22c55e}
.rep-stats-bar{display:flex;gap:24px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.06);margin-bottom:20px;flex-wrap:wrap}
.rep-stat{text-align:center}
.rep-stat-value{font-size:24px;font-weight:700;color:var(--text);font-family:var(--font-display)}
.rep-stat-label{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.rep-filter-bar{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}
.rep-filter-bar select,.rep-filter-bar input{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:var(--text);padding:8px 12px;border-radius:6px;font-size:13px;font-family:var(--font-body)}
.rep-filter-bar input{flex:1;min-width:200px}
.rep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.rep-detail-panel{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:10px;padding:28px;margin-top:20px}
.rep-detail-panel h2{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}
.rep-territory-tag{display:inline-block;padding:2px 8px;background:rgba(255,255,255,0.06);border-radius:4px;font-size:11px;color:var(--dim);margin:2px}
.rep-brand-chip{display:inline-block;padding:3px 10px;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:12px;font-size:11px;color:#60a5fa;margin:2px;cursor:pointer;transition:all 0.15s}
.rep-brand-chip:hover{background:rgba(37,99,235,0.2);border-color:rgba(37,99,235,0.4)}
.rep-contact-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.rep-contact-row:last-child{border-bottom:none}

/* ═══ Buyers Page ═══ */
.buyers-page{padding:24px;max-width:1400px;margin:0 auto}
.buyers-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}
.buyers-title{font-size:22px;font-weight:600;color:var(--text);margin:0}
.buyers-subtitle{font-size:12px;color:var(--muted);margin-top:4px}
.buyer-stats-bar{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.buyer-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;flex:1;min-width:140px;text-align:center}
.buyer-stat-num{font-size:20px;font-weight:700;color:var(--cyan);display:block}
.buyer-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.buyer-filter-bar{display:flex;gap:12px;margin-bottom:16px}
.buyer-search{flex:1;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:13px;outline:none}
.buyer-search:focus{border-color:var(--cyan)}
.buyer-brand-select{padding:10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);min-width:180px;font-size:13px}
.buyer-table-wrap{overflow-x:auto}
.buyer-table{width:100%;border-collapse:collapse;font-size:13px}
.buyer-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.buyer-table td{padding:8px 12px;border-bottom:1px solid var(--border-light, rgba(255,255,255,0.04))}
.buyer-row{transition:background 0.15s}
.buyer-row:hover{background:rgba(201,169,110,0.04)}
.buyer-row.low-match{border-left:3px solid var(--red)}
.buyer-row.high-match{border-left:3px solid #34d399}
.buyer-name{font-weight:500;color:var(--text)}
.buyer-email a{color:var(--cyan);text-decoration:none}
.buyer-email a:hover{text-decoration:underline}
.buyer-title,.buyer-company{color:var(--muted)}
.brand-link{color:var(--cyan);text-decoration:none;font-weight:500}
.brand-link:hover{text-decoration:underline}
.badge-valid{background:#34d399;color:#000;font-size:9px;padding:1px 5px;border-radius:8px;margin-left:4px}
.badge-invalid{background:var(--red);color:#000;font-size:9px;padding:1px 5px;border-radius:8px;margin-left:4px}
.match-bar{display:inline-block;width:48px;height:6px;background:var(--border);border-radius:3px;position:relative;font-size:10px;color:var(--muted);text-align:center;line-height:1}
.match-bar::before{content:'';position:absolute;left:0;top:0;height:100%;width:var(--match);background:linear-gradient(90deg, var(--red), #fbbf24, #34d399);border-radius:3px}
.btn-tiny{padding:3px 8px;font-size:10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer}
.btn-tiny:hover{border-color:var(--red);color:var(--red)}
.buyer-pagination{display:flex;justify-content:center;align-items:center;gap:12px;padding:16px 0}
.buyer-pagination button{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text);cursor:pointer;font-size:12px}
.buyer-pagination button:hover:not(:disabled){border-color:var(--cyan);color:var(--cyan)}
.buyer-pagination button:disabled{opacity:0.3;cursor:default}

/* ═══ Contact Intelligence Page ═══ */
.contacts-intel-page{padding:24px;max-width:1400px;margin:0 auto}
.ci-header{margin-bottom:20px}
.ci-title{font-size:22px;font-weight:600;color:var(--text);margin:0}
.ci-subtitle{font-size:12px;color:var(--muted);margin-top:4px}
.ci-stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:12px;margin-bottom:20px}
.ci-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color 0.2s}
.ci-stat-card:hover{border-color:var(--cyan)}
.ci-stat-card.warn{border-color:rgba(251,191,36,0.3)}
.ci-stat-num{font-size:24px;font-weight:700;color:var(--text)}
.ci-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
.ci-stat-bar{height:4px;background:var(--border);border-radius:2px;margin-top:8px;overflow:hidden}
.ci-bar-fill{height:100%;border-radius:2px;transition:width 0.6s ease}
.ci-bar-fill.green{background:#34d399}
.ci-bar-fill.blue{background:var(--cyan)}
.ci-bar-fill.amber{background:#fbbf24}
.ci-bar-fill.gray{background:var(--muted)}
.ci-stat-detail{font-size:11px;color:var(--muted);margin-top:6px}
.ci-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}
.ci-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;font-size:13px;font-weight:500;transition:all 0.2s}
.ci-tab:hover{color:var(--text)}
.ci-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.ci-content{min-height:300px}

/* Overview */
.ci-overview{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:800px){.ci-overview{grid-template-columns:1fr}}
.ci-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.ci-section h3{font-size:14px;font-weight:600;color:var(--text);margin:0 0 14px}
.ci-tier-bars{display:flex;flex-direction:column;gap:8px}
.ci-tier-row{display:flex;align-items:center;gap:8px}
.ci-tier-label{width:28px;font-size:10px;font-weight:600;color:var(--muted)}
.ci-tier-bar-wrap{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.ci-tier-bar{height:100%;border-radius:4px}
.ci-tier-count{width:48px;text-align:right;font-size:11px;color:var(--muted)}
:root{--tier-t1:#34d399;--tier-t2:var(--cyan);--tier-t3:#fbbf24;--tier-t4:var(--red)}
.ci-type-grid{display:flex;flex-wrap:wrap;gap:6px}
.ci-type-chip{padding:4px 10px;border:1px solid var(--border);border-radius:12px;font-size:11px;display:flex;gap:6px;align-items:center}
.ci-type-chip.untyped{border-color:rgba(251,191,36,0.3);background:rgba(251,191,36,0.05)}
.ci-type-count{font-weight:700;color:var(--cyan)}
.ci-type-name{color:var(--muted)}
.ci-quality-meter{text-align:center;padding:12px}
.ci-quality-score{font-size:48px;font-weight:700;color:var(--cyan)}
.ci-quality-breakdown{display:flex;flex-direction:column;gap:6px;margin-top:12px;text-align:left}
.ci-q-item{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}
.ci-q-item strong{color:var(--text)}

/* Quality Issues */
.ci-issues{display:flex;flex-direction:column;gap:10px}
.ci-issue{display:flex;gap:14px;align-items:flex-start;padding:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}
.ci-issue-critical{border-left:3px solid var(--red)}
.ci-issue-high{border-left:3px solid #fbbf24}
.ci-issue-medium{border-left:3px solid var(--cyan)}
.ci-issue-severity{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap}
.ci-issue-critical .ci-issue-severity{background:rgba(192,112,96,0.15);color:var(--red)}
.ci-issue-high .ci-issue-severity{background:rgba(251,191,36,0.15);color:#fbbf24}
.ci-issue-medium .ci-issue-severity{background:rgba(201,169,110,0.15);color:var(--cyan)}
.ci-issue-body{flex:1}
.ci-issue-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.ci-issue-desc{font-size:11px;color:var(--muted)}
.ci-issue-action{font-size:11px;color:var(--cyan);font-weight:500;white-space:nowrap}

/* Brand Health */
.ci-brand-health{overflow-x:auto}
.ci-bh-summary{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.ci-bh-stat{font-size:12px;color:var(--muted);padding:6px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}
.ci-bh-stat.warn{border-color:rgba(251,191,36,0.3);color:#fbbf24}
.ci-brand-table{width:100%;border-collapse:collapse;font-size:13px}
.ci-brand-table th{text-align:left;padding:8px 12px;border-bottom:2px solid var(--border);font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:var(--muted);font-weight:600}
.ci-brand-table td{padding:8px 12px;border-bottom:1px solid var(--border-light, rgba(255,255,255,0.04))}
.ci-brand-row:hover{background:rgba(201,169,110,0.04)}
.ci-brand-row.non-brand{opacity:0.6}
.ci-brand-row.non-brand:hover{opacity:1}
.brand-type-badge{display:inline-block;padding:2px 6px;border-radius:8px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}
.bt-brand{background:rgba(52,211,153,0.12);color:#34d399}
.bt-distributor{background:rgba(251,191,36,0.12);color:#fbbf24}
.bt-retailer{background:rgba(96,165,250,0.12);color:#60a5fa}
.bt-rep_group{background:rgba(167,139,250,0.12);color:#a78bfa}
.bt-subsidiary{background:rgba(148,163,184,0.12);color:#94a3b8}
.diamond{color:#fbbf24;font-size:10px}
.health-bar{width:60px;height:6px;background:var(--border);border-radius:3px;overflow:hidden;position:relative}
.health-fill{height:100%;width:var(--health);border-radius:3px}
.health-fill.good{background:#34d399}
.health-fill.ok{background:#fbbf24}
.health-fill.bad{background:var(--red)}

/* Hunting List */
.ci-hunting-empty{text-align:center;padding:48px;color:var(--muted)}
.ci-hunting-empty h3{color:var(--text);font-size:16px;margin-bottom:8px}
.ci-hunting-header{margin-bottom:14px;font-size:13px;color:var(--muted)}
.ci-hunting-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:10px}
.ci-hunt-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;border-left:3px solid var(--cyan)}
.ci-hunt-name{font-weight:600;color:var(--text);font-size:14px;margin-bottom:4px}
.ci-hunt-detail{font-size:12px;color:var(--muted);margin-bottom:6px}
.ci-hunt-email{font-size:11px;color:var(--cyan);margin-bottom:4px}
.ci-hunt-reason{font-size:11px;color:var(--muted);font-style:italic;margin-bottom:6px}
.ci-hunt-meta{font-size:10px;color:var(--muted);opacity:0.7}

/* Shared */
.loading-spinner{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.empty-state{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.error-state{text-align:center;padding:40px;color:var(--red);font-size:13px}
.btn-secondary{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text);cursor:pointer;font-size:12px;transition:all 0.2s}
.btn-secondary:hover{border-color:var(--cyan);color:var(--cyan)}
