/* ===================================================================
   Bindu Vistaar — Application stylesheet (loaded async after critical)
   Premium, app-like news UI. Tokens live in critical.css.
   =================================================================== */

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;
  border-radius:var(--r-pill);padding:10px 20px;font-weight:700;font-size:.94rem;line-height:1;
  background:var(--surface-3);color:var(--text);transition:.22s var(--ease);position:relative;overflow:hidden}
.btn:hover{transform:translateY(-2px)}
.btn-brand{background:linear-gradient(135deg,var(--brand),var(--brand-ink));color:#fff;box-shadow:var(--shadow-brand)}
.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--text)}
.btn-ghost:hover{background:var(--surface-3)}
.btn-block{width:100%}
.btn-sm{padding:7px 14px;font-size:.85rem}
.btn:disabled{opacity:.55;pointer-events:none}
.ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.5);
  animation:ripple .6s linear;pointer-events:none}
@keyframes ripple{to{transform:scale(3.2);opacity:0}}

/* ---------- Badges ---------- */
.badge-cat{display:inline-block;padding:4px 11px;border-radius:var(--r-pill);font-size:.72rem;font-weight:800;
  letter-spacing:.02em;color:#fff;background:var(--c,var(--brand));text-transform:uppercase;
  box-shadow:0 4px 12px rgba(0,0,0,.18)}
.badge-cat.sm{font-size:.66rem;padding:3px 9px}
.badge-live,.badge-breaking,.badge-trend{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;
  font-weight:800;text-transform:uppercase;padding:3px 9px;border-radius:var(--r-pill)}
.badge-live{background:var(--live);color:#fff}
.badge-live .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1s infinite}
.badge-breaking{background:#111;color:#fff}
.badge-trend{background:var(--brand-soft);color:var(--brand-ink)}

/* ---------- Card grid + page layout ---------- */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.layout{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
/* Full-width portal: reading pages (article / video / about / contact) stay centered & readable */
.layout-narrow{max-width:1200px;margin-inline:auto}
/* Generous side gutters on large screens so full-width content isn't glued to the edges */
@media(min-width:1280px){.container{padding-inline:28px}}
@media(min-width:1760px){.container{padding-inline:48px}}
.aside{position:sticky;top:calc(var(--header-h) + 14px);display:grid;gap:22px}
@media (max-width:992px){.layout{grid-template-columns:1fr}.aside{position:static}}
@media (max-width:560px){.grid-2{grid-template-columns:1fr}.news-grid{grid-template-columns:1fr;gap:14px}}

/* ---------- Vertical news card ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-media{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;background:var(--surface-3)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.card:hover .card-media img{transform:scale(1.07)}
.card-media .badge-cat{position:absolute;left:12px;top:12px}
.card-media .play{position:absolute;inset:0;margin:auto;width:54px;height:54px;border-radius:50%;
  background:rgba(0,0,0,.55);color:#fff;display:grid;place-items:center;font-size:1.5rem;backdrop-filter:blur(4px)}
.card-media .dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.78);color:#fff;font-size:.72rem;
  font-weight:700;padding:2px 7px;border-radius:6px}
.tile-cap{position:absolute;left:0;right:0;bottom:0;padding:24px 14px 12px;color:#fff;font-weight:700;font-size:.9rem;
  background:linear-gradient(transparent,rgba(0,0,0,.8))}
.tile-count{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.65);color:#fff;font-size:.72rem;font-weight:700;
  padding:3px 9px;border-radius:var(--r-pill);display:inline-flex;gap:5px;align-items:center}
.card-body{padding:14px 16px 16px}
.card-title{font-size:1.06rem;font-weight:800;line-height:1.34;margin:0 0 8px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card:hover .card-title{color:var(--brand)}
.card-excerpt{color:var(--text-muted);font-size:.9rem;margin:0 0 12px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{display:flex;align-items:center;gap:14px;font-size:.78rem;color:var(--text-soft);font-weight:600}
.card-meta i{margin-right:3px}
.card-share{margin-left:auto;flex:none;background:none;border:none;cursor:pointer;color:var(--text-soft);
  width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.95rem;
  transition:color .15s,background .15s}
.card-share:hover{color:var(--brand);background:var(--brand-soft)}
.card-meta.light{color:rgba(255,255,255,.85)}

/* ---------- Overlay (hero) card ---------- */
.card-overlay{position:relative;border-radius:var(--r-lg);overflow:hidden;display:block;height:100%;min-height:220px;
  box-shadow:var(--shadow);isolation:isolate}
.card-overlay img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.card-overlay:hover img{transform:scale(1.06)}
.card-overlay::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,9,13,.92) 4%,rgba(8,9,13,.45) 38%,rgba(8,9,13,0) 70%)}
.overlay-content{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;z-index:2;color:#fff}
.overlay-title{color:#fff;font-size:clamp(1.05rem,2.2vw,1.5rem);font-weight:800;line-height:1.28;margin:9px 0 8px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.hero-main .overlay-title{-webkit-line-clamp:2}

/* ---------- Horizontal card ---------- */
.card-h{display:grid;grid-template-columns:112px 1fr;gap:13px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:9px;transition:.25s var(--ease)}
.card-h:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.card-h-media{border-radius:10px;overflow:hidden;aspect-ratio:1/1;background:var(--surface-3)}
.card-h-media img{width:100%;height:100%;object-fit:cover}
.card-h-title{font-size:.95rem;font-weight:700;line-height:1.34;margin:6px 0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-h:hover .card-h-title{color:var(--brand)}

/* ---------- Ranked list (Popular / Most viewed) ---------- */
.rank-list{list-style:none;margin:0;padding:0;display:grid;gap:4px}
.rank-item{display:flex;gap:13px;align-items:flex-start;padding:11px 6px;border-bottom:1px dashed var(--border)}
.rank-item:last-child{border-bottom:none}
.rank-num{flex:none;width:30px;font-size:1.5rem;font-weight:900;line-height:1;
  background:linear-gradient(var(--brand),var(--brand-ink));-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.85}
.rank-item:nth-child(-n+3) .rank-num{opacity:1}
.rank-title{font-size:.92rem;font-weight:700;line-height:1.36;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rank-item:hover .rank-title{color:var(--brand)}
.rank-sub{font-size:.74rem;color:var(--text-soft);margin-top:4px}

/* ---------- Widgets / cards in sidebar ---------- */
.widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 16px 18px;box-shadow:var(--shadow-sm)}
.widget-head{font-size:1rem;font-weight:800;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--surface-3);
  display:flex;align-items:center;gap:8px}
.widget-head i{color:var(--brand)}
.tagcloud{display:flex;flex-wrap:wrap;gap:8px}
.tagcloud a{padding:6px 12px;border-radius:var(--r-pill);background:var(--surface-3);font-size:.82rem;font-weight:600;
  color:var(--text-muted);transition:.2s}
.tagcloud a:hover{background:var(--brand);color:#fff}

/* ---------- Horizontal swipe scroller (trending / sliders) ---------- */
.scroller{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(250px,80%);gap:16px;overflow-x:auto;
  scroll-snap-type:x mandatory;padding:4px 2px 10px;scrollbar-width:none}
.scroller::-webkit-scrollbar{display:none}
.scroller>*{scroll-snap-align:start}
@media(min-width:680px){.scroller{grid-auto-columns:minmax(290px,44%)}}
@media(min-width:992px){.scroller{grid-auto-columns:minmax(300px,31%)}}

/* ---------- Category strip (homepage sections w/ accent) ---------- */
.cat-strip{border-top:3px solid var(--c,var(--brand));background:var(--surface);border-radius:0 0 var(--r-lg) var(--r-lg);
  padding:6px 0}

/* ---------- Magazine category block (label + lead + side list) ---------- */
.cat-block{margin-block:30px}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;border-bottom:3px solid var(--c,var(--brand));margin-bottom:16px}
.cat-label{display:inline-block;background:var(--c,var(--brand));color:#fff;font-weight:800;font-size:1.05rem;
  padding:8px 22px;border-radius:8px 8px 0 0;letter-spacing:.02em}
.cat-more{font-weight:700;font-size:.82rem;color:var(--c,var(--brand));padding-bottom:8px;white-space:nowrap}
.cat-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:24px;align-items:start}
@media(max-width:820px){.cat-grid{grid-template-columns:1fr;gap:18px}}

.cat-lead-media{position:relative;display:block;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;
  background:var(--surface-3);box-shadow:var(--shadow-sm)}
.cat-lead-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.cat-lead:hover .cat-lead-media img{transform:scale(1.05)}
.cat-lead-media .badge-cat{position:absolute;left:12px;top:12px}
.cat-lead-media .badge-breaking{position:absolute;right:12px;top:12px}
.cat-lead-title{font-size:clamp(1.2rem,2.4vw,1.6rem);font-weight:800;line-height:1.3;margin:13px 0 7px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.cat-lead:hover .cat-lead-title{color:var(--c,var(--brand))}
.cat-lead-excerpt{color:var(--text-muted);font-size:.95rem;margin:0 0 10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.cat-side{display:flex;flex-direction:column}
.cat-side-item{display:grid;grid-template-columns:1fr 92px;gap:12px;align-items:center;padding:11px 0;border-bottom:1px dashed var(--border)}
.cat-side-item:first-child{padding-top:0}
.cat-side-item:last-child{border-bottom:none}
.cat-side-title{font-size:.96rem;font-weight:700;line-height:1.36;margin:0 0 5px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cat-side-item:hover .cat-side-title{color:var(--c,var(--brand))}
.cat-side-thumb{aspect-ratio:4/3;border-radius:9px;overflow:hidden;background:var(--surface-3)}
.cat-side-thumb img{width:100%;height:100%;object-fit:cover}
.cat-readmore{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-weight:700;font-size:.86rem;
  color:#fff;background:var(--c,var(--brand));padding:8px 18px;border-radius:var(--r-pill);align-self:flex-start;transition:.2s}
.cat-readmore:hover{filter:brightness(1.08);transform:translateY(-2px)}

/* feature variant: hero (left) + news side-list (right), then 3-card row */
.cat-feature-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:22px;align-items:start;margin-bottom:18px}
@media(max-width:820px){.cat-feature-grid{grid-template-columns:1fr;gap:16px;margin-bottom:14px}}
.cat-feature-grid .cat-side{justify-content:flex-start}
.cat-hero{position:relative;display:block;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;
  box-shadow:var(--shadow);isolation:isolate;background:var(--surface-3)}
.cat-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.cat-hero:hover img{transform:scale(1.04)}
.cat-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,9,13,.92) 4%,rgba(8,9,13,.4) 40%,transparent 72%)}
.cat-hero-cap{position:absolute;left:0;right:0;bottom:0;padding:20px 24px;z-index:2;color:#fff}
.cat-hero-title{color:#fff;font-size:clamp(1.3rem,2.9vw,2rem);font-weight:800;line-height:1.24;margin:9px 0 9px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 2px 14px rgba(0,0,0,.45)}
.cat-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
@media(max-width:760px){.cat-3{grid-template-columns:1fr 1fr;gap:14px}}
@media(max-width:480px){.cat-3{grid-template-columns:1fr}}

/* ---------- Video & gallery ---------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.gallery-masonry{columns:4 200px;column-gap:14px}
.gallery-masonry .tile{break-inside:avoid;margin-bottom:14px;border-radius:var(--r);overflow:hidden;position:relative;display:block}
.gallery-masonry .tile img{width:100%;transition:transform .5s}
.gallery-masonry .tile:hover img{transform:scale(1.05)}

/* ---------- Article page ---------- */
.article{max-width:760px}
/* article detail page is full-width: let the article fill the main column (no 760px cap) */
.layout>.article{max-width:none}
.article-header h1{font-size:var(--fs-h1);line-height:1.22;margin:10px 0 14px}
.article-lead{font-size:1.12rem;color:var(--text-muted);font-weight:500;margin-bottom:18px;line-height:1.6}
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:13px 0;border-block:1px solid var(--border);margin-bottom:18px}
.author-chip{display:flex;align-items:center;gap:10px}
.author-chip img,.author-ph{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--surface-3);
  display:grid;place-items:center;font-weight:800;color:var(--brand)}
.author-chip .nm{font-weight:700;font-size:.9rem}
.author-chip .sub{font-size:.76rem;color:var(--text-soft)}
.article-figure{border-radius:var(--r-lg);overflow:hidden;margin:0 auto 8px;max-width:900px;box-shadow:var(--shadow)}
.article-figure img{display:block;width:100%;height:auto}
.article-figure figcaption{font-size:.8rem;color:var(--text-soft);padding:8px 4px;text-align:center}
.article-body{font-size:1.12rem;line-height:1.85}
.article-body p{margin:0 0 1.15em}
.article-body h2,.article-body h3{margin:1.4em 0 .6em}
.article-body img{border-radius:var(--r);margin:1.2em 0}
.article-body a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}
.article-body blockquote{margin:1.4em 0;padding:14px 20px;border-left:4px solid var(--brand);background:var(--surface-2);
  border-radius:0 var(--r) var(--r) 0;font-size:1.15rem;font-style:italic;color:var(--text)}
.article-body ul,.article-body ol{padding-left:1.3em;margin:0 0 1.15em}
.article-body li{margin-bottom:.5em}

/* Reading progress + share */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:1200;
  background:linear-gradient(90deg,var(--brand),var(--gold));transition:width .1s linear}
.share-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:22px 0;padding:14px 0;border-block:1px solid var(--border)}
.share-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.05rem;
  transition:transform .2s;border:none}
.share-btn:hover{transform:translateY(-3px) scale(1.06)}
.s-wa{background:#25d366}.s-fb{background:#1877f2}.s-tw{background:#0f1419}.s-tg{background:#229ed9}.s-cp{background:var(--surface-3);color:var(--text)}.s-native{background:var(--brand)}
.engage{display:flex;gap:10px;margin-left:auto}
.engage .btn{background:var(--surface-3)}
.engage .btn.is-on{background:var(--brand-soft);color:var(--brand-ink);border-color:transparent}

/* author box + tags */
.author-box{display:flex;gap:14px;align-items:center;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:16px;margin:24px 0}
.author-box img,.author-box .author-ph{width:62px;height:62px;font-size:1.3rem}

/* ---------- Comments ---------- */
.comment{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.comment .av{width:42px;height:42px;border-radius:50%;background:var(--surface-3);flex:none;display:grid;place-items:center;font-weight:800;color:var(--brand)}
.comment .reply{margin-left:54px}
.comment .nm{font-weight:700;font-size:.9rem}
.comment .tm{font-size:.74rem;color:var(--text-soft)}

/* ---------- Footer ---------- */
.footer{background:var(--surface);border-top:1px solid var(--border);margin-top:40px;padding:40px 0 calc(var(--bottomnav-h) + 24px)}
@media (min-width:992px){.footer{padding-bottom:36px}}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:30px}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:460px){.footer-grid{grid-template-columns:1fr}}
.footer h4{font-size:.95rem;margin-bottom:14px;color:var(--text)}
.footer a{color:var(--text-muted);font-size:.9rem;display:block;padding:5px 0;transition:.2s}
.footer a:hover{color:var(--brand);transform:translateX(3px)}
.social-row{display:flex;gap:10px;margin-top:14px}
.social-row a{width:42px;height:42px;border-radius:12px;background:var(--surface-3);display:grid;place-items:center;
  font-size:1.1rem;color:var(--text)}
.social-row a:hover{background:var(--brand);color:#fff;transform:translateY(-3px)}
.footer-bottom{border-top:1px solid var(--border);margin-top:28px;padding-top:20px;text-align:center;
  font-size:.84rem;color:var(--text-soft)}

/* ---------- Bottom navigation (mobile, app-like) ---------- */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:1000;height:calc(var(--bottomnav-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);background:var(--glass);backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);border-top:1px solid var(--border);
  display:flex;justify-content:space-around;align-items:center}
.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.66rem;font-weight:700;
  color:var(--text-soft);padding:8px 0;transition:.2s;position:relative}
.bottom-nav a i{font-size:1.32rem}
.bottom-nav a.is-active{color:var(--brand)}
.bottom-nav a.is-active::before{content:"";position:absolute;top:0;width:26px;height:3px;border-radius:3px;background:var(--brand)}
.bn-fab{margin-top:-26px}
.bn-fab i{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-ink));
  color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-brand);font-size:1.4rem!important}
@media (min-width:992px){.bottom-nav{display:none}}

/* ---------- Theme toggle ---------- */
.theme-toggle{position:relative;width:52px;height:28px;border-radius:999px;background:var(--surface-3);border:1px solid var(--border);padding:0}
.theme-toggle .knob{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#ff8a3d);display:grid;place-items:center;font-size:.7rem;color:#fff;
  transition:transform .3s var(--ease)}
[data-theme="dark"] .theme-toggle .knob{transform:translateX(24px);background:linear-gradient(135deg,#5b9bff,#3a6ed8)}

/* ---------- Drawer (mobile menu) ---------- */
.scrim{position:fixed;inset:0;background:rgba(8,9,13,.5);backdrop-filter:blur(2px);z-index:1100;opacity:0;visibility:hidden;transition:.3s}
.scrim.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;bottom:0;left:0;width:min(82vw,330px);z-index:1101;background:var(--surface);
  transform:translateX(-100%);transition:transform .34s var(--ease-out);overflow-y:auto;box-shadow:var(--shadow-lg)}
.drawer.open{transform:none}
.drawer-head{padding:18px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.drawer nav a{display:flex;align-items:center;gap:12px;padding:13px 18px;font-weight:600;border-bottom:1px solid var(--border)}
.drawer nav a i{color:var(--brand);width:22px;text-align:center}
.drawer nav a:hover{background:var(--surface-2)}

/* ---------- Search modal ---------- */
.search-modal{position:fixed;inset:0;z-index:1200;background:var(--glass);backdrop-filter:blur(14px);
  display:none;padding-top:12vh}
.search-modal.open{display:block;animation:fadeIn .25s}
.search-box{max-width:640px;margin-inline:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);overflow:hidden}
.search-box input{width:100%;border:none;background:transparent;color:var(--text);font-size:1.15rem;padding:20px 22px;outline:none}
#searchResults{max-height:60vh;overflow:auto}
.search-item{display:flex;flex-direction:column;gap:2px;padding:12px 22px;border-top:1px solid var(--border)}
.search-item:hover{background:var(--surface-2)}
.search-item strong{font-size:.96rem;font-weight:700}
.search-item span{font-size:.76rem;color:var(--brand);font-weight:700}

/* ---------- Inputs ---------- */
.field{display:block;margin-bottom:14px}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:6px}
.input,textarea.input,select.input{width:100%;padding:12px 14px;border:1px solid var(--border-strong);border-radius:12px;
  background:var(--surface-2);color:var(--text);font-size:.95rem;font-family:inherit;transition:.2s}
.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}

/* ---------- FAB / back-to-top ---------- */
.fab{position:fixed;right:18px;bottom:calc(var(--bottomnav-h) + 18px);z-index:900;width:46px;height:46px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text);display:grid;place-items:center;
  opacity:0;transform:translateY(16px) scale(.8);transition:.3s var(--ease);pointer-events:none}
.fab.show{opacity:1;transform:none;pointer-events:auto}
@media (min-width:992px){.fab{bottom:24px}}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;left:50%;bottom:calc(var(--bottomnav-h) + 18px);transform:translateX(-50%);z-index:1300;display:grid;gap:8px}
@media (min-width:992px){.toast-wrap{bottom:24px}}
.toast{background:#111;color:#fff;padding:12px 18px;border-radius:var(--r-pill);font-size:.9rem;font-weight:600;
  box-shadow:var(--shadow-lg);animation:toastIn .3s var(--ease-out);display:flex;align-items:center;gap:9px}
.toast.ok{background:#16a34a}.toast.err{background:var(--brand)}

/* ---------- Install (PWA) banner ---------- */
.install-banner{position:fixed;left:14px;right:14px;bottom:calc(var(--bottomnav-h) + 14px);z-index:950;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  padding:14px;display:none;align-items:center;gap:12px}
.install-banner.show{display:flex;animation:slideUp .4s var(--ease-out)}
@media (min-width:992px){.install-banner{left:auto;right:24px;bottom:24px;max-width:360px}}
/* mobile: install banner uses only ~50% of the width (bottom-right, less intrusive) */
@media (max-width:991px){.install-banner{left:auto;right:14px;max-width:50%;flex-wrap:wrap;row-gap:8px}}

/* ---------- Animated counter ---------- */
.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;text-align:center}
@media (max-width:560px){.counters{grid-template-columns:repeat(2,1fr)}}
.counter .num{font-size:clamp(1.5rem,4vw,2.1rem);font-weight:900;color:var(--brand)}
.counter .lbl{font-size:.8rem;color:var(--text-muted);font-weight:600}

/* ---------- Ad slots ---------- */
.ad-slot{position:relative;margin:24px auto;padding:16px 8px 8px;border:1px solid var(--border);border-radius:var(--r);
  background:var(--surface-2);text-align:center;overflow:hidden}
.ad-slot img{max-width:100%;height:auto;border-radius:8px;display:inline-block;margin-inline:auto}
.ad-slot a{display:inline-block}
/* multi-ad slider: stacked creatives, one shown at a time (rotated by app.js) */
.ad-slides{position:relative;width:100%}
.ad-slide{display:none;width:100%}
.ad-slide.is-active{display:block;animation:adSlideFade .5s ease}
@keyframes adSlideFade{from{opacity:.25}to{opacity:1}}
/* wide banner slots + sidebar fill their container width 100% */
.ad-below-header a,.ad-between-posts a,.ad-header a,.ad-footer a,.ad-sidebar a{display:block}
.ad-below-header img,.ad-between-posts img,.ad-header img,.ad-footer img,.ad-sidebar img{width:100%;height:auto}
.ad-sidebar{max-width:100%;border:none;background:transparent;border-radius:0;padding:14px 0 0}
.ad-label{position:absolute;top:5px;left:50%;transform:translateX(-50%);font-size:.56rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-soft)}
/* footer ad layout (label-left, flex) lives in critical.css so it's inlined & cache-proof */
.ad-sticky-bottom{position:fixed;left:0;right:0;bottom:var(--bottomnav-h);z-index:940;margin:0;border-radius:0;
  border:none;border-top:1px solid var(--border);padding:6px 8px;display:flex;flex-direction:column;align-items:center;
  background:var(--surface);box-shadow:0 -6px 22px rgba(0,0,0,.14)}
.ad-sticky-bottom img{max-height:64px;width:auto}
.ad-sticky-bottom .ad-label{position:static;transform:none;margin-bottom:2px}
.ad-close{position:absolute;top:3px;right:6px;width:24px;height:24px;border:none;border-radius:50%;cursor:pointer;
  background:var(--surface-3);color:var(--text);font-size:1rem;line-height:1;display:grid;place-items:center;z-index:2}
@media (min-width:992px){.ad-sticky-bottom{bottom:0}}

/* ---------- Pagination / load more ---------- */
.loadmore-wrap{text-align:center;margin:26px 0}
.spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:spin .7s linear infinite;display:inline-block}
.dot-loader{display:inline-grid;grid-auto-flow:column;gap:6px}
.dot-loader span{width:9px;height:9px;border-radius:50%;background:var(--brand);animation:bounce .6s infinite alternate}
.dot-loader span:nth-child(2){animation-delay:.15s}.dot-loader span:nth-child(3){animation-delay:.3s}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.18s}

/* ---------- Misc utilities ---------- */
.flex{display:flex}.items-center{align-items:center}.gap{gap:12px}.mt{margin-top:18px}.mb{margin-bottom:18px}
.muted{color:var(--text-muted)}.center{text-align:center}.hide{display:none}
.divider{height:1px;background:var(--border);margin:24px 0;border:none}
.page-head{padding:22px 0 8px}
.page-head h1{font-size:var(--fs-h1)}
.breadcrumb{display:flex;flex-wrap:wrap;gap:6px;font-size:.82rem;color:var(--text-soft);margin-bottom:6px}
.breadcrumb a:hover{color:var(--brand)}
.empty{text-align:center;padding:50px 20px;color:var(--text-muted)}
.empty i{font-size:3rem;color:var(--border-strong);display:block;margin-bottom:12px}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bounce{to{transform:translateY(-8px)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:none}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
