 :root{
      --bg:#070914;
      --border:rgba(255,255,255,.12);
      --text:#EEF1FF;
      --muted:rgba(238,241,255,.72);
      --shadow: 0 18px 55px rgba(0,0,0,.60);

      /* your vibe */
      --grad: linear-gradient(90deg, #5170ff, #ff66c4, #ff66c4, #ff6448);
      --glass: rgba(255,255,255,.06);
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
      color:var(--text);
      background:
        radial-gradient(900px 700px at 12% 10%, rgba(81,112,255,.26), transparent 60%),
        radial-gradient(900px 700px at 88% 15%, rgba(255,102,196,.18), transparent 60%),
        radial-gradient(900px 700px at 50% 110%, rgba(255,100,72,.14), transparent 60%),
        var(--bg);
      line-height:1.5;
      overflow-x:hidden;
    }
    a{color:inherit; text-decoration:none}

    /* Soft animated glow */
    .glow{
      position:fixed;
      inset:auto -30% -40% -30%;
      height:60vh;
      background: var(--grad);
      filter: blur(80px);
      opacity:.18;
      transform: rotate(-10deg);
      pointer-events:none;
      animation: glowFloat 10s ease-in-out infinite;
    }
    .glow.top{
      inset:-45% -30% auto -30%;
      height:55vh;
      transform: rotate(10deg);
      opacity:.14;
      animation-duration: 12s;
    }
    @keyframes glowFloat{
      0%,100%{ transform: translateY(0) rotate(-10deg) scale(1); }
      50%{ transform: translateY(-18px) rotate(-10deg) scale(1.04); }
    }

    /* HEADER */
    header{
      position:sticky; top:0; z-index:999;
      backdrop-filter: blur(12px);
      background: rgba(7,9,20,.58);
      border-bottom: 1px solid rgba(255,255,255,.10);
    }
    .nav{
      max-width:1200px;
      margin:0 auto;
      padding:14px 18px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:10px;
      font-weight:950;
      letter-spacing:.2px;
      min-width:0;
    }
    .brand img{width:38px;height:38px;object-fit:contain}
    .brand span{
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

    /* Burger */
    .burger{
      width:46px; height:44px;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      border-radius:14px;
      border:1px solid rgba(255,255,255,.16);
      background: rgba(255,255,255,.06);
      cursor:pointer;
      user-select:none;
      -webkit-tap-highlight-color: transparent;
      transition: transform .18s ease, background .18s ease;
      position:relative;
    }
    .burger:hover{transform: translateY(-1px); background: rgba(255,255,255,.09)}
    .burger:active{transform: translateY(0px) scale(.99)}
    .burger .lines{
      width:18px; height:14px; position:relative;
    }
    .burger .lines span{
      position:absolute; left:0;
      width:100%; height:2px;
      border-radius: 999px;
      background: rgba(238,241,255,.92);
      transition: transform .28s ease, top .28s ease, opacity .18s ease;
    }
    .burger .lines span:nth-child(1){top:0}
    .burger .lines span:nth-child(2){top:6px}
    .burger .lines span:nth-child(3){top:12px}

    .burger.open .lines span:nth-child(1){top:6px; transform: rotate(45deg)}
    .burger.open .lines span:nth-child(2){opacity:0}
    .burger.open .lines span:nth-child(3){top:6px; transform: rotate(-45deg)}

    /* Menu dropdown */
    .menu{
      position:fixed;
      left:0; right:0;
      top:64px;
      z-index:1000;
      display:none;
      padding:0 14px 14px;
    }
    .menu.open{display:block}

    .menu-panel{
      max-width:1200px;
      margin:0 auto;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(10,12,24,.86);
      backdrop-filter: blur(14px);
      border-radius: 18px;
      box-shadow: 0 22px 70px rgba(0,0,0,.62);
      overflow:hidden;

      transform: translateY(-12px);
      opacity:0;
      animation: menuIn .26s ease forwards;
      position:relative;
    }
    @keyframes menuIn{
      to{transform: translateY(0); opacity:1;}
    }

    .menu-grid{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap:12px;
      padding:14px;
    }

    /* ✅ menu item style */
    .menu-item{
      border:1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.04);
      border-radius: 16px;
      padding:12px 12px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      transition: transform .18s ease, background .18s ease;
    }
    .menu-item:hover{transform: translateY(-1px); background: rgba(255,255,255,.06)}
    .menu-item .left{
      display:flex; align-items:center; gap:10px;
      font-weight:700;
    }
    .menu-item i{opacity:.9}

    /* ✅ make button look EXACT like menu-item link */
    .menu-item.btn-item{
      cursor:pointer;
      width:100%;
      text-align:left;
      color:inherit;
      font: inherit;
    }

    .menu-actions{
      padding:0 14px 14px;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      justify-content:flex-end;
    }

    /* Buttons */
    .btn{
      display:inline-flex; align-items:center; justify-content:center; gap:10px;
      padding:12px 16px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      color: var(--text);
      font-weight:950;
      cursor:pointer;
      user-select:none;
      white-space:nowrap;
      transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.09); }
    .btn:active{ transform: translateY(0) scale(.98); }

    .btn.primary{
      border: none;
      color: #fff;
      background: var(--grad);
      background-size: 240% 100%;
      background-position: 0% 50%;
      box-shadow: 0 16px 44px rgba(81,112,255,.16);
    }
    @keyframes gradMove {
      0% { background-position: 0% 50%; }
      100% { background-position: 100% 50%; }
    }
    .btn.primary:hover,
    .btn.primary:focus-visible{
      animation: gradMove .75s ease forwards;
      outline:none;
    }
    .btn.primary.is-pressed{
      animation:none;
      background: linear-gradient(90deg, #5170ff, #ff66c4, #ff6448);
      background-size: 200% 100%;
      background-position: 100% 50%;
      box-shadow: 0 18px 55px rgba(255,100,72,.16);
    }

    /* Layout */
    .container{max-width:1200px; margin:0 auto; padding:18px 18px 28px;}
    .page{display:none}
    .page.active{display:block}

    /* HERO */
    .hero{
      padding: 18px 0 6px;
      display:flex;
      flex-direction:column;
      align-items:center;
      text-align:center;
      gap:10px;
    }
    .heroTop{
      display:flex;
      align-items:center;
      justify-content:center;
      gap:14px;
      flex-wrap:wrap;
    }
    .heroLogo{
      width:78px; height:78px;
      object-fit:contain;
      animation: logoBeat 2.8s ease-in-out infinite;
      transform-origin: 50% 60%;
    }
    @keyframes logoBeat{
      0%,100%{ transform: translateY(0) scale(1); }
      50%{ transform: translateY(-6px) scale(1.04); }
    }

    .heroTitle{
      margin:0;
      font-size: clamp(26px, 4.5vw, 44px);
      letter-spacing:-.6px;
      line-height:1.08;
      font-weight:950;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      justify-content:center;
      align-items:baseline;
      animation: titleFloat 2.8s ease-in-out infinite;
    }
    @keyframes titleFloat{
      0%,100%{ transform: translateY(0); }
      50%{ transform: translateY(-4px); }
    }
    .heroTitle .gradText{
      background: var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color: transparent;
      background-size: 220% 100%;
      animation: titleFlow 4.5s ease-in-out infinite;
    }
    @keyframes titleFlow{
      0%,100%{ background-position: 0% 50%; }
      50%{ background-position: 100% 50%; }
    }

    .heroDesc{
      margin:0;
      color: var(--muted);
      max-width: 70ch;
      font-weight:800;
      animation: descFloat 3.6s ease-in-out infinite;
    }
    @keyframes descFloat{
      0%,100%{ transform: translateY(0); opacity: .92; }
      50%{ transform: translateY(-3px); opacity: 1; }
    }

    .heroCta{
      margin-top: 6px;
      display:flex;
      justify-content:center;
      gap:12px;
      flex-wrap:wrap;
    }

    /* Tools */
    .tools{
      margin-top: 18px;
      display:flex;
      flex-direction:column;
      gap:10px;
    }
    .toolsRow{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      flex-wrap:wrap;
      padding: 6px 0 10px;
      border-bottom: 1px solid rgba(255,255,255,.10);
    }
    .toolsLeft{
      display:flex;
      flex-direction:column;
      gap:3px;
      min-width: 220px;
    }
    .toolsLeft .label{
      font-weight:950;
      letter-spacing:-.2px;
    }
    .toolsLeft small{
      color: rgba(238,241,255,.68);
      font-weight:800;
    }

    .searchInput{
      width: 220px;
      max-width: 70vw;
      padding:9px 11px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(0,0,0,.20);
      color: var(--text);
      outline:none;
      font-weight:950;
    }
    .searchInput::placeholder{ color: rgba(238,241,255,.45); }

    .filters{
      display:flex; gap:8px; flex-wrap:wrap; justify-content:center;
      padding-top: 4px;
    }
    .chip{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:9px 12px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.05);
      color: rgba(238,241,255,.90);
      font-weight:950;
      cursor:pointer;
      user-select:none;
      transition: transform .14s ease, background .14s ease;
      font-size:13px;
      -webkit-tap-highlight-color: transparent;
    }
    .chip:hover{ transform: translateY(-1px); background: rgba(255,255,255,.08); }
    .chip.active{
      border-color: transparent;
      background: var(--grad);
      color:#fff;
      box-shadow: 0 16px 44px rgba(81,112,255,.12);
    }

    .note{color:rgba(238,241,255,.65); font-size:13px; font-weight:800}
    .status{ margin:10px 0 10px; }

    /* Grids */
    .gridGroups{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
    .gridSeries{display:grid; grid-template-columns: repeat(6, 1fr); gap:12px;}
    .gridEpisodes{display:grid; grid-template-columns: repeat(4, 1fr); gap:12px;}

    .card{
      border:1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.035);
      border-radius: 18px;
      overflow:hidden;
      cursor:pointer;
      transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
      position:relative;
    }
    .card::after{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:0;
      filter: blur(22px);
      transition: opacity .18s ease;
      pointer-events:none;
    }
    .card:hover{
      transform: translateY(-2px);
      background: rgba(255,255,255,.06);
      box-shadow: 0 16px 40px rgba(0,0,0,.35);
    }
    .card:hover::after{opacity:.14}

    .gcard{padding:14px}
    .gcard h3{
      margin:0 0 8px;
      font-size:16px;
      letter-spacing:-.2px;
      line-height:1.15;
    }

    .freeTag{
      border:none;
      background: transparent;
      color: rgba(238,241,255,.82);
      font-weight:950;
      font-size:11px;
      letter-spacing:.3px;
      opacity:.95;
      white-space:nowrap;
    }

    .poster{
      width:100%;
      aspect-ratio: 2/3;
      background: rgba(255,255,255,.05);
      display:flex;
      align-items:center;
      justify-content:center;
      position:relative;
      overflow:hidden;
      padding:10px;
    }
    .poster::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:.10;
      filter: blur(18px);
      pointer-events:none;
    }
    .poster img{
      width:100%; height:100%;
      object-fit:cover;
      display:block;
      position:relative;
      border-radius: 14px;
    }

    .badge{
      width:46px;height:46px;border-radius:999px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.06);
      display:flex;align-items:center;justify-content:center;
      font-weight:950; letter-spacing:.6px;
      color:rgba(238,241,255,.92);
      position:relative; overflow:hidden;
    }
    .badge::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:.18;
      filter: blur(14px);
      pointer-events:none;
    }
    .badge span{position:relative; font-size:12px}

    .meta{
      padding:10px;
      display:flex;
      flex-direction:column;
      gap:6px;
    }
    .name{
      font-weight:950;
      font-size:13px;
      line-height:1.2;
      min-height:2.4em;
    }
    .mini{
      display:flex;
      justify-content:space-between;
      gap:8px;
      color:rgba(238,241,255,.70);
      font-weight:800;
      font-size:12px;
      align-items:center;
    }

    .epCard{
      padding:12px;
      display:flex;
      gap:12px;
      align-items:center;
      min-width:0;
    }
    .epMeta{display:flex;flex-direction:column;gap:6px;min-width:0}
    .epTitle{
      font-weight:950;
      font-size:14px;
      line-height:1.15;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }
    .epMini{
      display:flex;
      justify-content:space-between;
      gap:8px;
      color:rgba(238,241,255,.68);
      font-weight:800;
      font-size:12px;
    }

    .seriesHeader{ display:flex; gap:14px; align-items:flex-start; flex-wrap:wrap; }
    .miniPoster{
      width:96px; height:144px;
      border-radius:16px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
      overflow:hidden;
      position:relative;
      box-shadow: 0 18px 50px rgba(0,0,0,.45);
    }
    .miniPoster::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:.14;
      filter: blur(18px);
      pointer-events:none;
    }
    .miniPoster img{
      width:100%; height:100%;
      object-fit:cover;
      display:block;
      position:relative;
    }
    .seriesHeaderText{flex:1; min-width: 260px}

    /* Pre footer */
    .preFooter{
      margin-top: 22px;
      padding-top: 18px;
      border-top: 1px solid rgba(255,255,255,.10);
      display:grid;
      grid-template-columns: 1.2fr .8fr;
      gap:18px;
      align-items:start;
    }
    .pfBlock h3{
      margin:0;
      font-size: 18px;
      letter-spacing:-.3px;
      font-weight:950;
    }
    .pfBlock h3 .gradText{
      background: var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      background-size: 220% 100%;
      animation: titleFlow 4.5s ease-in-out infinite;
    }
    .pfBlock p{
      margin:8px 0 0;
      color: var(--muted);
      font-weight:800;
      max-width: 62ch;
    }

    .deviceRow{
      margin-top: 12px;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      align-items:center;
    }
    .devicePill{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:10px 12px;
      border-radius: 999px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.04);
      transition: transform .14s ease, background .14s ease;
    }
    .devicePill:hover{ transform: translateY(-1px); background: rgba(255,255,255,.07); }
    .devicePill img{
      width:22px; height:22px;
      object-fit:contain;
      filter: drop-shadow(0 6px 16px rgba(0,0,0,.35));
    }
    .devicePill span{
      font-weight:950;
      font-size:12px;
      color: rgba(238,241,255,.92);
      letter-spacing:.2px;
      white-space:nowrap;
    }

    .pfList{
      margin-top: 10px;
      display:flex;
      flex-direction:column;
      gap:10px;
    }
    .pfItem{
      display:flex;
      gap:10px;
      align-items:flex-start;
    }
    .pfIcon{
      width:34px; height:34px;
      border-radius: 12px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
      display:flex;
      align-items:center;
      justify-content:center;
      flex: 0 0 auto;
      position:relative;
      overflow:hidden;
    }
    .pfIcon::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:.18;
      filter: blur(14px);
      pointer-events:none;
    }
    .pfIcon i{ position:relative; opacity:.92; }
    .pfItem b{ font-weight:950; }
    .pfItem div{ color: rgba(238,241,255,.78); font-weight:800; font-size:13px; }

    @media (max-width: 1100px){
      .gridSeries{grid-template-columns: repeat(5, 1fr)}
      .gridEpisodes{grid-template-columns: repeat(3, 1fr)}
      .menu-grid{grid-template-columns: 1fr 1fr;}
    }
    @media (max-width: 980px){
      .gridGroups{grid-template-columns: repeat(2, 1fr)}
      .gridSeries{grid-template-columns: repeat(3, 1fr)}
      .gridEpisodes{grid-template-columns: repeat(2, 1fr)}
      .preFooter{ grid-template-columns: 1fr; }
      .menu-grid{grid-template-columns: 1fr;}
    }
    @media (max-width: 520px){
      .gridGroups{grid-template-columns: repeat(2, 1fr)}
      .gridSeries{grid-template-columns: repeat(2, 1fr)}
      .gridEpisodes{grid-template-columns: repeat(2, 1fr)}
      .heroLogo{ width:64px; height:64px; }
      .searchInput{ width: 190px; }
    }

    /* Loading */
    .loading{
      position:fixed; inset:0; z-index:200;
      display:none;
      align-items:center;
      justify-content:center;
      padding:18px;
      background: rgba(0,0,0,.72);
      backdrop-filter: blur(10px);
    }
    .loading.show{display:flex}
    .loadCard{
      width:min(520px, 100%);
      border-radius: 22px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(10,12,24,.92);
      box-shadow: var(--shadow);
      position:relative;
      overflow:hidden;
      padding:18px 16px;
      text-align:center;
    }
    .loadGlow{
      position:absolute; inset:-2px;
      background: var(--grad);
      filter: blur(26px);
      opacity:.22;
      pointer-events:none;
    }
    .loadInner{position:relative; display:flex; flex-direction:column; gap:10px; align-items:center}
    .spinner{
      width:62px; height:62px;
      border-radius: 999px;
      border: 3px solid rgba(255,255,255,.12);
      border-top-color: rgba(255,255,255,.85);
      animation: spin 1s linear infinite;
      box-shadow: 0 0 0 10px rgba(255,255,255,.02) inset;
    }
    @keyframes spin{to{transform:rotate(360deg)}}
    .pulseDots{display:flex; gap:8px; align-items:center; justify-content:center; margin-top:2px}
    .pulseDots span{
      width:8px; height:8px; border-radius:999px;
      background: rgba(255,255,255,.75);
      animation: dot 1.1s ease-in-out infinite;
      opacity:.75;
    }
    .pulseDots span:nth-child(2){animation-delay:.15s}
    .pulseDots span:nth-child(3){animation-delay:.30s}
    @keyframes dot{
      0%,100%{ transform: translateY(0); opacity:.55 }
      50%{ transform: translateY(-6px); opacity:1 }
    }
    .loadTitle{font-size:20px; font-weight:950; letter-spacing:-.2px}
    .loadMsg{color: rgba(238,241,255,.70); font-weight:800; font-size:13px; max-width:46ch}

    /* Modal */
    .modal{
      position:fixed; inset:0; z-index:150;
      display:none;
      align-items:center; justify-content:center;
      padding:16px;
      background: rgba(0,0,0,.72);
      backdrop-filter: blur(8px);
    }
    .modal.open{display:flex}
    .modalbox{
      width:min(760px, 100%);
      border-radius: 22px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(10,12,24,.92);
      box-shadow: var(--shadow);
      overflow:hidden;
      position:relative;
      transform: translateY(12px) scale(.98);
      opacity: 0;
      animation: pop .24s ease forwards;
    }
    @keyframes pop{to{ transform: translateY(0) scale(1); opacity: 1; } }
    .modalGlow{
      position:absolute; inset:-2px;
      background: var(--grad);
      filter: blur(22px);
      opacity:.22;
      pointer-events:none;
    }
    .close{
      position:absolute; top:10px; right:10px;
      width:42px; height:42px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      color:var(--text);
      font-weight:950;
      cursor:pointer;
      z-index:2;
    }
    .modalInner{
      position:relative;
      padding:16px;
      display:flex;
      flex-direction:column;
      gap:12px;
    }
    .modalTitle{
      font-size:20px;
      font-weight:950;
      letter-spacing:-.2px;
      line-height:1.2;
      margin-top:2px;
    }
    .pillRow{display:flex; gap:8px; flex-wrap:wrap; margin-top:8px}
    .countSmall{
      display:inline-flex;
      padding:5px 9px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.05);
      color:rgba(238,241,255,.86);
      font-weight:800;
      font-size:11px;
      white-space:nowrap;
    }
    .modalDesc{
      color: rgba(238,241,255,.70);
      font-weight:800;
      font-size:13px;
      line-height:1.45;
      margin-top:8px;
    }
    .divider{height:1px; width:100%; background: rgba(255,255,255,.10); margin: 4px 0;}
    .modalActions{display:flex; gap:10px; flex-wrap:wrap; margin-top:2px}

    .modalMediaRow{
      display:flex;
      gap:14px;
      align-items:flex-start;
      flex-wrap:wrap;
    }
    .modalPoster{
      width:112px;
      height:168px;
      border-radius:18px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
      overflow:hidden;
      position:relative;
      flex: 0 0 auto;
      box-shadow: 0 18px 50px rgba(0,0,0,.45);
    }
    .modalPoster::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: var(--grad);
      opacity:.14;
      filter: blur(18px);
      pointer-events:none;
    }
    .modalPoster img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
      position:relative;
    }
    .modalRight{flex:1; min-width: 240px;}

    /* Footer */
    footer{
      border-top:1px solid rgba(255,255,255,.10);
      background: rgba(7,9,20,.55);
      backdrop-filter: blur(10px);
    }
    .footer-wrap{
      max-width:1200px;
      margin:0 auto;
      padding:22px 18px 16px;
      display:grid;
      grid-template-columns: 1.4fr .8fr .8fr;
      gap:18px;
    }
    .footer-brand{
      display:flex;
      flex-direction:column;
      gap:10px;
    }
    .footer-brand-top{
      display:flex;
      gap:12px;
      align-items:center;
    }
    .footer-brand-top img{
      width:44px;
      height:44px;
      object-fit:contain;
    }
    .footer-title{
      font-weight:950;
      letter-spacing:-.2px;
      font-size:16px;
    }
    .footer-tag{
      color: rgba(238,241,255,.70);
      font-weight:700;
      font-size:13px;
      line-height:1.45;
      max-width: 60ch;
    }

    .footer-col h4{
      margin:0 0 10px;
      font-size:14px;
      letter-spacing:-.2px;
      font-weight:950;
    }
    .footer-links{
      display:flex;
      flex-direction:column;
      gap:8px;
    }
    .footer-links a{
      color: rgba(238,241,255,.80);
      font-weight:700;
      font-size:13px;
      padding:6px 0;
      transition: opacity .15s ease, transform .15s ease;
    }
    .footer-links a:hover{
      opacity: 1;
      transform: translateY(-1px);
      color: rgba(238,241,255,.95);
    }

    .social-row{
      margin-top: 10px;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      align-items:center;
    }
    .social-btn{
      width:42px; height:42px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
      display:flex;
      align-items:center;
      justify-content:center;
      transition: transform .16s ease, background .16s ease;
      cursor:pointer;
    }
    .social-btn:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.08);
    }

    .footer-bottom{
      max-width:1200px;
      margin:0 auto;
      padding:14px 18px 18px;
      border-top:1px solid rgba(255,255,255,.10);
      display:flex;
      justify-content:space-between;
      gap:10px;
      flex-wrap:wrap;
      color: rgba(238,241,255,.72);
      font-weight:700;
      font-size:13px;
    }

    @media (max-width: 980px){
      .footer-wrap{ grid-template-columns: 1fr; }
    }
    /* =========================
   SERIES PAGE — FIX HEADER LAYOUT
   ========================= */

#seriesPage .seriesHeader{
  display:flex;
  align-items:flex-start;
  gap:16px;
  flex-wrap:nowrap;
  width:100%;
  padding:14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  box-shadow: 0 16px 44px rgba(0,0,0,.30);
}

#seriesPage .miniPoster{
  width:110px;
  height:165px;
  flex: 0 0 auto;
  border-radius: 18px;
}

/* Make the text area behave nicely */
#seriesPage .seriesHeaderText{
  flex:1;
  min-width:0; /* IMPORTANT for ellipsis/clamping */
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* Override heroTitle behavior ONLY in series page */
#seriesPage .seriesHeaderText .heroTitle{
  animation:none !important;
  transform:none !important;
  display:block !important;
  margin:0 !important;
  line-height:1.15;
  letter-spacing:-.4px;
  font-size: clamp(22px, 3.2vw, 34px);
}

/* Make series title strong and clean */
#seriesTitle{
  font-weight: 950;
  display:block;
  word-break: break-word;
}

/* Clean description: readable + limited lines */
#seriesPage #seriesDesc{
  color: rgba(238,241,255,.72);
  font-weight: 800;
  line-height: 1.55;
  margin: 0;
  max-width: 85ch;

  display: -webkit-box;
  -webkit-line-clamp: 4;       /* show max 4 lines */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* If poster missing, keep spacing nice */
#seriesPage .miniPoster[style*="display:none"] + .seriesHeaderText{
  margin-left: 0;
}

/* Mobile: stack poster above text, centered */
@media (max-width: 680px){
  #seriesPage .seriesHeader{
    flex-direction:column;
    align-items:center;
    text-align:center;
  }

  #seriesPage .miniPoster{
    width:120px;
    height:180px;
  }

  #seriesPage #seriesDesc{
    -webkit-line-clamp: 5;
  }
}
