:root {
  --bg:#06040F; --surface:#0D0818; --surface2:#130D20; --surface3:#181228;
  --border:#231A35; --border2:#2E2245;
  --accent:#00D4E8; --accent-dim:rgba(0,212,232,0.12);
  --blue:#7C3AED; --blue-dim:rgba(124,58,237,0.12);
  --purple:#C026D3; --purple-dim:rgba(192,38,211,0.12);
  --orange:#FF7A45; --orange-dim:rgba(255,122,69,0.12);
  --green:#00E676; --green-dim:rgba(0,230,118,0.12);
  --red:#FF3D5A; --red-dim:rgba(255,61,90,0.12);
  --yellow:#FFD166; --yellow-dim:rgba(255,209,102,0.1);
  --text:#F0ECFF; --text2:#C4B8E8; --text3:#8B7DB5;
}
*{margin:0;padding:0;box-sizing:border-box;}

/* TOOLTIPS */
.tooltip-wrap{position:relative;display:inline-flex;align-items:center;}
.tooltip-wrap .tooltip-box{
  position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:#1A1130;border:1px solid rgba(124,58,237,0.3);color:#E8E0F5;
  font-size:11px;line-height:1.5;padding:8px 12px;border-radius:8px;
  white-space:nowrap;max-width:240px;white-space:normal;width:200px;
  opacity:0;pointer-events:none;transition:opacity 0.2s;z-index:9999;
  box-shadow:0 8px 24px rgba(0,0,0,0.4);
}
.tooltip-wrap .tooltip-box::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#1A1130;
}
.tooltip-wrap:hover .tooltip-box{opacity:1;}
.tt-icon{width:14px;height:14px;border-radius:50%;background:rgba(124,58,237,0.2);
  color:#7C3AED;font-size:9px;display:inline-flex;align-items:center;justify-content:center;
  cursor:help;margin-left:5px;flex-shrink:0;font-weight:700;}

body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 100% 50% at 0% 0%,rgba(0,212,232,0.04),transparent 50%),radial-gradient(ellipse 80% 60% at 100% 100%,rgba(192,38,211,0.05),transparent 50%);pointer-events:none;z-index:0;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-track{background:var(--bg);}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* LAYOUT */
.app{display:flex;min-height:100vh;position:relative;z-index:1;}

/* SIDEBAR */
.sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;position:fixed;top:0;left:0;bottom:0;background:var(--surface);z-index:100;}
.logo{display:flex;align-items:center;gap:10px;padding:0 20px 24px;border-bottom:1px solid var(--border);margin-bottom:16px;}
.logo-mark{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),var(--blue));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.logo-text{font-family:'Syne',sans-serif;font-weight:800;font-size:15px;letter-spacing:-0.3px;line-height:1.2;}
.logo-text span{color:var(--accent);display:block;font-size:10px;font-weight:400;letter-spacing:1px;text-transform:uppercase;color:var(--text2);}
.nav-section{padding:0 12px;margin-bottom:8px;flex:1;overflow-y:auto;min-height:0;}
.nav-section::-webkit-scrollbar{width:3px;}.nav-section::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);padding:0 8px;margin-bottom:6px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;font-size:14px;color:var(--text2);cursor:pointer;transition:all 0.15s;margin-bottom:2px;border:1px solid transparent;position:relative;text-decoration:none;}
.nav-item:hover{color:var(--text);background:var(--surface2);}
.nav-item.active{color:var(--accent);background:var(--accent-dim);border-color:rgba(0,212,232,0.15);}
.nav-item.locked{opacity:0.4;cursor:not-allowed;}
.nav-item.locked:hover{color:var(--text2);background:transparent;}
.nav-item.locked .nav-lock{margin-left:auto;font-size:11px;opacity:0.7;}
.nav-icon{font-size:15px;width:18px;text-align:center;}
.crisis-badge{margin-left:auto;background:var(--red);color:white;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.sidebar-bottom{margin-top:auto;padding:16px 20px;border-top:1px solid var(--border);}
.api-label{font-size:12px;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);margin-bottom:5px;}
.api-input{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;padding:8px 10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:11px;outline:none;transition:border-color 0.2s;margin-bottom:10px;}
.api-input:focus{border-color:var(--accent);}
.api-input::placeholder{color:var(--text3);}

/* CONTENT */
.content{margin-left:220px;flex:1;min-width:0;height:100vh;overflow-y:auto;}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--border);background:rgba(5,8,13,0.8);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50;}
.dest-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;}
.dest-badge{font-size:11px;padding:3px 10px;border-radius:100px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(0,212,232,0.2);margin-left:10px;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.btn{padding:8px 16px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13px;cursor:pointer;transition:all 0.2s;border:none;display:flex;align-items:center;gap:6px;}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--text2);}
.btn-ghost:hover{color:var(--text);border-color:var(--accent);}
.btn-accent{background:var(--accent);color:var(--bg);font-weight:600;}
.btn-accent:hover{background:#00FFB0;transform:translateY(-1px);}
.btn-danger{background:var(--red-dim);border:1px solid rgba(255,61,90,0.3);color:var(--red);}

/* PAGES */
.page{display:none;}.page.active{display:block;position:relative;z-index:10;width:100%;}
body.loading-screen .sidebar{display:none;}
body.loading-screen .topbar{display:none;}
body.loading-screen .content{margin-left:0;}

/* ===== INPUT PAGE ===== */
.input-page{min-height:calc(100vh - 61px);display:flex;align-items:center;justify-content:center;padding:40px 28px;}
.input-wrap{width:100%;max-width:680px;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;border:1px solid rgba(0,212,232,0.25);background:var(--accent-dim);color:var(--accent);font-size:13px;font-weight:500;letter-spacing:0.8px;text-transform:uppercase;margin-bottom:20px;}
.pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.4;transform:scale(1.4);}}
.hero-title{font-family:'Syne',sans-serif;font-size:42px;font-weight:800;line-height:1.05;letter-spacing:-1.5px;margin-bottom:14px;}
.hero-title .grad{background:linear-gradient(135deg,var(--accent) 0%,var(--blue) 50%,var(--purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-sub{color:var(--text2);font-size:15px;line-height:1.65;margin-bottom:36px;}
.form-block{display:flex;flex-direction:column;gap:16px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field-label{font-size:12px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:0.9px;}
.field-input{background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:13px 16px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:all 0.2s;width:100%;}
.field-input:focus{border-color:var(--accent);background:var(--surface2);box-shadow:0 0 0 3px rgba(0,240,160,0.08);}
.field-input::placeholder{color:var(--text3);}
select.field-input option{background:var(--surface2);}
.conc-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}

/* SECTOR SELECTOR */
.sector-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;}
.sector-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 8px;border-radius:10px;background:var(--surface);border:2px solid var(--border);cursor:pointer;transition:all 0.2s;text-align:center;}
.sector-card:hover{border-color:var(--border2);background:var(--surface2);}
.sector-card.selected{border-color:var(--accent);background:var(--accent-dim);}
.sector-emoji{font-size:22px;}
.sector-label{font-size:11px;color:var(--text2);line-height:1.3;}
.sector-card.selected .sector-label{color:var(--accent);}

/* LANG SELECTOR */
.lang-grid{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.lang-btn{display:flex;align-items:center;gap:6px;padding:9px 14px;border-radius:8px;background:var(--surface);border:2px solid var(--border);cursor:pointer;transition:all 0.2s;font-size:13px;color:var(--text2);}
.lang-btn:hover{border-color:var(--border2);}
.lang-btn.selected{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);}
.lang-flag{font-size:28px;line-height:1;}

.btn-go{width:100%;padding:15px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--accent),var(--blue));color:var(--bg);font-family:'Syne',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;}
.btn-go:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,212,232,0.25);}
.btn-go:disabled{opacity:0.5;cursor:not-allowed;transform:none;}

/* LOADING */
.loading-page{min-height:calc(100vh - 61px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;}
.loading-ring{width:72px;height:72px;border-radius:50%;border:2px solid var(--border2);border-top-color:var(--accent);animation:spin 0.9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-title{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;}
.loading-title span{color:var(--accent);}
.steps-list{display:flex;flex-direction:column;gap:10px;min-width:300px;}
.step-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;background:var(--surface);border:1px solid var(--border);font-size:13px;color:var(--text3);transition:all 0.3s;}
.step-item.active{color:var(--text);border-color:var(--accent);background:var(--accent-dim);}
.step-item.done{color:var(--accent);border-color:rgba(0,212,232,0.2);}

/* DASHBOARD */
.dash-content{padding:24px 28px;}
.crisis-banner{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-radius:12px;background:var(--red-dim);border:1px solid rgba(255,61,90,0.3);margin-bottom:24px;animation:fadeIn 0.4s ease;}
.crisis-banner.hidden{display:none;}
@keyframes fadeIn{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}
.crisis-content h4{font-size:14px;font-weight:600;color:var(--red);margin-bottom:4px;}
.crisis-content p{font-size:13px;color:var(--text2);line-height:1.5;}

/* KPI */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;position:relative;overflow:hidden;}
.kpi-card::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;border-radius:0 14px 0 60px;opacity:0.06;}
.kpi-card.green::before{background:var(--accent);}
.kpi-card.blue::before{background:var(--blue);}
.kpi-card.orange::before{background:var(--orange);}
.kpi-card.red::before{background:var(--red);}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.kpi-icon{font-size:20px;}
.kpi-tag{font-size:11px;padding:3px 8px;border-radius:100px;font-weight:500;}
.tag-green{background:var(--accent-dim);color:var(--accent);}
.tag-blue{background:var(--blue-dim);color:var(--blue);}
.tag-orange{background:var(--orange-dim);color:var(--orange);}
.tag-red{background:var(--red-dim);color:var(--red);}
.tag-muted{background:rgba(75,95,110,0.2);color:var(--text2);}
.kpi-val{font-family:'Syne',sans-serif;font-size:30px;font-weight:800;line-height:1;margin-bottom:5px;}
.kpi-label{font-size:12px;color:var(--text2);}

/* CARDS */
.section-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.section-title::before{content:'';width:3px;height:14px;border-radius:2px;background:var(--accent);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}
.grid-big-small{display:grid;grid-template-columns:1fr 340px;gap:14px;margin-bottom:20px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;}

/* TREND */
.trend-svg-wrap{height:150px;}
.trend-svg-wrap svg{width:100%;height:100%;}

/* DONUT */
.donut-section{display:flex;flex-direction:column;align-items:center;gap:16px;}
.donut-outer{position:relative;width:130px;height:130px;}
.donut-outer svg{width:130px;height:130px;}
.donut-center-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.donut-pct{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;color:var(--accent);}
.donut-sub{font-size:10px;color:var(--text2);}
.sent-legend{width:100%;display:flex;flex-direction:column;gap:9px;}
.sent-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;}
.sent-left{display:flex;align-items:center;gap:7px;}
.sent-dot{width:7px;height:7px;border-radius:50%;}
.sent-pct{font-weight:600;font-size:13px;}

/* COMPETITORS */
.comp-list{display:flex;flex-direction:column;gap:10px;}
.comp-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);transition:border-color 0.2s;}
.comp-row:hover{border-color:var(--border2);}
.comp-num{width:26px;height:26px;border-radius:6px;background:var(--border);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:11px;font-weight:700;flex-shrink:0;}
.comp-num.you{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(0,212,232,0.2);}
.comp-info{flex:1;min-width:0;}
.comp-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.comp-bar{height:3px;background:var(--border);border-radius:2px;margin-top:5px;}
.comp-bar-fill{height:100%;border-radius:2px;transition:width 1s ease;}
.comp-score-val{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;flex-shrink:0;}
.benchmark-narrative{margin-top:14px;padding:14px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--blue);font-size:13px;color:var(--text2);line-height:1.65;}
.benchmark-narrative strong{color:var(--text);}

/* OPPS */
.opp-list{display:flex;flex-direction:column;gap:10px;}
.opp-row{display:flex;gap:12px;padding:14px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--accent);}
.opp-row.med{border-left-color:var(--blue);}
.opp-row.low{border-left-color:var(--border2);}
.opp-ico{font-size:20px;flex-shrink:0;}
.opp-body h4{font-size:13px;font-weight:600;margin-bottom:3px;}
.opp-body p{font-size:12px;color:var(--text2);line-height:1.5;}

/* PROFILE */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.profile-item{padding:14px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);}
.profile-item-label{font-size:10px;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);margin-bottom:8px;}
.profile-item-val{font-size:14px;font-weight:500;}
.origin-bars{display:flex;flex-direction:column;gap:7px;}
.origin-row{display:flex;align-items:center;gap:8px;font-size:12px;}
.origin-name{width:120px;color:var(--text2);flex-shrink:0;}
.origin-bar{flex:1;height:4px;background:var(--border);border-radius:2px;}
.origin-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--blue));transition:width 1s ease;}
.origin-pct{width:35px;text-align:right;font-weight:500;color:var(--text2);font-size:11px;}
.interest-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px;}
.interest-tag{padding:5px 11px;border-radius:100px;background:var(--surface3);border:1px solid var(--border2);font-size:12px;color:var(--text2);}

/* CRISIS */
.crisis-indicators{display:flex;flex-direction:column;gap:10px;}
.crisis-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);}
.crisis-level{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.level-high{background:var(--red);box-shadow:0 0 6px var(--red);animation:blink 1.5s infinite;}
.level-med{background:var(--yellow);}
.level-low{background:var(--accent);}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.crisis-text{flex:1;}
.crisis-text h5{font-size:13px;font-weight:600;margin-bottom:2px;}
.crisis-text p{font-size:11px;color:var(--text2);}
.crisis-delta{font-size:12px;font-weight:700;padding:3px 8px;border-radius:6px;}
.delta-red{background:var(--red-dim);color:var(--red);}
.delta-yellow{background:var(--yellow-dim);color:var(--yellow);}
.delta-green{background:var(--accent-dim);color:var(--accent);}

/* THEMES */
.theme-cloud{display:flex;flex-wrap:wrap;gap:8px;}
.theme-pill{display:flex;align-items:center;gap:6px;padding:7px 13px;border-radius:100px;border:1px solid var(--border);background:var(--surface2);font-size:12px;transition:border-color 0.2s;}
.theme-pill:hover{border-color:var(--border2);}
.theme-dot{width:6px;height:6px;border-radius:50%;}
.theme-count{color:var(--text3);font-size:11px;}

/* INSIGHTS */
.insight-block{font-size:14px;line-height:1.85;color:#9DB8CB;white-space:pre-line;}
.insight-block strong{color:var(--accent);font-weight:600;}

/* REPORT */
.report-preview{background:white;border-radius:12px;padding:32px;color:#1a1a2e;font-family:'DM Sans',sans-serif;}
.report-header-bar{background:linear-gradient(135deg,#05080D,#0C1118);color:white;padding:20px 28px;border-radius:8px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;}
.report-logo-txt{font-family:'Syne',sans-serif;font-weight:800;font-size:18px;}
.report-logo-txt span{color:#00F0A0;}
.report-date{font-size:12px;color:rgba(255,255,255,0.5);}
.report-city{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:#1a1a2e;margin-bottom:4px;}
.report-period{font-size:13px;color:#6b7280;margin-bottom:20px;}
.report-score-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;}
.report-score-box{border:2px solid #e5e7eb;border-radius:10px;padding:16px;text-align:center;}
.report-score-val{font-family:'Syne',sans-serif;font-size:32px;font-weight:800;color:#1a1a2e;}
.report-score-lbl{font-size:12px;color:#6b7280;margin-top:4px;}
.report-section{margin-bottom:20px;}
.report-section-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:#374151;margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid #00F0A0;display:inline-block;}
.report-list{list-style:none;display:flex;flex-direction:column;gap:7px;}
.report-list li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#374151;line-height:1.5;}
.report-list li::before{content:'•';color:#00F0A0;font-weight:700;flex-shrink:0;}
.report-fire li::before{content:'🔥';}
.report-footer{border-top:1px solid #e5e7eb;padding-top:14px;display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#9ca3af;}

/* ONBOARDING — hide entire app shell */
body.onboarding .sidebar { display:none; }
body.onboarding .content { display:none; }
body.onboarding .topbar { display:none; }
body.onboarding .mobile-hamburger { display:none!important; }

/* ONBOARDING USER MENU */
.ob-user-menu{position:absolute;top:20px;right:24px;z-index:600;}
.ob-user-menu-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;backdrop-filter:blur(8px);}
.ob-user-menu-btn:hover{border-color:var(--accent);background:rgba(0,212,232,0.08);}
.ob-user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#7C3AED);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--bg);}
.ob-user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ob-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--surface);border:1px solid rgba(255,255,255,0.1);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.5);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:1000;}
.ob-user-menu.open .ob-user-dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.ob-user-dropdown-header{padding:16px;border-bottom:1px solid rgba(255,255,255,0.06);}
.ob-user-dropdown-email{font-size:12px;color:var(--text3);margin-top:4px;word-break:break-all;}
.ob-user-dropdown-menu{padding:8px;}
.ob-user-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;border:none;background:none;width:100;}
.ob-user-dropdown-item:hover{background:rgba(255,255,255,0.05);color:var(--text);}
.ob-user-dropdown-item.danger{color:#ef4444;}
.ob-user-dropdown-item.danger:hover{background:rgba(239,68,68,.1);}
body.loading-screen .mobile-hamburger { display:none!important; }

/* ONBOARDING PAGES */
.ob-page { display:none; }
.ob-page.active { display:flex; flex-direction:column; position:fixed; inset:0; z-index:500; background:var(--bg); overflow-y:auto; }
.ob-bg {
  position:absolute; inset:0; z-index:0;
  background: radial-gradient(ellipse 70% 60% at 20% 30%, rgba(0,212,232,0.12) 0%, transparent 60%),
              radial-gradient(ellipse 60% 50% at 80% 70%, rgba(192,38,211,0.14) 0%, transparent 60%),
              radial-gradient(ellipse 40% 40% at 50% 10%, rgba(124,58,237,0.08) 0%, transparent 50%);
}
.ob-grid-lines {
  position:absolute; inset:0; z-index:0; opacity:0.04;
  background-image: linear-gradient(var(--accent) 1px, transparent 1px),
                    linear-gradient(90deg, var(--accent) 1px, transparent 1px);
  background-size: 60px 60px;
}
.ob-content { position:relative; z-index:1; flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:40px 24px; width:100%; box-sizing:border-box; }
.ob-logo { display:flex; align-items:center; gap:10px; margin-bottom:48px; }
.ob-logo-mark { width:42px; height:42px; border-radius:12px; background:linear-gradient(135deg,#00D4E8,#7C3AED,#C026D3); display:flex; align-items:center; justify-content:center; }
.ob-logo-text { font-family:'Syne',sans-serif; font-weight:800; font-size:18px; color:var(--text); }
.ob-logo-text span { color:var(--text2); font-size:10px; font-weight:400; letter-spacing:1.5px; text-transform:uppercase; margin-left:2px; }
.ob-title { font-family:'Syne',sans-serif; font-weight:800; font-size:clamp(28px,5vw,42px); color:var(--text); text-align:center; line-height:1.15; margin-bottom:12px; }
.ob-title .gr { background:linear-gradient(135deg,var(--accent),var(--blue),var(--purple)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.ob-sub { font-size:15px; color:var(--text2); text-align:center; margin-bottom:48px; max-width:900px; width:100%; line-height:1.6; }
.ob-step { display:flex; align-items:center; gap:8px; margin-bottom:40px; }
.ob-step-dot { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; transition:all 0.3s; }
.ob-step-dot.done { background:var(--accent); color:var(--bg); }
.ob-step-dot.active { background:var(--blue); color:white; box-shadow:0 0 16px rgba(124,58,237,0.5); }
.ob-step-dot.pending { background:var(--surface2); color:var(--text3); border:1px solid var(--border2); }
.ob-step-line { width:40px; height:2px; background:var(--border2); border-radius:1px; }
.ob-step-line.done { background:var(--accent); }

/* BIG CARDS */
.ob-cards { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; max-width:900px; width:100%; }
.ob-card {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px; padding:28px 20px; border-radius:20px;
  background:var(--surface); border:2px solid var(--border);
  cursor:pointer; transition:all 0.25s; text-align:center;
  min-width:140px; flex:1; max-width:170px; position:relative;
  overflow:hidden;
}
.ob-card::before {
  content:''; position:absolute; inset:0; opacity:0;
  background:radial-gradient(circle at 50% 40%, var(--card-color,var(--accent)), transparent 70%);
  transition:opacity 0.25s;
}
.ob-card:hover { border-color:var(--card-color,var(--accent)); transform:translateY(-3px); box-shadow:0 12px 32px rgba(0,0,0,0.3); }
.ob-card:hover::before { opacity:0.06; }
.ob-card.selected { border-color:var(--card-color,var(--accent)); background:rgba(0,212,232,0.06); }
.ob-card.selected::before { opacity:0.08; }
.ob-card-icon { font-size:36px; position:relative; z-index:1; }
.ob-card-label { font-size:13px; font-weight:700; color:var(--text); position:relative; z-index:1; }
.ob-card-sub { font-size:11px; color:var(--text3); position:relative; z-index:1; line-height:1.4; }
.ob-card.selected .ob-card-label { color:var(--card-color,var(--accent)); }

/* LANG CARDS — smaller */
.ob-lang-card { 
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; padding:16px 14px; max-width:130px; width:100%;
  border-radius:16px; border:2px solid var(--border2); background:var(--surface);
  cursor:pointer; transition:all .2s; position:relative; overflow:hidden;
}
.ob-lang-card:hover { border-color:var(--accent); transform:translateY(-2px); }
.ob-lang-card.sel { border-color:var(--accent); background:var(--accent-dim); }
.lang-flag { font-size:28px; line-height:1; }
.lang-code { font-size:14px; font-weight:700; color:var(--text); }
.lang-name { font-size:11px; color:var(--text3); }
.ob-lang-card.sel .lang-code { color:var(--accent); }
.ob-lang-card.sel .lang-name { color:var(--accent); }
.ob-lang-icon { font-size:28px; }

/* OB FORM */
.ob-form { width:100%; max-width:580px; display:flex; flex-direction:column; gap:16px; }
.ob-field-label { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--text3); margin-bottom:6px; }
.ob-input { width:100%; background:var(--surface2); border:1.5px solid var(--border2); border-radius:12px; padding:14px 18px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:15px; outline:none; transition:all 0.2s; }
.ob-input:focus { border-color:var(--accent); background:var(--surface3); }
.ob-input::placeholder { color:var(--text3); }
.ob-period-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.ob-period-btn { padding:10px 6px; border-radius:10px; border:1.5px solid var(--border2); background:var(--surface); color:var(--text2); font-size:12px; font-weight:600; text-align:center; cursor:pointer; transition:all 0.2s; }
.ob-period-btn.sel { border-color:var(--accent); background:var(--accent-dim); color:var(--accent); }
.ob-nav { display:flex; gap:12px; margin-top:8px; justify-content:center; }
.ob-btn-back { flex:1; padding:14px; border-radius:12px; border:1.5px solid var(--border2); background:transparent; color:var(--text2); font-family:'Syne',sans-serif; font-size:14px; font-weight:600; cursor:pointer; transition:all 0.2s; }
.ob-btn-back:hover { border-color:var(--text2); color:var(--text); }
.ob-btn-next { flex:2; max-width:320px; padding:14px; border-radius:12px; border:none; background:linear-gradient(135deg,var(--accent),var(--blue)); color:var(--bg); font-family:'Syne',sans-serif; font-size:15px; font-weight:700; cursor:pointer; transition:all 0.3s; display:flex; align-items:center; justify-content:center; gap:8px; min-height:50px; }
.ob-btn-next:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,212,232,0.3); }
.ob-btn-next:disabled { opacity:0.4; cursor:not-allowed; transform:none; }

/* TYPE TOGGLE */
.ob-type-toggle { display:flex; gap:0; border-radius:12px; overflow:hidden; border:1.5px solid var(--border2); margin-bottom:4px; }
.ob-type-btn { flex:1; padding:12px 16px; background:transparent; border:none; color:var(--text2); font-family:'DM Sans',sans-serif; font-size:14px; font-weight:600; cursor:pointer; transition:all 0.2s; }
.ob-type-btn.active { background:var(--surface3); color:var(--text); }

/* FADE ANIM */
@keyframes obFadeIn { from{opacity:0;transform:translateY(16px);} to{opacity:1;transform:translateY(0);} }
.ob-animate { animation:obFadeIn 0.4s ease forwards; }

/* MOBILE HAMBURGER */
.mobile-hamburger{display:none;position:fixed;top:14px;left:14px;z-index:200;width:40px;height:40px;border-radius:10px;background:var(--surface);border:1px solid var(--border);align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--text);}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:90;backdrop-filter:blur(2px);}
.sidebar-overlay.active{display:block;}

@media(max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform 0.25s ease;z-index:150;}
  .sidebar.open{transform:translateX(0);}
  .content{margin-left:0!important;}
  .mobile-hamburger{display:flex;}
  .topbar{padding-left:60px;}
  .kpi-row{grid-template-columns:1fr 1fr;}
  .grid-2,.grid-big-small{grid-template-columns:1fr;}
  .conc-grid,.row2,.row3,.sector-grid{grid-template-columns:1fr 1fr;}
  .lang-grid{flex-wrap:wrap;}
}
@media(max-width:480px){
  .kpi-row{grid-template-columns:1fr;}
  .conc-grid,.row2,.row3,.sector-grid{grid-template-columns:1fr;}
  .topbar-right{gap:4px;}
  .topbar-right .btn{padding:6px 10px;font-size:11px;}
  .dash-content{padding:16px 14px;}
  .hero-title{font-size:28px;}
}

@media print{
  *{overflow:visible!important;}
  html,body{height:auto!important;overflow:visible!important;margin:0!important;}
  body{padding:16px!important;background:#fff!important;color:#111!important;}
  .sidebar,.topbar,nav,.nav-item,.btn,.btn-accent,#btn-report-top,.lang-btn,.provider-bar,.chat-widget,.sidebar-bottom,#history-panel,a[href*="wa.me"],#onboarding,.ob-overlay{display:none!important;}
  .content{margin-left:0!important;padding:16px!important;height:auto!important;overflow:visible!important;width:100%!important;}
  .page{display:none!important;height:auto!important;}
  #page-report{display:block!important;height:auto!important;overflow:visible!important;}
  .report-preview{box-shadow:none!important;border:none!important;height:auto!important;overflow:visible!important;max-height:none!important;background:#fff!important;}
  .dash-content{padding:0!important;height:auto!important;overflow:visible!important;}
  .report-section,.report-block{page-break-inside:avoid;margin-bottom:12px;}
  .kpi-row,.grid-2,.grid-big-small{page-break-inside:avoid;}
}


/* ===== PULSE AI WIDGET ===== */

#pulse-ai-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 9999;
  width: 58px; height: 58px; border-radius: 50%; border: none;
  background: linear-gradient(135deg, #00D4E8, #A855F7);
  color: white; font-size: 26px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 28px rgba(0,212,232,0.4); transition: all .3s ease;
}
#pulse-ai-fab:hover { transform: scale(1.1); box-shadow: 0 8px 36px rgba(0,212,232,0.55); }
#pulse-ai-fab.open { transform: rotate(45deg) scale(1); border-radius: 16px; font-size: 22px; width: 48px; height: 48px; }
#pulse-ai-fab::after {
  content: ''; position: absolute; top: -2px; right: -2px;
  width: 14px; height: 14px; border-radius: 50%;
  background: #22C55E; border: 2.5px solid #05080D;
  animation: pulseAiFabPulse 2.5s ease-in-out infinite;
}
#pulse-ai-fab.open::after { display: none; }
@keyframes pulseAiFabPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.3); } }
#pulse-ai-panel {
  position: fixed; bottom: 92px; right: 24px; z-index: 9998;
  width: 400px; height: 580px; max-height: calc(100vh - 120px);
  border-radius: 20px; overflow: hidden;
  background: #05080D; border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 16px 64px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,212,232,0.08);
  display: none; flex-direction: column; animation: pulseAiSlideIn .3s ease;
  font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
}
#pulse-ai-panel.visible { display: flex; }
@keyframes pulseAiSlideIn { from { opacity:0; transform: translateY(16px) scale(0.96); } to { opacity:1; transform: translateY(0) scale(1); } }
.pai-header { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid rgba(255,255,255,0.06); background:rgba(10,14,23,0.95); backdrop-filter:blur(16px); }
.pai-header-left { display:flex; align-items:center; gap:10px; }
.pai-logo { width:36px; height:36px; border-radius:12px; background:linear-gradient(135deg,#00D4E8,#A855F7); display:flex; align-items:center; justify-content:center; font-size:18px; box-shadow:0 3px 14px rgba(0,212,232,0.25); }
.pai-title { font-family:'Syne',sans-serif; font-size:14px; font-weight:800; color:#F1F5F9; }
.pai-sub { font-size:11px; color:#64748B; margin-top:1px; }
.pai-online { width:6px; height:6px; border-radius:50%; background:#22C55E; display:inline-block; margin-right:4px; animation:paiBlink 2s ease-in-out infinite; }
@keyframes paiBlink { 0%,100%{opacity:1;} 50%{opacity:.3;} }
.pai-close { width:30px; height:30px; border-radius:8px; border:none; background:rgba(255,255,255,0.05); color:#94A3B8; font-size:16px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.pai-close:hover { background:rgba(255,255,255,0.1); color:#F1F5F9; }
.pai-lang-row { display:flex; gap:4px; }
.pai-lang { padding:3px 9px; border-radius:6px; border:1px solid rgba(255,255,255,0.08); background:transparent; color:#64748B; font-size:10px; font-weight:700; cursor:pointer; transition:all .15s; }
.pai-lang.active { border-color:#00D4E8; color:#00D4E8; background:rgba(0,212,232,0.06); }
.pai-quick { display:flex; gap:6px; padding:10px 14px; overflow-x:auto; border-bottom:1px solid rgba(255,255,255,0.04); background:#0A0E17; scrollbar-width:thin; scrollbar-color:rgba(0,212,232,0.3) transparent; position:relative; }
.pai-quick::-webkit-scrollbar { height:3px; }
.pai-quick::-webkit-scrollbar-thumb { background:rgba(0,212,232,0.3); border-radius:3px; }
.pai-quick::-webkit-scrollbar-track { background:transparent; }
.pai-quick::after { content:'→'; position:sticky; right:0; display:flex; align-items:center; padding:0 6px; font-size:12px; color:rgba(0,212,232,0.5); background:linear-gradient(90deg,transparent,#0A0E17 40%); pointer-events:none; flex-shrink:0; }
.pai-qbtn { padding:5px 12px; border-radius:100px; border:1px solid rgba(255,255,255,0.08); background:#111827; color:#94A3B8; font-size:10.5px; font-weight:600; cursor:pointer; white-space:nowrap; transition:all .15s; font-family:'DM Sans',sans-serif; }
.pai-qbtn:hover { border-color:#00D4E8; color:#00D4E8; }
.pai-messages { flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:12px; scrollbar-width:thin; scrollbar-color:#1A2236 transparent; }
.pai-messages::-webkit-scrollbar { width:4px; }
.pai-messages::-webkit-scrollbar-thumb { background:#1A2236; border-radius:2px; }
.pai-msg { display:flex; gap:8px; max-width:90%; animation:paiMsgIn .25s ease; }
.pai-msg.user { flex-direction:row-reverse; align-self:flex-end; }
@keyframes paiMsgIn { from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:translateY(0);} }
.pai-avatar { width:28px; height:28px; border-radius:9px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:14px; }
.pai-msg.bot .pai-avatar { background:linear-gradient(135deg,rgba(0,212,232,0.12),rgba(168,85,247,0.12)); }
.pai-msg.user .pai-avatar { background:linear-gradient(135deg,rgba(59,130,246,0.12),rgba(168,85,247,0.12)); }
.pai-bubble { padding:10px 14px; border-radius:14px; font-size:13px; line-height:1.6; color:#F1F5F9; }
.pai-msg.bot .pai-bubble { background:#111827; border:1px solid rgba(255,255,255,0.05); border-top-left-radius:3px; }
.pai-msg.user .pai-bubble { background:linear-gradient(135deg,rgba(0,212,232,0.1),rgba(168,85,247,0.1)); border:1px solid rgba(0,212,232,0.15); border-top-right-radius:3px; }
.pai-bubble strong { color:#00D4E8; }
.pai-typing { display:flex; align-items:center; gap:8px; padding:4px 16px; }
.pai-dots { display:flex; gap:4px; }
.pai-dot { width:6px; height:6px; border-radius:50%; background:#00D4E8; animation:paiDotBounce 1.4s ease-in-out infinite; }
.pai-dot:nth-child(2) { animation-delay:.2s; }
.pai-dot:nth-child(3) { animation-delay:.4s; }
@keyframes paiDotBounce { 0%,60%,100%{transform:translateY(0);opacity:.3;} 30%{transform:translateY(-6px);opacity:1;} }
.pai-input-area { padding:12px 14px 14px; border-top:1px solid rgba(255,255,255,0.05); background:rgba(5,8,13,0.95); }
.pai-input-wrap { display:flex; align-items:center; gap:8px; padding:4px 6px 4px 14px; border-radius:13px; border:1.5px solid rgba(255,255,255,0.08); background:#111827; transition:border-color .2s; }
.pai-input-wrap:focus-within { border-color:#00D4E8; box-shadow:0 0 0 2px rgba(0,212,232,0.06); }
.pai-input-wrap input { flex:1; background:none; border:none; outline:none; color:#F1F5F9; font-family:'DM Sans',sans-serif; font-size:13px; }
.pai-input-wrap input::placeholder { color:#64748B; }
.pai-send { width:34px; height:34px; border-radius:10px; border:none; background:linear-gradient(135deg,#00D4E8,#A855F7); color:white; font-size:16px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
.pai-send:hover { transform:scale(1.05); }
.pai-send:disabled { opacity:.35; cursor:not-allowed; transform:none; }
.pai-footer { font-size:9.5px; color:#475569; margin-top:6px; text-align:center; }
@media (max-width:480px) {
  #pulse-ai-panel { width:calc(100vw - 16px); right:8px; bottom:80px; height:calc(100vh - 100px); border-radius:16px; }
  #pulse-ai-fab { bottom:16px; right:16px; width:52px; height:52px; font-size:24px; }
}

/* ===== GÊMEO DIGITAL v3 ===== */

/* Scenarios */
.scen-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;}
.scen-card{padding:16px;border-radius:12px;background:var(--surface2);border:2px solid transparent;transition:all .3s;cursor:pointer;position:relative;overflow:hidden;}
.scen-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;transition:background .3s;}
.scen-card.active{transform:translateY(-3px);}
.scen-card[data-s="0"]{border-color:rgba(124,58,237,.12);}.scen-card[data-s="0"]::after{background:var(--blue);}
.scen-card[data-s="0"].active{border-color:var(--blue);box-shadow:0 4px 20px rgba(124,58,237,.2);}
.scen-card[data-s="1"]{border-color:rgba(0,212,232,.12);}.scen-card[data-s="1"]::after{background:var(--accent);}
.scen-card[data-s="1"].active{border-color:var(--accent);box-shadow:0 4px 20px rgba(0,212,232,.2);}
.scen-card[data-s="2"]{border-color:rgba(255,61,90,.12);}.scen-card[data-s="2"]::after{background:var(--red);}
.scen-card[data-s="2"].active{border-color:var(--red);box-shadow:0 4px 20px rgba(255,61,90,.2);}
.scen-label{font-family:'Syne',sans-serif;font-size:13px;font-weight:800;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;}
.scen-desc{font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:8px;}
.scen-impact{font-size:11px;font-weight:700;padding:4px 10px;border-radius:100px;display:inline-block;}
.scen-metric{font-size:11px;color:var(--text3);margin-top:6px;transition:all .3s;}

/* Metrics */
.rx-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px;}
.rx-metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;transition:all .4s;}
.rx-metric-name{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;}
.rx-metric-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px;}
.rx-metric-old{font-size:13px;color:var(--text3);}
.rx-metric-new{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;transition:color .3s;}
.rx-metric-bar{height:4px;border-radius:2px;background:var(--border);margin-top:8px;overflow:hidden;}
.rx-metric-bar-fill{height:100%;border-radius:2px;transition:width .5s ease,background .3s;}

/* ROI */
.roi-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;}
@media(max-width:600px){.roi-grid{grid-template-columns:1fr;}}
.roi-box{padding:16px;border-radius:12px;text-align:center;transition:all .4s;}
.roi-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;}
.roi-val{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;transition:all .3s;}
.roi-sub{font-size:11px;color:var(--text3);margin-top:4px;}

/* Risk Assessment */
.risk-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;}
@media(max-width:600px){.risk-grid{grid-template-columns:1fr 1fr;}}
.risk-box{padding:14px;border-radius:12px;text-align:center;background:var(--surface2);border:1px solid var(--border);}
.risk-box-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:8px;}
.risk-box-val{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;margin-bottom:2px;}
.risk-box-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;}
.risk-summary{font-size:13px;color:var(--text2);line-height:1.6;margin-top:12px;padding:12px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--border);}

/* Timeline */
.tl-item{display:flex;gap:10px;padding:10px 12px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);margin-bottom:6px;}
.tl-periodo{flex-shrink:0;font-size:11px;color:var(--text3);white-space:nowrap;padding-top:2px;min-width:70px;}
.tl-evento{font-size:13px;color:var(--text1);}

/* Chat */
.gemeo-chat-card{border-color:rgba(96,165,250,.25);position:relative;overflow:hidden;}
.gemeo-chat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:14px 14px 0 0;}
.chat-messages{max-height:380px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 0;margin-bottom:14px;}
.chat-msg{max-width:85%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.65;animation:chatIn .3s ease;}
@keyframes chatIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.chat-msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--blue),#3b82f6);color:white;border-bottom-right-radius:4px;}
.chat-msg.ai{align-self:flex-start;background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-bottom-left-radius:4px;}
.chat-msg.ai strong{color:var(--text1);}
.chat-msg.system{align-self:center;background:transparent;border:1px dashed var(--border);color:var(--text3);font-size:11px;padding:6px 12px;border-radius:100px;}
.chat-msg.error{align-self:center;background:var(--red-dim);border:1px solid rgba(255,61,90,.2);color:var(--red);font-size:12px;padding:8px 14px;border-radius:10px;}
.chat-input-row{display:flex;gap:8px;}
.chat-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .2s;}
.chat-input:focus{border-color:var(--blue);}.chat-input::placeholder{color:var(--text3);}
.chat-send{padding:10px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--blue),var(--purple));color:white;font-family:'Syne',sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;flex-shrink:0;}
.chat-send:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(124,58,237,.3);}
.chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.chat-typing{align-self:flex-start;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;border-bottom-left-radius:4px;display:flex;gap:4px;align-items:center;}
.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--text3);animation:typeDot 1.2s infinite;}
.chat-typing span:nth-child(2){animation-delay:.2s;}.chat-typing span:nth-child(3){animation-delay:.4s;}
@keyframes typeDot{0%,100%{opacity:.3;transform:scale(.8);}50%{opacity:1;transform:scale(1.1);}}
.quick-qs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.quick-q{padding:6px 12px;border-radius:100px;border:1px solid var(--border);background:var(--surface2);color:var(--text3);font-size:11px;cursor:pointer;transition:all .2s;}
.quick-q:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim);}

/* Context panel */
.ctx-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:0;margin:0;}
.ctx-toggle:hover .ctx-chevron{color:var(--accent);}
.ctx-chevron{font-size:16px;color:var(--text3);transition:transform .3s,color .2s;}
.ctx-chevron.open{transform:rotate(180deg);}
.ctx-body{overflow:hidden;transition:max-height .4s ease,opacity .3s;max-height:0;opacity:0;}
.ctx-body.open{max-height:800px;opacity:1;margin-top:16px;}
.ctx-section{margin-bottom:16px;}
.ctx-section-title{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;display:flex;align-items:center;gap:6px;}

/* Upload zone */
.upload-zone{border:2px dashed var(--border2);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;position:relative;}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--blue);background:var(--blue-dim);}
.upload-zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;}

/* File chips */
.file-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;}
.file-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:100px;background:var(--surface2);border:1px solid var(--border);font-size:12px;color:var(--text2);animation:chatIn .2s ease;}
.file-chip .file-icon{font-size:14px;}
.file-chip .file-name{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.file-chip .file-size{font-size:10px;color:var(--text3);}
.file-chip .file-status{font-size:10px;padding:2px 6px;border-radius:100px;}
.file-chip .file-remove{cursor:pointer;color:var(--text3);font-size:14px;margin-left:2px;transition:color .15s;}
.file-chip .file-remove:hover{color:var(--red);}

/* Context textarea */
.ctx-textarea{width:100%;min-height:70px;max-height:160px;resize:vertical;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.6;outline:none;transition:border-color .2s;}

/* Sandbox */
.sandbox-card{padding:20px;border-radius:14px;border:1px solid var(--border);background:var(--surface);position:relative;overflow:hidden;}
.sandbox-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.sandbox-card.mode-investment::before{background:linear-gradient(90deg,var(--accent),var(--blue));}
.sandbox-card.mode-intensity::before{background:linear-gradient(90deg,var(--purple),var(--red));}
.sandbox-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.sandbox-context{font-size:11px;color:var(--text3);margin-top:2px;}

/* Responsive */
@media(max-width:768px){.grid-2,.scen-grid{grid-template-columns:1fr!important;}}
