/* ============================================================
   NEETI — Warm Intelligence design system
   Shared across every page. Single source of truth.
   warm ivory paper · brown-black ink · ONE vermilion accent
   Zodiak (serif display) × Hanken Grotesk (body)
   readability-first: comfortable size, line-height, measure
   ============================================================ */

/* ---- tokens ---- */
:root{
  --paper:    oklch(0.965 0.012 88);   /* warm ivory, never #fff */
  --paper-2:  oklch(0.945 0.014 85);
  --paper-3:  oklch(0.925 0.016 84);
  --ink:      oklch(0.27 0.020 50);    /* warm brown-black, never #000 */
  --ink-2:    oklch(0.43 0.022 50);
  --ink-3:    oklch(0.56 0.020 52);
  --rule:     oklch(0.86 0.018 78);
  --rule-2:   oklch(0.90 0.014 80);
  --verm:     oklch(0.55 0.185 32);    /* the single accent */
  --verm-hi:  oklch(0.50 0.19 31);
  --up:       oklch(0.50 0.13 150);
  --down:     oklch(0.52 0.17 30);

  --maxw: 1160px;
  --maxw-read: 760px;                  /* comfortable reading column */
  --gut: clamp(22px, 5.5vw, 72px);
  --serif: "Zodiak", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --deva:  "Rozha One", "Tiro Devanagari Hindi", var(--serif);  /* Hindi नीति wordmark */
}

/* ---- reset / base ---- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-weight:400;
  font-size:clamp(16.5px, 1.15vw, 19px);
  line-height:1.68; letter-spacing:0;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--verm); color:var(--paper); }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }
.read{ max-width:var(--maxw-read); margin:0 auto; padding:0 var(--gut); }
img{ max-width:100%; display:block; }

/* ---- masthead + nav ---- */
.mast{ border-bottom:1px solid var(--ink); position:sticky; top:0; z-index:40;
  background:oklch(0.965 0.012 88 / .9); backdrop-filter:saturate(120%) blur(8px); }
.mast .top{ max-width:var(--maxw); margin:0 auto; padding:14px var(--gut);
  display:flex; align-items:center; justify-content:space-between; gap:20px; }
.mast .name{ font-family:var(--deva); font-weight:400; font-size:1.7rem; line-height:1; flex-shrink:0; }
.mast .name .d{ color:var(--verm); }
.mast nav{ display:flex; align-items:center; gap:clamp(14px,2.2vw,30px); margin-left:auto; }
.mast nav a{ font-size:0.92rem; color:var(--ink-2); white-space:nowrap; transition:color .2s; }
.mast nav a:hover{ color:var(--ink); }
.mast nav a.on{ color:var(--ink); font-weight:500; }
.mast nav a.cta{ background:var(--verm); color:var(--paper); font-weight:600; font-size:0.86rem;
  padding:8px 16px; border-radius:3px; transition:background .2s; }
.mast nav a.cta:hover{ background:var(--verm-hi); color:var(--paper); }
.mast .rule2{ height:1px; background:var(--ink); margin-top:1px; opacity:0.32; }
.mast .meta{ font-size:0.78rem; color:var(--ink-3); letter-spacing:0.05em;
  font-variant-numeric:tabular-nums; display:inline-flex; align-items:center; gap:9px; }
.mast .meta .liveDot{ width:6px; height:6px; border-radius:50%; background:var(--verm);
  animation:pulse 2.6s ease-out infinite; flex-shrink:0; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 oklch(0.55 0.185 32 / .45);} 70%{ box-shadow:0 0 0 7px oklch(0.55 0.185 32 / 0);} 100%{ box-shadow:0 0 0 0 oklch(0.55 0.185 32 / 0);} }
@media(prefers-reduced-motion:reduce){ .mast .meta .liveDot{ animation:none; } }
@media(max-width:680px){
  .mast nav a.lnk{ display:none; }            /* keep brand + CTA on small screens */
  .mast .top{ padding:12px var(--gut); }
}

/* ---- shared buttons / email field ---- */
.field{ display:flex; border:1px solid var(--ink); border-radius:3px;
  background:var(--paper); overflow:hidden; }
.field input{ flex:1; min-width:0; background:transparent; border:0; outline:0;
  color:var(--ink); font-family:var(--sans); font-size:1rem; padding:14px 16px; }
.field input::placeholder{ color:var(--ink-3); }
.field button{ border:0; cursor:pointer; background:var(--verm); color:var(--paper);
  font-family:var(--sans); font-weight:600; font-size:0.92rem; padding:0 24px; white-space:nowrap;
  transition:background .2s, transform .15s; }
.field button:hover{ background:var(--verm-hi); }
.field button:active{ transform:scale(.98); }
.field button:disabled{ opacity:.6; cursor:default; }
/* honeypot: off-screen (not display:none, which some bots skip), never reachable by keyboard */
.hp{ position:absolute !important; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; opacity:0; pointer-events:none; }
.cap{ max-width:480px; }
.cap .note{ font-size:0.82rem; color:var(--ink-3); margin:12px 2px 0; }
.cap .err{ display:none; font-size:0.88rem; color:var(--ink-2); font-weight:500; padding:12px 2px 0; }
.cap .done{ display:none; font-size:0.95rem; color:var(--verm); font-weight:500; padding:14px 2px; }
.cap.ok form, .cap.ok .note, .cap.ok .err{ display:none; } .cap.ok .done{ display:block; }
.cap.fail .err{ display:block; }

/* ---- eyebrow / section headings ---- */
.eyebrow{ font-size:0.8rem; color:var(--verm); font-weight:600; letter-spacing:0.12em;
  text-transform:uppercase; margin:0 0 18px; }

/* ============================================================ HOME */
.hero{ padding:clamp(48px,7vh,92px) 0 clamp(40px,6vh,76px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(36px,5vw,72px); align-items:center; }
@media(max-width:900px){ .hero-grid{ grid-template-columns:1fr; } }
.kicker{ font-size:0.8rem; color:var(--verm); font-weight:600;
  letter-spacing:0.12em; text-transform:uppercase; margin:0 0 22px; }
h1.head{ font-family:var(--serif); font-weight:500; font-size:clamp(2.5rem,5.6vw,4.4rem);
  line-height:1.04; letter-spacing:-0.012em; margin:0; text-wrap:balance; }
h1.head .em{ color:var(--verm); font-style:italic; font-weight:500; }
.hero p.lede{ margin:26px 0 0; font-size:1.12rem; color:var(--ink-2); line-height:1.6; max-width:42ch; }
.hero .cap{ margin:32px 0 0; }

.band{ padding:clamp(56px,9vh,104px) 0; border-top:1px solid var(--rule); }
.band h2{ font-family:var(--serif); font-weight:500; font-size:clamp(1.8rem,3.6vw,2.8rem);
  line-height:1.12; letter-spacing:-0.01em; margin:0; max-width:20ch; }
.band .sub{ margin:18px 0 0; color:var(--ink-2); font-size:1.08rem; max-width:58ch; line-height:1.6; }
.cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,3.5vw,52px); margin-top:clamp(36px,5vh,60px); }
@media(max-width:820px){ .cols{ grid-template-columns:1fr; gap:32px; } }
.col .h{ display:flex; align-items:baseline; gap:12px; margin:0 0 12px; padding-bottom:12px; border-bottom:1px solid var(--rule); }
.col .h .no{ font-family:var(--serif); color:var(--verm); font-weight:500; font-size:0.95rem; }
.col h3{ font-family:var(--serif); font-weight:500; font-size:1.4rem; margin:0; letter-spacing:-0.005em; }
.col p{ margin:0; color:var(--ink-2); font-size:1.0rem; line-height:1.6; max-width:38ch; }

.cad{ margin-top:clamp(36px,5vh,56px); border-top:1px solid var(--rule); }
.cad .r{ display:grid; grid-template-columns:120px 1fr; gap:24px; padding:20px 0; border-bottom:1px solid var(--rule-2); align-items:baseline; }
.cad .r .t{ font-family:var(--serif); font-weight:500; color:var(--verm); font-size:1.05rem; font-variant-numeric:tabular-nums; }
.cad .r .d strong{ font-weight:600; display:block; margin-bottom:3px; }
.cad .r .d span{ color:var(--ink-2); }
@media(max-width:560px){ .cad .r{ grid-template-columns:80px 1fr; gap:14px; } }

/* ---- sample brief card (home) ---- */
.brief-card{ position:relative; background:var(--paper-2); border:1px solid var(--rule);
  border-radius:6px; overflow:hidden; box-shadow:0 24px 60px -38px oklch(0.27 0.02 50 / .35);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease; }
.brief-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--verm); z-index:2; }
@media(hover:hover){ .brief-card:hover{ transform:translateY(-4px); box-shadow:0 34px 72px -36px oklch(0.27 0.02 50 / .42); } }
.brief-card .bh{ padding:15px 20px; border-bottom:1px solid var(--rule);
  display:flex; align-items:center; justify-content:space-between; background:var(--paper); }
.brief-card .bh .id{ font-weight:600; font-size:0.8rem; letter-spacing:0.06em; }
.brief-card .bh .id b{ color:var(--verm); }
.brief-card .bh .m{ font-size:0.74rem; color:var(--ink-3); font-variant-numeric:tabular-nums; letter-spacing:0.03em; }
.mini{ padding:16px 20px; border-bottom:1px solid var(--rule-2); display:flex; gap:14px; }
.mini:last-child{ border-bottom:0; }
.mini .n{ font-family:var(--serif); font-weight:500; color:var(--verm); font-size:0.95rem; min-width:20px; padding-top:1px; }
.mini h4{ font-family:var(--serif); font-weight:500; font-size:1.04rem; line-height:1.3; margin:0 0 5px; letter-spacing:-0.005em; }
.mini p{ margin:0; font-size:0.9rem; color:var(--ink-2); line-height:1.5; }
.mini p .pin{ color:var(--verm); font-weight:600; font-size:0.74rem; letter-spacing:0.04em; margin-right:6px; }
.srcs{ display:flex; gap:6px; flex-wrap:wrap; margin-top:9px; }
.src{ font-size:0.67rem; color:var(--ink-3); border:1px solid var(--rule); border-radius:3px; padding:2px 8px; letter-spacing:0.02em; }

/* ============================================================ BRIEF READER */
/* reading-progress bar */
.progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--verm); z-index:60; transition:width .1s linear; }

.brief-hero{ padding:clamp(40px,6vh,72px) 0 clamp(28px,4vh,44px); border-bottom:1px solid var(--ink); }
.brief-hero .id{ font-size:0.82rem; color:var(--verm); font-weight:600; letter-spacing:0.1em; text-transform:uppercase; margin:0 0 16px; }
.brief-hero h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2rem,4.4vw,3.2rem);
  line-height:1.08; letter-spacing:-0.012em; margin:0; max-width:24ch; }
.brief-hero .dek{ margin:18px 0 0; color:var(--ink-2); font-size:1.12rem; max-width:54ch; line-height:1.55; }
.brief-hero .stamp{ margin:22px 0 0; display:flex; flex-wrap:wrap; gap:8px 22px;
  font-size:0.84rem; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.brief-hero .stamp b{ color:var(--ink); font-weight:500; }

/* signals strip */
.signals{ border-bottom:1px solid var(--rule); background:var(--paper-2); position:sticky; top:55px; z-index:20; }
.signals .in{ max-width:var(--maxw); margin:0 auto; padding:10px var(--gut); display:flex; gap:26px;
  overflow-x:auto; scrollbar-width:none; font-size:0.8rem; font-variant-numeric:tabular-nums; }
.signals .in::-webkit-scrollbar{ display:none; }
.sig{ display:inline-flex; align-items:center; gap:8px; white-space:nowrap; }
.sig .s{ color:var(--ink-3); letter-spacing:0.02em; }
.sig .v{ color:var(--ink); font-weight:500; }
.sig .c{ display:inline-flex; align-items:center; gap:3px; }
.sig .c.up{ color:var(--up); } .sig .c.down{ color:var(--down); }
/* live update: soft warm highlight behind the value, fading out (palette-safe, no green) */
.sig.flash .v{ animation:sigflash .9s ease-out; border-radius:3px; }
@keyframes sigflash{ 0%{ background:var(--paper-3); box-shadow:0 0 0 3px var(--paper-3); } 100%{ background:transparent; box-shadow:0 0 0 3px transparent; } }
/* live / closed status chip, pushed to the right edge */
.sigstat{ display:inline-flex; align-items:center; gap:6px; margin-left:auto; padding-left:18px;
  font-size:0.72rem; letter-spacing:0.09em; font-weight:500; color:var(--ink-3); }
.sigstat.live{ color:var(--verm); }
.sigstat .pulse{ width:6px; height:6px; border-radius:50%; background:var(--verm); animation:sigpulse 1.8s ease-in-out infinite; }
@keyframes sigpulse{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.35; transform:scale(.7); } }
@media(prefers-reduced-motion:reduce){ .sig.flash .v{ animation:none; } .sigstat .pulse{ animation:none; } }
@media(max-width:680px){ .signals{ top:51px; } }

/* story feed */
.feed{ padding:clamp(36px,5vh,56px) 0 clamp(48px,8vh,90px); }
.story{ max-width:var(--maxw-read); margin:0 auto; padding:clamp(30px,4.5vh,48px) 0; border-bottom:1px solid var(--rule); }
.story:last-of-type{ border-bottom:0; }
.story .meta{ display:flex; align-items:baseline; gap:14px; margin:0 0 14px; }
.story .num{ font-family:var(--serif); font-weight:500; color:var(--verm); font-size:1.1rem; min-width:24px; }
.story .topic{ font-size:0.72rem; color:var(--ink-3); letter-spacing:0.12em; text-transform:uppercase; }
.story h2{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,3vw,2.1rem);
  line-height:1.18; letter-spacing:-0.01em; margin:0 0 16px; }
.story .impact{ font-size:1.08rem; color:var(--ink); line-height:1.72; margin:0 0 14px; }
.story .impact .label{ display:inline-block; color:var(--verm); font-weight:600; font-size:0.72rem;
  letter-spacing:0.08em; text-transform:uppercase; margin-right:10px; vertical-align:2px; }
.story .context{ font-size:1.0rem; color:var(--ink-2); line-height:1.66; margin:0 0 16px; max-width:62ch; }
.story .foot{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.entities{ display:flex; gap:6px; flex-wrap:wrap; }
.chip{ font-size:0.74rem; color:var(--ink-2); background:var(--paper-2); border:1px solid var(--rule);
  border-radius:100px; padding:3px 11px; }

/* caught-up end state */
.caught{ text-align:center; padding:clamp(60px,10vh,110px) 0; border-top:1px solid var(--ink); }
.caught .mark{ font-family:var(--deva); font-weight:400; font-size:2.4rem; line-height:1; }
.caught .mark .d{ color:var(--verm); }
.caught h3{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,3.4vw,2.2rem);
  letter-spacing:-0.01em; margin:18px 0 0; }
.caught p{ color:var(--ink-2); margin:12px auto 0; max-width:42ch; }
.caught .cap{ margin:28px auto 0; }

/* ============================================================ ARCHIVE */
.arch-head{ padding:clamp(44px,7vh,88px) 0 clamp(28px,4vh,44px); border-bottom:1px solid var(--ink); }
.arch-head h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem,5vw,3.4rem);
  line-height:1.06; letter-spacing:-0.015em; margin:0; }
.arch-head p{ margin:16px 0 0; color:var(--ink-2); font-size:1.08rem; max-width:50ch; }
.arch-list{ padding:clamp(20px,3vh,36px) 0 clamp(56px,9vh,100px); }
.arch{ display:grid; grid-template-columns:170px 1fr auto; gap:clamp(16px,3vw,40px); align-items:baseline;
  padding:clamp(22px,3vh,32px) 0; border-bottom:1px solid var(--rule); transition:padding-left .25s ease; }
.arch:hover{ padding-left:10px; }
.arch .date{ font-size:0.92rem; color:var(--ink-3); font-variant-numeric:tabular-nums; letter-spacing:0.02em; }
.arch .date .id{ display:block; color:var(--verm); font-weight:600; font-size:0.78rem; letter-spacing:0.08em; margin-bottom:4px; }
.arch h3{ font-family:var(--serif); font-weight:500; font-size:clamp(1.2rem,2.4vw,1.6rem);
  line-height:1.2; letter-spacing:-0.005em; margin:0 0 8px; }
.arch .lead{ color:var(--ink-2); font-size:0.98rem; line-height:1.55; max-width:60ch; }
.arch .count{ font-size:0.84rem; color:var(--ink-3); white-space:nowrap; font-variant-numeric:tabular-nums; }
@media(max-width:720px){ .arch{ grid-template-columns:1fr; gap:8px; } .arch .count{ display:none; } }

/* ============================================================ ABOUT (prose) */
.page-head{ padding:clamp(48px,8vh,100px) 0 clamp(28px,4vh,48px); border-bottom:1px solid var(--ink); }
.page-head h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2.3rem,5.4vw,3.6rem);
  line-height:1.06; letter-spacing:-0.015em; margin:0; max-width:18ch; }
.page-head .dek{ margin:20px 0 0; color:var(--ink-2); font-size:1.18rem; max-width:52ch; line-height:1.55; }
.prose{ padding:clamp(40px,6vh,72px) 0 clamp(56px,9vh,100px); }
.prose h2{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,3vw,2rem);
  letter-spacing:-0.01em; margin:clamp(36px,5vh,56px) 0 14px; }
.prose h2:first-child{ margin-top:0; }
.prose p{ font-size:1.1rem; color:var(--ink); line-height:1.75; margin:0 0 18px; }
.prose p.muted{ color:var(--ink-2); }
.prose ul{ margin:0 0 18px; padding-left:0; list-style:none; }
.prose li{ font-size:1.05rem; color:var(--ink); line-height:1.6; padding:12px 0 12px 26px; position:relative; border-bottom:1px solid var(--rule-2); }
.prose li::before{ content:""; position:absolute; left:0; top:21px; width:10px; height:1px; background:var(--verm); }
.prose strong{ font-weight:600; }

/* ============================================================ FINAL CTA + FOOTER */
.final{ padding:clamp(70px,12vh,130px) 0; border-top:1px solid var(--ink); text-align:center; }
.final h2{ font-family:var(--serif); font-weight:500; font-size:clamp(2.1rem,5vw,3.6rem);
  line-height:1.08; letter-spacing:-0.012em; margin:0 auto; max-width:18ch; }
.final h2 .em{ color:var(--verm); font-style:italic; }
.final .cap{ margin:30px auto 0; }
.final .small{ font-size:0.85rem; color:var(--ink-3); margin:22px 0 0; }

footer{ border-top:1px solid var(--rule); padding:40px 0 56px; }
.foot{ display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; align-items:flex-start; }
.foot .name{ font-family:var(--deva); font-weight:400; font-size:1.45rem; line-height:1; }
.foot .name .d{ color:var(--verm); }
.foot .l p{ margin:6px 0 0; color:var(--ink-3); font-size:0.88rem; max-width:40ch; }
.foot .links{ display:flex; gap:26px; flex-wrap:wrap; }
.foot .links a{ font-size:0.9rem; color:var(--ink-2); transition:color .2s; }
.foot .links a:hover{ color:var(--verm); }
.foot .r{ font-size:0.74rem; color:var(--ink-3); text-align:right; letter-spacing:0.03em; line-height:1.9; }

/* ---- reveal ---- */
.rv{ opacity:0; transform:translateY(16px); }
.rv.in{ opacity:1; transform:none; transition:opacity .85s ease, transform .85s ease; }
@media(prefers-reduced-motion:reduce){ .rv{ opacity:1; transform:none; } html{ scroll-behavior:auto; } }

/* ============================================================ SOURCE MARK (tier-coded monogram) */
.smark{ width:26px; height:26px; border-radius:50%; flex-shrink:0; display:inline-flex;
  align-items:center; justify-content:center; font-size:0.6rem; font-weight:600; letter-spacing:0.02em; }
.smark.indian{ background:var(--ink); color:var(--paper); }
.smark.intl{ border:1px solid var(--ink); color:var(--ink); }
.smark.inst{ background:var(--verm); color:var(--paper); }
.smark.unknown{ border:1px dashed var(--ink-3); color:var(--ink-3); }

/* ============================================================ CRISIS BANNER */
.crisis{ display:flex; align-items:center; gap:12px; padding:13px var(--gut);
  background:var(--verm); color:var(--paper); cursor:pointer;
  max-width:var(--maxw); margin:0 auto; border-radius:4px; }
.crisis .tag{ font-size:0.66rem; font-weight:700; letter-spacing:0.12em; border:1px solid oklch(1 0 0 / .5);
  padding:3px 8px; border-radius:3px; white-space:nowrap; }
.crisis .lbl{ font-weight:500; font-size:0.96rem; flex:1; }
.crisis .chev{ opacity:.85; }
.crisis-wrap{ padding:16px 0 0; }

/* ============================================================ STORY DETAIL */
.sd{ max-width:var(--maxw-read); margin:0 auto; }
.sd .back{ font-size:0.86rem; color:var(--ink-3); display:inline-flex; gap:7px; align-items:center;
  margin:clamp(28px,4vh,44px) 0 26px; transition:color .2s; }
.sd .back:hover{ color:var(--verm); }
.sd .pos{ font-size:0.74rem; color:var(--verm); font-weight:600; letter-spacing:0.12em; text-transform:uppercase; margin:0 0 14px; }
.sd h1{ font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,4vw,2.9rem);
  line-height:1.12; letter-spacing:-0.012em; margin:0 0 clamp(28px,4vh,40px); }
.sd .seclabel{ font-size:0.74rem; color:var(--ink-3); font-weight:600; letter-spacing:0.14em;
  text-transform:uppercase; margin:clamp(30px,4.5vh,44px) 0 16px; padding-bottom:10px; border-bottom:1px solid var(--rule); }
.sd .sentence{ font-size:1.12rem; color:var(--ink); line-height:1.75; margin:0 0 16px; }
.sd .cite{ display:inline-flex; align-items:center; vertical-align:2px; margin-left:5px;
  font-size:0.7rem; color:var(--verm); background:oklch(0.55 0.185 32 / .1); border-radius:3px;
  padding:1px 6px; cursor:pointer; transition:background .15s; }
.sd .cite:hover{ background:oklch(0.55 0.185 32 / .2); }
.sd .impact-row{ display:flex; gap:16px; margin:0 0 18px; }
.sd .role{ flex-shrink:0; width:84px; font-size:0.7rem; color:var(--verm); font-weight:600;
  letter-spacing:0.08em; padding-top:5px; }
.sd .impact-row p{ margin:0; font-size:1.08rem; color:var(--ink); line-height:1.7; }
.sd .arc-row{ display:grid; grid-template-columns:90px 1fr; gap:16px; padding:14px 0;
  border-bottom:1px solid var(--rule-2); align-items:baseline; }
.sd .arc-row .d{ font-size:0.8rem; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.sd .arc-row h4{ font-family:var(--serif); font-weight:500; font-size:1.02rem; line-height:1.3; margin:0 0 3px; }
.sd .arc-row .s{ font-size:0.8rem; color:var(--ink-3); }
.eflow{ display:flex; gap:8px; flex-wrap:wrap; }
.eflow a{ font-size:0.86rem; color:var(--ink); background:var(--paper-2); border:1px solid var(--rule);
  border-radius:100px; padding:6px 14px; transition:border-color .2s, color .2s; }
.eflow a:hover{ border-color:var(--verm); color:var(--verm); }
.source-row{ display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--rule-2); }
.source-row .nm{ font-weight:500; font-size:0.96rem; }
.source-row .url{ font-size:0.8rem; color:var(--ink-3); margin-left:auto; max-width:40%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.persp{ background:var(--paper-2); border:1px solid var(--rule); border-radius:5px; padding:18px 20px; margin:10px 0; }
.persp .t{ font-size:0.72rem; color:var(--ink-3); letter-spacing:0.08em; text-transform:uppercase; margin:0 0 6px; }
.persp p{ margin:0; font-size:1.0rem; color:var(--ink); line-height:1.55; }
.caution-note{ font-size:0.92rem; color:var(--ink-2); font-style:italic; margin:18px 0 0;
  padding:12px 16px; border-left:2px solid var(--verm); background:var(--paper-2); }

/* ============================================================ CITATION MODAL */
.modal{ position:fixed; inset:0; z-index:80; display:none; align-items:flex-end; justify-content:center; }
.modal.open{ display:flex; }
.modal .scrim{ position:absolute; inset:0; background:oklch(0.2 0.02 50 / .45); backdrop-filter:blur(2px); }
.modal .card{ position:relative; width:100%; max-width:600px; background:var(--paper);
  border:1px solid var(--ink); border-radius:12px 12px 0 0; padding:26px var(--gut) 40px;
  max-height:80vh; overflow-y:auto; animation:sheetUp .3s cubic-bezier(.2,.7,.2,1); }
@media(min-width:680px){ .modal{ align-items:center; } .modal .card{ border-radius:12px; } }
@keyframes sheetUp{ from{ transform:translateY(30px); opacity:0; } to{ transform:none; opacity:1; } }
.modal .ttl{ font-size:0.74rem; color:var(--ink-3); letter-spacing:0.14em; text-transform:uppercase; margin:0 0 14px; }
.modal .cited{ display:flex; align-items:center; gap:12px; margin:0 0 22px; }
.modal .cited .nm{ font-family:var(--serif); font-weight:500; font-size:1.2rem; }
.modal .orig{ font-size:1.06rem; color:var(--ink); line-height:1.7; background:var(--paper-2);
  border:1px solid var(--rule); border-radius:6px; padding:18px; margin:0 0 20px; }
.modal .open-link{ display:inline-flex; gap:8px; align-items:center; color:var(--verm); font-weight:500; font-size:0.96rem; }
.modal .x{ position:absolute; top:18px; right:20px; cursor:pointer; color:var(--ink-3); font-size:1.3rem; line-height:1; background:none; border:0; }

/* ============================================================ ENTITY PAGE */
.ent-head{ padding:clamp(40px,6vh,80px) 0 clamp(24px,3.5vh,40px); border-bottom:1px solid var(--ink); }
.ent-head .back{ font-size:0.86rem; color:var(--ink-3); display:inline-flex; gap:7px; margin:0 0 22px; }
.ent-head .back:hover{ color:var(--verm); }
.ent-head h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2rem,4.4vw,3.2rem);
  line-height:1.06; letter-spacing:-0.015em; margin:0; }
.ent-head .type{ margin:14px 0 0; display:flex; gap:14px; align-items:center; font-size:0.84rem;
  color:var(--ink-3); letter-spacing:0.06em; text-transform:uppercase; }
.ent-head .type a{ color:var(--verm); text-transform:none; letter-spacing:0; }
.ent-body{ padding:clamp(32px,5vh,56px) 0 clamp(56px,9vh,100px); }
.ent-body .desc{ font-size:1.18rem; color:var(--ink); line-height:1.65; max-width:60ch; margin:0 0 26px; }
.ent-india{ background:var(--paper-2); border:1px solid var(--rule); border-left:2px solid var(--verm);
  border-radius:5px; padding:20px 22px; margin:0 0 30px; max-width:64ch; }
.ent-india .t{ font-size:0.72rem; color:var(--verm); font-weight:600; letter-spacing:0.1em; text-transform:uppercase; margin:0 0 8px; }
.ent-india p{ margin:0; font-size:1.05rem; line-height:1.6; }
.ent-aka{ font-size:0.95rem; color:var(--ink-2); margin:0 0 30px; }
.ent-aka b{ color:var(--ink-3); font-weight:600; font-size:0.72rem; letter-spacing:0.08em; text-transform:uppercase; margin-right:10px; }
.ment-row{ display:grid; grid-template-columns:90px 1fr auto; gap:16px; padding:16px 0;
  border-bottom:1px solid var(--rule-2); align-items:baseline; transition:padding-left .2s; }
.ment-row:hover{ padding-left:8px; }
.ment-row .d{ font-size:0.82rem; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.ment-row h4{ font-family:var(--serif); font-weight:500; font-size:1.08rem; line-height:1.25; margin:0; }
.ment-row .p{ font-size:0.78rem; color:var(--ink-3); white-space:nowrap; }

/* ============================================================ SEARCH */
.search-head{ padding:clamp(40px,6vh,80px) 0 0; }
.search-field{ display:flex; align-items:center; gap:12px; border:1px solid var(--ink); border-radius:4px;
  padding:0 16px; background:var(--paper); max-width:var(--maxw-read); }
.search-field svg{ flex-shrink:0; color:var(--ink-3); }
.search-field input{ flex:1; border:0; outline:0; background:transparent; color:var(--ink);
  font-family:var(--sans); font-size:1.1rem; padding:16px 0; }
.search-field input::placeholder{ color:var(--ink-3); }
.search-body{ max-width:var(--maxw-read); margin:0 auto; padding:clamp(28px,4vh,44px) 0 clamp(56px,9vh,100px); }
.suggest{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.suggest button{ font-family:var(--sans); font-size:0.92rem; color:var(--ink); background:var(--paper-2);
  border:1px solid var(--rule); border-radius:100px; padding:8px 16px; cursor:pointer; transition:border-color .2s; }
.suggest button:hover{ border-color:var(--verm); color:var(--verm); }
.search-hint{ color:var(--ink-3); font-size:1.0rem; }
.res-count{ font-size:0.86rem; color:var(--ink-3); margin:0 0 8px; }
.res{ display:block; padding:22px 0; border-bottom:1px solid var(--rule); transition:padding-left .2s; }
.res:hover{ padding-left:8px; }
.res .top{ display:flex; gap:12px; font-size:0.78rem; color:var(--ink-3); margin:0 0 8px; font-variant-numeric:tabular-nums; }
.res h3{ font-family:var(--serif); font-weight:500; font-size:1.3rem; line-height:1.2; margin:0 0 8px; }
.res .ex{ color:var(--ink-2); font-size:0.98rem; line-height:1.55; max-width:62ch; }
.res .ents{ color:var(--verm); font-size:0.84rem; margin:8px 0 0; }

/* ============================================================ PRICING (paywall) */
.price-head{ text-align:center; padding:clamp(48px,8vh,100px) 0 clamp(28px,4vh,48px); }
.price-head .eyebrow{ display:block; }
.price-head h1{ font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem,5vw,3.6rem);
  line-height:1.06; letter-spacing:-0.015em; margin:0 auto; max-width:18ch; }
.price-head p{ margin:18px auto 0; color:var(--ink-2); font-size:1.12rem; max-width:48ch; }
.plans{ display:grid; grid-template-columns:1fr 1fr; gap:20px; max-width:760px; margin:0 auto;
  padding:0 0 clamp(40px,6vh,72px); }
@media(max-width:680px){ .plans{ grid-template-columns:1fr; } }
.plan{ border:1px solid var(--rule); border-radius:8px; padding:30px 28px; background:var(--paper); }
.plan.pro{ border-color:var(--ink); background:var(--paper-2); position:relative; }
.plan .save{ position:absolute; top:-11px; left:28px; background:var(--verm); color:var(--paper);
  font-size:0.7rem; font-weight:600; letter-spacing:0.04em; padding:4px 10px; border-radius:3px; }
.plan .pname{ font-size:0.78rem; color:var(--ink-3); letter-spacing:0.1em; text-transform:uppercase; margin:0 0 14px; }
.plan .amt{ font-family:var(--serif); font-weight:500; font-size:2.6rem; letter-spacing:-0.02em; }
.plan .per{ font-size:0.92rem; color:var(--ink-3); }
.plan button{ width:100%; margin-top:22px; border:0; cursor:pointer; border-radius:3px;
  font-family:var(--sans); font-weight:600; font-size:0.96rem; padding:14px; transition:background .2s, transform .15s; }
.plan button:active{ transform:scale(.99); }
.plan.pro button{ background:var(--verm); color:var(--paper); }
.plan.pro button:hover{ background:var(--verm-hi); }
.plan.free button{ background:transparent; color:var(--ink); border:1px solid var(--ink); }
.benefits{ max-width:600px; margin:0 auto; padding:0 0 clamp(56px,9vh,100px); }
.benefits .b{ display:flex; gap:14px; align-items:baseline; padding:16px 0; border-bottom:1px solid var(--rule-2); }
.benefits .b .k{ color:var(--verm); font-weight:600; }
.benefits .b p{ margin:0; font-size:1.05rem; }

/* ============================================================ ENTITY SURFACES */
/* watchlist banner (the "alert") */
.watch-banner{ display:flex; align-items:center; gap:10px 14px; flex-wrap:wrap;
  background:var(--paper-2); border:1px solid var(--rule); border-left:2px solid var(--verm);
  border-radius:5px; padding:14px 18px; margin:clamp(20px,3vh,32px) 0; }
.watch-banner .wb-k{ font-size:0.72rem; color:var(--verm); font-weight:600; letter-spacing:0.1em; text-transform:uppercase; }
.watch-banner a{ font-weight:500; border-bottom:1px solid var(--rule); padding-bottom:1px; transition:border-color .2s; }
.watch-banner a:hover{ border-color:var(--verm); color:var(--verm); }
.watch-banner .wb-c{ font-size:0.82rem; color:var(--ink-3); margin-left:auto; font-variant-numeric:tabular-nums; }
.watch-banner.none{ border-left-color:var(--rule); color:var(--ink-3); font-size:0.92rem; }

/* follow button */
.follow{ font-family:var(--sans); font-size:0.78rem; font-weight:600; cursor:pointer;
  background:transparent; color:var(--ink); border:1px solid var(--ink); border-radius:100px;
  padding:5px 14px; white-space:nowrap; transition:background .2s, color .2s, border-color .2s; }
.follow:hover{ border-color:var(--verm); color:var(--verm); }
.follow.on{ background:var(--verm); color:var(--paper); border-color:var(--verm); }

/* most-active heat list */
.most-active{ margin-top:8px; }
.heat{ display:grid; grid-template-columns:1.4fr 2fr auto auto; gap:16px; align-items:center;
  padding:13px 0; border-bottom:1px solid var(--rule-2); }
.heat .nm{ display:flex; align-items:center; gap:9px; min-width:0; }
.heat .nm a{ font-family:var(--serif); font-weight:500; font-size:1.05rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.heat .nm a:hover{ color:var(--verm); }
.heat .sens{ width:7px; height:7px; border-radius:50%; background:var(--verm); flex-shrink:0; }
.heat .track{ height:6px; background:var(--rule-2); border-radius:100px; overflow:hidden; }
.heat .fill{ height:100%; background:var(--verm); border-radius:100px; }
.heat .mn{ font-size:0.84rem; color:var(--ink-3); font-variant-numeric:tabular-nums; white-space:nowrap; }
.heat .tr{ font-size:0.8rem; font-variant-numeric:tabular-nums; }
.heat .tr.up{ color:var(--up); } .heat .tr.down{ color:var(--down); } .heat .tr.flat{ color:var(--ink-3); }
@media(max-width:640px){ .heat{ grid-template-columns:1fr auto; } .heat .track,.heat .mn{ display:none; } }

/* directory */
.dir-group{ margin-top:clamp(28px,4vh,44px); }
.dir-h{ font-size:0.74rem; color:var(--ink-3); font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
  margin:0 0 14px; padding-bottom:10px; border-bottom:1px solid var(--rule); }
.dir-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.dir-card{ position:relative; display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  border:1px solid var(--rule); border-radius:6px; padding:16px 18px; background:var(--paper);
  transition:border-color .2s, transform .2s; }
.dir-card:hover{ border-color:var(--ink-3); transform:translateY(-2px); }
.dir-card .info{ min-width:0; }
.dir-card .info a.t{ font-family:var(--serif); font-weight:500; font-size:1.12rem; display:flex; align-items:center; gap:8px; }
.dir-card .info a.t:hover{ color:var(--verm); }
.dir-card .info .meta{ font-size:0.8rem; color:var(--ink-3); margin-top:5px; font-variant-numeric:tabular-nums; }
.dir-card .sens-dot{ width:7px; height:7px; border-radius:50%; background:var(--verm); flex-shrink:0; }

/* relationship graph */
.graph-wrap{ border:1px solid var(--rule); border-radius:8px; background:var(--paper-2);
  margin:clamp(16px,3vh,28px) 0; overflow:hidden; }
.egraph{ display:block; width:100%; height:auto; }
.egraph .ge{ stroke:var(--rule); stroke-width:1; }
.egraph .gn{ fill:var(--paper); stroke:var(--ink); stroke-width:1.5; transition:fill .15s; }
.egraph .gn.sens{ fill:var(--verm); stroke:var(--verm); }
.egraph .gn.focal{ stroke:var(--ink); stroke-width:2.5; }
.egraph .gnode:hover .gn{ fill:var(--ink); }
.egraph .gnode:hover .gn.sens{ fill:var(--verm-hi); }
.egraph .gl{ font-family:var(--sans); font-size:12px; fill:var(--ink-2); text-anchor:middle; pointer-events:none; }
.graph-legend{ display:flex; gap:22px; flex-wrap:wrap; font-size:0.84rem; color:var(--ink-3); padding:4px 0 clamp(40px,6vh,72px); }
.graph-legend span{ display:inline-flex; align-items:center; gap:8px; }
.graph-legend .dot{ width:11px; height:11px; border-radius:50%; border:1.5px solid var(--ink); background:var(--paper); }
.graph-legend .dot.sens{ background:var(--verm); border-color:var(--verm); }
.graph-legend .edgekey{ width:18px; height:1px; background:var(--rule); }

/* entity-page additions */
.ent-actions{ display:flex; align-items:center; gap:12px; margin:18px 0 0; flex-wrap:wrap; }
.alert-pill{ font-size:0.74rem; font-weight:600; color:var(--verm); background:oklch(0.55 0.185 32 / .1);
  border-radius:100px; padding:5px 13px; letter-spacing:0.02em; }
.minigraph-wrap{ border:1px solid var(--rule); border-radius:8px; background:var(--paper-2); margin:10px 0 0; overflow:hidden; }

/* ===== Explore (living-story index) ===== */
.threads{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media(max-width:720px){ .threads{ grid-template-columns:1fr; } }
.thread{ display:block; border:1px solid var(--rule); border-radius:10px; background:var(--paper-2);
  padding:22px 24px; text-decoration:none; color:inherit; transition:border-color .2s, transform .2s, box-shadow .2s; }
.thread:hover{ border-color:var(--ink-3); transform:translateY(-2px); box-shadow:0 8px 24px -16px var(--ink); }
.thread-top{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.thread h2{ font-family:var(--serif); font-weight:500; font-size:1.3rem; line-height:1.25; margin:0 0 8px; letter-spacing:-0.005em; }
.thread-latest{ color:var(--ink-2); font-size:0.95rem; line-height:1.55; margin:0 0 16px; }
.thread-foot{ display:flex; justify-content:space-between; gap:12px; align-items:baseline; font-size:0.78rem; }
.thread-foot .ents{ color:var(--ink-3); } .thread-foot .tmeta{ color:var(--ink-3); white-space:nowrap; }
/* status chip (palette-safe: vermilion = hot, ink = steady, muted = cooling) */
.status{ font-size:0.68rem; font-weight:600; letter-spacing:0.09em; text-transform:uppercase; padding:3px 9px; border-radius:100px; border:1px solid currentColor; }
.status.developing{ color:var(--verm); } .status.active{ color:var(--ink-2); } .status.cooling{ color:var(--ink-3); } .status.closed{ color:var(--ink-3); }
.newbadge{ font-size:0.72rem; font-weight:600; color:var(--verm); letter-spacing:0.02em; }

/* ===== Dossier (one story's timeline) ===== */
.dossier .back{ margin-bottom:20px; }
.dossier-head{ display:flex; align-items:center; gap:12px; margin:0 0 10px; }
.dossier-sub{ color:var(--ink-3); font-size:0.9rem; margin:0 0 30px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.timeline{ position:relative; }
.tl-entry{ position:relative; padding:0 0 30px 26px; border-left:1px solid var(--rule); }
.tl-entry:last-child{ border-left-color:transparent; padding-bottom:4px; }
.tl-dot{ position:absolute; left:-5px; top:5px; width:9px; height:9px; border-radius:50%; background:var(--ink-3); border:2px solid var(--paper); }
.tl-entry.is-new .tl-dot{ background:var(--verm); }
.tl-when{ display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.tl-date{ font-weight:500; color:var(--ink); font-size:0.92rem; }
.tl-n{ font-size:0.74rem; color:var(--ink-3); letter-spacing:0.04em; text-transform:uppercase; }
.newtag{ font-size:0.64rem; font-weight:700; letter-spacing:0.1em; color:var(--paper); background:var(--verm); padding:2px 7px; border-radius:4px; }
.tl-body h3{ font-family:var(--serif); font-weight:500; font-size:1.3rem; line-height:1.3; margin:0 0 8px; letter-spacing:-0.005em; }
.tl-sum{ color:var(--ink-2); font-size:1rem; line-height:1.6; margin:0 0 14px; }
.tl-impact{ margin-top:6px; border-left:2px solid var(--rule); padding-left:16px; }
.dossier-foot{ margin:18px 0 0; padding-top:18px; border-top:1px solid var(--rule); color:var(--ink-3); font-size:0.85rem; font-style:italic; }
