/* ============================================================
   NAMMA OORU · DUBAI THARAM — Design System
   Aesthetic: premium editorial civic-tech with Tamil warmth
   Ivory paper · deep teal ink · gold accent · Fraunces + Hanken Grotesk
   ============================================================ */

:root{
  /* ---- Color ---- */
  --ink:#0c2a31;            /* primary text — deep teal-charcoal */
  --ink-soft:#3a5560;       /* secondary text */
  --ink-faint:#6d8893;      /* captions / meta */
  --teal:#0e5563;           /* primary brand */
  --teal-deep:#072a33;      /* dark sections / hero */
  --teal-mid:#127286;       /* hover / links */
  --teal-tint:#e7f0f1;      /* light fill */
  --gold:#c8881f;           /* accent — Tamil warmth */
  --gold-soft:#e6a93a;
  --gold-tint:#f7ecd7;
  --paper:#fbf7ef;          /* warm ivory background */
  --paper-2:#f4ecde;        /* deeper paper for bands */
  --card:#fffdf8;           /* card surface */
  --line:#e3d8c4;           /* warm hairline border */
  --line-cool:#cfe0e2;
  --white:#ffffff;

  /* state */
  --green:#1b7d4f; --green-bg:#e6f3ec;
  --amber:#b57910; --amber-bg:#faeed6;
  --red:#bb3b2b;   --red-bg:#f8e7e3;

  /* dashboard dark */
  --dk-bg:#08232a; --dk-panel:#0e323b; --dk-line:#1c4651; --dk-text:#dCEef0; --dk-faint:#7fa6ae;

  /* ---- Type ---- */
  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --tamil:'Noto Sans Tamil', 'Hanken Grotesk', sans-serif;
  --mono:'Spline Sans Mono','JetBrains Mono', ui-monospace, monospace;

  /* ---- Space / radius ---- */
  --r-sm:6px; --r:12px; --r-lg:18px; --r-xl:26px; --r-full:999px;
  --shadow-sm:0 1px 3px rgba(12,42,49,.07), 0 1px 2px rgba(12,42,49,.05);
  --shadow:0 8px 26px rgba(12,42,49,.10), 0 3px 8px rgba(12,42,49,.06);
  --shadow-lg:0 24px 60px rgba(12,42,49,.16), 0 8px 20px rgba(12,42,49,.08);
  --maxw:1180px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
:lang(ta),.ta{font-family:var(--tamil);line-height:1.85}

/* ---- Type scale ---- */
.display{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.02em;font-optical-sizing:auto}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
h1{font-size:clamp(2.5rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.35rem,2.2vw,1.8rem)}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.lede{font-size:clamp(1.1rem,1.6vw,1.35rem);line-height:1.6;color:var(--ink-soft)}
.small{font-size:.86rem}
.muted{color:var(--ink-faint)}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(64px,9vw,120px) 0}
.band-paper2{background:var(--paper-2)}
.band-deep{background:var(--teal-deep);color:#eaf4f4}
.band-deep h1,.band-deep h2,.band-deep h3{color:#fff}
.center{text-align:center}
.grid{display:grid;gap:24px}
@media(min-width:760px){.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}}
.stack-sm>*+*{margin-top:10px}
.kicker-rule{width:54px;height:4px;background:var(--gold);border-radius:2px;margin:18px 0}
.section-num{font-family:var(--display);font-size:.95rem;color:var(--gold);font-weight:600;letter-spacing:.02em}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:700;font-size:.98rem;
  padding:13px 24px;border-radius:var(--r-full);transition:.18s ease;border:1.5px solid transparent;letter-spacing:.005em}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--teal-mid);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-gold{background:var(--gold);color:#241402}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-1px)}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff;background:rgba(255,255,255,.06)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline{border-color:var(--teal);color:var(--teal)}
.btn-outline:hover{background:var(--teal-tint)}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:60;background:rgba(251,247,239,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:68px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--ink)}
.brand .mk{width:34px;height:34px;flex:0 0 34px}
.brand small{display:block;font-family:var(--sans);font-weight:600;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:1px}
.nav-links{display:none;gap:22px;margin-left:auto}
.nav-links a{font-size:.92rem;font-weight:600;color:var(--ink-soft);padding:4px 0;border-bottom:2px solid transparent;transition:.15s}
.nav-links a:hover{color:var(--teal)}
.nav-cta{margin-left:auto;display:flex;gap:10px;align-items:center}
@media(min-width:980px){.nav-links{display:flex}.nav-cta{margin-left:0}}

/* ---- Hero ---- */
.hero{position:relative;background:
   radial-gradient(120% 90% at 85% -10%, #0f3d49 0%, rgba(15,61,73,0) 55%),
   radial-gradient(100% 80% at -5% 110%, #114a4f 0%, rgba(17,74,79,0) 50%),
   linear-gradient(160deg,#072a33 0%,#0b3a42 60%,#0e4a52 100%);
  color:#eef6f5;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(circle at center, rgba(200,136,31,.10) 0 1.4px, transparent 1.6px);
  background-size:30px 30px;mask-image:radial-gradient(120% 90% at 70% 10%,#000,transparent 75%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(70px,11vw,130px) 28px clamp(60px,8vw,104px)}
.hero h1{color:#fff;max-width:16ch}
.hero h1 .accent{color:var(--gold-soft);font-style:italic}
.hero .lede{color:rgba(255,255,255,.8);max-width:46ch;margin-top:22px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero-tagline{margin-top:40px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-tagline .ta{font-family:var(--tamil);font-size:1.4rem;color:var(--gold-soft);font-weight:600}
.hero-tagline span{color:rgba(255,255,255,.6);font-size:.95rem;letter-spacing:.04em}
.hero-strip{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.12);background:rgba(4,22,27,.4)}
.hero-strip .wrap{display:grid;gap:18px;padding-top:26px;padding-bottom:26px}
@media(min-width:760px){.hero-strip .wrap{grid-template-columns:repeat(4,1fr)}}
.hs-stat .n{font-family:var(--display);font-size:2rem;font-weight:600;color:#fff;line-height:1}
.hs-stat .l{font-size:.8rem;color:rgba(255,255,255,.62);margin-top:6px;letter-spacing:.02em}

/* ---- Stat callouts ---- */
.statbig{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,5vw,4rem);line-height:1;color:var(--teal);letter-spacing:-.02em}
.statbig.gold{color:var(--gold)}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px}
.stat-card .lab{font-size:.82rem;color:var(--ink-soft);margin-top:10px;line-height:1.5}
.stat-card .src{font-size:.72rem;color:var(--ink-faint);margin-top:8px}

/* ---- Sector cards ---- */
.sector-grid{display:grid;gap:18px}
@media(min-width:680px){.sector-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.sector-grid{grid-template-columns:repeat(3,1fr)}}
.sector{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 22px 20px;
  position:relative;overflow:hidden;transition:.2s ease;display:flex;flex-direction:column;gap:9px}
.sector::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:.25s}
.sector:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-3px)}
.sector:hover::before{transform:scaleX(1)}
.sector .ic{width:42px;height:42px;border-radius:11px;background:var(--teal-tint);color:var(--teal);display:flex;align-items:center;justify-content:center}
.sector .ic svg{width:22px;height:22px}
.sector .nm{font-family:var(--display);font-size:1.22rem;font-weight:600;color:var(--ink)}
.sector .nm .ta{font-family:var(--tamil);font-size:.95rem;color:var(--gold);font-weight:600;display:block;margin-top:1px}
.sector .model{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:700}
.sector .wow{font-size:.92rem;color:var(--ink-soft);line-height:1.5}
.sector .wow b{color:var(--teal);font-weight:700}
.sector .promise{margin-top:auto;padding-top:12px;border-top:1px dashed var(--line);font-size:.9rem;color:var(--ink)}
.sector .promise::before{content:"→ ";color:var(--gold);font-weight:700}

/* ---- Generic feature card ---- */
.fcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.fcard h3{font-size:1.25rem;margin-bottom:8px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 11px;border-radius:var(--r-full);background:var(--gold-tint);color:#7a5310}

/* ---- Loop / steps ---- */
.loop{display:grid;gap:14px;counter-reset:s}
@media(min-width:760px){.loop{grid-template-columns:repeat(5,1fr)}}
.loop .step{position:relative;padding:20px 16px;background:var(--card);border:1px solid var(--line);border-radius:var(--r)}
.loop .step .k{font-family:var(--display);font-size:1.1rem;color:var(--gold);font-weight:600}
.loop .step h4{font-size:1rem;margin:6px 0 4px;font-family:var(--sans);font-weight:700}
.loop .step p{font-size:.85rem;color:var(--ink-soft);line-height:1.5}

/* ---- Quote ---- */
.quote{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.25;font-weight:500;letter-spacing:-.01em}
.quote .ta{font-family:var(--tamil);color:var(--gold-soft)}

/* ---- Footer ---- */
.footer{background:var(--teal-deep);color:rgba(255,255,255,.78);padding:64px 0 30px}
.footer h4{font-family:var(--display);color:#fff;font-size:1.7rem;font-weight:600;max-width:18ch}
.footer .ta{color:var(--gold-soft)}
.footer a{color:rgba(255,255,255,.72)}.footer a:hover{color:#fff}
.footer .cols{display:grid;gap:30px;margin-top:36px}
@media(min-width:760px){.footer .cols{grid-template-columns:2fr 1fr 1fr}}
.footer .lnk{display:block;font-size:.92rem;padding:5px 0}
.footer .disc{font-size:.74rem;color:rgba(255,255,255,.5);line-height:1.6;margin-top:34px;padding-top:22px;border-top:1px solid rgba(255,255,255,.14)}

/* ---- Badges (SLA) ---- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-full);font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.b-ontrack{background:var(--green-bg);color:var(--green)}
.b-due{background:var(--amber-bg);color:var(--amber)}
.b-breach{background:var(--red-bg);color:var(--red)}
.b-resolved{background:var(--teal-tint);color:var(--teal)}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}

/* ---- Disclaimer ribbon ---- */
.demo-ribbon{background:var(--gold-tint);border-bottom:1px solid var(--line);color:#6f4e12;font-size:.8rem;text-align:center;padding:8px 16px}
.demo-ribbon b{color:#4a340b}

/* =========================================================
   PRODUCT UI (VOICE demo / dashboard / TN Nilam)
   ========================================================= */
.app-top{background:var(--teal-deep);color:#fff;border-bottom:1px solid var(--dk-line)}
.app-top .wrap{display:flex;align-items:center;gap:16px;height:60px}
.app-top a.back{color:rgba(255,255,255,.7);font-size:.9rem;font-weight:600}
.app-top .ttl{font-family:var(--display);font-weight:600}
.phone{max-width:392px;margin:0 auto;background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);overflow:hidden}
.phone-head{background:var(--teal);color:#fff;padding:16px 18px;display:flex;align-items:center;gap:12px}
.phone-head .av{width:38px;height:38px;border-radius:50%;background:var(--gold);color:#241402;display:flex;align-items:center;justify-content:center;font-weight:800}
.phone-body{padding:18px;min-height:520px;background:var(--paper)}
.vcard{background:linear-gradient(120deg,#0e5563,#127286);color:#fff;border-radius:var(--r);padding:14px 16px;position:relative;overflow:hidden}
.vcard::after{content:"";position:absolute;right:-20px;top:-20px;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,136,31,.35),transparent 70%)}
.vcard .lab{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;opacity:.8}
.vcard .num{font-family:var(--mono);font-size:1.02rem;letter-spacing:.06em;margin-top:3px}
.vcard .nm{font-weight:700;margin-top:8px}

.chan-row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:16px}
.chan{display:flex;flex-direction:column;align-items:center;gap:6px;padding:11px 4px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);font-size:.62rem;color:var(--ink-soft);text-align:center;transition:.15s}
.chan svg{width:20px;height:20px;color:var(--teal)}
.chan:hover,.chan.sel{border-color:var(--teal);background:var(--teal-tint)}
.bigbtn{width:100%;margin-top:16px;background:var(--teal);color:#fff;border-radius:var(--r);padding:16px;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:10px;transition:.15s}
.bigbtn:hover{background:var(--teal-mid)}
.bigbtn.gold{background:var(--gold);color:#241402}
.field{margin-top:14px}
.field label{font-size:.78rem;font-weight:700;color:var(--ink-soft);display:block;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:.92rem;color:var(--ink)}
.field textarea{min-height:84px;resize:vertical}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cat{display:flex;flex-direction:column;align-items:center;gap:5px;padding:11px 4px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:.66rem;text-align:center;color:var(--ink-soft);transition:.12s}
.cat .em{font-size:1.2rem}
.cat:hover{border-color:var(--teal)}
.cat.sel{border-color:var(--teal);background:var(--teal-tint);color:var(--teal);font-weight:700;box-shadow:0 0 0 3px rgba(14,85,99,.12)}

/* triage card */
.triage{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.triage .hd{background:var(--green-bg);color:var(--green);padding:13px 15px;font-weight:700;display:flex;align-items:center;gap:9px}
.triage .row{display:flex;justify-content:space-between;gap:12px;padding:10px 15px;border-top:1px solid var(--line);font-size:.86rem}
.triage .row .k{color:var(--ink-faint)}
.triage .row .v{font-weight:600;text-align:right}
.ai-chip{display:inline-flex;align-items:center;gap:5px;font-size:.66rem;font-weight:700;color:var(--teal);background:var(--teal-tint);padding:3px 8px;border-radius:var(--r-full)}

/* stepper (vertical) */
.tl{position:relative;margin-top:8px;padding-left:6px}
.tl .node{position:relative;padding:0 0 18px 30px}
.tl .node::before{content:"";position:absolute;left:8px;top:3px;bottom:-3px;width:2px;background:var(--line)}
.tl .node:last-child::before{display:none}
.tl .dot{position:absolute;left:0;top:0;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--line)}
.tl .node.done .dot{background:var(--teal);border-color:var(--teal)}
.tl .node.done::before{background:var(--teal)}
.tl .node.active .dot{border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-tint);background:#fff}
.tl .node .st{font-weight:700;font-size:.92rem}
.tl .node .mt{font-size:.76rem;color:var(--ink-faint)}
.tl .node .de{font-size:.84rem;color:var(--ink-soft);margin-top:3px}
.pulse{animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

.rate-faces{display:flex;gap:12px;justify-content:center;margin:16px 0}
.face{flex:1;max-width:96px;border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:14px 4px;text-align:center;transition:.14s}
.face .em{font-size:1.8rem}.face .l{font-size:.74rem;margin-top:4px;color:var(--ink-soft)}
.face:hover{border-color:var(--teal)}
.face.sel{border-color:var(--gold);background:var(--gold-tint);box-shadow:0 0 0 3px rgba(200,136,31,.2)}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--teal-deep);color:#fff;
  padding:13px 20px;border-radius:var(--r-full);box-shadow:var(--shadow-lg);font-size:.9rem;font-weight:600;opacity:0;transition:.3s;z-index:200;display:flex;gap:9px;align-items:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* =========================================================
   DASHBOARD (war-room, dark)
   ========================================================= */
.war{background:var(--dk-bg);color:var(--dk-text);min-height:100vh}
.war .wrap{max-width:1280px}
.war-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 0 6px;flex-wrap:wrap}
.war-head h2{color:#fff}
.live{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:700;color:#7fe0b0;letter-spacing:.04em;text-transform:uppercase}
.live .dot{width:9px;height:9px;border-radius:50%;background:#37d391;box-shadow:0 0 0 0 rgba(55,211,145,.6);animation:live 1.8s infinite}
@keyframes live{0%{box-shadow:0 0 0 0 rgba(55,211,145,.5)}70%{box-shadow:0 0 0 10px rgba(55,211,145,0)}100%{box-shadow:0 0 0 0 rgba(55,211,145,0)}}
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:18px 0}
@media(min-width:760px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1080px){.kpis{grid-template-columns:repeat(6,1fr)}}
.kpi{background:var(--dk-panel);border:1px solid var(--dk-line);border-radius:var(--r);padding:16px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent,#3aa6bd)}
.kpi.ok::before{background:#37d391}.kpi.warn::before{background:#e6a93a}.kpi.bad::before{background:#e06450}
.kpi .v{font-family:var(--display);font-size:1.9rem;font-weight:600;color:#fff;line-height:1}
.kpi .l{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dk-faint);margin-top:7px}
.kpi .s{font-size:.78rem;color:#a9cbd1;margin-top:6px}
.war-grid{display:grid;gap:16px}
@media(min-width:980px){.war-grid{grid-template-columns:1.15fr 1fr}}
.panel{background:var(--dk-panel);border:1px solid var(--dk-line);border-radius:var(--r-lg);padding:18px}
.panel h3{color:#fff;font-size:1.1rem;font-family:var(--sans);font-weight:700;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}
.panel .sub{font-size:.78rem;color:var(--dk-faint);margin-bottom:14px}
/* bar chart */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:120px 1fr 42px;align-items:center;gap:10px;font-size:.82rem}
.bar-track{height:14px;background:#0a2a31;border-radius:var(--r-full);overflow:hidden}
.bar-fill{height:100%;border-radius:var(--r-full);background:linear-gradient(90deg,#127286,#3aa6bd);transition:width 1s cubic-bezier(.2,.7,.2,1)}
.bar-row .val{text-align:right;color:#bfe0e5;font-family:var(--mono);font-size:.8rem}
/* map */
.tnmap{width:100%;height:auto}
.tnmap .dist{stroke:#0a2a31;stroke-width:1.2;cursor:pointer;transition:.15s}
.tnmap .dist:hover{stroke:#fff;stroke-width:1.6}
.legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;font-size:.74rem;color:var(--dk-faint)}
.legend i{width:12px;height:12px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:-1px}
/* table */
.dtable{width:100%;border-collapse:collapse;font-size:.82rem}
.dtable th{text-align:left;color:var(--dk-faint);font-weight:700;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--dk-line)}
.dtable td{padding:9px 10px;border-bottom:1px solid rgba(28,70,81,.5);color:#dceef0}
.dtable tr:hover td{background:rgba(18,114,134,.12)}
.score{font-weight:800;font-family:var(--mono)}
.score.hi{color:#37d391}.score.mid{color:#e6a93a}.score.lo{color:#e06450}
.breach-item{display:grid;grid-template-columns:1fr auto;gap:10px;padding:12px 0;border-bottom:1px solid rgba(28,70,81,.5)}
.breach-item .id{font-family:var(--mono);font-size:.74rem;color:#9fc2c8}
.breach-item .meta{font-size:.82rem;color:#dceef0;margin-top:2px}
.breach-item .over{font-size:.74rem;color:#e98a78;font-weight:700;margin-top:3px}
.nudge{align-self:center;background:var(--gold);color:#241402;font-weight:700;font-size:.76rem;padding:7px 12px;border-radius:var(--r-full)}
.nudge:hover{background:var(--gold-soft)}
.tooltip{position:fixed;z-index:300;background:#04181d;border:1px solid var(--dk-line);border-radius:10px;padding:10px 12px;font-size:.78rem;color:#dceef0;pointer-events:none;box-shadow:var(--shadow-lg);max-width:220px;opacity:0;transition:.12s}
.tooltip.show{opacity:1}
.tooltip b{color:#fff}

/* TN Nilam */
.nilam-app{max-width:430px;margin:0 auto}
.tabbar{display:flex;background:var(--card);border:1px solid var(--line);border-radius:var(--r-full);padding:4px;gap:4px;margin-bottom:16px}
.tabbar button{flex:1;padding:9px;border-radius:var(--r-full);font-size:.82rem;font-weight:700;color:var(--ink-soft)}
.tabbar button.on{background:var(--teal);color:#fff}
.doc{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow-sm)}
.doc .qr{width:74px;height:74px;border-radius:10px;background:
   repeating-linear-gradient(0deg,#0c2a31 0 4px,transparent 4px 8px),
   repeating-linear-gradient(90deg,#0c2a31 0 4px,#fff 4px 8px);opacity:.92}
.kv{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:.88rem}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--ink-faint)}.kv .v{font-weight:600;text-align:right}
.verified{display:inline-flex;align-items:center;gap:6px;color:var(--green);font-weight:700;font-size:.82rem}

/* utility */
.hide{display:none!important}
.flex{display:flex}.between{justify-content:space-between}.center-y{align-items:center}.gap{gap:12px}.wrapf{flex-wrap:wrap}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mt40{margin-top:40px}
.tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);background:var(--teal-tint);padding:4px 10px;border-radius:var(--r-full)}
