:root{--deep:#071226;--royal:#315BFF;--blue:#2563EB;--teal:#14B8A6;--violet:#7C3AED;--bg:#F6F8FC;--ink:#081328;--muted:#64748B;--line:#E4EAF3;--green:#10B981;--orange:#F59E0B;--red:#EF4444;--shadow:0 18px 42px rgba(8,19,40,.08);--radius:18px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--bg)}.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px 20px;background:radial-gradient(circle at 20% 8%,rgba(49,91,255,.28),transparent 24%),linear-gradient(180deg,#071226,#081633 50%,#061024);color:#fff;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}.sidebar:after{content:'';position:absolute;inset:auto -120px 80px -95px;height:560px;background:radial-gradient(circle at 28% 62%,rgba(49,91,255,.18),transparent 22%),url('assets/wave-bg.svg') center/cover no-repeat;opacity:1;filter:saturate(1.2)}.brand,.tagline,nav,.profile{position:relative;z-index:1}.brand{display:flex;align-items:center;gap:14px}.brand img{width:68px;filter:drop-shadow(0 0 18px rgba(49,91,255,.35))}.brand strong{font-family:Sora;font-size:38px;letter-spacing:-1.8px;line-height:.9}.brand span{display:block;color:#1CE0D0;letter-spacing:.42em;font-weight:900;margin-top:7px;font-size:13px}.brand small{display:block;color:#7DD3FC;letter-spacing:.08em;font-size:10px;font-weight:800;margin-top:7px;text-transform:uppercase}.tagline{font-weight:800;line-height:1.5}.tagline em{color:#1CE0D0;font-style:normal}nav{display:grid;gap:8px;margin-top:24px}nav button{height:44px;border:0;border-radius:12px;background:transparent;color:#E7EEFF;text-align:left;padding:0 14px;font-weight:800;cursor:pointer;transition:.2s}nav button.active,nav button:hover{background:linear-gradient(135deg,#315BFF,#2D48E8);box-shadow:0 12px 28px rgba(49,91,255,.32);transform:translateX(2px)}.profile{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.055);border-radius:16px;padding:12px;display:flex;gap:12px;align-items:center}.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#F1D0C8,#9E695D);display:grid;place-items:center;font-weight:900}.profile small{display:block;color:#CBD5E1}.main{padding:22px;overflow:auto}.screen{display:none}.screen.active{display:block;animation:fade .24s ease}@keyframes fade{from{opacity:0;transform:translateY(5px)}}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.eyebrow{margin:0 0 5px;color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:900}.topbar h1{font-family:Sora;margin:0;font-size:28px}.topbar p{margin:5px 0 0;color:var(--muted)}.top-actions{display:flex;gap:12px}.top-actions select,.top-actions button{border:1px solid var(--line);background:#fff;border-radius:12px;padding:11px 14px;font-weight:800;box-shadow:0 8px 18px rgba(8,19,40,.04)}.top-actions .bell{position:relative}.bell i{position:absolute;right:-6px;top:-8px;background:#315BFF;color:#fff;border-radius:99px;width:20px;height:20px;display:grid;place-items:center;font-style:normal;font-size:11px}.top-actions .new-case{background:linear-gradient(135deg,var(--royal),var(--teal));color:white;border:0}.card{background:#fff;border:1px solid #E7EDF6;border-radius:var(--radius);box-shadow:0 9px 26px rgba(8,19,40,.055);padding:18px;transition:.2s}.card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.card h3{font-family:Sora;margin:0 0 12px}.label{margin:0;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase}.link{color:var(--blue);font-size:12px;font-weight:900}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.card-head h2{font-family:Sora;margin:3px 0 0}.card-head a{color:var(--blue);font-size:12px;font-weight:900}.kpi-grid{display:grid;grid-template-columns:1.35fr repeat(4,1fr);gap:12px;margin-bottom:12px}.confidence-main{display:grid;grid-template-columns:132px 1fr;gap:16px;align-items:center}.ring{width:132px;height:132px;border-radius:50%;background:conic-gradient(from 20deg,var(--teal) 0 18%,var(--royal) 18% 82%,#D8E3F7 82%);position:relative;display:flex;align-items:center;justify-content:center;flex-direction:column}.ring:after{content:'';position:absolute;inset:18px;background:#fff;border-radius:50%}.ring strong,.ring span{position:relative;z-index:1;line-height:1;margin:0}.ring strong{font-family:Sora;font-size:38px;transform:translateY(3px)}.ring span{font-size:14px;color:var(--muted);transform:translateY(5px)}.confidence-main h2{font-family:Sora;color:var(--teal);font-size:25px;margin:4px 0}.confidence-main p{color:#465772;line-height:1.45}.confidence-main small{color:var(--muted);font-size:12px}.kpi p{margin:0;color:var(--muted);font-size:12px;font-weight:800}.kpi h3{font-family:Sora;font-size:31px;margin:5px 0}.kpi b{color:var(--teal);font-size:12px}.kpi canvas{height:56px!important;margin-top:8px}.dashboard-grid{display:grid;grid-template-columns:1.25fr .85fr .9fr;gap:12px}.tabs{display:flex;gap:30px;border-bottom:1px solid var(--line);margin:0 -18px 8px;padding:0 18px}.tab{border:0;background:transparent;padding:13px 0 12px;font-weight:900;color:#42526C;cursor:pointer;position:relative}.tab.active{color:var(--royal)}.tab.active:after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--royal);border-radius:99px}.detail-row{display:grid;grid-template-columns:30px 1fr 90px 26px;gap:12px;align-items:center;padding:12px 0;border-bottom:1px solid #EEF2F7}.detail-row:last-child{border:0}.detail-row b{font-size:13px}.detail-row .icon{color:var(--teal);font-size:18px}.status{font-size:12px;font-weight:900;text-align:right}.met{color:var(--green)}.missing{color:var(--orange)}.needed{color:var(--red)}.na{color:var(--muted)}.dot{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;border:1px solid currentColor;font-size:13px}.pill{border-radius:99px;padding:7px 10px;font-size:12px;font-weight:900}.pill.high{background:#DCFCE7;color:#047857}.pill.medium{background:#FEF3C7;color:#B45309}.pill.low{background:#FEE2E2;color:#B91C1C}.action{display:grid;grid-template-columns:36px 1fr 18px;gap:12px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:13px;margin-bottom:10px;transition:.18s}.action:hover{transform:translateX(2px);border-color:#C7D2FE;background:#FAFCFF}.action i{font-style:normal;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:white;background:linear-gradient(135deg,var(--violet),var(--royal));font-weight:900}.action b{font-size:12px}.action small{display:block;color:var(--muted);font-size:11px}.dark-card{background:#071226;color:white;overflow:hidden;position:relative;min-height:185px;display:grid;grid-template-columns:124px 1fr;gap:18px;align-items:center}.dark-card:after{content:'';position:absolute;right:-55px;bottom:-60px;width:300px;height:190px;background:url('assets/wave-bg.svg') center/cover no-repeat;opacity:.8}.dark-ring{width:118px;height:118px;border-radius:50%;background:conic-gradient(from 20deg,var(--teal) 0 18%,var(--royal) 18% 82%,rgba(255,255,255,.18) 82%);display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative;z-index:1}.dark-ring strong,.dark-ring span{line-height:1}.dark-ring strong{font-family:Sora;font-size:38px}.dark-ring span{font-size:13px;color:#CBD5E1;margin-top:5px}.dark-card h3,.dark-card p{position:relative;z-index:1}.dark-card p{color:#CBD5E1;line-height:1.5}.scoring-card{margin-top:12px}.score-logic{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.score-logic div{text-align:center;border-right:1px solid var(--line)}.score-logic div:last-child{border:0}.score-logic b{display:block;color:var(--royal);font-size:22px}.score-logic span,.score-logic em{display:block;font-size:11px;font-style:normal}.score-logic em{color:var(--muted);margin-top:3px}.middle-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;margin-top:12px}.flow-dots{display:grid;grid-template-columns:1fr 32px 1fr 32px 1.15fr 32px 1fr 32px 1fr;gap:4px;align-items:center;margin:18px 0}.flow-node{text-align:center}.flow-node i{width:54px;height:54px;border-radius:50%;background:#F1F5FD;display:grid;place-items:center;margin:0 auto 8px;color:#315BFF;font-style:normal;font-size:22px}.flow-node i img{width:34px}.flow-node b{font-size:11px}.flow-node.clariq-node i{background:radial-gradient(circle,#fff,#E0F2FE);box-shadow:0 0 0 7px rgba(49,91,255,.07)}.flow-dots span{height:2px;background:linear-gradient(90deg,#7C3AED,#14B8A6);position:relative;overflow:hidden}.flow-dots span:after{content:'';position:absolute;top:-3px;left:-14px;width:8px;height:8px;border-radius:50%;background:#315BFF;animation:flow 1.6s linear infinite}@keyframes flow{to{left:110%}}.small{color:var(--muted);font-size:12px;line-height:1.5}.sources-card{position:relative;overflow:hidden}.source-list{display:grid;gap:12px;position:relative;z-index:1}.source-list div{display:grid;grid-template-columns:30px 1fr;gap:10px}.source-list span{color:#315BFF;font-size:22px}.source-list b{font-size:12px}.source-list small{display:block;color:var(--muted);margin-top:2px}.brain{position:absolute;right:18px;bottom:14px;font-size:74px;opacity:.14}.lower-grid{display:grid;grid-template-columns:1fr 1fr 1.05fr 1fr;gap:12px;margin-top:12px}.list-row{display:grid;grid-template-columns:28px 1fr 58px;gap:10px;align-items:center;border-bottom:1px solid #EEF2F7;padding:10px 0}.list-row:last-child{border:0}.list-row b{font-size:12px}.list-row small,.list-row em{display:block;color:var(--muted);font-style:normal;font-size:11px}.score{justify-self:end;border:1px solid var(--royal);color:var(--royal);width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:900}.mini-donut{display:grid;grid-template-columns:110px 1fr;gap:14px;align-items:center}.mini-donut div{width:95px;height:95px;border-radius:50%;background:conic-gradient(var(--teal) 0 41%,var(--blue) 41% 76%,var(--orange) 76% 100%)}.mini-donut li{list-style:none;font-size:12px;margin:9px 0}.mini-donut b{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.green{background:var(--teal)}.blue{background:var(--blue)}.orange{background:var(--orange)}.activity p{display:flex;justify-content:space-between;gap:10px;font-size:12px}.activity b{color:var(--teal)}.activity span{color:var(--muted)}.case-grid,.investor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.case-card{cursor:pointer}.case-card h3{margin-bottom:4px}.case-card small{color:var(--muted)}.analytics-grid{display:grid;grid-template-columns:1.2fr 1.2fr .9fr;gap:12px}.analytics-grid canvas{max-height:280px}.impact{display:grid;grid-template-columns:86px 1fr;gap:12px;margin:14px 0}.impact b{font-family:Sora;color:var(--royal);font-size:21px}.impact span{color:var(--muted);font-size:13px}.workflow-large{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.workflow-large div{background:white;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 9px 26px rgba(8,19,40,.055)}.workflow-large b{display:block;font-family:Sora;font-size:34px;color:var(--royal)}.workflow-large span{display:block;font-weight:900;margin:10px 0}.workflow-large small{color:var(--muted)}@media(max-width:1180px){.app{grid-template-columns:235px 1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.middle-grid,.lower-grid,.analytics-grid,.investor-grid{grid-template-columns:1fr}.flow-dots{grid-template-columns:1fr}.flow-dots span{height:24px;width:2px;margin:auto}.workflow-large{grid-template-columns:1fr}}@media(max-width:760px){.app{display:block}.sidebar{position:relative;width:100%;height:auto}.brand img{width:54px}.brand strong{font-size:30px}.tagline,.profile{display:none}.sidebar:after{inset:auto -100px -40px 0;height:260px;opacity:.48}nav{display:flex;overflow:auto;gap:8px}nav button{white-space:nowrap}.main{padding:16px}.topbar{flex-direction:column}.top-actions{display:grid;grid-template-columns:1fr auto auto;width:100%;gap:10px}.top-actions select{min-width:0;width:100%}.kpi-grid{grid-template-columns:1fr}.confidence-main{grid-template-columns:1fr;text-align:center}.ring{margin:auto;width:118px;height:118px}.ring strong{font-size:34px}.detail-row{grid-template-columns:24px 1fr 70px 22px}.dark-card{grid-template-columns:1fr;text-align:center}.dark-ring{margin:auto}.score-logic{grid-template-columns:repeat(2,1fr)}.lower-grid{grid-template-columns:1fr}.mini-donut{grid-template-columns:1fr}}

/* === MERGED PRODUCT DEPTH UPGRADE === */
.story-toggle{
  background:#fff!important;
  color:#315BFF!important;
  border:1px solid #BFDBFE!important;
}
body.story-mode .missing,
body.story-mode .needed{
  animation:pulseWarn 1.25s ease-in-out infinite;
}
body.story-mode .confidence-main,
body.story-mode .active-case,
body.story-mode .action-card{
  outline:2px solid rgba(49,91,255,.22);
  box-shadow:0 0 0 6px rgba(49,91,255,.06), var(--shadow);
}
@keyframes pulseWarn{
  0%,100%{filter:none}
  50%{filter:drop-shadow(0 0 6px rgba(245,158,11,.45))}
}
.card,.action,.list-row,.case-card,.driver-row,.stage{
  transition:.2s ease;
}
.list-row:hover,.detail-row:hover,.driver-row:hover{
  background:#FAFCFF;
}
.case-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin-bottom:14px;
}
.searchbox{
  flex:1;
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#F8FAFC;
  padding:10px 12px;
}
.searchbox input{
  border:0;
  outline:0;
  background:transparent;
  width:100%;
  font:inherit;
  font-weight:700;
}
.filter-pills{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.filter-pills button{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:9px 12px;
  font-weight:900;
  color:#42526C;
  cursor:pointer;
}
.filter-pills button.active{
  background:linear-gradient(135deg,var(--royal),var(--teal));
  color:#fff;
  border-color:transparent;
}
.case-workspace{
  display:grid;
  grid-template-columns:1.4fr .8fr;
  gap:12px;
}
.queue-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.queue-card{
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.queue-card:hover{
  transform:translateY(-3px);
  border-color:#BFDBFE;
}
.queue-card h3{
  margin:0 0 4px;
}
.queue-card small{
  color:var(--muted);
}
.queue-meta{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin:12px 0;
  font-size:12px;
}
.queue-score{
  position:absolute;
  top:16px;
  right:16px;
  width:48px;
  height:48px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:3px solid var(--royal);
  font-weight:900;
  font-family:Sora;
}
.case-panel{
  position:sticky;
  top:18px;
  align-self:start;
  min-height:360px;
}
.empty-panel{
  height:310px;
  display:grid;
  place-items:center;
  text-align:center;
  color:var(--muted);
}
.panel-score{
  width:96px;
  height:96px;
  border-radius:50%;
  background:conic-gradient(var(--teal) 0 20%,var(--royal) 20% 80%,#D8E3F7 80%);
  display:grid;
  place-items:center;
  color:#081328;
  font-family:Sora;
  font-size:28px;
  margin-bottom:12px;
}
.panel-actions div{
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
  margin:8px 0;
  font-size:12px;
  font-weight:800;
}
.insight-banner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  margin-bottom:12px;
  background:linear-gradient(135deg,#fff,#EFF6FF);
}
.insight-banner h2{
  font-family:Sora;
  margin:4px 0;
  color:#081328;
}
.insight-banner button{
  border:0;
  border-radius:12px;
  padding:12px 16px;
  background:linear-gradient(135deg,var(--royal),var(--teal));
  color:#fff;
  font-weight:900;
}
.premium-analytics{
  grid-template-columns:1fr 1fr 1fr 1fr;
}
.driver-row{
  position:relative;
  display:grid;
  grid-template-columns:1fr 45px;
  gap:8px;
  align-items:center;
  padding:11px 0 16px;
  border-bottom:1px solid #EEF2F7;
  font-size:13px;
}
.driver-row i{
  position:absolute;
  left:0;
  right:0;
  bottom:5px;
  height:6px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--royal),var(--teal));
}
.impact-card{
  background:linear-gradient(180deg,#fff,#F8FBFF);
}
.workflow-stage{
  margin-bottom:14px;
}
.stage-line{
  display:grid;
  grid-template-columns:1fr 34px 1fr 34px 1.2fr 34px 1fr 34px 1fr;
  align-items:center;
  gap:8px;
}
.stage{
  text-align:center;
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px 12px;
  background:#fff;
}
.stage i{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  margin:0 auto 10px;
  border-radius:50%;
  background:#EFF6FF;
  color:var(--royal);
  font-style:normal;
  font-weight:900;
}
.stage.clariq{
  background:linear-gradient(135deg,#EFF6FF,#ECFEFF);
  border-color:#BFDBFE;
  transform:scale(1.02);
}
.stage.clariq i{
  background:linear-gradient(135deg,var(--royal),var(--teal));
  color:#fff;
}
.stage b,.stage span{
  display:block;
}
.stage span{
  color:var(--muted);
  font-size:12px;
  margin-top:6px;
}
.stage-line em{
  height:2px;
  background:linear-gradient(90deg,var(--royal),var(--teal));
  position:relative;
  overflow:hidden;
}
.stage-line em:after{
  content:"";
  position:absolute;
  left:-10px;
  top:-3px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--royal);
  animation:flow 1.6s linear infinite;
}
.intercept-note{
  margin-top:18px;
  border-radius:16px;
  background:#F8FAFC;
  border:1px solid var(--line);
  padding:16px;
}
.investor-hero{
  display:grid;
  grid-template-columns:1fr 260px;
  gap:20px;
  align-items:center;
  margin-bottom:12px;
  background:linear-gradient(135deg,#071226,#10245A);
  color:#fff;
  overflow:hidden;
  position:relative;
}
.investor-hero:after{
  content:"";
  position:absolute;
  right:-60px;
  bottom:-70px;
  width:360px;
  height:220px;
  background:url("assets/wave-bg.svg") center/cover no-repeat;
  opacity:.75;
}
.investor-hero h2{
  font-family:Sora;
  font-size:34px;
  margin:4px 0;
  color:#fff;
}
.investor-hero p,
.investor-hero .eyebrow{
  color:#CBD5E1;
}
.roi-stack{
  position:relative;
  z-index:1;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:18px;
}
.roi-stack strong{
  display:block;
  color:#5EEAD4;
  font-family:Sora;
  font-size:28px;
}
.roi-stack span{
  display:block;
  margin:2px 0 14px;
  color:#E2E8F0;
  font-size:12px;
}
.who-grid{
  margin-bottom:12px;
}
.investor-icons{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.investor-icons span{
  background:#F8FAFC;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
  font-weight:800;
  font-size:12px;
}
.market-map{
  margin-bottom:12px;
}
.scope-ring{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;
}
.scope-ring div{
  min-height:78px;
  border-radius:18px;
  background:#F8FAFC;
  border:1px solid var(--line);
  display:grid;
  place-items:center;
  font-weight:900;
}
.scope-ring .center{
  background:linear-gradient(135deg,var(--royal),var(--teal));
  color:#fff;
  box-shadow:0 12px 28px rgba(49,91,255,.22);
}
@media(max-width:1180px){
  .case-workspace,.premium-analytics,.investor-hero{grid-template-columns:1fr}
  .queue-grid{grid-template-columns:1fr}
  .stage-line{grid-template-columns:1fr}
  .stage-line em{height:28px;width:2px;margin:auto}
  .investor-icons,.scope-ring{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .case-toolbar{display:block}
  .filter-pills{margin-top:12px}
  .insight-banner{grid-template-columns:1fr}
  .investor-icons,.scope-ring{grid-template-columns:1fr}
}


/* === STORY MODE + ANALYTICS FIX PATCH === */
.brand small{display:none!important;}
.tagline{
  font-size:16px;
  line-height:1.55;
  margin-top:20px;
  margin-bottom:22px;
}
.tagline em{
  color:#1CE0D0;
  font-style:normal;
}
.story-toggle{
  background:#fff!important;
  color:#315BFF!important;
  border:1px solid #BFDBFE!important;
}
.story-overlay{
  display:none;
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:9999;
  max-width:360px;
}
body.story-mode .story-overlay{display:block;}
.story-card{
  background:#071226;
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
  border-radius:20px;
  padding:18px;
  box-shadow:0 24px 70px rgba(8,19,40,.32);
  position:relative;
  overflow:hidden;
}
.story-card:after{
  content:"";
  position:absolute;
  right:-50px;
  bottom:-60px;
  width:220px;
  height:160px;
  background:url("assets/wave-bg.svg") center/cover no-repeat;
  opacity:.65;
}
.story-card h3,.story-card p,.story-controls,.story-step{position:relative;z-index:1}
.story-step{
  color:#5EEAD4;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:11px;
  font-weight:900;
}
.story-card h3{
  font-family:Sora;
  margin:8px 0;
  color:#fff;
}
.story-card p{
  color:#CBD5E1;
  line-height:1.5;
}
.story-controls{
  display:flex;
  gap:10px;
}
.story-controls button{
  border:0;
  border-radius:12px;
  padding:10px 12px;
  font-weight:900;
  cursor:pointer;
}
.story-controls button:first-child{
  background:linear-gradient(135deg,#315BFF,#14B8A6);
  color:#fff;
}
.story-controls button:last-child{
  background:rgba(255,255,255,.1);
  color:#fff;
}
body.story-mode .confidence-main,
body.story-mode .active-case,
body.story-mode .action-card{
  outline:2px solid rgba(49,91,255,.30);
  box-shadow:0 0 0 8px rgba(49,91,255,.08), var(--shadow);
}
body.story-mode .story-focus{
  outline:3px solid rgba(20,184,166,.65)!important;
  box-shadow:0 0 0 10px rgba(20,184,166,.10), var(--shadow)!important;
}
body.story-mode .missing,
body.story-mode .needed{
  animation:pulseWarn 1.15s ease-in-out infinite;
}
body.story-mode.demo-improved #score,
body.story-mode.demo-improved #sideScore{
  animation:scorePop .8s ease;
}
body.story-mode.demo-improved #likelihood{
  color:#10B981!important;
}
@keyframes pulseWarn{
  0%,100%{filter:none;opacity:1}
  50%{filter:drop-shadow(0 0 7px rgba(245,158,11,.55));opacity:.82}
}
@keyframes scorePop{
  0%{transform:scale(.9)}
  45%{transform:scale(1.15)}
  100%{transform:scale(1)}
}
.chart-box{
  height:260px;
  width:100%;
  position:relative;
}
.chart-box canvas{
  width:100%!important;
  height:260px!important;
  display:block!important;
}
.analytics-grid canvas{
  display:block!important;
}
@media(max-width:760px){
  .story-overlay{
    left:16px;
    right:16px;
    bottom:16px;
    max-width:none;
  }
  .chart-box{
    height:240px;
  }
  .chart-box canvas{
    height:240px!important;
  }
}


/* === CINEMATIC STORY MODE + FINAL VISUAL PATCH === */
.brand small{display:none!important;}
.tagline{font-size:16px;line-height:1.55;margin-top:20px;margin-bottom:22px}
.tagline em{color:#1CE0D0;font-style:normal}

/* Filled active-case/action sections should never look empty while JS is loading */
#detailRows:empty::before{
  content:"Loading criteria intelligence…";
  display:block;
  color:#64748B;
  padding:18px 0;
}
#actions:empty::before{
  content:"Loading recommended actions…";
  display:block;
  color:#64748B;
  padding:18px 0;
}

/* Cinematic overlay */
.story-toggle{background:#fff!important;color:#315BFF!important;border:1px solid #BFDBFE!important}
.story-overlay{display:none;position:fixed;right:24px;bottom:24px;z-index:10020;max-width:390px}
body.story-mode .story-overlay{display:block;animation:storyIn .35s ease}
.story-card{
  background:linear-gradient(145deg,#071226,#0B1C44);
  color:#fff;border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:20px;
  box-shadow:0 24px 80px rgba(8,19,40,.38);position:relative;overflow:hidden
}
.story-card:after{content:"";position:absolute;right:-70px;bottom:-70px;width:260px;height:180px;background:url("assets/wave-bg.svg") center/cover no-repeat;opacity:.72}
.story-card h3,.story-card p,.story-controls,.story-step,.story-progress{position:relative;z-index:1}
.story-step{color:#5EEAD4;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:900}
.story-card h3{font-family:Sora;margin:8px 0;color:#fff}
.story-card p{color:#CBD5E1;line-height:1.5}
.story-controls{display:flex;gap:10px;margin-top:12px}
.story-controls button{border:0;border-radius:12px;padding:10px 12px;font-weight:900;cursor:pointer}
.story-controls button:first-child{background:linear-gradient(135deg,#315BFF,#14B8A6);color:#fff}
.story-controls button:last-child{background:rgba(255,255,255,.1);color:#fff}
.story-progress{height:6px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden;margin-top:12px}
.story-progress i{display:block;height:100%;width:0%;background:linear-gradient(90deg,#315BFF,#14B8A6);border-radius:99px;transition:width .45s ease}
@keyframes storyIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* Spotlight / focus */
.spotlight{display:none;position:fixed;inset:0;background:rgba(8,19,40,.22);z-index:10000;pointer-events:none;backdrop-filter:blur(1px)}
body.story-mode .spotlight{display:block}
body.story-mode .story-focus{
  position:relative!important;z-index:10010!important;
  outline:3px solid rgba(20,184,166,.75)!important;
  box-shadow:0 0 0 12px rgba(20,184,166,.12),0 24px 70px rgba(8,19,40,.22)!important;
  animation:focusPulse 1.6s ease-in-out infinite;
}
@keyframes focusPulse{0%,100%{filter:none}50%{filter:brightness(1.03)}}
body.story-mode .missing,body.story-mode .needed{animation:pulseWarn 1.05s ease-in-out infinite}
@keyframes pulseWarn{0%,100%{filter:none;opacity:1}50%{filter:drop-shadow(0 0 7px rgba(245,158,11,.6));opacity:.82}}

/* Cinematic score improvement */
body.story-improved #likelihood{color:#10B981!important}
body.story-improved #score,body.story-improved #sideScore{animation:scorePop .8s ease}
@keyframes scorePop{0%{transform:scale(.92)}45%{transform:scale(1.15)}100%{transform:scale(1)}}

/* Better active case content fade */
.detail-row,.action{animation:softRise .28s ease}
@keyframes softRise{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* Analytics canvas fix */
.chart-box{height:260px;width:100%;position:relative}
.chart-box canvas{width:100%!important;height:260px!important;display:block!important}
.analytics-grid canvas{display:block!important;min-height:240px}

/* Data Sources: node visual replaces generic brain */
.data-node-visual{
  position:absolute;right:18px;bottom:18px;width:118px;height:88px;opacity:.95
}
.data-node-visual .node,.data-node-visual .center-node{
  position:absolute;border-radius:50%;display:grid;place-items:center
}
.data-node-visual .node{width:14px;height:14px;background:#38BDF8;box-shadow:0 0 0 5px rgba(56,189,248,.12)}
.data-node-visual .n1{left:8px;top:8px}.data-node-visual .n2{right:12px;top:10px}.data-node-visual .n3{left:18px;bottom:12px}.data-node-visual .n4{right:6px;bottom:16px}
.data-node-visual .center-node{
  width:44px;height:44px;left:38px;top:22px;background:linear-gradient(135deg,#315BFF,#14B8A6);color:#fff;font-family:Sora;font-weight:900
}
.data-node-visual i{
  position:absolute;height:2px;background:linear-gradient(90deg,#315BFF,#14B8A6);transform-origin:left center;opacity:.75
}
.data-node-visual .l1{left:20px;top:17px;width:45px;transform:rotate(22deg)}
.data-node-visual .l2{left:58px;top:35px;width:48px;transform:rotate(-24deg)}
.data-node-visual .l3{left:28px;bottom:22px;width:45px;transform:rotate(-22deg)}
.data-node-visual .l4{left:58px;bottom:34px;width:45px;transform:rotate(18deg)}
.sources-card{position:relative;overflow:hidden}
.sources-card .source-list{padding-right:118px}

/* Story mode transformed UI classes */
.story-fixed .status.missing,.story-fixed .status.needed{color:#10B981!important}
.story-fixed .dot.missing,.story-fixed .dot.needed{color:#10B981!important}
.story-fixed .pill.low,.story-fixed #statusPill{background:#DCFCE7!important;color:#047857!important}

@media(max-width:760px){
  .story-overlay{left:16px;right:16px;bottom:16px;max-width:none}
  .sources-card .source-list{padding-right:0}
  .data-node-visual{position:relative;right:auto;bottom:auto;margin:18px auto 0}
}

.tagline {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 18px;
  letter-spacing: 0.2px;
  max-width: 260px;
}

.tagline em {
  font-weight: 400;
  opacity: 0.8;
  color: #7dd3fc;
  white-space: nowrap;
}


/* === FINAL POLISH PASS: DESKTOP LAYOUT + BLANK SPACE FIX === */

/* Fix the white gap issue next to sidebar: keep main content compact and start immediately */
.app{
  align-items:start !important;
}
.main{
  min-width:0 !important;
  padding:22px 22px 28px !important;
  display:block !important;
}
.topbar{
  min-height:0 !important;
  height:auto !important;
  margin-bottom:16px !important;
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:18px !important;
}
.topbar > div:first-child{
  max-width:650px !important;
}
.topbar h1{
  margin:0 !important;
  line-height:1.05 !important;
}
.topbar p{
  max-width:720px !important;
}
.top-actions{
  margin-top:0 !important;
  align-self:flex-start !important;
  flex-shrink:0 !important;
}

/* Make dashboard cards appear right under header, not below a large blank zone */
.kpi-grid{
  margin-top:0 !important;
  align-items:stretch !important;
}
.dashboard-grid,.middle-grid,.lower-grid{
  margin-top:12px !important;
}

/* Keep chart cards from becoming huge/blank on desktop */
.kpi canvas{
  height:54px !important;
  max-height:54px !important;
}
.chart-box{
  height:240px !important;
  min-height:240px !important;
}
.chart-box canvas{
  height:240px !important;
}
.analytics-grid canvas{
  min-height:220px !important;
  max-height:240px !important;
}

/* Sidebar subtitle refinement */
.tagline{
  font-size:14px !important;
  font-weight:500 !important;
  line-height:1.55 !important;
  margin-top:18px !important;
  letter-spacing:.1px !important;
  max-width:260px !important;
}
.tagline em{
  font-weight:400 !important;
  opacity:.88 !important;
  color:#7DD3FC !important;
  white-space:nowrap !important;
}

/* Make nav panel closer to reference */
.sidebar{
  width:280px !important;
}
.sidebar:after{
  opacity:.95 !important;
}

/* Better desktop proportions */
@media(min-width:1181px){
  .kpi-grid{
    grid-template-columns:1.35fr repeat(4, minmax(150px,1fr)) !important;
  }
  .dashboard-grid{
    grid-template-columns:1.22fr .82fr .9fr !important;
  }
}

/* Laptop/smaller desktop: avoid forced blank horizontal/vertical space */
@media(max-width:1250px){
  .topbar{
    flex-wrap:wrap !important;
  }
  .top-actions{
    width:auto !important;
  }
  .kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

/* Mobile remains clean */
@media(max-width:760px){
  .main{
    padding:16px !important;
  }
  .topbar{
    display:block !important;
  }
  .top-actions{
    margin-top:14px !important;
    display:grid !important;
    grid-template-columns:1fr auto auto !important;
    width:100% !important;
  }
  .kpi-grid{
    grid-template-columns:1fr !important;
  }
}
