/* ==========================================================================
   News4Social — FRESH original design system (v3)
   Identity: ink + electric-blue · "boxed" geometric motif (from the 4-in-box logo)
   Dark ink header w/ real logo · magazine hero · warm-paper canvas · CLS-safe
   ========================================================================== */

:root{
  --bg:#FBFAF8; --surface:#FFFFFF; --surface-2:#F1EEE6; --line:#E6E2D8;
  --ink:#14161B; --text:#14161B; --text-2:#5E6168; --text-3:#66696F;
  --brand:#1A56E8; --brand-2:#0B3FC2; --brand-soft:#E9EEFD;
  --hot:#D62B20;            /* breaking / live / youtube red (AA-darkened) */
  --amber:#F2A024;          /* video / play affordance */
  --header-bg:#14161B; --header-line:#2C2F37; --header-text:#FFFFFF; --header-muted:#A9ADB5;

  --c-desh:#1A56E8; --c-rajya:#0A7480; --c-rajniti:#6D3BEA; --c-khel:#107A50;
  --c-manoranjan:#C2461F; --c-business:#0A7480; --c-tech:#8A52E6; --c-viral:#D62B20;

  --r-sm:6px; --r-md:10px; --r-lg:14px; --r-pill:999px;
  --maxw:1280px;
  --font-body:"Noto Sans Devanagari","Mukta",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-head:"Mukta","Noto Sans Devanagari",system-ui,sans-serif;
  --shadow:0 1px 2px rgba(20,22,27,.05),0 6px 22px rgba(20,22,27,.07);
  --shadow-lg:0 14px 40px rgba(20,22,27,.16);
}
[data-theme="dark"]{
  --bg:#0E0F13; --surface:#16181D; --surface-2:#1E2128; --line:#2A2D34;
  --ink:#F4F3EF; --text:#F4F3EF; --text-2:#A7ABB3; --text-3:#787C84;
  --brand:#5B86FF; --brand-2:#82A2FF; --brand-soft:#15203A;
  --hot:#FF5A4F; --amber:#FBB13C;
  --header-bg:#0A0B0E; --header-line:#23262D; --header-text:#FFFFFF; --header-muted:#9CA0A8;
  --c-desh:#5B86FF; --c-rajya:#3FC1CE; --c-rajniti:#A98BFF; --c-khel:#4FC07F;
  --c-manoranjan:#FF8A5C; --c-business:#3FC1CE; --c-tech:#B79BFF; --c-viral:#FF5A4F;
  --shadow:0 1px 2px rgba(0,0,0,.5),0 8px 26px rgba(0,0,0,.45);
  --shadow-lg:0 16px 44px rgba(0,0,0,.6);
}

/* reset */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background .25s,color .25s}
body::before{content:"";display:block;height:4px;background:var(--brand)}   /* signature top stripe */
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:800;line-height:1.18;margin:0;letter-spacing:-.005em}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:3px}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:18px}
.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}

/* ---------- Topbar (ink) ---------- */
.topbar{background:var(--header-bg);color:var(--header-muted);border-bottom:1px solid var(--header-line)}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:34px;gap:12px;font-size:12.5px}
.topbar .date{display:flex;align-items:center;gap:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .tlinks{display:flex;gap:18px;white-space:nowrap;align-items:center}
.topbar .tlinks a{color:var(--header-muted);font-weight:600}
.topbar .tlinks a:hover{color:#fff}
.t-yt{color:#fff!important;display:inline-flex;align-items:center;gap:5px}
.t-yt svg{fill:var(--hot)}
@media(max-width:640px){.topbar .tlinks a:not(.t-video):not(.t-yt){display:none}}

/* ---------- Header (ink, real white logo) ---------- */
.site-header{position:sticky;top:0;z-index:50;background:var(--header-bg);border-bottom:1px solid var(--header-line);
  transition:transform .3s ease}
.site-header.hide{transform:translateY(-100%)}
.header-row{display:flex;align-items:center;gap:18px;height:66px}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand img{height:42px;width:auto;filter:brightness(0) invert(1)}   /* black logo → white on ink header */
.brand .tag{display:none}

.main-nav{display:flex;gap:1px;margin-inline-start:6px;flex:1;overflow:visible}
.main-nav a{position:relative;padding:22px 13px;font-weight:700;font-size:15.5px;color:var(--header-text);white-space:nowrap;transition:color .15s}
.main-nav a:hover{color:#fff}
.main-nav a::after{content:"";position:absolute;left:13px;right:13px;bottom:14px;height:3px;background:var(--brand);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .2s}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}
.main-nav a.active{color:#fff}
.main-nav a.nav-video::before{content:"";display:inline-block;width:0;height:0;border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent var(--hot);margin-inline-end:6px;vertical-align:1px}

.nav-more{position:relative;display:flex;align-items:center}
.nav-more-btn{background:transparent;border:0;font:inherit;font-weight:700;font-size:15.5px;color:var(--header-text);padding:22px 12px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;cursor:pointer}
.nav-more:hover .nav-more-btn{color:#fff}
.nav-flyout{position:absolute;top:62px;inset-inline-start:0;min-width:200px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:7px;display:none;flex-direction:column;z-index:55}
.nav-more:hover .nav-flyout,.nav-more:focus-within .nav-flyout{display:flex}
.nav-flyout a{padding:9px 12px;border-radius:var(--r-sm);font-weight:600;font-size:15px;color:var(--text)}
.nav-flyout a:hover{background:var(--surface-2);color:var(--brand)}

.header-actions{display:flex;align-items:center;gap:8px;margin-inline-start:auto}
.icon-btn{width:40px;height:40px;border:1px solid var(--header-line);background:transparent;border-radius:var(--r-sm);display:grid;place-items:center;color:#fff;transition:.15s}
.icon-btn:hover{background:rgba(255,255,255,.08);border-color:var(--brand)}
.icon-btn svg{width:19px;height:19px}
.hamburger{display:none}
/* Header expandable search: input is collapsed until the magnifier is clicked. */
.hdr-search{display:flex;align-items:center}
.hdr-search input{width:0;min-width:0;padding:0;border:0;opacity:0;background:rgba(255,255,255,.1);color:#fff;border-radius:var(--r-sm);font-family:inherit;font-size:14px;transition:width .2s,opacity .15s,padding .2s,margin .2s}
.hdr-search input::placeholder{color:rgba(255,255,255,.6)}
.hdr-search.open input{width:200px;padding:8px 12px;opacity:1;margin-inline-end:6px}
@media(max-width:560px){.hdr-search.open input{width:124px}}
/* Search results page form */
.search-page-form{display:flex;gap:8px;margin-top:14px;max-width:540px}
.search-page-form input{flex:1;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-family:inherit;font-size:15px}
.hd-sub{display:inline-flex;align-items:center;gap:6px;background:var(--hot);color:#fff;font-weight:700;font-size:13.5px;padding:9px 14px;border-radius:var(--r-sm);white-space:nowrap}
.hd-sub svg{width:17px;height:17px;fill:#fff}
.hd-sub:hover{filter:brightness(1.08)}
@media(max-width:1240px){.main-nav,.nav-more{display:none}.hamburger{display:grid}.hd-sub .lbl{display:none}.hd-sub{padding:9px 11px}}

/* ---------- Mobile drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);opacity:0;visibility:hidden;transition:.25s;z-index:60}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;inset-inline-end:0;height:100%;width:min(84vw,340px);background:var(--bg);
  border-inline-start:1px solid var(--line);transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:61;display:flex;flex-direction:column;padding:18px}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.drawer-head img{height:34px;filter:none}
[data-theme="dark"] .drawer-head img{filter:brightness(0) invert(1)}
.drawer nav{display:flex;flex-direction:column;margin-top:8px}
.drawer nav a{padding:13px 8px;border-bottom:1px solid var(--line);font-weight:700;font-size:17px;display:flex;justify-content:space-between;align-items:center}
.drawer nav a:hover{color:var(--brand)}
.drawer-sub{display:block;padding:16px 8px 5px;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text-3)}

/* ---------- Breaking strip ---------- */
.breaking{background:var(--surface);border-bottom:1px solid var(--line)}
.breaking .container{display:flex;align-items:center;gap:14px;height:46px;overflow:hidden}
.breaking .badge{display:inline-flex;align-items:center;gap:7px;background:var(--hot);color:#fff;font-weight:800;font-size:12.5px;
  padding:6px 12px;border-radius:var(--r-sm);flex:0 0 auto;letter-spacing:.6px;text-transform:uppercase}
.breaking .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.breaking .feed{flex:1;overflow:hidden;position:relative;height:24px}
.breaking .feed a{position:absolute;inset:0;display:flex;align-items:center;font-weight:600;font-size:15px;color:var(--text);
  opacity:0;transform:translateY(8px);transition:opacity .5s,transform .5s}
.breaking .feed a.show{opacity:1;transform:none}
.breaking .feed a:hover{color:var(--brand)}

/* ---------- Topic strip ---------- */
.topic-strip{background:var(--bg);border-bottom:1px solid var(--line)}
.topic-strip .container{display:flex;align-items:center;gap:10px;height:46px;overflow-x:auto;scrollbar-width:none}
.topic-strip .container::-webkit-scrollbar{display:none}
.topic-strip .tt-lbl{font-weight:800;font-size:12.5px;color:var(--text-2);flex:0 0 auto;text-transform:uppercase;letter-spacing:.5px}
.topic-strip a{flex:0 0 auto;font-size:13.5px;font-weight:700;color:var(--text-2);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:5px 12px;white-space:nowrap}
.topic-strip a:hover{border-color:var(--brand);color:var(--brand)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:var(--r-sm);padding:11px 20px;border:1.5px solid transparent;transition:.15s;font-size:15px}
.btn-primary,.btn-brand{background:var(--brand);color:#fff}
.btn-primary:hover,.btn-brand:hover{background:var(--brand-2)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-block{width:100%;justify-content:center}
.btn-yt{background:var(--hot);color:#fff}
.btn-yt:hover{filter:brightness(1.08)}
.btn-yt svg{width:20px;height:20px;fill:currentColor}

/* ---------- Section header (boxed motif) ---------- */
.section{margin-top:46px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;
  border-bottom:2px solid var(--ink);padding-bottom:9px}
.section-head h2{font-size:22px;display:flex;align-items:center;gap:10px;text-transform:none}
.section-head h2::before{content:"";width:13px;height:13px;background:var(--brand);border-radius:2px;flex:0 0 auto}
.section-head .more{font-weight:700;font-size:13px;color:var(--brand);display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
  border:1.5px solid var(--line);padding:5px 11px;border-radius:var(--r-sm)}
.section-head .more:hover{border-color:var(--brand);background:var(--brand-soft)}
.sec-desh h2::before{background:var(--c-desh)} .sec-khel h2::before{background:var(--c-khel)}
.sec-manoranjan h2::before{background:var(--c-manoranjan)} .sec-business h2::before{background:var(--c-business)}
.sec-tech h2::before{background:var(--c-tech)} .sec-rajya h2::before{background:var(--c-rajya)}
.sec-explainer h2::before{background:var(--c-rajniti)} .sec-video h2::before{background:var(--hot)}

/* ---------- Category label (boxed) ---------- */
.cat-label{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;color:var(--c-desh);
  text-transform:uppercase;letter-spacing:.5px}
.cat-label::before{content:"";width:9px;height:9px;background:currentColor;border-radius:2px}
.cat-rajniti{color:var(--c-rajniti)} .cat-khel{color:var(--c-khel)} .cat-manoranjan{color:var(--c-manoranjan)}
.cat-business{color:var(--c-business)} .cat-tech{color:var(--c-tech)} .cat-viral{color:var(--c-viral)}
.cat-desh{color:var(--c-desh)} .cat-rajya{color:var(--c-rajya)}

/* ---------- Article card ---------- */
.card{display:flex;flex-direction:column;gap:10px}
.card .thumb{position:relative;aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;background:var(--surface-2)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.card:hover .thumb img{transform:scale(1.05)}
.card h3{font-size:17.5px;line-height:1.3;font-weight:700;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card a:hover h3{color:var(--brand)}
.card .deck{font-size:14px;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .meta{font-size:12.5px;color:var(--text-3);display:flex;align-items:center;gap:8px;margin-top:auto;font-weight:600}
.card .meta .sep{opacity:.5}

/* list / row card */
.card-row{display:flex;gap:13px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.card-row:last-child{border-bottom:0}
.card-row .thumb{flex:0 0 110px;aspect-ratio:16/10;border-radius:var(--r-sm);overflow:hidden;background:var(--surface-2)}
.card-row .thumb img{width:100%;height:100%;object-fit:cover}
.card-row h3{font-size:15.5px;line-height:1.38;font-weight:700;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.card-row a:hover h3{color:var(--brand)}
.card-row .meta{font-size:12px;color:var(--text-3);margin-top:6px;font-weight:600}

/* ---------- HERO (magazine overlay + numbered top list) ---------- */
.hero-grid{display:grid;grid-template-columns:1.62fr 1fr;gap:26px;margin-top:26px}
.hero-lead{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--ink);min-height:430px;display:flex}
.hero-lead img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-lead::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,9,12,.92) 8%,rgba(8,9,12,.4) 48%,rgba(8,9,12,.05) 80%)}
.hero-lead .body{position:relative;z-index:2;margin-top:auto;padding:26px 28px;color:#fff}
.hero-lead .klabel{display:inline-flex;align-items:center;gap:6px;background:var(--hot);color:#fff;font-size:12px;font-weight:800;
  text-transform:uppercase;letter-spacing:.6px;padding:5px 11px;border-radius:var(--r-sm);margin-bottom:12px}
.hero-lead h1{font-size:33px;line-height:1.15;color:#fff;font-weight:800}
.hero-lead .deck{font-size:16px;color:rgba(255,255,255,.86);margin-top:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hero-lead .meta{font-size:13px;color:rgba(255,255,255,.78);margin-top:13px;display:flex;gap:9px;align-items:center;font-weight:600}
.hero-lead .vtag{position:absolute;top:16px;inset-inline-start:16px;z-index:2;display:inline-flex;align-items:center;gap:6px;
  background:rgba(8,9,12,.62);color:#fff;font-size:12px;font-weight:700;padding:6px 11px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.hero-lead .vtag svg{width:12px;height:12px;fill:#fff}

/* numbered top stories */
.toplist{display:flex;flex-direction:column}
.toplist .th{font-family:var(--font-head);font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--text-2);padding-bottom:9px;border-bottom:2px solid var(--ink);margin-bottom:4px}
.toplist a{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--line)}
.toplist a:last-child{border-bottom:0}
.toplist .n{font-family:var(--font-head);font-weight:800;font-size:22px;line-height:1;color:var(--brand);flex:0 0 auto;width:26px;opacity:.85}
.toplist .tx{font-size:15.5px;line-height:1.35;font-weight:700}
.toplist a:hover .tx{color:var(--brand)}
.toplist .tx small{display:block;color:var(--text-3);font-weight:600;font-size:12px;margin-top:4px}

/* ---------- grids ---------- */
.grid{display:grid;gap:24px}
.grid-4{grid-template-columns:repeat(4,1fr)} .grid-3{grid-template-columns:repeat(3,1fr)} .grid-2{grid-template-columns:repeat(2,1fr)}

/* ---------- Ad slot ---------- */
.ad-slot{margin:30px auto 0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-2);
  border:1px dashed var(--line);border-radius:var(--r-md);color:var(--text-3);min-height:110px;gap:3px}
.ad-slot .lbl{font-size:10px;letter-spacing:1px;text-transform:uppercase}
.ad-slot .ph{font-size:13px;font-weight:600}
.ad-rect{min-height:250px;min-width:300px}
.ad-leader{min-height:100px;width:100%}
/* Real (filled) GPT slots: drop the dashed placeholder chrome, keep a subtle label +
   the reserved height so there's no layout shift when the ad loads. */
.ad-live{background:transparent;border:0;padding:0}
.ad-live .lbl{opacity:.6;margin-bottom:6px}
.ad-live > div{display:flex;justify-content:center;width:100%}

/* ---------- scroller / shorts ---------- */
.scroller{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}
.scroller::-webkit-scrollbar{height:6px}.scroller::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.shorts-rail .short{flex:0 0 162px;scroll-snap-align:start}
.shorts-rail .short .poster{position:relative;aspect-ratio:9/16;border-radius:var(--r-md);overflow:hidden;background:var(--surface-2)}
.shorts-rail .short .poster img{width:100%;height:100%;object-fit:cover}
.shorts-rail .short .poster::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,9,12,.8),transparent 55%);z-index:1}
.shorts-rail .short .s-badge{position:absolute;top:8px;inset-inline-start:8px;background:var(--hot);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:var(--r-sm);z-index:2;text-transform:uppercase;letter-spacing:.4px}
.shorts-rail .short .t{position:absolute;bottom:9px;left:9px;right:9px;color:#fff;font-size:12.5px;font-weight:700;line-height:1.3;z-index:2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- INSTAGRAM feed ---------- */
.sec-instagram h2::before{display:none}
.sec-instagram .section-head h2{display:inline-flex;align-items:center;gap:9px}
.ig-mark{display:inline-flex;width:24px;height:24px;border-radius:7px;background:linear-gradient(45deg,#f9ce34 0%,#ee2a7b 45%,#6228d7 100%);color:#fff;align-items:center;justify-content:center;flex:0 0 auto}
.ig-mark svg{width:14px;height:14px}
.ig-rail{gap:14px}
.ig-rail .ig-card{flex:0 0 226px;scroll-snap-align:start;display:flex;flex-direction:column;gap:9px;text-decoration:none}
.ig-rail .ig-img{position:relative;aspect-ratio:1/1;border-radius:var(--r-md);overflow:hidden;background:var(--surface-2)}
.ig-rail .ig-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.ig-rail .ig-card:hover .ig-img img{transform:scale(1.05)}
.ig-rail .ig-vid{position:absolute;top:8px;inset-inline-end:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:rgba(8,9,12,.6);border-radius:50%}
.ig-rail .ig-vid svg{width:12px;height:12px}
.ig-rail .ig-cap{font-size:13px;line-height:1.5;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0}
.ig-rail .ig-tags{display:flex;flex-wrap:wrap;gap:5px}
.ig-rail .ig-tags span{font-size:11.5px;font-weight:700;color:#B22F79;background:var(--surface-2);border-radius:var(--r-sm);padding:2px 7px}

/* ---------- VIDEO hub ---------- */
.sec-video{background:var(--ink);border-radius:var(--r-lg);padding:26px;margin-top:46px}
.sec-video .section-head{border-color:rgba(255,255,255,.18)}
.sec-video .section-head h2{color:#fff}
.sec-video .section-head h2::before{background:var(--hot)}
.sec-video .yt-sub{color:#fff;font-weight:700;font-size:13.5px;display:inline-flex;align-items:center;gap:5px;border:1.5px solid rgba(255,255,255,.25);padding:6px 13px;border-radius:var(--r-sm)}
.sec-video .yt-sub:hover{background:var(--hot);border-color:var(--hot)}
.video-hub{display:grid;grid-template-columns:1.7fr 1fr;gap:22px}
@media(max-width:860px){.video-hub{grid-template-columns:1fr}}
.yt-facade{position:relative;display:block;cursor:pointer}
.yt-facade .poster{position:relative;aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;background:#000;display:block}
.yt-facade .poster img{width:100%;height:100%;object-fit:cover}
.yt-facade.feature .yt-title{display:block;font-family:var(--font-head);font-weight:800;font-size:19px;line-height:1.28;margin-top:13px;color:#fff}
.sec-video .yt-facade.feature:hover .yt-title{color:var(--brand-2)}
.yt-play{position:absolute;top:calc(50% - 31px);left:calc(50% - 31px);width:62px;height:62px;background:var(--hot);border-radius:50%;display:grid;place-items:center;box-shadow:0 6px 22px rgba(0,0,0,.4);transition:transform .15s;z-index:2}
.yt-facade:hover .yt-play{transform:scale(1.08)}
.yt-play svg{width:25px;height:25px;margin-inline-start:3px;fill:#fff}
.yt-facade .dur{position:absolute;bottom:8px;inset-inline-end:8px;background:rgba(0,0,0,.82);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px;z-index:2}
.yt-facade.playing{aspect-ratio:16/9;display:block;border-radius:var(--r-md);overflow:hidden}
.yt-facade.playing .yt-play,.yt-facade.playing .dur,.yt-facade.playing .yt-title{display:none}
.yt-facade.playing iframe{width:100%;height:100%;border:0;display:block}
.video-rail{display:flex;flex-direction:column;gap:2px}
.vid-row{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.vid-row:last-child{border-bottom:0}
.vid-row .vthumb{position:relative;flex:0 0 130px;aspect-ratio:16/9;border-radius:var(--r-sm);overflow:hidden;background:#000}
.vid-row .vthumb img{width:100%;height:100%;object-fit:cover}
.vid-row .vthumb .mini-play{position:absolute;top:calc(50% - 12px);left:calc(50% - 12px);width:24px;height:24px;background:var(--hot);border-radius:50%;display:grid;place-items:center}
.vid-row .vthumb .mini-play svg{width:11px;height:11px;fill:#fff;margin-inline-start:1px}
.vid-row .vthumb .dur{position:absolute;bottom:5px;inset-inline-end:5px;background:rgba(0,0,0,.82);color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px}
.vid-row h3{font-size:14px;line-height:1.36;font-weight:700;color:#fff;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.vid-row:hover h3{color:var(--brand-2)}

/* video card (grid) */
.vcard{display:flex;flex-direction:column;gap:9px}
.vcard h3{font-size:16px;line-height:1.32;font-weight:700;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.vcard:hover h3{color:var(--brand)}
.vcard .meta{font-size:12.5px;color:var(--text-3);font-weight:600}

/* ---------- explainer ---------- */
.explainer-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;display:flex;flex-direction:column;gap:9px;border-top:3px solid var(--c-rajniti)}
.explainer-card .ex-kicker{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--c-rajniti)}
.explainer-card h3{font-size:18px;line-height:1.3;font-weight:700}
.explainer-card:hover h3{color:var(--brand)}
.explainer-card p{font-size:14px;color:var(--text-2);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- main + sidebar ---------- */
.with-side{display:grid;grid-template-columns:1fr 340px;gap:44px;align-items:start;margin-top:46px}
.sidebar{position:sticky;top:88px;display:flex;flex-direction:column;gap:26px}
.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px}
.widget>h3{font-size:16px;font-weight:800;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.trend{list-style:none;margin:0;padding:0}
.trend li{display:flex;gap:13px;padding:13px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.trend li:last-child{border-bottom:0;padding-bottom:0}
.trend .n{font-family:var(--font-head);font-weight:800;font-size:21px;color:var(--brand);line-height:1;flex:0 0 auto;width:24px}
.trend .tx{font-size:15px;font-weight:700;line-height:1.36;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.trend .tx:hover{color:var(--brand)}
.trend li small{display:block;color:var(--text-3);font-weight:600;font-size:12px;margin-top:3px}

/* latest river */
.river{display:flex;flex-direction:column}
.river .card-row{padding:18px 0}
.river .card-row .thumb{flex:0 0 184px;aspect-ratio:16/10}
.river .card-row h3{font-size:18.5px}
.river .card-row .deck{font-size:14px;color:var(--text-2);margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.loadmore{margin-top:26px;text-align:center}

/* ---------- newsletter ---------- */
.newsletter{margin-top:56px;background:var(--ink);border-radius:var(--r-lg);padding:40px 30px;color:#fff;text-align:center;position:relative;overflow:hidden}
.newsletter::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--brand)}
.newsletter h2{color:#fff;font-size:25px}
.newsletter p{max-width:520px;margin:10px auto 20px;color:rgba(255,255,255,.82);font-size:15.5px}
.newsletter form{display:flex;gap:10px;max-width:460px;margin-inline:auto}
.newsletter input{flex:1;border:0;border-radius:var(--r-sm);padding:13px 16px;font-size:15px;font-family:inherit}
.newsletter .btn{background:var(--brand);color:#fff;flex:0 0 auto}
.newsletter .btn:hover{background:var(--brand-2)}
@media(max-width:560px){.newsletter form{flex-direction:column}}

/* ---------- footer ---------- */
.site-footer{margin-top:60px;background:var(--ink);color:#fff;padding:46px 0 24px}
.site-footer .brand img{height:40px;filter:brightness(0) invert(1)}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:32px}
.footer-grid h4{font-family:var(--font-body);font-size:12.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--header-muted);margin-bottom:14px;font-weight:800}
.footer-grid ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-grid a{font-size:14.5px;color:rgba(255,255,255,.84)}
.footer-grid a:hover{color:#fff}
.footer-about p{color:var(--header-muted);font-size:14px;margin:14px 0 16px;max-width:340px}
.social{display:flex;gap:9px}
.social a{width:38px;height:38px;border:1px solid var(--header-line);border-radius:var(--r-sm);display:grid;place-items:center;color:rgba(255,255,255,.8)}
.social a:hover{border-color:var(--hot);color:#fff;background:rgba(255,255,255,.06)}
.footer-bottom{border-top:1px solid var(--header-line);margin-top:32px;padding-top:20px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--header-muted)}
.footer-bottom a{color:rgba(255,255,255,.84)} .footer-bottom a:hover{color:#fff}

/* ---------- breadcrumb ---------- */
.crumb{display:flex;gap:7px;align-items:center;font-size:13px;color:var(--text-2);margin-top:22px;flex-wrap:wrap;font-weight:600}
.crumb a:hover{color:var(--brand)} .crumb .sep{opacity:.5}

/* ---------- article ---------- */
.article-wrap{display:grid;grid-template-columns:62px minmax(0,720px) 1fr;gap:30px;margin-top:16px;align-items:start}
@media(max-width:1080px){.article-wrap{grid-template-columns:1fr;gap:0}}
.share-rail{position:sticky;top:90px;display:flex;flex-direction:column;gap:10px}
@media(max-width:1080px){.share-rail{flex-direction:row;position:static;margin:16px 0;flex-wrap:wrap}}
.share-rail .lbl{font-size:11px;color:var(--text-3);text-align:center;font-weight:700;text-transform:uppercase}
.share-rail .s-btn{width:46px;height:46px;border-radius:var(--r-sm);display:grid;place-items:center;color:#fff;transition:transform .15s}
.share-rail .s-btn:hover{transform:translateY(-2px)}
.s-wa{background:#25D366} .s-fb{background:#1877F2} .s-tw{background:#14161B} .s-cp{background:var(--text-2)}
.article h1{font-size:34px;line-height:1.18;margin:10px 0 12px;font-weight:800}
.article .standfirst{font-size:19px;color:var(--text-2);line-height:1.5;margin-bottom:18px;font-family:var(--font-body);font-weight:500}
.byline{display:flex;align-items:center;gap:13px;padding:16px 0;border-block:1px solid var(--line);flex-wrap:wrap}
.byline .avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;background:var(--surface-2);flex:0 0 auto}
.avatar-mono{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:800;line-height:1;font-family:Mukta,system-ui,sans-serif;flex:0 0 auto;overflow:hidden;text-transform:uppercase;-webkit-user-select:none;user-select:none}
.byline .who b{font-size:15px}.byline .who b:hover{color:var(--brand)}
.byline .who small{display:block;color:var(--text-3);font-size:12.5px;font-weight:600}
.byline .times{margin-inline-start:auto;font-size:13px;color:var(--text-3);text-align:end;font-weight:600}
.figure{margin:22px 0}
.figure img{width:100%;border-radius:var(--r-md);background:var(--surface-2)}
.figure figcaption{font-size:13px;color:var(--text-3);margin-top:8px;font-weight:500}
.prose{font-size:18.5px;line-height:1.8}
.prose p{margin:0 0 22px}
.prose h2{font-size:24px;margin:34px 0 14px;font-weight:800}
.prose h3{font-size:20px;margin:28px 0 12px;font-weight:800}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{margin:0 0 22px;padding-inline-start:24px}
.prose li{margin-bottom:9px}
.prose blockquote{margin:26px 0;padding:18px 22px;background:var(--surface-2);border-inline-start:4px solid var(--brand);border-radius:0 var(--r-md) var(--r-md) 0;font-weight:600;font-size:19px;line-height:1.5}
/* Server-side social-embed cards (Twitter/X, Instagram, Facebook) — no widget JS; see App\Support\SocialEmbed. */
.prose blockquote.social-embed{border:1px solid var(--line);border-inline-start:3px solid var(--text);border-radius:var(--r-md);padding:14px 18px;font-weight:400;font-size:16px;line-height:1.6}
.prose blockquote.social-embed::before{display:block;font-size:11.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);margin-bottom:9px}
.prose blockquote.social-embed--twitter::before{content:"X (Twitter)"}
.prose blockquote.social-embed--instagram{border-inline-start-color:#C13584}
.prose blockquote.social-embed--instagram::before{content:"Instagram"}
.prose blockquote.social-embed--facebook{border-inline-start-color:#1877F2}
.prose blockquote.social-embed--facebook::before{content:"Facebook"}
.prose blockquote.social-embed p{margin:0 0 8px;font-weight:400}
.prose .social-embed__link{display:inline-block;margin-top:4px;font-weight:700;font-size:13.5px;color:var(--brand);text-decoration:none}
.highlights{background:var(--surface);border:1px solid var(--line);border-top:4px solid var(--brand);border-radius:var(--r-md);padding:16px 20px;margin:18px 0}
.highlights h2{font-size:13.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--brand);margin-bottom:9px;font-family:var(--font-body);font-weight:800}
.highlights ul{margin:0;padding-inline-start:20px}
.highlights li{font-size:16px;margin-bottom:7px;line-height:1.5;font-weight:500}
.inline-cta{margin:30px 0;background:var(--brand-soft);border:1px solid var(--line);border-radius:var(--r-md);padding:22px}
.inline-cta h4{font-size:18px;color:var(--brand);margin-bottom:6px}
.inline-cta p{margin:0 0 14px;color:var(--text-2);font-size:15px}
.inline-cta form{display:flex;gap:10px}.inline-cta input{flex:1;border:1px solid var(--line);background:var(--bg);border-radius:var(--r-sm);padding:11px 14px;font-family:inherit;color:var(--text)}
@media(max-width:520px){.inline-cta form{flex-direction:column}}
.tags{display:flex;gap:9px;flex-wrap:wrap;margin:26px 0}
.tags a{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:7px 14px;font-size:13.5px;font-weight:700;color:var(--text-2)}
.tags a:hover{border-color:var(--brand);color:var(--brand)}
.prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:30px 0}
.prevnext a{border:1px solid var(--line);border-radius:var(--r-md);padding:16px;transition:.15s;background:var(--surface)}
.prevnext a:hover{border-color:var(--brand)}
.prevnext small{color:var(--text-3);font-size:12px;display:flex;align-items:center;gap:5px;font-weight:700}
.prevnext b{display:block;margin-top:7px;font-size:15.5px;font-family:var(--font-head)}
.prevnext .next{text-align:end}.prevnext .next small{justify-content:flex-end}
@media(max-width:560px){.prevnext{grid-template-columns:1fr}}
.authorbox{display:flex;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px;margin:30px 0}
.authorbox img{width:64px;height:64px;border-radius:50%;flex:0 0 auto;background:var(--surface-2)}
.authorbox h4{font-size:17px}.authorbox p{font-size:14px;color:var(--text-2);margin:6px 0 0}
@media(max-width:1080px){
  .share-rail.sticky-share{position:fixed;top:auto;bottom:0;left:0;right:0;height:auto;z-index:45;background:var(--surface);border-top:1px solid var(--line);flex-direction:row;justify-content:center;gap:16px;padding:9px;margin:0}
  .share-rail.sticky-share .lbl{display:none}
  body.has-sticky-share{padding-bottom:64px}
}
.vmeta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:14px 0;font-size:13.5px;color:var(--text-3);font-weight:600}
.video-demo-note{background:var(--surface-2);border:1px dashed var(--line);border-radius:var(--r-md);padding:12px 16px;font-size:13.5px;color:var(--text-2);margin:16px 0}

/* ---------- page head (category) ---------- */
.page-head{margin-top:24px;border-bottom:2px solid var(--ink);padding-bottom:14px}
.page-head h1{font-size:30px;display:flex;align-items:center;gap:12px;font-weight:800}
.page-head h1::before{content:"";width:16px;height:28px;background:var(--brand);border-radius:2px}
.page-head p{color:var(--text-2);margin-top:8px;font-size:15px;max-width:640px;font-weight:500}
.pagination{display:flex;gap:6px;justify-content:center;margin-top:30px;flex-wrap:wrap}
.pagination a{min-width:42px;height:42px;display:grid;place-items:center;border:1.5px solid var(--line);border-radius:var(--r-sm);font-weight:700;font-size:15px;padding:0 6px}
.pagination a:hover{border-color:var(--brand);color:var(--brand)}
.pagination a.cur{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-lead{min-height:360px}
  .with-side{grid-template-columns:1fr;gap:40px}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .grid-4{grid-template-columns:repeat(2,1fr)} .grid-3{grid-template-columns:repeat(2,1fr)}
  .hero-lead h1{font-size:25px} .article h1{font-size:27px} .section{margin-top:38px}
}
@media(max-width:480px){
  body{font-size:16px}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr;gap:18px}
  .river .card-row .thumb{flex:0 0 130px}
  .footer-grid{grid-template-columns:1fr} .section-head h2{font-size:19px}
}

/* ---------- Topic hubs (entity linking) ---------- */
.prose .entity-link{color:var(--brand);font-weight:600;text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--brand) 35%,transparent)}
.prose .entity-link:hover{border-bottom-color:var(--brand)}
.topic-chips{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:22px 0 4px}
.topic-chips .tc-lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-2)}
.topic-chips a{font-size:13.5px;font-weight:600;color:var(--brand);background:color-mix(in srgb,var(--brand) 8%,transparent);border:1px solid color-mix(in srgb,var(--brand) 20%,transparent);border-radius:var(--r-pill,999px);padding:5px 12px;text-decoration:none}
.topic-chips a:hover{background:color-mix(in srgb,var(--brand) 16%,transparent)}

/* ---------- In-body related link ---------- */
.prose .read-more-inline{margin:6px 0 14px;padding:10px 14px;border-inline-start:3px solid var(--brand);background:var(--surface-2);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:15px;font-weight:600}
.prose .read-more-inline a{color:var(--brand);text-decoration:none}
.prose .read-more-inline a:hover{text-decoration:underline}
