/* ============================================================ */
/* theme-22-inner.css — shared shell for every inner page         */
/* Imported by theme-22-{result,state,archive,all-india,          */
/* prize-structure,disclaimer,privacy,terms,contact,check}.html   */
/* ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
body{font-family:"DM Sans",system-ui,sans-serif;background:#eef2f7;color:#0f172a;line-height:1.6;-webkit-font-smoothing:antialiased;font-size:16.5px}
a{color:#7c3aed;text-decoration:none}
a:hover{text-decoration:underline}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* === DESKTOP NAV (full-width bg, 1100px inner) === */
.desktop-nav{background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:50;width:100%}
.desktop-nav .inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:20px;min-height:72px}
.desktop-nav .brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#0f172a}
.desktop-nav .brand .mark{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;box-shadow:0 8px 20px rgba(124,58,237,.3)}
.desktop-nav .brand .name{font-size:17px;font-weight:800;letter-spacing:-.01em;line-height:1.1}
.desktop-nav .brand .name small{display:block;font-size:10.5px;color:#7c3aed;font-weight:700;margin-top:2px;letter-spacing:1px;text-transform:uppercase}
.desktop-nav .menu{list-style:none;display:none;gap:4px;margin-left:18px;align-items:center}
@media(min-width:880px){.desktop-nav .menu{display:flex}}
.desktop-nav .menu a{padding:10px 14px;font-size:15px;font-weight:600;color:#475569;border-radius:10px;text-decoration:none;transition:all .15s}
.desktop-nav .menu a:hover{background:#f1f5f9;color:#7c3aed;text-decoration:none}
.desktop-nav .menu a.active{background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(220,38,38,.05));color:#7c3aed;font-weight:700}
.desktop-nav .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.desktop-nav .state-btn{background:#fff;border:1px solid #e2e8f0;padding:8px 14px;border-radius:10px;font-family:inherit;font-size:13.5px;font-weight:700;color:#0f172a;cursor:pointer;display:inline-flex;align-items:center;gap:6px}

/* === INNER HERO === */
.inner-hero{background:linear-gradient(135deg,#7c3aed 0%,#a855f7 50%,#dc2626 100%);color:#fff;padding:48px 24px 56px;position:relative;overflow:hidden;width:100%}
.inner-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% -20%,rgba(251,191,36,.3) 0,transparent 50%)}
.inner-hero .inner{max-width:1100px;margin:0 auto;position:relative;z-index:1;text-align:center}
.inner-hero .breadcrumb{font-size:13px;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:12px;letter-spacing:.3px}
.inner-hero .breadcrumb a{color:#fbbf24;text-decoration:none}
.inner-hero .breadcrumb a:hover{text-decoration:underline}
.inner-hero h1{font-size:clamp(26px,4vw,38px);font-weight:800;letter-spacing:-.02em;margin-bottom:10px;line-height:1.15}
.inner-hero .dek{font-size:16.5px;opacity:.94;max-width:780px;margin:0 auto;line-height:1.55}
.inner-hero .dek strong{color:#fbbf24;font-weight:800}

/* === PAGE GRID + AD RAILS === */
.page-grid{display:block}
@media(min-width:1480px){
  .page-grid{display:grid;grid-template-columns:160px minmax(0,1100px) 160px;gap:30px;justify-content:center;align-items:start;max-width:1480px;margin:0 auto;padding:0 12px}
}
.ad-rail{display:none}
@media(min-width:1480px){
  .ad-rail{display:block;position:sticky;top:96px;align-self:start}
  .ad-rail .slot{background:#fff;border:1px dashed #cbd5e1;border-radius:8px;padding:14px 8px;text-align:center;font-size:11px;font-weight:700;color:#94a3b8;letter-spacing:1px;text-transform:uppercase;line-height:1.4;min-height:600px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
  .ad-rail .slot::before{content:"AD";display:block;font-size:32px;font-weight:900;color:#cbd5e1;margin-bottom:6px}
  .ad-rail .slot small{font-size:10px;color:#cbd5e1;font-weight:600;letter-spacing:.5px;text-transform:none;margin-top:6px}
}
.app{max-width:1100px;margin:18px auto 0;padding:0 24px;background:transparent}
/* grid-column:2 pins content to the centre column so the body stays centred
   even when the ad rails are hidden/absent (otherwise .app auto-places into
   the first 160px track and the whole page shifts left). */
@media(min-width:1480px){.page-grid .app{max-width:none;margin:0;padding:0;grid-column:2}}

/* === BYLINE === */
.byline-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:18px 22px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 12px rgba(15,23,42,.04);margin-bottom:18px}
.byline-card .avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:22px;flex-shrink:0;letter-spacing:.5px}
.byline-card .who{flex:1;min-width:0}
.byline-card .reviewed{font-size:11px;font-weight:800;color:#15803d;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px}
.byline-card .name{font-size:17px;font-weight:800;color:#0f172a;letter-spacing:-.01em;line-height:1.2}
.byline-card .creds{font-size:14.5px;color:#64748b;margin-top:2px;line-height:1.45}
.byline-card .when{font-size:12.5px;color:#94a3b8;margin-top:6px;font-weight:600}

/* === FACTBOX === */
/* ─────────────────────────────────────────────────────────
   .factbox — info-panel card used on state pages, /result/{date},
   info pages, contact, etc. (14 pages site-wide). Designed to feel
   like a quick-reference settings panel — uppercase pill header,
   compact uppercase labels on the left, bold values on the right,
   subtle row separators. Lighter visual weight than the old heavy
   purple-bordered box.
   ───────────────────────────────────────────────────────── */
.factbox{background:#fff;border:1px solid #e9d5ff;border-radius:16px;padding:6px 0 0;margin-bottom:24px;box-shadow:0 1px 3px rgba(15,23,42,.04);overflow:hidden}
.factbox h2{font-size:11.5px;font-weight:800;color:#7c3aed;letter-spacing:1.8px;text-transform:uppercase;margin:18px 24px 14px;display:flex;align-items:center;gap:8px;line-height:1.2}
.factbox h2::before{content:"⚡";font-size:16px;line-height:1}
.factbox dl{display:grid;grid-template-columns:1fr;gap:0;margin:0;border-top:1px solid #f1f5f9}
@media(min-width:600px){.factbox dl{grid-template-columns:minmax(160px,auto) 1fr;gap:0}}
.factbox dt{font-size:12px;font-weight:800;color:#7c3aed;letter-spacing:.8px;text-transform:uppercase;padding:14px 24px;border-bottom:1px solid #f1f5f9;background:#faf5ff;display:flex;align-items:center}
@media(max-width:599px){.factbox dt{padding-bottom:2px;background:transparent;border-bottom:none}}
.factbox dd{font-size:15px;color:#0f172a;font-weight:600;padding:14px 24px;border-bottom:1px solid #f1f5f9;line-height:1.5;margin:0}
@media(max-width:599px){.factbox dd{padding-top:4px;padding-bottom:14px}}
.factbox dt:last-of-type,.factbox dd:last-of-type{border-bottom:none}
.factbox dd b{font-family:ui-monospace,Monaco,monospace;color:#15803d;font-weight:800;background:#dcfce7;padding:2px 8px;border-radius:5px}
.factbox dd em{font-style:italic;color:#475569;font-weight:500}
.factbox dd .src{display:block;font-size:11.5px;color:#94a3b8;font-weight:500;margin-top:4px;font-style:italic}
.factbox dd a{color:#7c3aed;font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* === ARTICLE BODY === */
.article{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:28px 32px;box-shadow:0 4px 14px rgba(15,23,42,.04);margin-bottom:18px}
@media(max-width:640px){.article{padding:20px}}
.article h2{font-size:24px;font-weight:800;color:#0f172a;letter-spacing:-.015em;margin:24px 0 10px;line-height:1.2;scroll-margin-top:90px}
.article h2:first-child{margin-top:0}
.article h2 .accent{background:linear-gradient(135deg,#7c3aed,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.article h3{font-size:19px;font-weight:800;color:#0f172a;margin:20px 0 8px;letter-spacing:-.01em;line-height:1.3;padding-left:14px;border-left:3px solid #7c3aed}
.article p{font-size:16.5px;color:#334155;line-height:1.75;margin-bottom:14px}
.article p:last-child{margin-bottom:0}
.article p strong{color:#0f172a;font-weight:700}
.article p em{font-style:italic;color:#7c3aed;font-weight:600}
.article ul,.article ol{margin:0 0 16px 24px}
.article li{font-size:16.5px;color:#334155;line-height:1.75;margin-bottom:8px}
.article li strong{color:#0f172a;font-weight:700}
.article a{color:#7c3aed;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.article code{background:#f1f5f9;padding:2px 7px;border-radius:5px;font-family:ui-monospace,Monaco,monospace;font-size:15.5px;color:#dc2626;font-weight:700}
.article blockquote{border-left:4px solid #fbbf24;background:#fffbeb;padding:14px 18px;margin:16px 0;border-radius:0 8px 8px 0;font-size:16.5px;color:#78350f;line-height:1.6}
.article blockquote cite{display:block;font-size:13px;color:#92400e;margin-top:8px;font-style:normal;font-weight:700}

/* === Source note === */
.source-note{font-size:14px;color:#64748b;background:#f8fafc;border-left:3px solid #cbd5e1;padding:10px 14px;margin:12px 0;border-radius:0 6px 6px 0;line-height:1.55}
.source-note strong{color:#0f172a}

/* === Related links === */
.related{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:22px 26px;box-shadow:0 4px 14px rgba(15,23,42,.04);margin-bottom:18px}
.related h2{font-size:18px;font-weight:800;color:#0f172a;margin-bottom:14px;letter-spacing:-.01em}
.related-grid{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:680px){.related-grid{grid-template-columns:1fr 1fr}}
.related a{display:flex;gap:12px;padding:14px 16px;background:#fafbff;border:1px solid #e2e8f0;border-radius:12px;text-decoration:none;color:#0f172a;transition:all .15s}
.related a:hover{border-color:#7c3aed;background:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 18px rgba(124,58,237,.08)}
.related a .ico{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#ede9fe,#fbcfe8);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.related a .text{flex:1;min-width:0}
.related a .text strong{display:block;font-size:15.5px;font-weight:800;color:#0f172a;line-height:1.3;margin-bottom:2px}
.related a .text span{display:block;font-size:14px;color:#64748b;line-height:1.4}

/* === FAQ === */
.faq{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:22px 26px;box-shadow:0 4px 14px rgba(15,23,42,.04);margin-bottom:18px}
.faq h2{font-size:22px;font-weight:800;color:#0f172a;margin-bottom:14px;letter-spacing:-.01em}
.faq h2 .accent{background:linear-gradient(135deg,#7c3aed,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.faq details{padding:14px 0;border-bottom:1px solid #f1f5f9}
.faq details:last-child{border-bottom:none}
.faq summary{font-weight:700;font-size:16.5px;color:#0f172a;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px;line-height:1.4}
.faq summary::after{content:"+";color:#7c3aed;font-size:22px;font-weight:300;line-height:1;flex-shrink:0;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{font-size:16.5px;color:#475569;line-height:1.7;margin-top:10px}
.faq details p strong{color:#0f172a}

/* === Trust block === */
.trust-block{background:#fff7ed;border:1px solid #fed7aa;border-left:4px solid #ea580c;border-radius:0 14px 14px 0;padding:18px 22px;font-size:15.5px;color:#7c2d12;line-height:1.65;margin-bottom:18px}
.trust-block strong{color:#0f172a}

/* === Tables (used in archive, prize-structure) === */
.data-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;margin:14px 0}
.data-table thead th{background:linear-gradient(90deg,#0f172a,#1e293b);color:#fff;padding:12px 14px;text-align:left;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase}
.data-table tbody td{padding:12px 14px;font-size:16px;color:#0f172a;border-bottom:1px solid #f1f5f9;line-height:1.4}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:#fafbff}
.data-table td.mono{font-family:ui-monospace,Monaco,monospace;font-weight:700}
.data-table td.green{color:#15803d;font-weight:700}
.data-table td.muted{color:#64748b;font-size:14px}

/* === State chips (used in all-india + sometimes related) === */
.state-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin:14px 0}
.state-chip{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;text-decoration:none;color:#0f172a;transition:all .15s;position:relative;overflow:hidden}
.state-chip::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#e2e8f0;transition:background .15s}
.state-chip.live::before{background:linear-gradient(90deg,#15803d,#16a34a)}
.state-chip:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(124,58,237,.1);border-color:#7c3aed}
.state-chip.live{background:linear-gradient(135deg,#dcfce7,#fff)}
.state-chip .flag{font-size:26px}
.state-chip .body{flex:1;min-width:0}
.state-chip .name{font-size:15px;font-weight:800;color:#0f172a;line-height:1.2}
.state-chip .brand{font-size:12px;color:#64748b;margin-top:2px;line-height:1.4}
.state-chip .pill{font-size:10px;font-weight:800;padding:4px 8px;border-radius:99px;background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;letter-spacing:.5px;text-transform:uppercase;line-height:1.2;flex-shrink:0}
.state-chip.live .pill{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border-color:#991b1b;animation:livePulse 2s infinite;display:inline-flex;align-items:center;gap:5px}
.state-chip.live .pill::before{content:"";width:5px;height:5px;background:#fff;border-radius:50%}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.7}}

/* === FOOTER === */
footer{background:#0f172a;color:#cbd5e1;padding:36px 24px 22px;margin-top:36px;font-size:16px;line-height:1.6}
footer .inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:720px){footer .inner{grid-template-columns:1.4fr 1fr 1fr 1fr}}
footer h4{font-size:12px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px}
footer a{color:#cbd5e1;display:block;padding:3px 0;text-decoration:none}
footer a:hover{color:#a855f7;text-decoration:none}
footer .brand-line{display:flex;align-items:center;gap:10px;margin-bottom:8px}
footer .brand-line .mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px}
footer .brand-line strong{color:#fff;font-size:16px}
footer .copy{border-top:1px solid #1e293b;margin-top:28px;padding-top:16px;text-align:center;font-size:13.5px;color:#94a3b8}
/* Brand image logo (replaces the old "LS" text mark + name) */
.desktop-nav .brand{gap:0}
.desktop-nav .brand img{display:block;height:70px;width:auto;max-width:260px;object-fit:contain}
@media(max-width:879px){.desktop-nav .brand img{height:58px;max-width:200px}}
footer .brand-line{display:inline-flex;align-items:center;background:#fff;padding:8px 12px;border-radius:10px;margin-bottom:10px}
footer .brand-line img{display:block;height:auto;max-width:200px;width:auto}

/* ─────────────────────────────────────────────────────────────
   Nav: hamburger, states dropdown, mobile drawer (May 2026)
   ───────────────────────────────────────────────────────────── */

/* Hamburger button — visible only on mobile (<880px) */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:transparent;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;padding:0 10px;flex-shrink:0;transition:all .15s}
.nav-hamburger:hover{background:#f1f5f9;border-color:#7c3aed}
.nav-hamburger span{display:block;width:100%;height:2.5px;background:#0f172a;border-radius:2px;transition:all .2s}
@media(max-width:879px){.nav-hamburger{display:flex}}

/* States dropdown (desktop, hover/click) */
.menu .has-dropdown{position:relative}
.menu .has-dropdown > a{cursor:pointer}
/* States dropdown — slim 2-column popup, anchored to the right of the
   "States ▾" trigger so it never overflows the viewport.
   Uses a small overflow buffer (--sd-w) to stay within the page bleed. */
.menu .has-dropdown{position:relative}
.states-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  width:480px;max-width:calc(100vw - 24px);
  background:#fff;border:1px solid #e9d5ff;border-radius:14px;
  box-shadow:0 20px 44px rgba(15,23,42,.18),0 4px 12px rgba(124,58,237,.08);
  padding:14px;z-index:200;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s ease;
  pointer-events:none;
}
/* Tiny invisible bridge between trigger and panel so the hover doesn't
   close when the cursor moves from "States ▾" down into the dropdown. */
.states-dropdown::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.menu .has-dropdown:hover > .states-dropdown,
.menu .has-dropdown:focus-within > .states-dropdown{
  opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;
}
.states-dropdown-head{
  padding:4px 8px 10px;border-bottom:1px solid #f1f5f9;margin-bottom:8px;
  display:flex;flex-direction:column;gap:2px;
}
.states-dropdown-head strong{
  font-size:12px;font-weight:800;color:#7c3aed;letter-spacing:1.3px;text-transform:uppercase;
}
.states-dropdown-head span{font-size:12px;color:#64748b;font-weight:600}

/* 2-column grid — never 3 columns (it overflowed on the right edge). */
.states-dropdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}

/* One row per state — emoji + (name over brand) + status pill on the right.
   Uses a 3-column subgrid so the badge always sits flush right and the
   brand line truncates with ellipsis instead of pushing the badge off-screen. */
.sd-item{
  display:grid;
  grid-template-columns:22px minmax(0,1fr) auto;
  align-items:center;
  column-gap:8px;
  padding:7px 8px;
  border-radius:8px;
  text-decoration:none;color:#0f172a;
  transition:background .12s;
  min-width:0;
}
.sd-item:hover{background:#faf5ff;text-decoration:none}
.sd-emoji{font-size:17px;line-height:1;text-align:center}
.sd-text{display:flex;flex-direction:column;gap:0;min-width:0;overflow:hidden}
.sd-name{font-weight:800;font-size:13px;color:#0f172a;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sd-brand{font-size:10.5px;color:#64748b;font-weight:600;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sd-badge{
  font-size:9px;font-weight:900;
  padding:2px 6px;border-radius:4px;
  letter-spacing:.7px;text-transform:uppercase;
  white-space:nowrap;
}
.sd-live{background:#dcfce7;color:#15803d}
.sd-soon{background:#f1f5f9;color:#94a3b8}

.states-dropdown-footer{
  display:block;margin-top:8px;padding:10px 12px;
  background:linear-gradient(135deg,#f5f3ff,#fef2f2);border-radius:9px;
  color:#7c3aed;font-weight:800;font-size:12.5px;text-align:center;
  text-decoration:none;
}
.states-dropdown-footer:hover{text-decoration:none;background:linear-gradient(135deg,#ede9fe,#fde2e2)}

/* Belt-and-suspenders: never show the dropdown on mobile (the drawer handles it) */
@media(max-width:879px){
  .states-dropdown{display:none}
}

/* Mobile drawer */
.nav-drawer-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(2px);z-index:200;opacity:0;transition:opacity .25s}
.nav-drawer-backdrop.is-open{opacity:1}
.nav-drawer{position:fixed;top:0;left:0;bottom:0;width:min(340px,86vw);background:#fff;z-index:201;box-shadow:8px 0 28px rgba(15,23,42,.18);transform:translateX(-100%);transition:transform .25s ease;display:flex;flex-direction:column;overflow:hidden}
.nav-drawer.is-open{transform:translateX(0)}
.nav-drawer-head{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0;background:linear-gradient(135deg,#fafbff,#fff)}
.nav-drawer-brand img{display:block;height:42px;width:auto;max-width:200px}
.nav-drawer-close{background:#f1f5f9;border:none;width:36px;height:36px;border-radius:9px;font-size:16px;font-weight:700;cursor:pointer;color:#0f172a;flex-shrink:0;transition:background .12s}
.nav-drawer-close:hover{background:#e2e8f0}
.nav-drawer-body{flex:1;overflow-y:auto;padding:14px 16px 80px;-webkit-overflow-scrolling:touch}
.nav-drawer-section{margin-bottom:18px}
.nav-drawer-section h4{font-size:11px;font-weight:800;color:#7c3aed;letter-spacing:1.5px;text-transform:uppercase;margin:0 0 8px;padding:0 8px}
.nav-drawer-section ul{list-style:none;margin:0;padding:0}
.nav-drawer-section li a{display:flex;align-items:center;gap:10px;padding:11px 10px;border-radius:9px;color:#0f172a;font-size:14.5px;font-weight:600;text-decoration:none;line-height:1.3;transition:background .12s}
.nav-drawer-section li a:hover{background:#fafbff;text-decoration:none}
.nav-drawer-section li a.active{background:linear-gradient(135deg,#ede9fe,#fde2e2);color:#7c3aed;font-weight:800}
.ds-emoji{font-size:18px;line-height:1;flex-shrink:0;width:22px;text-align:center}
.ds-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ds-badge{font-size:9.5px;font-weight:900;padding:2px 6px;border-radius:4px;letter-spacing:.6px;text-transform:uppercase;flex-shrink:0}
.ds-live{background:#dcfce7;color:#15803d}
.ds-soon{background:#f1f5f9;color:#64748b}
.nav-drawer-helpline{background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav-drawer-helpline strong{font-size:11px;font-weight:800;color:#c2410c;letter-spacing:1px;text-transform:uppercase}
.nav-drawer-helpline a{font-size:18px;font-weight:900;color:#9a3412;text-decoration:none;font-family:ui-monospace,Monaco,monospace}
.nav-drawer-helpline span{font-size:11.5px;color:#7c2d12;line-height:1.4}

/* Hide desktop menu on mobile (drawer takes over) */
@media(max-width:879px){
  .desktop-nav .menu{display:none}
}
/* Push desktop menu to the right (now that .right state-btn is removed) */
@media(min-width:880px){.desktop-nav .menu{margin-left:auto}}
/* Page-meta card (replaces the named-reviewer byline cards) */
.page-meta-card{background:linear-gradient(135deg,#fafbff,#fff);border:1px solid #e9d5ff;border-left:4px solid #7c3aed;border-radius:14px;padding:14px 18px;margin-bottom:20px;box-shadow:0 4px 10px rgba(124,58,237,.05)}
.page-meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.page-meta-tag{font-size:11.5px;font-weight:800;color:#7c3aed;letter-spacing:1.3px;text-transform:uppercase}
.page-meta-when{font-size:13px;font-weight:600;color:#475569}
.page-meta-when time{font-weight:800;color:#0f172a}
.page-meta-advisory{margin:10px 0 0;padding:10px 12px;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;font-size:14.5px;color:#7c2d12;line-height:1.55}
.page-meta-advisory strong{color:#9a3412}

/* Smooth scroll + transitions (inner pages) */
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* FAQ details fade-in (matches homepage) */
.faq details[open] > p,
.section.faq-block details[open] > p{
  animation:faq-fade-in .25s ease both;
}
@keyframes faq-fade-in{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}
.faq details summary::after,
.section.faq-block details summary::after{transition:transform .22s ease}

/* Related-grid + state-chip hover lift */
.related-grid a{transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}
.related-grid a:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(124,58,237,.1)}

/* Buy-card + legal-yes hover */
.buy-card{transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.buy-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(124,58,237,.1);border-color:#c4b5fd}
.legal-yes{transition:transform .15s ease,background .15s ease}
.legal-yes:hover{transform:translateY(-1px);background:#dcfce7}

@media (prefers-reduced-motion:reduce){
  .related-grid a,.buy-card,.legal-yes{transition:none}
  .faq details[open] > p,.section.faq-block details[open] > p{animation:none}
}

/* ─────────────────────────────────────────────────────────
   FAQ block — proper accordion card (used across state pages,
   /all-india, /archive, etc.). Each .faq-item gets its own row
   with separator + padding + hover state. The first item's open
   state is visually distinct from collapsed items.
   ───────────────────────────────────────────────────────── */
.section.faq-block{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:8px 0;box-shadow:0 1px 3px rgba(15,23,42,.04);margin-bottom:18px;overflow:hidden}
.section.faq-block > h2{font-size:20px;font-weight:800;color:#0f172a;margin:18px 26px 14px;letter-spacing:-.015em;line-height:1.2}
.section.faq-block > h2 .accent{background:linear-gradient(135deg,#7c3aed,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.section.faq-block .faq-item{border-top:1px solid #f1f5f9;padding:0}
.section.faq-block .faq-item:first-of-type{border-top:1px solid #e2e8f0}

.section.faq-block .faq-item summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;
  cursor:pointer;padding:18px 26px;
  font-size:15px;font-weight:700;color:#0f172a;line-height:1.4;
  transition:background .15s
}
.section.faq-block .faq-item summary:hover{background:#fafbff}
.section.faq-block .faq-item[open] summary{background:#faf5ff;color:#7c3aed}
.section.faq-block .faq-item summary::-webkit-details-marker{display:none}
.section.faq-block .faq-item summary strong{font-weight:700;color:inherit}
.section.faq-block .faq-item summary::after{
  content:"+";color:#7c3aed;font-size:24px;font-weight:300;line-height:1;
  flex-shrink:0;transition:transform .22s ease;
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  background:#f5f3ff;border-radius:50%
}
.section.faq-block .faq-item[open] summary::after{transform:rotate(45deg);background:#fff;color:#dc2626}

.section.faq-block .faq-item p{margin:0;padding:0 26px 20px;font-size:15px;color:#475569;line-height:1.7}
.section.faq-block .faq-item p a{color:#7c3aed;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.section.faq-block .faq-item p strong{color:#0f172a;font-weight:700}

/* ─────────────────────────────────────────────────────────
   Standalone .related-grid (used outside .related section)
   The .related a {display:flex} rule only applies inside
   <section class="related">. When .related-grid is used by
   itself inside an .article, anchor children need their own
   flex + strong/span block rules.
   ───────────────────────────────────────────────────────── */
.related-grid > a{display:flex;gap:12px;padding:14px 16px;background:#fafbff;border:1px solid #e2e8f0;border-radius:12px;text-decoration:none;color:#0f172a;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;align-items:center}
.related-grid > a:hover{border-color:#7c3aed;background:#fff;text-decoration:none;color:#0f172a;transform:translateY(-2px);box-shadow:0 8px 18px rgba(124,58,237,.08)}
.related-grid > a .ico{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#ede9fe,#fbcfe8);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.related-grid > a .text{flex:1;min-width:0}
.related-grid > a .text strong{display:block;font-size:15px;font-weight:800;color:#0f172a;line-height:1.3;margin-bottom:2px}
.related-grid > a .text span{display:block;font-size:13.5px;color:#64748b;line-height:1.4}

/* ─────────────────────────────────────────────────────────
   Archive shared components (used by /archive, /archive/{year},
   /archive/{year}/{month}). Promoted from page-specific CSS so
   all archive pages render consistently.
   ───────────────────────────────────────────────────────── */

/* Stat strip — 4 visual tiles instead of a definition list */
.archive-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px}
@media(min-width:680px){.archive-stats{grid-template-columns:repeat(4,1fr)}}
.stat-tile{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px 18px 16px;box-shadow:0 1px 3px rgba(15,23,42,.04);position:relative;overflow:hidden}
.stat-tile .icon{position:absolute;top:14px;right:14px;font-size:22px;opacity:.65}
.stat-tile .label{font-size:11.5px;font-weight:800;color:#7c3aed;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:6px}
.stat-tile .value{font-size:26px;font-weight:800;color:#0f172a;line-height:1.1;letter-spacing:-.02em;margin-bottom:4px;font-variant-numeric:tabular-nums}
.stat-tile .value.sm{font-size:18px}
.stat-tile .sub{font-size:13px;color:#64748b;line-height:1.4}

/* Picker card — used for year and month grids */
.picker-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px 26px;margin-bottom:24px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.picker-wrap > h2{font-size:20px;font-weight:800;color:#0f172a;margin:0 0 6px;letter-spacing:-.015em}
.picker-wrap > h2 .accent{background:linear-gradient(135deg,#7c3aed,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.picker-wrap > p.lead{font-size:14.5px;color:#64748b;line-height:1.6;margin:0 0 18px;max-width:680px}

/* Year grid — for /archive */
.year-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.year-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 14px;background:linear-gradient(180deg,#fafbff,#f5f3ff);border:2px solid #e9d5ff;border-radius:14px;text-decoration:none;color:#0f172a;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;position:relative}
.year-card:hover{border-color:#7c3aed;background:linear-gradient(180deg,#fff,#fef2f2);transform:translateY(-2px);box-shadow:0 8px 18px rgba(124,58,237,.15);text-decoration:none;color:#0f172a}
.year-card .yr{font-size:32px;font-weight:800;color:#7c3aed;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:4px}
.year-card .cnt{font-size:12.5px;color:#64748b;font-weight:600;text-align:center}
.year-card.current{border-color:#dc2626;background:linear-gradient(180deg,#fff,#fef2f2)}
.year-card.current .yr{color:#dc2626}
.year-card .badge{position:absolute;top:-8px;right:-8px;background:#dc2626;color:#fff;font-size:9.5px;font-weight:800;padding:3px 7px;border-radius:99px;letter-spacing:.6px;text-transform:uppercase;box-shadow:0 4px 10px rgba(220,38,38,.3)}

/* Month grid — for /archive/{year}. 4-col on desktop, 3-col on tablet, 2-col on mobile.
   Each month card has a status: data | no-data | future | current. */
.month-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.month-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:780px){.month-grid{grid-template-columns:repeat(4,1fr)}}
.month-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 12px;background:linear-gradient(180deg,#fafbff,#f5f3ff);border:2px solid #e9d5ff;border-radius:12px;text-decoration:none;color:#0f172a;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;position:relative;min-height:96px}
.month-card:hover{border-color:#7c3aed;background:linear-gradient(180deg,#fff,#fef2f2);transform:translateY(-2px);box-shadow:0 8px 18px rgba(124,58,237,.15);text-decoration:none;color:#0f172a}
.month-card .mn{font-size:18px;font-weight:800;color:#7c3aed;line-height:1.1;letter-spacing:-.01em;margin-bottom:4px;text-transform:uppercase}
.month-card .cnt{font-size:12px;color:#64748b;font-weight:600;text-align:center;line-height:1.3}
.month-card.current{border-color:#dc2626;background:linear-gradient(180deg,#fff,#fef2f2)}
.month-card.current .mn{color:#dc2626}
.month-card.no-data{background:#f8fafc;border-color:#e2e8f0;border-style:dashed;cursor:default;opacity:.7}
.month-card.no-data:hover{transform:none;box-shadow:none;border-color:#e2e8f0}
.month-card.no-data .mn{color:#94a3b8}
.month-card.no-data .cnt{color:#94a3b8;font-style:italic}
.month-card.future{background:#f8fafc;border-color:#e2e8f0;border-style:dashed;cursor:default;opacity:.5}
.month-card.future:hover{transform:none;box-shadow:none;border-color:#e2e8f0}
.month-card.future .mn{color:#cbd5e1}
.month-card.future .cnt{color:#cbd5e1}
.month-card .badge{position:absolute;top:-6px;right:-6px;background:#dc2626;color:#fff;font-size:9px;font-weight:800;padding:3px 6px;border-radius:99px;letter-spacing:.4px;text-transform:uppercase;box-shadow:0 4px 8px rgba(220,38,38,.3)}

/* Quick-action strip — 3 chunky border-left cards */
.quick-strip{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:24px}
@media(min-width:680px){.quick-strip{grid-template-columns:repeat(3,1fr)}}
.quick-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border:1px solid #e2e8f0;border-left:4px solid #7c3aed;border-radius:12px;text-decoration:none;color:#0f172a;transition:border-color .15s,transform .15s,box-shadow .15s}
.quick-card:hover{border-color:#7c3aed;border-left-color:#dc2626;transform:translateX(2px);text-decoration:none;color:#0f172a;box-shadow:0 6px 14px rgba(124,58,237,.08)}
.quick-card .ico{font-size:24px;flex-shrink:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ede9fe,#fbcfe8);border-radius:10px}
.quick-card .body{flex:1;min-width:0}
.quick-card .body strong{display:block;font-size:14.5px;font-weight:800;color:#0f172a;line-height:1.3;margin-bottom:2px}
.quick-card .body span{display:block;font-size:12.5px;color:#64748b;line-height:1.35}

/* Mini explainer pill — short tinted block to replace text walls */
.mini-explainer{background:linear-gradient(135deg,#faf5ff,#fdf2f8);border:1px solid #e9d5ff;border-radius:14px;padding:18px 22px;margin-bottom:24px;font-size:14.5px;line-height:1.6;color:#475569}
.mini-explainer strong{color:#7c3aed;font-weight:700}
.mini-explainer.warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fde68a;color:#78350f}
.mini-explainer.warning strong{color:#92400e}

/* Highlight block — for year/month summary insights */
.highlight-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:24px}
@media(min-width:680px){.highlight-grid{grid-template-columns:1fr 1fr}}
.highlight-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px 22px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.highlight-card .ico{font-size:24px;margin-bottom:8px;display:inline-block;width:42px;height:42px;background:linear-gradient(135deg,#ede9fe,#fbcfe8);border-radius:10px;display:flex;align-items:center;justify-content:center}
.highlight-card h3{font-size:15px;font-weight:800;color:#0f172a;margin:10px 0 4px;letter-spacing:-.01em;line-height:1.3}
.highlight-card p{font-size:14px;color:#475569;line-height:1.55;margin:0}
.highlight-card p strong{color:#0f172a;font-weight:700}

/* Empty-state placeholder card */
.empty-state{background:#fff;border:2px dashed #cbd5e1;border-radius:14px;padding:36px 22px;text-align:center;margin-bottom:24px}
.empty-state .emoji{font-size:42px;margin-bottom:8px;display:block}
.empty-state h3{font-size:18px;font-weight:800;color:#0f172a;margin:0 0 6px;letter-spacing:-.01em}
.empty-state p{font-size:14px;color:#64748b;line-height:1.55;margin:0 auto;max-width:480px}

/* Sub-header for less-prominent sections at page bottom */
.sub-header{font-size:15px;font-weight:800;color:#475569;letter-spacing:.4px;text-transform:uppercase;margin:32px 0 12px;padding-bottom:8px;border-bottom:2px solid #f1f5f9}

/* ─────────────────────────────────────────────────────────
   Small utility classes — extracted from inline styles that
   were repeating across views (ticket links, inline code,
   date-format badges, today-row highlight, etc.).
   ───────────────────────────────────────────────────────── */

/* Green monospace pill for clickable 1st-prize ticket numbers in tables.
   Used in /all-india, /archive/{year}/{month}, and any future per-state
   listing of winners. Was inline style="display:inline-block;..." ×4. */
.ticket-link{display:inline-block;font-family:ui-monospace,Monaco,monospace;font-weight:700;color:#15803d;background:#dcfce7;padding:4px 10px;border-radius:6px;text-decoration:none;letter-spacing:.5px;transition:background .12s,color .12s}
.ticket-link:hover{background:#bbf7d0;color:#14532d;text-decoration:none}

/* Inline <code> styling for paths, route names, etc. Was inline
   style="background:#f1f5f9;..." ×5 across views. */
code.inline,.code-inline{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-family:ui-monospace,Monaco,monospace;font-size:13px;color:#0f172a}

/* Date-format monospace badge — used in /archive/{year}/{month} to show
   the same month in 3 search formats. Was inline ×3. */
.date-format-badge{display:inline-block;font-family:ui-monospace,Monaco,monospace;background:rgba(124,58,237,.08);padding:2px 8px;border-radius:5px;margin:0 2px;font-size:13.5px;color:#7c3aed;font-weight:700}

/* Highlight a table row representing "today" (yellow background) +
   matching "Today" pill in the date cell. */
tr.today-row{background:#fef3c7}
.today-pill{display:inline-block;font-size:9.5px;font-weight:800;color:#dc2626;text-transform:uppercase;letter-spacing:.6px;background:#fff;padding:2px 6px;border-radius:99px;margin-left:6px;border:1px solid #fbbf24;vertical-align:middle}

/* Empty/skipped marker used in /all-india when a state has no result
   for the date yet. Was inline italic style ×N. */
.empty-cell{color:#64748b;font-style:italic;padding:12px 16px;background:#fafbff;border-radius:8px;border:1px solid #e2e8f0;display:block}

/* Variant of .mini-explainer for "live now" status (green tint).
   Was inline conditional gradient in /all-india. */
.mini-explainer.live{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#86efac;color:#14532d}
.mini-explainer.live strong{color:#14532d}

/* "Disabled" treatment for .related-grid > a — used by coming-soon
   states without an official source link. Replaces inline opacity. */
.related-grid > a.disabled{opacity:.7;pointer-events:none;cursor:default}

/* ─────────────────────────────────────────────────────────
   Result page (/result/{slug}) — promoted from per-page
   @push('styles') so every per-result URL benefits.
   ───────────────────────────────────────────────────────── */

/* 1st-prize winner hero — purple→red gradient card */
.winner-hero{background:linear-gradient(135deg,#7c3aed 0%,#dc2626 100%);color:#fff;border-radius:18px;padding:30px 28px;margin-bottom:18px;text-align:center;position:relative;overflow:hidden;box-shadow:0 14px 32px rgba(124,58,237,.28)}
.winner-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% -15%,rgba(251,191,36,.22) 0,transparent 55%);pointer-events:none}
.winner-hero .crown{font-size:32px;display:inline-block;margin-bottom:4px;filter:drop-shadow(0 4px 12px rgba(251,191,36,.45))}
.winner-hero .lbl{font-size:11.5px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;opacity:.9;margin-bottom:4px}
.winner-hero .amt{font-size:16px;font-weight:700;color:#fef3c7;margin-bottom:14px;letter-spacing:.3px}
.winner-hero .ticket{font-family:ui-monospace,Monaco,monospace;font-size:46px;font-weight:900;color:#fff;letter-spacing:-1px;line-height:1;margin-bottom:8px;text-shadow:0 4px 16px rgba(0,0,0,.18)}
@media(max-width:480px){.winner-hero .ticket{font-size:36px}}
.winner-hero .net{font-size:14px;color:rgba(255,255,255,.92);font-weight:600;margin-bottom:24px}
.winner-hero .net.tight{margin-bottom:8px}
.winner-hero .net a{color:#fef3c7;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.winner-hero .actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.winner-hero .btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:10px;font-weight:800;font-size:14.5px;text-decoration:none;transition:transform .12s,box-shadow .12s}
.winner-hero .btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.18);text-decoration:none}
.winner-hero .btn-pdf{background:#fff;color:#7c3aed}
.winner-hero .btn-wa{background:#25d366;color:#fff}

/* Interactive ticket-checker widget */
.ticket-checker{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:24px 26px;margin-bottom:18px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.ticket-checker h2{font-size:18px;font-weight:800;color:#0f172a;margin:0 0 4px;letter-spacing:-.01em}
.ticket-checker h2 .accent{background:linear-gradient(135deg,#7c3aed,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ticket-checker p.hint{font-size:13.5px;color:#64748b;margin:0 0 14px;line-height:1.55}
.ticket-checker .row{display:flex;gap:10px;flex-wrap:wrap}
.ticket-checker input{flex:1;min-width:0;padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-family:ui-monospace,Monaco,monospace;font-size:18px;font-weight:700;letter-spacing:1px;background:#fafbff;color:#0f172a;text-transform:uppercase;transition:border-color .15s,box-shadow .15s}
.ticket-checker input:focus{outline:none;border-color:#7c3aed;background:#fff;box-shadow:0 0 0 4px rgba(124,58,237,.12)}
.ticket-checker button{padding:14px 24px;background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;border:none;border-radius:10px;font-family:inherit;font-weight:800;font-size:15px;cursor:pointer;letter-spacing:.3px;transition:transform .12s,box-shadow .12s}
.ticket-checker button:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(124,58,237,.32)}
.check-result{margin-top:14px;padding:16px 18px;border-radius:10px;font-size:14.5px;line-height:1.55;display:none}
.check-result.show{display:block;animation:slideIn .25s}
@keyframes slideIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.check-result.win{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #22c55e;color:#14532d}
.check-result.win strong{color:#14532d;font-weight:800}
.check-result.lose{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.check-result .big{font-size:18px;font-weight:800;display:block;margin-bottom:4px}

/* Prize tier cards (2nd / 3rd / 4th / 5th / consolation) */
.tier-block{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:14px;overflow:hidden;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.tier-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 24px;background:linear-gradient(135deg,#faf5ff,#fdf2f8);border-bottom:1px solid #e9d5ff;flex-wrap:wrap}
.tier-head .tier-label{font-size:15px;font-weight:800;color:#0f172a;letter-spacing:-.01em}
.tier-head .tier-label small{display:block;font-size:12px;color:#64748b;font-weight:600;margin-top:2px;letter-spacing:0}
.tier-head .tier-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.tier-head .tier-amt{background:#fff;color:#15803d;font-family:ui-monospace,Monaco,monospace;font-weight:800;font-size:14px;padding:5px 12px;border-radius:6px;border:1px solid #bbf7d0;letter-spacing:.3px}
.tier-head .tier-count{background:#7c3aed;color:#fff;font-size:11.5px;font-weight:800;padding:4px 10px;border-radius:99px;letter-spacing:.4px;text-transform:uppercase}
.tier-body{padding:18px 22px}
.tier-body .tier-hint{font-size:13.5px;color:#64748b;margin:0 0 14px;line-height:1.55;padding-left:10px;border-left:3px solid #e9d5ff}
.tier-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.tier-chips .chip{font-family:ui-monospace,Monaco,monospace;font-size:15px;font-weight:700;text-align:center;padding:8px 6px;background:#fafbff;border:1px solid #e2e8f0;border-radius:8px;color:#0f172a;letter-spacing:.5px;transition:border-color .12s,background .12s,color .12s,transform .12s,box-shadow .12s;cursor:default}
.tier-chips .chip:hover{border-color:#7c3aed;background:#fff;color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 10px rgba(124,58,237,.1)}
.tier-chips .chip.consolation{background:#fffbeb;border-color:#fde68a}
.tier-block.t1 .tier-head{background:linear-gradient(135deg,#fff7ed,#fef3c7);border-bottom-color:#fbbf24}
.tier-block.t2 .tier-head{background:linear-gradient(135deg,#faf5ff,#fdf2f8);border-bottom-color:#e9d5ff}
.tier-block.t3 .tier-head{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-bottom-color:#bbf7d0}
.tier-block.t4 .tier-head{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom-color:#bfdbfe}
.tier-block.t5 .tier-head{background:linear-gradient(135deg,#fdf2f8,#fce7f3);border-bottom-color:#fbcfe8}
.tier-block.tc .tier-head{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom-color:#fde68a}

/* How-to-check visual numbered steps (2-col on desktop) */
.how-steps{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:18px}
@media(min-width:680px){.how-steps{grid-template-columns:1fr 1fr}}
.step-card{display:flex;gap:14px;padding:18px 20px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:flex-start;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.step-card .num{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0}
.step-card .body{flex:1;min-width:0}
.step-card .body strong{display:block;font-size:14.5px;font-weight:800;color:#0f172a;margin-bottom:4px;line-height:1.3}
.step-card .body p{margin:0;font-size:13.5px;color:#475569;line-height:1.55}
.step-card .body code{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-size:12.5px;font-family:ui-monospace,Monaco,monospace}

/* ─────────────────────────────────────────────────────────
   Bottom-nav on inner pages — same look as homepage
   ───────────────────────────────────────────────────────── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid #e2e8f0;padding:6px 8px env(safe-area-inset-bottom,14px);display:flex;justify-content:space-around;z-index:50;box-shadow:0 -10px 30px rgba(15,23,42,.06)}
@media(min-width:880px){.bottom-nav{display:none}}
.bn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 10px;text-decoration:none;color:#94a3b8;font-size:11.5px;font-weight:700;flex:1;border-radius:10px;transition:all .15s;min-width:0}
.bn .ico{font-size:20px;line-height:1}
.bn .lbl{font-size:10.5px;letter-spacing:.2px}
.bn:hover,.bn.active{color:#7c3aed;text-decoration:none}
.bn.fab{position:relative}
.bn.fab .ico{background:linear-gradient(135deg,#7c3aed,#dc2626);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 18px rgba(124,58,237,.35);margin-top:-12px;line-height:1}
.bn.fab .lbl{color:#7c3aed;margin-top:2px}

/* Make room for the bottom-nav on mobile so content isn't hidden */
@media(max-width:879px){body{padding-bottom:84px}}

/* Footer on mobile — collapse 4-col grid to 1-col, smaller padding */
@media(max-width:879px){
  footer .inner{display:flex;flex-direction:column;gap:20px;padding:28px 18px 18px}
  footer h4{margin-bottom:8px}
}
