/* Market Study — components.css */
/* ════════════════════════════════════════════
   SECTION HEADER
════════════════════════════════════════════ */
.sec-head{display:flex;align-items:center;gap:10px;margin:0 0 14px}
.sec-ico{
  width:28px;height:28px;border-radius:9px;display:grid;place-items:center;
  color:#fff;font-size:12px;
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  box-shadow:0 4px 12px rgba(99,72,222,.3);flex-shrink:0;
}
.sec-head h2{font-family:var(--dp);font-weight:700;font-size:16px;letter-spacing:-.02em}
.sec-head .hint{margin-left:auto;font-size:11.5px;color:var(--muted)}
.sec-mb{margin-bottom:18px}

/* ════════════════════════════════════════════
   BIAS HERO CARD
════════════════════════════════════════════ */
.bias-card{padding:22px;position:relative;overflow:hidden;border:none;transition:background .5s}
.bias-card.up{background:linear-gradient(145deg,#059669,#16A34A,#15803D)}
.bias-card.down{background:linear-gradient(145deg,#E11D48,#DC2626,#B91C1C)}
.bias-card.neutral{background:linear-gradient(145deg,#D97706,#B45309,#92400E)}
.bias-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,.08);
}
.bias-card::after{
  content:'';position:absolute;bottom:-60px;left:-30px;
  width:240px;height:240px;border-radius:50%;
  background:rgba(255,255,255,.06);
}
.bias-inner{position:relative;z-index:1}
.bias-eye{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:6px;margin-bottom:10px}
.bias-dir{font-family:var(--dp);font-size:clamp(30px,3.6vw,44px);font-weight:800;color:#fff;line-height:1;display:flex;align-items:center;gap:12px;margin-bottom:6px}
.bias-sub{font-size:12.5px;color:rgba(255,255,255,.88);line-height:1.55;max-width:32ch}
.conf-wrap{margin-top:14px}
.conf-row{display:flex;justify-content:space-between;font-size:11.5px;font-weight:700;color:rgba(255,255,255,.9);margin-bottom:5px}
.conf-track{height:8px;background:rgba(255,255,255,.22);border-radius:999px;overflow:hidden}
.conf-fill{height:100%;background:rgba(255,255,255,.95);border-radius:999px;transition:width .7s cubic-bezier(.2,.8,.2,1)}
.bias-stamp{font-size:11px;color:rgba(255,255,255,.78);margin-top:12px;display:flex;align-items:center;gap:6px}
/* Nearest-strike intel (inside coloured bias card) */
.strike-intel{margin-top:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:12px;padding:11px 12px;backdrop-filter:blur(4px)}
.si-head{font-family:var(--dp);font-weight:700;font-size:11.5px;color:#fff;display:flex;align-items:center;gap:6px;margin-bottom:9px}
.si-time{margin-left:auto;font-size:10px;font-weight:600;color:rgba(255,255,255,.75)}
.si-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:9px}
.si-pill{background:rgba(255,255,255,.92);border-radius:9px;padding:8px 10px;display:flex;flex-direction:column;gap:1px}
.si-pill-lbl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;display:flex;align-items:center;gap:4px}
.si-pill.buy .si-pill-lbl{color:var(--bull)}
.si-pill.sell .si-pill-lbl{color:var(--bear)}
.si-pill-strike{font-family:var(--nm);font-size:16px;font-weight:700;color:var(--ink);line-height:1.1}
.si-pill-amt{font-family:var(--nm);font-size:11.5px;font-weight:600;color:var(--muted)}
.si-watch{background:rgba(255,255,255,.92);border-radius:9px;padding:8px 11px;font-size:11.5px;color:var(--ink2);display:flex;align-items:center;gap:8px;line-height:1.4}
.si-watch i{color:var(--brand2);font-size:13px;flex-shrink:0}
.si-watch b{color:var(--ink);font-weight:700}

/* white spark tile */
.ws-tile{
  margin-top:14px;background:rgba(255,255,255,.95);border-radius:11px;
  padding:10px 12px 8px;box-shadow:0 6px 18px rgba(0,0,0,.16);position:relative;z-index:1;
}
.ws-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}
.ws-label{font-size:10.5px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px;letter-spacing:.03em;text-transform:uppercase}
.ws-val{font-family:var(--nm);font-size:13.5px;font-weight:700}
.ws-spark{height:46px;margin-top:3px}
.ws-stats{display:flex;justify-content:space-between;margin-top:7px;padding-top:7px;border-top:1px solid #EDF0F7}
.ws-stats div{text-align:center;font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.ws-stats b{display:block;font-family:var(--nm);font-size:12px;color:var(--ink);text-transform:none;margin-top:1px}

/* ════════════════════════════════════════════
   KPI MINI CARDS (row of 4)
════════════════════════════════════════════ */
.kpi-card{padding:16px 18px;position:relative;overflow:hidden}
.kpi-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--kpi-accent,linear-gradient(var(--brand),var(--brand2)));
  border-radius:4px 0 0 4px;
}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.kpi-lbl{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.kpi-ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:13px}
.kpi-val{font-family:var(--nm);font-size:24px;font-weight:700;letter-spacing:-.01em;line-height:1;margin-bottom:5px}
.kpi-tag{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px}
.kpi-tag.g{color:var(--bull);background:var(--bull-bg)}
.kpi-tag.r{color:var(--bear);background:var(--bear-bg)}
.kpi-tag.w{color:var(--warn);background:var(--warn-bg)}

/* ════════════════════════════════════════════
   LIVE SNAPSHOT CHARTS (in Overview)
════════════════════════════════════════════ */
.snap-card{padding:18px 18px 14px}
.snap-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:6px}
.snap-card-head h3{font-family:var(--dp);font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:7px}
.snap-card-head .date-badge{
  font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;
  background:#EEF0FF;color:var(--brand);
}
.sc-legend{display:flex;gap:10px;flex-wrap:wrap}
.sc-legend b{font-size:10px;font-weight:700;color:var(--ink2);display:flex;align-items:center;gap:4px}
.sc-legend i{width:8px;height:8px;border-radius:3px;display:inline-block}
.chart-h100{position:relative;height:100px}
.chart-h120{position:relative;height:120px}
.chart-h140{position:relative;height:140px}
.chart-h160{position:relative;height:160px}
.chart-h200{position:relative;height:200px}
.chart-h220{position:relative;height:220px}
/* Horizontal scroll wrapper — keeps charts readable when many data points */
.chart-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:4px}
.chart-scroll::-webkit-scrollbar{height:6px}
.chart-scroll::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:9px}
.chart-scroll::-webkit-scrollbar-track{background:#F1F4FB;border-radius:9px}
.chart-scroll>div{min-width:100%}
/* Overview nav-cards (quick links) */
.nav-card{display:flex;align-items:center;gap:14px;padding:18px 20px;cursor:pointer;transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s;position:relative;overflow:hidden}
.nav-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(124,58,237,.05),transparent);opacity:0;transition:opacity .2s}
.nav-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.nav-card:hover::after{opacity:1}
.nav-card:hover .nav-card-arrow{transform:translateX(4px);color:var(--brand2)}
.nav-card-ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;font-size:18px;flex-shrink:0;box-shadow:0 6px 16px rgba(48,40,120,.22)}
.nav-card-body{flex:1;min-width:0}
.nav-card-title{font-family:var(--dp);font-weight:700;font-size:15px;color:var(--ink)}
.nav-card-sub{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4}
.nav-card-arrow{color:var(--faint);font-size:14px;transition:transform .2s,color .2s;flex-shrink:0}

/* ════════════════════════════════════════════
   SESSION BARS CARD
════════════════════════════════════════════ */
.session-card{padding:18px 20px}
.session-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.session-nums{display:flex;gap:20px}
.sn-item .sn-big{font-family:var(--nm);font-size:34px;font-weight:700;line-height:1}
.sn-item .sn-lbl{font-size:11px;font-weight:600;color:var(--muted);margin-top:2px}

/* ════════════════════════════════════════════
   SENTIMENT / DONUT
════════════════════════════════════════════ */
.sentiment-card{padding:20px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.sent-lbl{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);align-self:flex-start}
.sent-donut{position:relative;width:110px;height:110px}
.sent-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.sent-emoji{font-size:26px}
.sent-word{font-family:var(--dp);font-weight:700;font-size:12px}
.sent-rating{font-family:var(--nm);font-size:26px;font-weight:700}
.sent-sub{font-size:11.5px;color:var(--muted)}

/* ════════════════════════════════════════════
   LATEST REVIEWS STRIP
════════════════════════════════════════════ */
.reviews-strip{padding:18px 20px}
.mini-rev{display:flex;gap:11px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line2)}
.mini-rev:last-child{border-bottom:none;padding-bottom:0}
.mini-av{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;
}
.mini-name{font-family:var(--dp);font-weight:700;font-size:13px}
.mini-body{font-size:12px;color:var(--ink2);line-height:1.5;margin-top:3px}
