/* Layout container */
.wrap { max-width:1200px; margin:0 auto; padding:0 16px; }

/* =========================
   Header (merged + glow)
   ========================= */

/* Header */
header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(8px);
  background: linear-gradient(180deg, #000c, #0006);
  border-bottom: 1px solid #1b1b1b;
  transition: all .25s ease;
}

/* one row: brand on left, pills on right */
header .bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 22px 0;                 /* default height */
  transition: padding .25s ease;
}
header.at-top .bar { padding: 28px 0; } /* taller at very top */

/* Brand text logo (clickable) */
.brand {
  display: inline-flex; align-items: center; font-weight: 900; letter-spacing: .2px;
  margin-right: 8px;                      /* breathing room before pills */
  position: relative; isolation: isolate; /* enable background glow layer */
}
.brand-word { font-size: 24px; line-height: 1; }

/* Your existing brand color + glow on text */
.brand-word b { color: var(--brand); text-shadow: 0 0 16px var(--brand-glow); }
.brand-word .dot { color: var(--brand); }

/* NEW: soft background glow behind the brand */
.brand::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 120%;
  height: 140%;
  border-radius: 999px;
  /* use your CSS vars; fall back to brand red if vars are weaker */
  background:
    radial-gradient(60% 70% at 20% 50%,
      color-mix(in srgb, var(--brand, #ff0040) 25%, transparent),
      transparent 70%);
  filter: blur(14px);
  z-index: -1;
  pointer-events: none;
  opacity: 0.7;
}

/* Balanced glow for Shorts.md logo */
header .brand-word b {
  color: var(--brand);
  text-shadow:
    0 0 4px rgba(255, 17, 73, 0.55),
    0 0 10px rgba(255, 17, 73, 0.45),
    0 0 18px rgba(255, 17, 73, 0.35);
}


header .brand::before {
  opacity: 0.9;
  filter: blur(18px);
}

header:not(.at-top) .brand::before {
  opacity: 0.6;
  filter: blur(14px);
}


/* Dial the glow down a bit when scrolled */
header:not(.at-top) .brand::before { opacity: .45; filter: blur(12px); }

/* shrink brand a bit when scrolled */
header:not(.at-top) .brand-word { font-size: 20px; transition: font-size .25s ease; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  header { transition: none; }
}

/* =========================
   Loader (Netflix-style)
   ========================= */

.loader {
  --size: 40px;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  border: 4px solid #333;
  border-top-color: var(--brand, #ff0040);  /* brand red */
  animation: spin 0.9s linear infinite;
  margin: 0 auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Center the loader in the status area */
#gridStatus.loading {
  display: grid;
  place-items: center;
  min-height: 40vh;     /* decent vertical center for short pages */
  color: #aaa;          /* if you add any text next to spinner */
}

#gridStatus.loading::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(50% 50% at 50% 50%, rgba(0,0,0,.3), rgba(0,0,0,0));
  pointer-events:none;
}

/* If your page uses reel mode and you want full column centering under header */
.reel-container #gridStatus.loading {
  min-height: calc(100svh - var(--hdr-top, 56px));
}

/* Reduced motion: stop rotation, keep top border colored */
@media (prefers-reduced-motion: reduce) {
  .loader { animation: none; }
}





/*.pill {*/
/*  padding:10px 14px;*/
/*  border:1px solid #242424; background:#111; border-radius:999px; color:#ddd;*/
/*  font-size:14px; line-height:1; cursor:pointer;*/
/*  transition:transform .12s ease, background .2s, border-color .2s;*/
/*}*/
/*.pill:hover { transform:translateY(-1px); background:#151515; }*/
/*.pill.active {*/
/*  border-color:#3a3a3a; background:#181818; color:#fff;*/
/*  box-shadow:0 0 0 2px #000, 0 0 18px var(--brand-glow);*/
/*}*/

.pill {
  position: relative;
  padding: 10px 14px;
  border: 1px solid #242424;
  background: #111;
  border-radius: 999px;
  color: #ddd;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition:
    transform .12s ease,
    background .2s ease,
    border-color .2s ease,
    color .2s ease,
    box-shadow .2s ease;
}

.pill:hover {
  transform: translateY(-1px);
  background: #151515;
}

/* MUCH more visible active state */
.pill.active {
  border-color: var(--brand, #ff1149);
  background: radial-gradient(circle at 50% 0,
              rgba(255,17,73,0.25) 0,
              rgba(24,24,24,1) 55%);
  color: #fff;
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.9),
    0 0 18px rgba(255,17,73,0.55);
  transform: translateY(-1px) scale(1.03);
}

/* optional: a tiny “pill ring” highlight */
.pill.active::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  border: 1px solid rgba(255,17,73,0.55);
  pointer-events: none;
}


/* Grid */
main { padding:22px 0 60px; }
.category-hero {
  margin: 6px 0 18px;
  transition: opacity .35s ease, transform .35s ease, max-height .35s ease, margin .35s ease;
  max-height: 220px;
  overflow: hidden;
}
@media (max-width: 820px) {
  .reel-mode .category-hero,
  body.hero-hidden .category-hero {
    opacity: 0;
    transform: translateY(-8px);
    max-height: 0;
    margin: 0;
    pointer-events: none;
  }
}
.video-page .card {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
}
.video-page .player {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
}
.category-hero h1 {
  margin: 0 0 8px;
  font-size: clamp(22px, 4vw, 32px);
  line-height: 1.2;
  letter-spacing: 0.2px;
}
.category-intro {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
  max-width: 820px;
}
.video-hero .sub {
  margin-top: 6px;
  color: var(--muted);
  font-size: 14px;
}
.video-hero .sub a { color: var(--muted); text-decoration: underline; }
.key-points {
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 14px;
}
.related {
  margin-top: 22px;
}
.related h2 {
  margin: 0 0 10px;
  font-size: 18px;
}
.related ul {
  margin: 0;
  padding-left: 18px;
}
.related li { margin: 6px 0; }
.grid { display:grid; gap:16px; }
@media (min-width:520px) { .grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (min-width:980px) { .grid { grid-template-columns:repeat(3,minmax(0,1fr)); } }

/* Cards */
.card {
  background:#0d0d0d; border:1px solid #1b1b1b; border-radius:16px; overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.35); display:flex; flex-direction:column;
}
.thumb { width:100%; aspect-ratio:9/16; background:#111; position:relative; display:block; }
.thumb::after { content:""; position:absolute; inset:0; box-shadow:inset 0 -80px 100px rgba(0,0,0,.55); pointer-events:none; }
.meta { padding:10px 12px 12px; color:#cfcfcf; font-size:14px; }
.title { color:#fff; font-weight:600; margin:0 0 6px; font-size:15px; line-height:1.25; }

.legal { max-width:800px; margin:0 auto; padding:10px 0 40px; }
.legal h1 { font-size:28px; margin:10px 0 12px; }
.legal h2 { font-size:18px; margin:20px 0 8px; color:#eaeaea; }
.legal p, .legal li { color:#cfcfcf; line-height:1.6; }
.legal .muted { color:#9a9a9a; font-size:13px; }
.legal ul { padding-left:18px; }

/* Ensure images fill the 9:16 area */
.thumb img { width:100%; height:100%; object-fit:cover; display:block; }

/* Duration badge (top-right) */
.duration {
  position:absolute; top:8px; right:8px;
  background:rgba(0,0,0,.65); color:#fff; font-size:12px; line-height:1;
  padding:6px 8px; border-radius:8px; border:1px solid rgba(255,255,255,.08);
}

/* Play indicator (center) */
.play {
  position:absolute; inset:auto; left:50%; top:50%;
  transform:translate(-50%,-50%);
  font-size:28px; line-height:1; color:#ffffffd0;
  text-shadow:0 2px 10px rgba(0,0,0,.5);
  opacity:0; transition:opacity .2s;
}
/* Always visible on thumbnails */
.thumb .play { opacity: .95; }
.thumb:hover .play { opacity: 1; }     /* optional: a tiny boost on hover */

.play img {
  width: 60px;
  height: 60px;
  opacity: 1;
  filter: drop-shadow(0 0 10px rgba(255,0,40,0.45));   /* optional glow */
  transition: transform .2s ease;
}

.thumb:hover .play img {
  transform: scale(1.06);
}

.player {
  position: relative;
  width: 100%;
  aspect-ratio: 9/16;
  border-radius: 16px;
  overflow: hidden;
  background: #111;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.player iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.card {
  background: #0d0d0d;
  border: 1px solid #1b1b1b;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

/* Header spacing tweaks */
header .bar { padding:18px 0; }
header.at-top .bar { padding:24px 0; }

/* Hamburger button (hidden on desktop) */
.menu-btn {
  display:none;
  width:40px;height:40px;border-radius:999px;
  border:1px solid #262626;background:#111;color:#fff;
  align-items:center;justify-content:center;gap:4px;
}
.menu-btn span {
  display:block;width:18px;height:2px;background:#e8e8e8;border-radius:2px;
  transition:transform .2s, opacity .2s;
}

/* mobile layout */
@media (max-width: 820px) {
  /* brand + burger on one row */
  header .bar { gap:12px; }
  .menu-btn { display:inline-flex; }

  /* nav becomes a slide-down panel under header */
  .cats {
    position: fixed; left:0; right:0;
    top: calc(var(--hdr-top, 64px));
    margin:0; padding:10px 14px;
    background: linear-gradient(180deg, #0a0a0a, #090909);
    border-bottom:1px solid #1b1b1b;
    display:flex; gap:10px; overflow-x:auto; white-space:nowrap;
    transform: translateY(-10px); opacity:0; pointer-events:none;
    transition: transform .18s ease, opacity .18s ease;
    z-index:49;   /* under the header (50) */
  }
  /* when menu open */
  header[data-menu="open"] .cats {
    transform: translateY(0); opacity:1; pointer-events:auto;
  }

  /* animate hamburger to X when open */
  header[data-menu="open"] .menu-btn span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  header[data-menu="open"] .menu-btn span:nth-child(2) { opacity:0; }
  header[data-menu="open"] .menu-btn span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

  /* pills slightly larger for touch */
  .pill { padding:10px 14px; }
}

/* reserve a CSS var for header height used by the panel */
:root { --hdr-top: 64px; }
@media (max-width: 820px){
  :root { --hdr-top: 58px; }
}



.wrap { padding-left:18px; padding-right:18px; } /* a touch more edge padding */

/* ===== CATEGORIES (cats) + arrows ===== */


/* container with edge hints */
.cats-wrap { position: relative; flex: 1; }

/* horizontal pills row */
.cats{
  display:flex; align-items:center; gap:10px;
  margin:0; padding:10px 40px;               /* room for arrows */
  overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.cats::-webkit-scrollbar{ display:none; }

/* edge fades (only visible when open on mobile, see media rule below) */
.cats-wrap::before,
.cats-wrap::after{
  content:""; position:absolute; top:0; bottom:0; width:32px; pointer-events:none;
  opacity:0; transition:opacity .18s ease;
}
.cats-wrap::before{ left:0;  background:linear-gradient(90deg,  rgba(0,0,0,.9), rgba(0,0,0,0)); }
.cats-wrap::after { right:0; background:linear-gradient(270deg, rgba(0,0,0,.9), rgba(0,0,0,0)); }

/* arrow buttons (default hidden) */
.cats-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:28px; height:28px; border-radius:999px;
  border:1px solid #2a2a2a; background:#0f0f0f; color:#eee;
  display:none; align-items:center; justify-content:center;
  z-index:1; opacity:.9;
}
.cats-nav.prev{ left:6px; }
.cats-nav.next{ right:6px; }
.cats-nav[disabled]{ opacity:.35; }



/* Desktop: arrows always hidden, cats inline */
@media (min-width:821px){
  .cats-nav{ display:none !important; }

    header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 80;
  }

  body { padding-top: 72px; }
}

@media (min-width: 420px) {
  .loader { --size: 48px; border-width: 5px; }
}

/* Mobile behaviour */
@media (max-width:820px){

    .brand {
        margin-left: 12px;   /* or 14–18px if you want more space */
    }

  /* ---------- Compact sticky header ---------- */
  :root { --hdr-top: 56px; } /* header height used by cats panel & reel calc */

  header { position: sticky; top: 0; z-index: 50; }
  header .bar{
    gap: 10px;
    padding: 12px 0;                 /* slimmer header on mobile */
  }
  header.at-top .bar{ padding: 14px 0; }

  /* Pills a bit tighter for touch */
  .pill{ padding:8px 12px; font-size:13px; }

  /* Hamburger visible on mobile */
  .menu-btn{ display:inline-flex; }

  /* Slide-down categories under header (your original behavior) */
  .cats{
    position: fixed; left:0; right:0;
    top: var(--hdr-top);
    margin:0; padding:10px 14px;
    background: linear-gradient(180deg, #0a0a0a, #090909);
    border-bottom:1px solid #1b1b1b;
    display:flex; gap:10px; overflow-x:auto; white-space:nowrap;
    transform: translateY(-10px); opacity:0; pointer-events:none;
    transition: transform .18s ease, opacity .18s ease;
    z-index:49;   /* under header (50) */
  }
  header[data-menu="open"] .cats{
    transform: translateY(0); opacity:1; pointer-events:auto;
  }

  /* Animate hamburger to X */
  header[data-menu="open"] .menu-btn span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  header[data-menu="open"] .menu-btn span:nth-child(2) { opacity:0; }
  header[data-menu="open"] .menu-btn span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

  /* Pills row with edge fades + arrow buttons (classic behavior) */
  .cats-wrap{ position: relative; flex:1; }
  .cats-wrap::before,
  .cats-wrap::after{
    content:""; position:absolute; top:0; bottom:0; width:32px; pointer-events:none;
    opacity:0; transition:opacity .18s ease;
  }
  .cats-wrap::before{ left:0;  background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,0)); }
  .cats-wrap::after { right:0; background:linear-gradient(270deg,rgba(0,0,0,.9),rgba(0,0,0,0)); }
  header[data-menu="open"] .cats-wrap::before,
  header[data-menu="open"] .cats-wrap::after{ opacity:1; }

  .cats-nav{
    position:absolute; top:50%; transform:translateY(-50%);
    width:28px; height:28px; border-radius:999px;
    border:1px solid #2a2a2a; background:#0f0f0f; color:#eee;
    display:none; align-items:center; justify-content:center;
    z-index:1; opacity:.9;
  }
  .cats-nav.prev{ left:6px; }
  .cats-nav.next{ right:6px; }
  .cats-nav[disabled]{ opacity:.35; }
  header[data-menu="open"] .cats-nav{ display:flex; }

  /* ---------- Reel mode sizing (no overlays) ---------- */
  /* Let the video stack start below the header and fill the rest */
  .reel-container{
    margin-top: var(--hdr-top) !important;      /* sit under the header */
    height: calc(100svh - var(--hdr-top));      /* fill remaining viewport */
    overflow-y: auto;
    scroll-snap-type: y mandatory;
    overscroll-behavior-y: contain;
    background:#000;
    padding:0 !important;
  }
  .reel-card{
    position: relative;
    height: calc(100svh - var(--hdr-top));
    scroll-snap-align: start;
    display: grid;
    place-items: center;
    margin: 0 !important;
    padding: 0 !important;
    background:#000;
  }
  .reel-card .frame-wrap{
    width:100%; height:100%;
    display:grid; place-items:center;
  }
  .reel-card iframe,
  .reel-card .thumb{
    width:100%; height:100%;
    max-height: calc(100svh - var(--hdr-top));
    aspect-ratio: 9/16;
    object-fit: cover;
    background:#000;
  }

  /* No floating brand badge / no categories overlay panel on mobile now */
  .reel-brand-badge, .reel-cats-btn, .reel-cats-panel{ display:none !important; }

  /* Cleanup of any previous immersive-hide rules */
  body.reel-ui-hidden #hdr{ transform:none; opacity:1; pointer-events:auto; }

/* Kill the global top padding in reel mode */
  .reel-mode main{ padding-top: 0 !important; }

  /* Ensure the section itself doesn’t add spacing */
  .reel-mode #shortsGrid{ margin-top: 0 !important; padding-top: 0 !important; }

  /* Just in case a wrapper adds spacing */
  .reel-mode .wrap{ padding-top: 0 !important; margin-top: 0 !important; }
}
