*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Brand */
  --brand:#9d0d08;--brand-dark:#7b0906;--brand-mid:#c13820;--brand-soft:#d95030;
  --brand-pale:#fdf0ed;--brand-pale2:#f9e0da;--brand-pale3:#f2ccc4;
  --p:#b22d2d;--c:#4a8f7a;--danger:#d94f4f;

  /* Backgrounds — warm off-white */
  --bg:#faf7f5;--bg2:#f5f0ed;--bg3:#ede6e1;--bg4:#e6ddd7;

  /* Surfaces */
  --surface:#ffffff;--surface2:#fdf9f7;--surface3:#f8f2ef;

  /* Borders */
  --border:rgba(157,13,8,.10);--border2:rgba(157,13,8,.06);--border3:rgba(157,13,8,.04);

  /* Text */
  --text1:#1e1210;--text2:#5c3a32;--text3:#9e7060;--text4:#c4a090;

  /* Accent fills */
  --accent-bg:rgba(157,13,8,.06);--accent-bg2:rgba(157,13,8,.10);
  --accent-border:rgba(157,13,8,.18);

  /* Type */
  --serif:'Fraunces',Georgia,serif;
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;

  /* Radii */
  --r-sm:10px;--r-md:16px;--r-lg:22px;--r-xl:28px;
}

html,body{min-height:100vh;background:var(--bg)}
body{font-family:var(--sans);color:var(--text1);
  padding-top:env(safe-area-inset-top,0);padding-right:env(safe-area-inset-right,0);
  padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0)}

/* ── APP SHELL ─────────────────────────────────────────────── */
#app{display:flex;width:100%;min-height:100vh;height:100vh;overflow:hidden;
  font-size:13px;font-family:var(--sans);background:var(--bg);
  box-shadow:0 0 0 1px var(--border)}

/* ── SIDEBAR ───────────────────────────────────────────────── */
#sb{width:260px;min-width:260px;
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);
  border-right:1px solid var(--border);display:flex;flex-direction:column}
#sbh{padding:22px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center}
#sbh h1{flex:1;min-width:0}
.sba{padding:14px 14px 12px;display:flex;flex-direction:column;gap:9px;border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:19px;
  font-weight:700;color:var(--text1);letter-spacing:-.02em;cursor:pointer}
.brand-logo{width:36px;height:36px;display:block;border-radius:9px;object-fit:contain;
  box-shadow:0 4px 16px rgba(157,13,8,.18)}
.brand-name{display:block;line-height:1}
#nav{padding:8px 8px;flex:1;overflow-y:auto;scrollbar-width:none}
#nav::-webkit-scrollbar{display:none}
.sbf{padding:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;
  background:var(--surface2)}
.ns{font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;
  letter-spacing:.15em;padding:12px 12px 5px}
.ni{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);
  cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);min-width:0;
  transition:all .15s;position:relative}
.ni:hover{background:var(--accent-bg);color:var(--text1)}
.ni.on{background:var(--brand-pale2);color:var(--brand);font-weight:600}
.ni.on::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--brand);border-radius:0 3px 3px 0}
.ni svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;opacity:.6}
.ni.on svg,.ni:hover svg{opacity:1}
.ni .lbl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.nd{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.ndp{background:var(--brand)}.ndc{background:var(--c)}
.cnt{font-size:10px;font-weight:700;color:var(--text3);flex-shrink:0;
  background:var(--bg3);padding:2px 8px;border-radius:999px;border:1px solid var(--border2)}

/* ── BUTTONS (sidebar CTAs) ─────────────────────────────────── */
.hbtn{width:100%;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;padding:11px 16px;border-radius:var(--r-lg);
  cursor:pointer;white-space:nowrap;transition:all .15s;border:1px solid transparent}
.hbtn-p{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-mid) 100%);
  color:#fff;border-color:var(--brand-dark);
  box-shadow:0 3px 14px rgba(157,13,8,.28),inset 0 1px 0 rgba(255,255,255,.12)}
.hbtn-p:hover{box-shadow:0 5px 22px rgba(157,13,8,.4);transform:translateY(-1px)}
.hbtn-c{background:var(--surface);color:var(--text2);border-color:var(--border)}
.hbtn-c:hover{background:var(--brand-pale);color:var(--brand);border-color:var(--accent-border)}

/* ── TOPBAR ─────────────────────────────────────────────────── */
#mn{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
#tbar{padding:0 26px;border-bottom:1px solid var(--border);display:flex;align-items:center;
  gap:12px;height:62px;background:var(--surface);flex-shrink:0}
.mobile-nav-btn{display:none;width:38px;height:38px;align-items:center;justify-content:center;
  border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg2);
  color:var(--text2);cursor:pointer}
.mobile-nav-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round}
#bc{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--text1);flex:1;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}
.graph-filter{display:none;align-items:center;gap:10px;min-width:0;max-width:540px;flex:1;justify-content:flex-end}
.graph-filter.on{display:flex}
.graph-filter-box{display:flex;flex-direction:column;align-items:stretch;gap:8px;min-width:0;flex:1;
  padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg2)}
.graph-filter-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}
.graph-filter-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:4px 10px;
  border-radius:999px;background:var(--brand-pale2);border:1px solid var(--accent-border);
  font-size:11px;font-weight:700;color:var(--brand);white-space:nowrap}
.graph-filter-chip button{border:0;background:transparent;cursor:pointer;color:var(--brand);font-size:13px;line-height:1}
.graph-filter-chip-text{overflow:hidden;text-overflow:ellipsis}
.graph-filter-input{width:100%;min-width:150px;border:0;background:transparent;outline:none;
  font-size:13px;color:var(--text1);font-family:var(--sans);padding:2px}
.graph-filter-input::placeholder{color:var(--text3)}
.graph-filter-add{padding:9px 14px;border-radius:var(--r-sm);border:1px solid var(--border);
  background:var(--surface);color:var(--text2);font-size:12px;font-weight:700;cursor:pointer}
.graph-filter-add:hover{color:var(--brand);border-color:var(--accent-border);background:var(--brand-pale)}
.vtabs{display:flex;gap:8px}
.vt{padding:9px 20px;font-size:13px;font-weight:600;border:1px solid var(--border);
  border-radius:999px;cursor:pointer;background:transparent;color:var(--text2);transition:all .15s}
.vt.on,.vt:hover{background:var(--brand-pale2);border-color:var(--accent-border);color:var(--brand)}

/* ── CONTENT ────────────────────────────────────────────────── */
#ct{flex:1;overflow:hidden;position:relative;min-width:0;background:var(--bg)}
.view{display:none;height:100%;overflow-y:auto;padding:30px;scrollbar-width:thin;
  scrollbar-color:var(--bg4) transparent}
.view::-webkit-scrollbar{width:5px}
.view::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
.view.on{display:block}
#vinsights.on{display:flex;flex-direction:column;padding:0;overflow:hidden}
#gv{display:none;height:100%;padding:0;flex-direction:column;background:var(--bg2)}
#gv.on{display:flex}
#gc{display:block;flex:1;min-height:0;cursor:grab;background:var(--bg2)}
#gc.grabbing{cursor:grabbing}
#gleg{padding:10px 18px;display:flex;gap:14px;font-size:11px;color:var(--text3);
  background:var(--surface);align-items:center;flex-wrap:wrap;border-top:1px solid var(--border)}
.li{display:flex;align-items:center;gap:5px}
.gleg-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0;vertical-align:middle}

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
.st{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--text1);
  letter-spacing:-.02em;line-height:1.2;margin-bottom:10px}
.eyebrow{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brand);margin-bottom:10px}
.rn{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--text1);
  margin-bottom:2px;letter-spacing:-.02em}
.rs{font-size:12px;color:var(--text3);line-height:1.5}

/* ── HERO / DASHBOARD ───────────────────────────────────────── */
.hero{display:grid;grid-template-columns:1.4fr .9fr;gap:14px;margin-bottom:18px}
.hero-main,.hero-side{position:relative;overflow:hidden;border-radius:var(--r-xl);
  border:1px solid var(--border);background:var(--surface)}
.hero-main{padding:26px}
.hero-main::after{content:'';position:absolute;top:-50px;right:-50px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(157,13,8,.06),transparent 70%);pointer-events:none}
.hero-insight{position:relative;z-index:1}
.hero-insight .st{margin-top:0}
.hero-insight .insight-grid{margin-top:16px}
.hero-actions{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.hero-action{padding:13px 15px;border-radius:var(--r-lg);border:1px solid var(--border);
  background:var(--bg2);cursor:pointer;transition:all .15s}
.hero-action:hover{border-color:var(--accent-border);background:var(--brand-pale);transform:translateY(-1px)}
.hero-action-top{display:flex;align-items:center;gap:11px}
.hero-action-rank{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;background:var(--brand-pale2);color:var(--brand);font-size:11px;font-weight:800;flex-shrink:0}
.hero-action-title{font-size:14px;font-weight:700;color:var(--text1);letter-spacing:-.01em}
.hero-action-meta{font-size:12px;line-height:1.55;color:var(--text2);margin-top:5px}
.hero-side{padding:22px;display:flex;flex-direction:column;justify-content:space-between;min-height:200px}
.hero-side::before{content:'';position:absolute;bottom:-30px;left:-30px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(157,13,8,.05),transparent 70%);pointer-events:none}
.hero-title{font-family:var(--serif);font-size:40px;line-height:.95;letter-spacing:-.04em;
  color:var(--text1);max-width:10ch}
.hero-copy{margin-top:12px;font-size:14px;line-height:1.6;color:var(--text2);max-width:44ch}
.hero-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.hero-pill{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:999px;
  background:var(--bg2);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text2)}
.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--brand-pale3)}
.hero-side-label{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text3)}
.hero-side-num{font-family:var(--serif);font-size:68px;line-height:.9;letter-spacing:-.06em;
  color:var(--text1);margin-top:8px}
.hero-side-copy{font-size:13px;line-height:1.55;color:var(--text2);max-width:22ch}
.hero-list{display:flex;flex-direction:column;gap:7px;margin-top:12px}
.hero-person{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);
  background:var(--bg2);border:1px solid var(--border)}
.hero-rank{width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:var(--brand-pale2);color:var(--brand);font-size:10px;font-weight:800;flex-shrink:0}
.hero-person-name{font-size:13px;font-weight:700;color:var(--text1);line-height:1.2}
.hero-person-meta{font-size:11px;color:var(--text3);margin-top:1px}
.hero-shortcuts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;margin-top:14px}
.hero-shortcut{padding:15px;border-radius:var(--r-lg);border:1px solid var(--border);
  background:var(--bg2);cursor:pointer;transition:all .15s}
.hero-shortcut:hover{border-color:var(--accent-border);background:var(--brand-pale);transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(157,13,8,.08)}
.hero-shortcut-title{font-size:13px;font-weight:700;color:var(--text1);margin-bottom:4px}
.hero-shortcut-copy{font-size:12px;line-height:1.5;color:var(--text2)}

/* ── STAT CARDS ─────────────────────────────────────────────── */
.dg{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:22px}
.dc{background:var(--surface);border-radius:var(--r-lg);padding:20px 18px;
  border:1px solid var(--border);position:relative;overflow:hidden}
.dc::after{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;
  background:radial-gradient(circle,rgba(157,13,8,.04),transparent 70%);pointer-events:none}
.dn{font-family:var(--serif);font-size:38px;font-weight:900;color:var(--text1);
  letter-spacing:-.04em;line-height:1}
.dl{font-size:11px;font-weight:600;color:var(--text3);margin-top:3px;text-transform:uppercase;letter-spacing:.1em}

/* ── LIST / PEOPLE ──────────────────────────────────────────── */
.list-shell{max-width:720px;margin:0 auto}
.list-copy{font-size:13px;line-height:1.65;color:var(--text2);margin-bottom:20px;max-width:56ch}
.ri{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-lg);
  border:1px solid var(--border);background:var(--surface);cursor:pointer;
  transition:all .15s;margin-bottom:7px}
.ri:hover{border-color:var(--accent-border);background:var(--brand-pale);transform:translateX(2px)}
.ria{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;flex-shrink:0;color:#fff}
.riap{background:linear-gradient(135deg,var(--brand),var(--brand-mid))}
.riac{background:linear-gradient(135deg,#1e6b55,#134a3c)}
.rin{font-size:13px;font-weight:700;color:var(--text1);letter-spacing:-.01em}
.ris{font-size:11px;color:var(--text3);margin-top:2px}
.rim{font-size:11px;color:var(--text3);margin-left:auto;flex-shrink:0;white-space:nowrap}

/* ── SEARCH ─────────────────────────────────────────────────── */
.search-bar{display:flex;gap:9px;margin-bottom:16px}
.search-input{flex:1;padding:10px 14px;font-size:13px;border:1px solid var(--border);
  border-radius:var(--r-md);background:var(--surface);color:var(--text1);outline:none;
  font-family:var(--sans);transition:border-color .15s}
.search-input::placeholder{color:var(--text3)}
.search-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px rgba(157,13,8,.07)}
.page-search-wrap{position:relative;margin-bottom:18px}
.page-search-wrap::before{content:'';position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;opacity:.45;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%239d0d08' stroke-width='1.6' stroke-linecap='round'%3E%3Ccircle cx='6.5' cy='6.5' r='4'/%3E%3Cline x1='9.8' y1='9.8' x2='13' y2='13'/%3E%3C/svg%3E") center/contain no-repeat}
.page-search{width:100%;padding:12px 14px 12px 40px;font-size:14px;
  border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);color:var(--text1);outline:none;
  font-family:var(--sans);transition:all .15s;
  box-shadow:0 1px 4px rgba(157,13,8,.03)}
.page-search::placeholder{color:var(--text3)}
.page-search:focus{border-color:var(--accent-border);
  box-shadow:0 0 0 3px rgba(157,13,8,.07),0 1px 4px rgba(157,13,8,.04)}

/* ── PERSON / COMPANY DETAIL ────────────────────────────────── */
.eh{display:flex;align-items:center;gap:15px;margin-bottom:18px;padding-bottom:18px;
  border-bottom:1px solid var(--border)}
.eav{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:16px;font-weight:800;flex-shrink:0;color:#fff}
.eav.avp{background:linear-gradient(135deg,var(--brand),var(--brand-mid))}
.eav.avc{background:linear-gradient(135deg,#1e6b55,#134a3c);border-radius:12px!important}
.et{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--text1);
  letter-spacing:-.02em;line-height:1.1}
.es{font-size:12px;color:var(--text3);margin-top:3px}
.pr{display:flex;align-items:flex-start;gap:14px;margin-bottom:13px;padding-bottom:13px;
  border-bottom:1px solid var(--border3)}
.pl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--text3);min-width:88px;padding-top:4px}
.pv{display:flex;flex-wrap:wrap;gap:6px;flex:1}
.tag{display:inline-flex;align-items:center;padding:4px 11px;border-radius:999px;
  font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;border:1px solid transparent}
.tagp{background:var(--brand-pale2);color:var(--brand);border-color:var(--accent-border)}
.tagp:hover{background:var(--brand-pale3)}
.tagc{background:rgba(30,107,85,.1);color:#1e6b55;border-color:rgba(30,107,85,.18)}
.tagc:hover{background:rgba(30,107,85,.17)}
.empty{font-size:12px;color:var(--text3);font-style:italic}
.bls{margin-bottom:16px}
.blt{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--text3);margin-bottom:9px}
.bli{display:flex;align-items:center;gap:8px;padding:8px 11px;border-radius:var(--r-sm);
  background:var(--bg2);cursor:pointer;font-size:13px;color:var(--text2);
  margin-bottom:4px;transition:all .12s;border:1px solid var(--border2)}
.bli:hover{color:var(--brand);border-color:var(--accent-border);background:var(--brand-pale)}
.conn-grid{display:flex;flex-wrap:wrap;gap:7px;margin-top:8px}
.conn-chip{padding:7px 12px;border-radius:var(--r-md);border:1px solid var(--border);
  background:var(--surface);cursor:pointer;transition:all .12s;min-width:0}
.conn-chip:hover{border-color:var(--accent-border);background:var(--brand-pale)}
.conn-chip-name{font-size:13px;font-weight:600;color:var(--text1);line-height:1.2}
.conn-chip-role{font-size:11px;color:var(--text3);margin-top:1px}
.detail-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.detail-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}
.ntbox{width:100%;min-height:120px;resize:vertical;border:1px solid var(--border);
  border-radius:var(--r-sm);background:var(--bg2);color:var(--text1);
  font-size:13px;line-height:1.65;padding:11px;font-family:var(--sans);outline:none;
  transition:border-color .15s;margin-top:9px}
.ntbox:focus{border-color:var(--accent-border)}
.detail-ai{margin-top:9px}
.detail-ai-item{padding:11px 13px;border-radius:var(--r-md);border:1px solid var(--border);
  background:var(--bg2);margin-bottom:7px}
.detail-ai-title{font-size:13px;font-weight:700;color:var(--text1);margin-bottom:3px}
.detail-ai-copy{font-size:12px;line-height:1.6;color:var(--text2)}
.detail-ai-empty{font-size:12px;color:var(--text3);line-height:1.65;font-style:italic}
.heat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-md);padding:13px 15px}
.heat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.heat-title{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.08em}
.heat-value{font-size:11px;font-weight:600;color:var(--text1)}
.heat-scale{display:flex;gap:6px}
.heat-dot{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.4);cursor:pointer;
  transition:all .15s;opacity:.35;position:relative}
.heat-dot:not(.off){opacity:1;transform:scale(1.06)}
.heat-dot:hover{opacity:1;transform:scale(1.1)}
.heat-legend{font-size:11px;color:var(--text3);margin-top:7px;line-height:1.5}
.heat-field{padding:13px 15px;background:var(--bg2);border-radius:var(--r-md);border:1px solid var(--border)}
.heat-inline .heat-card{background:transparent;border:none;padding:0}
.heat-inline-compact{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.hic-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3)}
.hic-scale{display:flex;gap:5px}
.hic-value{font-size:12px;font-weight:600;color:var(--text2)}

/* ── CHAT / INSIGHTS ────────────────────────────────────────── */
.chat-shell{max-width:700px}
.chat-thread{display:flex;flex-direction:column;gap:13px;margin:20px 0;min-height:60px}
.chat-message{max-width:90%}
.chat-message.user{align-self:flex-end}
.chat-message.assistant{align-self:flex-start;max-width:100%}
.chat-role{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--text3);margin-bottom:5px}
.chat-message.user .chat-role{text-align:right;color:var(--brand)}
.chat-text{font-size:13px;line-height:1.7;color:var(--text2);padding:13px 15px;
  border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface)}
.chat-message.user .chat-text{
  background:linear-gradient(135deg,var(--brand-pale2),var(--brand-pale));
  border-color:var(--accent-border);color:var(--text1);
  border-radius:var(--r-lg) var(--r-lg) 6px var(--r-lg)}
.chat-message.assistant .chat-text{border-radius:6px var(--r-lg) var(--r-lg) var(--r-lg)}
.chat-empty{font-size:13px;color:var(--text3);padding:16px;
  border:1px dashed var(--border);border-radius:var(--r-lg);line-height:1.7;font-style:italic}
.chat-composer{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:4px;
  align-items:end;padding:14px 16px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);position:sticky;bottom:0;
  box-shadow:0 -2px 16px rgba(157,13,8,.04)}
.insight-input{border:none;background:transparent;color:var(--text1);font-size:13px;
  line-height:1.6;font-family:var(--sans);outline:none;resize:none;min-height:48px;padding:4px 0}
.insight-input::placeholder{color:var(--text3)}
.insight-run{padding:10px 20px;border-radius:var(--r-md);border:none;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-mid) 100%);
  color:#fff;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;
  transition:all .15s;font-family:var(--sans);
  box-shadow:0 3px 14px rgba(157,13,8,.28);align-self:flex-end}
.insight-run:hover:not(:disabled){box-shadow:0 5px 22px rgba(157,13,8,.4);transform:translateY(-1px)}
.insight-run:disabled{opacity:.5;cursor:not-allowed}
.insight-tags{display:flex;flex-wrap:wrap;gap:5px;margin:7px 0 10px}
.insight-tag{font-size:10px;font-weight:700;padding:3px 9px;border-radius:999px;
  background:var(--brand-pale2);color:var(--brand);border:1px solid var(--accent-border)}
.insight-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:10px}
.insight-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px}
.insight-kicker{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--text3);margin-bottom:9px}
.insight-item{padding:9px 11px;border-radius:var(--r-sm);background:var(--surface);
  border:1px solid var(--border);cursor:pointer;transition:all .12s;margin-bottom:5px}
.insight-item:last-child{margin-bottom:0}
.insight-item:hover{border-color:var(--accent-border);background:var(--brand-pale)}
.insight-name{font-size:13px;font-weight:700;color:var(--text1);margin-bottom:2px}
.insight-meta{font-size:11px;color:var(--text3);margin-bottom:3px}
.insight-reason{font-size:11px;color:var(--text2);line-height:1.5}
.insight-empty{font-size:12px;color:var(--text3);font-style:italic;padding:4px 0}
.insight-list{display:flex;flex-direction:column}
/* Insight compact rows */
.ir-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.ir{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:10px 13px;border-radius:var(--r-md);background:var(--surface);
  border:1px solid var(--border);cursor:pointer;transition:all .12s}
.ir:hover{border-color:var(--accent-border);background:var(--brand-pale)}
.ir-left{min-width:0;flex:1}
.ir-name{font-size:13px;font-weight:700;color:var(--text1);letter-spacing:-.01em}
.ir-sub{font-size:11px;color:var(--brand);margin-top:1px;font-weight:500}
.ir-reason{font-size:11px;color:var(--text3);line-height:1.45;text-align:right;
  max-width:220px;flex-shrink:0}
/* Chat full-page layout — composer fixo no fundo, thread cresce */
.chat-fullpage{display:flex;flex-direction:column;height:100%;max-width:720px;
  position:absolute;inset:0;padding:0}
.chat-header{padding:24px 28px 0;flex-shrink:0}
.chat-thread{flex:1;overflow-y:auto;padding:16px 28px;display:flex;flex-direction:column;
  gap:13px;scrollbar-width:thin;scrollbar-color:var(--bg4) transparent}
.chat-thread::-webkit-scrollbar{width:4px}
.chat-thread::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
.chat-composer{flex-shrink:0;padding:12px 28px 20px;
  background:linear-gradient(to bottom,transparent,var(--bg) 30%)}

/* ── ACTIONS PAGE ───────────────────────────────────────────── */
.stack-list{display:flex;flex-direction:column;gap:8px}
/* Dashboard */
.db-row{display:flex;gap:14px;align-items:flex-start}
.db-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:18px 20px}
.db-kicker{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--text3);margin-bottom:12px}
.db-force-ring{display:flex;justify-content:center;margin:8px 0 4px}
.db-card-force{text-align:center}
.db-stat-row{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.db-stat{flex:1;padding:12px 8px;text-align:center;border-right:1px solid var(--border)}
.db-stat:last-child{border-right:none}
.db-num{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--text1);line-height:1;letter-spacing:-.03em}
.db-lbl{font-size:10px;color:var(--text3);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.db-funnel{display:flex;align-items:flex-end;gap:12px;min-height:80px;padding-bottom:4px}
.db-funnel-stage{display:flex;flex-direction:column;align-items:center;flex:1;gap:4px}
.db-funnel-bar-wrap{display:flex;align-items:flex-end;height:80px;width:100%;justify-content:center}
.db-funnel-bar{width:100%;border-radius:4px 4px 0 0;min-height:6px;transition:height .4s}
.db-funnel-count{font-size:15px;font-weight:700;color:var(--text1);font-family:var(--serif)}
.db-funnel-label{font-size:10px;color:var(--text3);text-align:center;line-height:1.3;font-weight:600}
.db-funnel-pct{font-size:10px;color:var(--text4)}
.db-funnel-conv{font-size:10px;color:var(--brand);font-weight:700}
.db-hub{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);
  cursor:pointer;transition:all .12s;margin-bottom:4px;border:1px solid transparent}
.db-hub:hover{background:var(--brand-pale);border-color:var(--accent-border)}
.db-hub-rank{width:22px;height:22px;border-radius:50%;background:var(--brand-pale2);
  color:var(--brand);font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.db-cluster{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border2)}
.db-cluster:last-of-type{border-bottom:none}
.db-cluster-size{width:26px;height:26px;border-radius:50%;background:var(--bg4);
  color:var(--text2);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.db-seg{margin-bottom:10px}
.db-seg:last-child{margin-bottom:0}
.db-desc{font-size:11px;color:var(--text3);line-height:1.45;margin-bottom:12px;margin-top:-6px}
@media(max-width:900px){
  .db-row{flex-direction:column}
  .db-stat-row{flex-wrap:wrap}
  .db-funnel{gap:6px}
  .db-funnel-label{font-size:9px}
}
.af-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px 16px;margin-bottom:16px}
.af-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text3);margin-bottom:10px}
.af-field{display:flex;flex-wrap:wrap;gap:6px;align-items:center;
  min-height:36px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--r-md);
  background:var(--bg2);cursor:text}
.af-field:focus-within{border-color:var(--accent-border);background:var(--surface)}
.af-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 10px;
  border-radius:999px;background:var(--brand-pale2);border:1px solid var(--accent-border);
  font-size:12px;font-weight:600;color:var(--brand)}
.af-chip button{border:none;background:none;cursor:pointer;color:var(--brand);
  font-size:14px;line-height:1;padding:0;opacity:.7}
.af-chip button:hover{opacity:1}
.af-input{border:none;background:transparent;outline:none;font-size:13px;
  color:var(--text1);font-family:var(--sans);flex:1;min-width:120px;padding:2px}
.af-input::placeholder{color:var(--text3)}
.af-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.af-suggestion{padding:5px 12px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface);font-size:12px;font-weight:500;color:var(--text2);
  cursor:pointer;font-family:var(--sans);transition:all .12s}
.af-suggestion:hover{border-color:var(--accent-border);color:var(--brand);background:var(--brand-pale)}
.af-clear{font-size:11px;color:var(--text3);cursor:pointer;margin-top:8px;
  text-decoration:underline;display:inline-block}
.af-clear:hover{color:var(--brand)}
.stack-item{padding:15px 17px;border-radius:var(--r-lg);border:1px solid var(--border);
  background:var(--surface);transition:all .15s}
.stack-item.clickable{cursor:pointer}
.stack-item.clickable:hover{border-color:var(--accent-border);background:var(--brand-pale);transform:translateX(2px)}
.stack-title{font-size:13px;font-weight:700;color:var(--text1);margin-bottom:4px;letter-spacing:-.01em}
.stack-copy{font-size:12px;line-height:1.6;color:var(--text2)}

/* ── PROFILE PAGE ───────────────────────────────────────────── */
.profile-shell{max-width:700px;display:flex;flex-direction:column;gap:14px}
.profile-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:26px}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* ── FORMS ──────────────────────────────────────────────────── */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.fl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text3)}
.fi{padding:10px 13px;font-size:13px;border:1px solid var(--border);border-radius:var(--r-md);
  background:var(--bg2);color:var(--text1);outline:none;font-family:var(--sans);transition:all .15s}
.fi::placeholder{color:var(--text3)}
.fi:focus{border-color:var(--accent-border);background:var(--surface);
  box-shadow:0 0 0 3px rgba(157,13,8,.07)}
.fh{font-size:11px;color:var(--text3);line-height:1.5;margin-top:2px}
.fsub{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px}
.fw{padding:22px;border-radius:var(--r-xl);background:var(--surface);
  border:1px solid var(--border);max-width:620px}
.fw h2{font-family:var(--serif);font-size:21px;font-weight:700;color:var(--text1);
  margin-bottom:4px;letter-spacing:-.02em}
.ar{display:flex;gap:9px;margin-top:18px;flex-wrap:wrap}

/* ── BUTTONS (general) ──────────────────────────────────────── */
.btn{padding:9px 16px;border-radius:var(--r-md);border:1px solid var(--border);
  background:var(--bg2);color:var(--text2);font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;font-family:var(--sans);white-space:nowrap}
.btn:hover{color:var(--brand);border-color:var(--accent-border);background:var(--brand-pale)}
.btnd{background:rgba(217,79,79,.07)!important;color:#c44!important;border-color:rgba(217,79,79,.18)!important}
.btnd:hover{background:rgba(217,79,79,.13)!important}

/* ── PICKER ─────────────────────────────────────────────────── */
.pick{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg2);overflow:hidden}
.pick-sel{padding:9px 12px;min-height:38px;display:flex;flex-wrap:wrap;gap:5px;
  border-bottom:1px solid var(--border2)}
.pick-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;
  background:var(--brand-pale2);color:var(--brand);font-size:11px;font-weight:700;
  border:1px solid var(--accent-border)}
.pick-chip button{border:0;background:transparent;cursor:pointer;color:inherit;font-size:13px;line-height:1;opacity:.7}
.pick-search{display:flex;gap:8px;padding:9px 12px;border-bottom:1px solid var(--border2)}
.pick-list{padding:7px 10px;display:flex;flex-direction:column;gap:3px;max-height:150px;overflow-y:auto}
.pick-item{padding:7px 9px;border-radius:var(--r-sm);border:1px solid transparent;
  background:transparent;color:var(--text2);font-size:12px;font-family:var(--sans);
  text-align:left;cursor:pointer;transition:all .12s}
.pick-item:hover{border-color:var(--border);background:var(--surface);color:var(--brand)}
.pick-create{background:rgba(76,175,125,.07);border-color:rgba(76,175,125,.15)!important;color:#1e6b55!important}
.pick-empty{font-size:11px;color:var(--text3);padding:2px}

/* ── MODAL ──────────────────────────────────────────────────── */
.mbg{position:absolute;inset:0;background:rgba(30,18,16,.4);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}
.md{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:26px;max-width:380px;width:100%;
  box-shadow:0 24px 64px rgba(157,13,8,.1)}
.md h3{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--text1);margin-bottom:9px}
.md p{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:18px}
.mdb{display:flex;gap:9px;justify-content:flex-end}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);
  background:var(--text1);color:#fff;
  padding:11px 20px;border-radius:999px;font-size:12px;font-weight:700;
  opacity:0;transition:opacity .3s;pointer-events:none;z-index:9999;
  box-shadow:0 8px 28px rgba(30,18,16,.25);white-space:nowrap}

/* ── SESSION / AUTH ─────────────────────────────────────────── */
.head-actions{display:flex;gap:8px;flex-wrap:wrap}
.session{display:flex;flex-direction:column;gap:8px}
.session-pill{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--r-md);
  background:var(--bg2);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text2)}
.session-avatar{width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-pale2),var(--brand-pale3));
  display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:var(--brand);overflow:hidden}
.session-avatar img{width:100%;height:100%;object-fit:cover}
.session-btn{padding:9px 14px;border-radius:var(--r-md);border:1px solid var(--border);
  background:var(--bg2);color:var(--text2);font-size:12px;font-weight:700;
  cursor:pointer;transition:all .15s;font-family:var(--sans)}
.session-btn:hover{color:var(--brand);border-color:var(--accent-border);background:var(--brand-pale)}
.session-actions{display:flex;gap:8px}
.session-actions .session-btn{flex:1}
.session-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.authgate{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(250,247,245,.85);backdrop-filter:blur(18px)}
.authgate.hidden,.hidden{display:none!important}
.authcard{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  width:min(360px,100%);padding:36px 28px;border-radius:var(--r-xl);
  background:var(--surface);border:1px solid var(--border);
  box-shadow:0 32px 72px rgba(157,13,8,.1)}
.authlogo{width:76px;height:76px;display:block;border-radius:14px;object-fit:contain;
  box-shadow:0 12px 32px rgba(157,13,8,.2)}
.authcard .session-btn{width:100%;justify-content:center;display:inline-flex;padding:13px 18px;font-size:13px}
.authform{width:100%;display:flex;flex-direction:column;gap:11px}
.authinput{width:100%;padding:12px 14px;font-size:13px;border:1px solid var(--border);
  border-radius:var(--r-md);background:var(--bg2);color:var(--text1);outline:none;
  font-family:var(--sans);transition:all .15s}
.authinput::placeholder{color:var(--text3)}
.authinput:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px rgba(157,13,8,.07)}
.authcheck{display:flex;align-items:center;gap:9px;width:100%;font-size:13px;color:var(--text2)}
.authcheck input{width:14px;height:14px;accent-color:var(--brand)}
.sb-backdrop{display:none}

/* ── MOBILE ─────────────────────────────────────────────────── */
@media (max-width: 900px){
  #app{height:auto;min-height:100vh;flex-direction:column}
  #sb{position:fixed;top:max(env(safe-area-inset-top,0),0px);left:0;bottom:0;
    width:min(82vw,280px);min-width:0;z-index:1200;
    transform:translateX(-104%);transition:transform .24s ease;
    box-shadow:0 0 60px rgba(157,13,8,.12)}
  #app.mobile-nav-open #sb{transform:translateX(0)}
  #mn{min-width:0;width:100%;display:flex;flex-direction:column;flex:1}
  .sb-backdrop{display:block;position:fixed;inset:0;background:rgba(30,18,16,.35);
    backdrop-filter:blur(3px);z-index:1100;opacity:0;pointer-events:none;transition:opacity .2s}
  #app.mobile-nav-open .sb-backdrop{opacity:1;pointer-events:auto}
  #tbar{padding:0 16px;height:54px}
  .mobile-nav-btn{display:inline-flex}
  .graph-filter{order:3;width:100%;max-width:none}
  .view{padding:16px}
  #vinsights.on{padding:0}
  .chat-header{padding:16px 16px 0}
  .chat-thread{padding:12px 16px}
  .chat-composer{padding:10px 16px 16px}
  .ir-reason{display:none}
  .hero{grid-template-columns:1fr}
  .hero-shortcuts{grid-template-columns:1fr}
  .dg{grid-template-columns:1fr}
  .insight-grid{grid-template-columns:1fr}
  .chat-composer{grid-template-columns:1fr}
  .chat-message{max-width:100%}
  .profile-grid{grid-template-columns:1fr}
  .detail-split{grid-template-columns:1fr}
  .pr{flex-direction:column}
  .pl{min-width:0;padding-top:0}
  .eh{align-items:flex-start;flex-wrap:wrap}
  .head-actions{width:100%}
  .head-actions .btn{flex:1}
  #ct{flex:1;height:0;min-height:0;overflow:auto}
  #gv.on{height:calc(100vh - 54px);min-height:300px}
  #gc{height:100%;min-height:0}
  #vinsights.on{overflow:auto}
  #gv{height:100%}
  .view{height:auto;min-height:100%}
}
@media (max-width: 640px){
  .hbtn{flex:1}
  .sba{flex-direction:row}
  .view{padding:13px}
  .et{font-size:21px}
  .eav{width:46px;height:46px;font-size:14px}
  .fw{padding:15px}
  .st{font-size:21px}
}

/* ── AI ELEMENTS ─────────────────────────────────────────────── */
.ai-text{line-height:1.7}
.ai-loading{display:flex;gap:6px;align-items:center;padding:4px 0}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--brand);opacity:.35;animation:ai-bounce 1.2s infinite}
.ai-dot:nth-child(2){animation-delay:.2s}
.ai-dot:nth-child(3){animation-delay:.4s}
@keyframes ai-bounce{0%,80%,100%{transform:translateY(0);opacity:.35}40%{transform:translateY(-5px);opacity:1}}
.ai-panel{border-radius:var(--r-xl);border:1px solid var(--accent-border);background:linear-gradient(135deg,var(--brand-pale2),var(--brand-pale));padding:20px 22px;margin-bottom:16px}
.ai-panel-header{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--text1);margin-bottom:10px;font-family:var(--sans)}
.ai-badge{background:var(--brand);color:#fff;font-size:10px;font-weight:800;padding:3px 9px;border-radius:999px;letter-spacing:.06em}
.ai-panel-body{font-size:13px;line-height:1.75;color:var(--text2)}
.ai-panel-desc{font-size:13px;color:var(--text2);margin-bottom:13px;line-height:1.6}
.ai-gen-btn{background:linear-gradient(135deg,var(--brand),var(--brand-mid))!important;color:#fff!important;border:none!important;padding:10px 18px!important;font-size:13px!important;box-shadow:0 3px 14px rgba(157,13,8,.25)!important}
.ai-gen-btn:hover{box-shadow:0 5px 20px rgba(157,13,8,.38)!important;transform:translateY(-1px)}
.ai-regen-btn{font-size:11px;color:var(--brand);background:transparent;border:1px solid var(--accent-border);border-radius:999px;padding:5px 13px;cursor:pointer;margin-top:8px;font-family:var(--sans);transition:all .15s}
.ai-regen-btn:hover{background:var(--brand-pale2)}
.ai-loading-bar{height:3px;background:var(--brand-pale3);border-radius:2px;overflow:hidden;margin-top:4px}
.ai-loading-bar-fill{height:100%;width:35%;background:var(--brand);border-radius:2px;animation:ai-slide 1.4s infinite}
@keyframes ai-slide{0%{transform:translateX(-100%)}100%{transform:translateX(380%)}}
.ai-profile-result{font-size:13px;line-height:1.75;color:var(--text2)}
.ai-inline-loading{display:flex;gap:5px;align-items:center;font-size:12px;color:var(--text3);padding:8px 0}
