/* ============================================================
   THE JEFF QUARTERLY — INDIA DESK
   Editorial dark research journal. Instrument Serif / Newsreader /
   JetBrains Mono. Warm charcoal, amber brand, per-company accents.
   ============================================================ */
@import url('https://fonts.bunny.net/css?family=instrument-serif:400,400i|newsreader:400,400i,500,500i,600|jetbrains-mono:400,500,700');

:root {
  --bg: #0f0d0a;
  --bg-elev: #15110d;
  --bg-card: #191510;
  --bg-card-hover: #1f1a13;
  --ink: #ece3d3;
  --ink-dim: #b0a591;
  --ink-faint: #786e5d;
  --amber: #d9a23f;
  --amber-bright: #f0bd55;
  --amber-dim: rgba(217,162,63,.14);
  --rule: #2b2419;
  --rule-strong: #3d3322;
  --up: #84b573;
  --down: #cb5f52;
  --flat: #9b917e;
  --accent: var(--amber);
  --accent-dim: var(--amber-dim);
  --serif-display: 'Instrument Serif', Georgia, serif;
  --serif-body: 'Newsreader', Georgia, serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
  --maxw: 1080px;
}
body[data-company="maruti"] { --accent: #8fb7d9; --accent-dim: rgba(143,183,217,.13); }
body[data-company="iex"]    { --accent: #5cc9a7; --accent-dim: rgba(92,201,167,.13); }
body[data-company="itc"]    { --accent: #d98d5f; --accent-dim: rgba(217,141,95,.13); }

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--serif-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
/* grain + vignette atmosphere */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}
body::after {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(1200px 500px at 50% -10%, rgba(217,162,63,.06), transparent 60%),
    radial-gradient(900px 600px at 100% 100%, rgba(0,0,0,.45), transparent 55%);
}
main, header.masthead, footer { position: relative; z-index: 1; }
a { color: var(--amber-bright); text-decoration: none; }
a:hover { text-decoration: underline; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* ---------- masthead ---------- */
header.masthead {
  border-bottom: 1px solid var(--rule-strong);
  padding: 34px 0 22px;
  animation: fadeDown .7s cubic-bezier(.2,.7,.3,1) both;
}
.mast-top { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.mast-brand { font-family: var(--mono); font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--ink-dim); }
.mast-brand a { color: var(--ink-dim); }
.mast-brand a:hover { color: var(--amber-bright); text-decoration: none; }
.mast-date { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--ink-faint); }
h1.mast-title {
  font-family: var(--serif-display);
  font-weight: 400;
  font-size: clamp(44px, 7vw, 84px);
  line-height: 1.02;
  letter-spacing: -.01em;
  margin-top: 18px;
}
h1.mast-title em { font-style: italic; color: var(--amber); }
.mast-dek {
  margin-top: 14px; max-width: 720px;
  font-size: 19px; color: var(--ink-dim); font-style: italic;
}
.mast-meta { margin-top: 18px; display: flex; gap: 22px; flex-wrap: wrap; font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
.mast-meta span b { color: var(--ink-dim); font-weight: 500; }

/* ---------- editor's note ---------- */
.editors-note {
  margin: 36px 0 8px; padding: 26px 30px;
  border-left: 2px solid var(--amber);
  background: linear-gradient(90deg, var(--amber-dim), transparent 70%);
  animation: fadeUp .7s .15s cubic-bezier(.2,.7,.3,1) both;
}
.editors-note .kicker { margin-bottom: 10px; }
.editors-note p { font-size: 17.5px; color: var(--ink-dim); max-width: 860px; }
.editors-note p + p { margin-top: 10px; }
.editors-note strong { color: var(--ink); font-weight: 600; }

.kicker {
  font-family: var(--mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: .26em; text-transform: uppercase; color: var(--amber);
}

/* ---------- compare strip ---------- */
.compare { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 34px 0 10px; }
.compare-card {
  position: relative; text-align: left; cursor: pointer;
  background: var(--bg-card); border: 1px solid var(--rule);
  padding: 20px 20px 16px; transition: border-color .25s, transform .25s, background .25s;
  font-family: inherit; color: inherit;
  animation: fadeUp .6s cubic-bezier(.2,.7,.3,1) both;
}
.compare-card:nth-child(2) { animation-delay: .08s; }
.compare-card:nth-child(3) { animation-delay: .16s; }
.compare-card:hover { transform: translateY(-3px); background: var(--bg-card-hover); }
.compare-card[data-c="maruti"]:hover, .compare-card[data-c="maruti"].active { border-color: #8fb7d9; }
.compare-card[data-c="iex"]:hover,    .compare-card[data-c="iex"].active    { border-color: #5cc9a7; }
.compare-card[data-c="itc"]:hover,    .compare-card[data-c="itc"].active    { border-color: #d98d5f; }
.compare-card .cc-tick { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: var(--ink-faint); }
.compare-card .cc-name { font-family: var(--serif-display); font-size: 26px; margin: 4px 0 10px; }
.compare-card .cc-price { font-family: var(--mono); font-size: 22px; font-weight: 500; }
.compare-card .cc-price small { font-size: 12px; color: var(--ink-faint); }
.compare-card .cc-row { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11px; color: var(--ink-dim); margin-top: 7px; border-top: 1px dashed var(--rule); padding-top: 7px; }
.compare-card .cc-row b { font-weight: 500; color: var(--ink); }
.compare-card .neg { color: var(--down); } .compare-card .pos { color: var(--up); }

/* ---------- tab bar ---------- */
nav.tabbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(15,13,10,.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--rule-strong);
  margin-top: 30px;
}
.tabbar-inner { display: flex; gap: 4px; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
.tab-btn {
  appearance: none; background: none; border: none; cursor: pointer;
  font-family: var(--mono); font-size: 12px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-faint); padding: 16px 22px 14px; border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.tab-btn:hover { color: var(--ink-dim); }
.tab-btn.active { color: var(--ink); border-bottom-color: var(--accent); }
.tab-btn .dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; margin-right: 8px; vertical-align: 1px; }
.tab-btn[data-c="maruti"] .dot { background: #8fb7d9; }
.tab-btn[data-c="iex"] .dot    { background: #5cc9a7; }
.tab-btn[data-c="itc"] .dot    { background: #d98d5f; }

/* ---------- company panels ---------- */
section.company { display: none; padding-bottom: 30px; }
section.company.active { display: block; }
section.company.active > * { animation: fadeUp .55s cubic-bezier(.2,.7,.3,1) both; }
section.company.active > *:nth-child(2) { animation-delay: .06s; }
section.company.active > *:nth-child(3) { animation-delay: .12s; }

/* hero */
.hero { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; padding: 44px 0 34px; border-bottom: 1px solid var(--rule); }
.hero h2 { font-family: var(--serif-display); font-weight: 400; font-size: clamp(36px, 4.6vw, 56px); line-height: 1.05; }
.hero .hero-sector { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); margin: 4px 0 14px; }
.hero .hero-thesis { font-size: 18px; font-style: italic; color: var(--ink-dim); max-width: 560px; }
.hero-right { display: flex; flex-direction: column; gap: 14px; justify-content: center; }
.price-block { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.price-big { font-family: var(--mono); font-size: 46px; font-weight: 500; letter-spacing: -.02em; }
.price-big small { font-size: 16px; color: var(--ink-faint); font-weight: 400; }
.chip {
  display: inline-block; font-family: var(--mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; padding: 5px 12px;
  border: 1px solid var(--accent); color: var(--accent); border-radius: 2px;
}
.range-wrap { margin-top: 4px; }
.range-labels { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10.5px; color: var(--ink-faint); margin-bottom: 6px; }
.range-bar { position: relative; height: 4px; background: var(--rule-strong); border-radius: 2px; }
.range-fill { position: absolute; left: 0; top: 0; bottom: 0; background: linear-gradient(90deg, var(--accent), transparent); opacity: .35; border-radius: 2px; }
.range-marker {
  position: absolute; top: 50%; width: 12px; height: 12px; border-radius: 50%;
  background: var(--accent); border: 2px solid var(--bg); transform: translate(-50%, -50%);
  box-shadow: 0 0 0 2px var(--accent), 0 0 14px var(--accent);
  transition: left 1.2s cubic-bezier(.2,.7,.2,1);
}
.target-line { display: flex; gap: 26px; flex-wrap: wrap; }
.target-item .t-label { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); }
.target-item .t-val { font-family: var(--mono); font-size: 21px; font-weight: 500; margin-top: 2px; }
.target-item .t-val.pos { color: var(--up); } .target-item .t-val.neg { color: var(--down); }

/* conviction gauge */
.gauge-row { display: flex; align-items: center; gap: 14px; }
.gauge-row svg { flex: none; }
.gauge-note { font-size: 14px; font-style: italic; color: var(--ink-dim); line-height: 1.45; }

/* section heads */
.sec-head { display: flex; align-items: baseline; gap: 16px; margin: 46px 0 8px; }
.sec-head .sec-num { font-family: var(--mono); font-size: 12px; color: var(--accent); letter-spacing: .1em; }
.sec-head h3 { font-family: var(--serif-display); font-weight: 400; font-size: 30px; letter-spacing: .01em; }
.sec-head::after { content: ''; flex: 1; border-bottom: 1px solid var(--rule); transform: translateY(-6px); }
.sec-sub { color: var(--ink-dim); font-style: italic; font-size: 15.5px; margin-bottom: 22px; max-width: 760px; }

/* ---------- KPI grid ---------- */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(235px, 1fr)); gap: 12px; margin-top: 20px; }
.kpi {
  background: var(--bg-card); border: 1px solid var(--rule); padding: 16px 16px 13px;
  transition: transform .2s, border-color .2s, background .2s; position: relative; overflow: hidden;
}
.kpi:hover { transform: translateY(-2px); border-color: var(--rule-strong); background: var(--bg-card-hover); }
.kpi::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--accent); opacity: 0; transition: opacity .2s; }
.kpi:hover::before { opacity: 1; }
.kpi .k-label { font-family: var(--mono); font-size: 9.5px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); min-height: 26px; }
.kpi .k-val { font-family: var(--mono); font-size: 19px; font-weight: 500; margin: 6px 0 6px; display: flex; align-items: baseline; gap: 8px; }
.kpi .k-arrow { font-size: 13px; }
.kpi .k-arrow.up { color: var(--up); } .kpi .k-arrow.down { color: var(--down); } .kpi .k-arrow.flat { color: var(--flat); }
.kpi .k-note { font-size: 12.5px; line-height: 1.45; color: var(--ink-dim); font-style: italic; }

/* ---------- charts ---------- */
figure.chart { background: var(--bg-elev); border: 1px solid var(--rule); padding: 22px 22px 14px; margin-top: 20px; }
figure.chart figcaption { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
figure.chart .fig-title { font-family: var(--serif-display); font-size: 21px; }
figure.chart .fig-note { font-family: var(--mono); font-size: 10px; letter-spacing: .08em; color: var(--ink-faint); text-transform: uppercase; }
figure.chart svg { display: block; width: 100%; height: auto; }
.chart-legend { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--rule); }
.chart-legend span { font-family: var(--mono); font-size: 10.5px; letter-spacing: .08em; color: var(--ink-dim); display: inline-flex; align-items: center; gap: 7px; }
.chart-legend i { width: 14px; height: 3px; display: inline-block; }
.chart-legend i.swatch-box { height: 9px; }
.fig-footnote { font-size: 12px; color: var(--ink-faint); font-style: italic; margin-top: 8px; }

#tooltip {
  position: fixed; z-index: 100; pointer-events: none; opacity: 0; transition: opacity .12s;
  background: #221c13; border: 1px solid var(--rule-strong); padding: 8px 12px;
  font-family: var(--mono); font-size: 11.5px; line-height: 1.6; color: var(--ink);
  box-shadow: 0 8px 28px rgba(0,0,0,.55); max-width: 280px; white-space: pre-line;
}
#tooltip .tt-head { color: var(--amber-bright); font-weight: 700; }

/* svg text */
svg text { font-family: 'JetBrains Mono', monospace; fill: var(--ink-faint); }

/* ---------- scenarios ---------- */
.scen-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 20px; }
.scen-card {
  appearance: none; font-family: inherit; color: inherit; text-align: left; cursor: pointer;
  background: var(--bg-card); border: 1px solid var(--rule); padding: 18px 18px 14px;
  transition: border-color .2s, transform .2s;
}
.scen-card:hover { transform: translateY(-2px); }
.scen-card.active { border-color: var(--accent); background: var(--bg-card-hover); }
.scen-card .s-name { font-family: var(--mono); font-size: 10.5px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; }
.scen-card.bear .s-name { color: var(--down); }
.scen-card.base .s-name { color: var(--amber); }
.scen-card.bull .s-name { color: var(--up); }
.scen-card .s-target { font-family: var(--mono); font-size: 27px; font-weight: 500; margin: 8px 0 2px; }
.scen-card .s-upside { font-family: var(--mono); font-size: 11.5px; color: var(--ink-dim); }
.prob-track { height: 3px; background: var(--rule-strong); margin-top: 12px; position: relative; }
.prob-fill { position: absolute; left: 0; top: 0; bottom: 0; width: 0; transition: width .9s cubic-bezier(.2,.7,.2,1); }
.scen-card.bear .prob-fill { background: var(--down); }
.scen-card.base .prob-fill { background: var(--amber); }
.scen-card.bull .prob-fill { background: var(--up); }
.scen-card .s-prob { font-family: var(--mono); font-size: 10px; color: var(--ink-faint); margin-top: 6px; letter-spacing: .1em; }
.scen-narrative {
  margin-top: 14px; padding: 20px 24px; border-left: 2px solid var(--accent);
  background: var(--bg-elev); font-size: 16px; color: var(--ink-dim); line-height: 1.7; min-height: 96px;
}
.scen-narrative b { color: var(--ink); }
.ladder-fig { margin-top: 16px; }

/* ---------- forecast table & data tables ---------- */
.data-table { width: 100%; border-collapse: collapse; margin-top: 18px; font-size: 14.5px; }
.data-table th {
  font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--rule-strong);
}
.data-table td { padding: 10px 12px; border-bottom: 1px solid var(--rule); color: var(--ink-dim); }
.data-table td.num, .data-table th.num { text-align: right; font-family: var(--mono); font-size: 13.5px; }
.data-table td.num { color: var(--ink); }
.data-table tr:hover td { background: rgba(217,162,63,.04); }
.data-table td.est { color: var(--amber-bright); }
.data-table .rowlabel { color: var(--ink); font-weight: 500; }
.assume { margin-top: 16px; columns: 2; column-gap: 36px; }
.assume li { font-size: 14px; color: var(--ink-dim); margin: 0 0 9px 18px; break-inside: avoid; }
.assume li::marker { color: var(--accent); }

/* ---------- street pulse ---------- */
.pulse-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 20px; }
.pulse-card { background: var(--bg-card); border: 1px solid var(--rule); padding: 20px; position: relative; transition: border-color .2s; }
.pulse-card:hover { border-color: var(--rule-strong); }
.pulse-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.pulse-src { font-family: var(--mono); font-size: 9.5px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); border: 1px solid var(--rule-strong); padding: 3px 8px; }
.pulse-sent { font-family: var(--mono); font-size: 9.5px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; padding: 3px 8px; }
.pulse-sent.bullish { color: var(--up); border: 1px solid rgba(132,181,115,.4); }
.pulse-sent.bearish { color: var(--down); border: 1px solid rgba(203,95,82,.4); }
.pulse-sent.mixed { color: var(--flat); border: 1px solid rgba(155,145,126,.4); }
.pulse-theme { font-family: var(--serif-display); font-size: 20px; line-height: 1.25; margin-bottom: 8px; }
.pulse-detail { font-size: 13.5px; color: var(--ink-dim); line-height: 1.55; }
.pulse-verdict { margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--rule); font-size: 13.5px; line-height: 1.55; }
.pulse-verdict .v-tag { font-family: var(--mono); font-size: 9px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); display: block; margin-bottom: 4px; }

/* ---------- risks & catalysts ---------- */
.rc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 20px; }
.rc-col h4 { font-family: var(--mono); font-size: 11px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; padding-bottom: 10px; border-bottom: 1px solid var(--rule-strong); margin-bottom: 4px; }
.rc-col.risks h4 { color: var(--down); }
.rc-col.cats h4 { color: var(--up); }
.rc-col ul { list-style: none; }
.rc-col li { padding: 11px 0 11px 22px; border-bottom: 1px solid var(--rule); font-size: 14px; color: var(--ink-dim); line-height: 1.55; position: relative; }
.rc-col.risks li::before { content: '–'; position: absolute; left: 2px; color: var(--down); font-family: var(--mono); }
.rc-col.cats li::before { content: '+'; position: absolute; left: 2px; color: var(--up); font-family: var(--mono); }

/* ---------- full report prose ---------- */
details.full-report { margin-top: 26px; border: 1px solid var(--rule-strong); background: var(--bg-elev); }
details.full-report > summary {
  cursor: pointer; list-style: none; padding: 20px 26px; display: flex; align-items: center; gap: 16px;
  font-family: var(--mono); font-size: 11.5px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--amber);
  transition: background .2s;
}
details.full-report > summary:hover { background: var(--bg-card-hover); }
details.full-report > summary::-webkit-details-marker { display: none; }
details.full-report > summary::before { content: '+'; font-size: 18px; font-weight: 400; color: var(--accent); width: 18px; }
details.full-report[open] > summary::before { content: '−'; }
details.full-report > summary .wc { margin-left: auto; color: var(--ink-faint); font-weight: 400; letter-spacing: .1em; }
.prose { padding: 10px 46px 50px; max-width: 860px; }
.prose h1 { display: none; }
.prose h2 {
  font-family: var(--serif-display); font-weight: 400; font-size: 28px; margin: 44px 0 14px;
  padding-top: 22px; border-top: 1px solid var(--rule-strong); letter-spacing: .01em;
}
.prose h3 { font-family: var(--serif-body); font-weight: 600; font-size: 19px; margin: 28px 0 10px; color: var(--ink); }
.prose h4 { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--amber); margin: 22px 0 8px; }
.prose p { margin: 0 0 14px; color: var(--ink-dim); font-size: 16px; }
.prose strong { color: var(--ink); font-weight: 600; }
.prose em { color: var(--ink-dim); }
.prose ul, .prose ol { margin: 0 0 16px 22px; color: var(--ink-dim); font-size: 15.5px; }
.prose li { margin-bottom: 6px; }
.prose li::marker { color: var(--accent); }
.prose hr { border: none; border-top: 1px dashed var(--rule-strong); margin: 30px 0; }
.prose code { font-family: var(--mono); font-size: 13px; background: var(--bg-card); padding: 1px 6px; border: 1px solid var(--rule); }
.prose blockquote { border-left: 2px solid var(--accent); padding: 4px 0 4px 20px; margin: 0 0 16px; font-style: italic; }
.tbl-wrap { overflow-x: auto; margin: 0 0 20px; border: 1px solid var(--rule); }
.prose table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.prose table th {
  font-family: var(--mono); font-size: 9.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-faint); text-align: left; padding: 9px 12px; background: var(--bg-card);
  border-bottom: 1px solid var(--rule-strong); white-space: nowrap;
}
.prose table td { padding: 8px 12px; border-bottom: 1px solid var(--rule); color: var(--ink-dim); vertical-align: top; }
.prose table td.num { font-family: var(--mono); font-size: 12.5px; text-align: right; color: var(--ink); white-space: nowrap; }
.prose table tr:last-child td { border-bottom: none; }
.prose table tr:hover td { background: rgba(217,162,63,.045); }

/* ---------- footer ---------- */
footer { border-top: 1px solid var(--rule-strong); margin-top: 70px; padding: 36px 0 60px; }
footer .foot-grid { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; }
footer p { font-size: 13px; color: var(--ink-faint); max-width: 640px; line-height: 1.6; }
footer .foot-brand { font-family: var(--serif-display); font-size: 24px; color: var(--ink-dim); }
footer .foot-brand em { color: var(--amber); }

/* ---------- animations ---------- */
@keyframes fadeDown { from { opacity: 0; transform: translateY(-14px); } to { opacity: 1; transform: none; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

/* ---------- responsive ---------- */
@media (max-width: 880px) {
  .compare { grid-template-columns: 1fr; }
  .hero { grid-template-columns: 1fr; gap: 24px; }
  .scen-grid { grid-template-columns: 1fr; }
  .pulse-grid { grid-template-columns: 1fr; }
  .rc-grid { grid-template-columns: 1fr; }
  .assume { columns: 1; }
  .prose { padding: 6px 24px 36px; }
  .tabbar-inner { padding: 0 12px; overflow-x: auto; }
  .tab-btn { padding: 14px 14px 12px; white-space: nowrap; }
  .wrap { padding: 0 18px; }
}
