    :root{
      --bg0:#070A12;
      --bg1:#0B1230;
      --bg2:#071A2B;
      --card: rgba(255,255,255,.06);
      --card2: rgba(255,255,255,.10);
      --line: rgba(255,255,255,.12);
      --text:#F4F7FF;
      --muted: rgba(244,247,255,.72);
      --accent:#2a6fdb;
      --accent2:#35c3ff;
      --glow: 0 18px 60px rgba(42,111,219,.35);
      --shadow: 0 22px 70px rgba(0,0,0,.55);
      --radius: 22px;
      --max: 1100px;
      --font: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    }

    *{ box-sizing:border-box; }
    html, body{ height:100%; }
    body{
      margin:0;
  font-family: var(--font);
  color: var(--text);
  line-height:1.5;
  background: radial-gradient(1200px 900px at 20% 15%, var(--bg1) 0%, var(--bg0) 55%, #04060b 100%);
  overflow-x:hidden;

  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
    }

    .aurora{
      position: fixed;
      inset: -30vh -30vw;
      z-index:-2;
      background:
        radial-gradient(800px 600px at 30% 30%, rgba(53,195,255,.18), transparent 60%),
        radial-gradient(900px 700px at 75% 25%, rgba(42,111,219,.22), transparent 60%),
        radial-gradient(700px 550px at 65% 70%, rgba(53,195,255,.14), transparent 55%),
        radial-gradient(900px 700px at 25% 75%, rgba(42,111,219,.16), transparent 58%);
      filter: blur(18px);
      animation: drift 14s ease-in-out infinite alternate;
      opacity: .95;
    }
    @keyframes drift{
      0%{ transform: translate3d(-2%, -2%, 0) scale(1.02); }
      100%{ transform: translate3d(2%, 2%, 0) scale(1.06); }
    }

    .grain{
      pointer-events:none;
      position:fixed;
      inset:0;
      z-index:-1;
      opacity:.11;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
      mix-blend-mode: overlay;
    }


/* Diagonal light sweep (top-left → bottom-right) */
/* Diagonal light sweep (top-left → bottom-right) */
.sweep{
  pointer-events:none;
  position:fixed;
  inset:-30vh -30vw;
  z-index:-2;              /* keep it behind content */
  opacity:1;
  transform: rotate(-18deg);
  filter: blur(6px);
}

/* Put aurora even deeper, grain on top of sweep */
.aurora{ z-index:-3; }
.grain{ z-index:-1; }

.sweep::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.00) 34%,
    rgba(120,210,255,0.22) 45%,
    rgba(120,210,255,0.38) 50%,
    rgba(120,210,255,0.22) 55%,
    rgba(255,255,255,0.00) 66%,
    transparent 100%
  );
  transform: translateX(-75%);
  animation: wncaSweepPulse 12s ease-in-out infinite;
}

/* Pulse = brightness bloom as it crosses */
@keyframes wncaSweepPulse{
  0%   { transform: translateX(-80%); opacity: 0; filter: blur(18px) brightness(.95); }
  20%  { opacity: .35; }
  50%  { opacity: .95; filter: blur(7px) brightness(1.35); }
  80%  { opacity: .35; }
  100% { transform: translateX(80%); opacity: 0; filter: blur(18px) brightness(.95); }
}




    .wrap{
      max-width: var(--max);
      margin: 0 auto;
      padding: 28px 20px 70px;
    }

    .topbar{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap: 14px;
      padding: 12px 0 22px;
    }

    .topbar .mark{
      display:flex;
      align-items:center;
      gap: 10px;
      user-select:none;
    }
    .dot{
      width:10px;height:10px;border-radius:50%;
      background: linear-gradient(135deg, var(--accent2), var(--accent));
      box-shadow: 0 0 0 6px rgba(53,195,255,.12);
    }
    .topbar .mark span{
      font-weight: 750;
      letter-spacing: .3px;
      color: rgba(244,247,255,.92);
    }

    .navlinks{
      display:flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-content:flex-end;
    }

    .pill{
      display:inline-flex;
      align-items:center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 999px;
      border: 1px solid var(--line);
      background: rgba(255,255,255,.04);
      color: rgba(244,247,255,.88);
      text-decoration:none;
      transition: transform .12s ease, background .18s ease, border-color .18s ease;
      backdrop-filter: blur(10px);
    }
    .pill:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.07);
      border-color: rgba(255,255,255,.18);
    }

    .hero{
      display:grid;
      gap: 18px;
      padding: 26px;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.12);
      background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
      box-shadow: var(--shadow);
      position:relative;
      overflow:hidden;
    }

    .hero::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: radial-gradient(900px 420px at 20% 20%, rgba(53,195,255,.12), transparent 62%),
                  radial-gradient(900px 520px at 80% 10%, rgba(42,111,219,.18), transparent 60%);
      z-index:0;
    }

    .hero-inner{
      display:grid;
      gap: 18px;
      position:relative;
      z-index:1;
    }

    .logo-row{
      display:flex;
      align-items:center;
      justify-content:center;
      padding: 8px 0 0;
    }

    .logo{
      max-width: 760px;
      width: min(760px, 100%);
      height:auto;
      filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
      border-radius: 16px;
      background: rgba(255,255,255,.95);
      padding: 10px 14px;
    }

    h1{
      margin: 6px 0 0;
      text-align:center;
      font-size: clamp(1.8rem, 3.4vw, 2.6rem);
      letter-spacing: .2px;
    }

    .subtitle{
      margin:0 auto;
      text-align:center;
      max-width: 80ch;
      color: var(--muted);
      font-size: 1.06rem;
      line-height: 1.65;
    }

    .cta-row{
      display:flex;
      flex-wrap:wrap;
      gap: 12px;
      justify-content:center;
      margin-top: 6px;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap: 10px;
      padding: 12px 16px;
      border-radius: 14px;
      text-decoration:none;
      font-weight: 780;
      letter-spacing:.2px;
      border: 1px solid transparent;
      transition: transform .1s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
      user-select:none;
      cursor:pointer;
      white-space: nowrap;
    }

    .btn.primary{
      color: #06101f;
      background: linear-gradient(135deg, var(--accent2), var(--accent));
      box-shadow: var(--glow);
    }
    .btn.primary:hover{
      transform: translateY(-1px);
      box-shadow: 0 22px 80px rgba(53,195,255,.22);
    }

    .btn.ghost{
      color: rgba(244,247,255,.92);
      background: rgba(255,255,255,.04);
      border-color: rgba(255,255,255,.14);
      backdrop-filter: blur(10px);
    }
    .btn.ghost:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.07);
      border-color: rgba(255,255,255,.20);
    }

    /* ===== Featured Productions strip ===== */
    .featured{
      margin-top: 18px;
      padding: 18px;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.04);
      box-shadow: 0 16px 50px rgba(0,0,0,.35);
      backdrop-filter: blur(10px);
      position: relative;
      overflow: hidden;
    }

    .featured::before{
      content:"";
      position:absolute;
      inset:-2px;
      background:
        radial-gradient(900px 420px at 10% 0%, rgba(53,195,255,.10), transparent 60%),
        radial-gradient(900px 520px at 90% 10%, rgba(42,111,219,.14), transparent 60%);
      opacity:.9;
      pointer-events:none;
    }

    .featured-inner{
      position:relative;
      z-index:1;
    }

    .featured-head{
      display:flex;
      align-items:baseline;
      justify-content:space-between;
      gap: 12px;
      flex-wrap: wrap;
      margin-bottom: 12px;
    }
    .featured-head h2{
      margin:0;
      font-size: 1.2rem;
      letter-spacing: .2px;
    }
    .featured-head p{
      margin:0;
      color: var(--muted);
    }

    .tiles{
      display:grid;
      gap: 12px;
    }
    @media (min-width: 860px){
      .tiles{ grid-template-columns: repeat(3, 1fr); }
    }

    .tile{
      display:grid;
      gap: 10px;
      padding: 16px;
      border-radius: 18px;
      border: 1px solid rgba(255,255,255,.12);
      background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
      text-decoration:none;
      color: var(--text);
      box-shadow: 0 18px 40px rgba(0,0,0,.35);
      transition: transform .12s ease, border-color .18s ease, background .18s ease;
      position: relative;
      overflow:hidden;
      min-height: 164px;
    }
    .tile:hover{
      transform: translateY(-2px);
      border-color: rgba(53,195,255,.30);
      background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
    }

    .tile .tag{
      display:inline-flex;
      align-items:center;
      gap:8px;
      width:max-content;
      padding: 6px 10px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(0,0,0,.25);
      color: rgba(244,247,255,.86);
      font-size: .78rem;
      letter-spacing:.35px;
      user-select:none;
    }

    .tile .title{
      font-weight: 800;
      font-size: 1.08rem;
      margin: 0;
      letter-spacing:.2px;
    }

    .tile .desc{
      margin:0;
      color: rgba(244,247,255,.72);
      line-height: 1.55;
      font-size: .97rem;
    }

    .tile .go{
      margin-top:auto;
      display:flex;
      align-items:center;
      justify-content:space-between;
      color: rgba(244,247,255,.86);
      font-weight: 700;
      opacity: .95;
    }

    .chev{
      width: 34px;
      height: 34px;
      border-radius: 12px;
      display:grid;
      place-items:center;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.05);
      box-shadow: 0 16px 40px rgba(0,0,0,.25);
    }

    /* Content blocks */
    .section{
      margin-top: 18px;
      display:grid;
      gap: 14px;
    }

    .grid{
      display:grid;
      gap: 14px;
      margin-top: 10px;
    }
    @media (min-width: 900px){
      .grid{ grid-template-columns: 1.15fr .85fr; }
    }

    .card{
      padding: 18px;
      border-radius: var(--radius);
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.05);
      box-shadow: 0 16px 50px rgba(0,0,0,.35);
      backdrop-filter: blur(10px);
    }

    .card h2{
      margin: 0 0 8px;
      font-size: 1.25rem;
      letter-spacing:.2px;
    }

    .card p{
      margin: 0;
      color: var(--muted);
      line-height: 1.65;
    }

    .list{
      margin: 10px 0 0;
      padding: 0;
      list-style:none;
      display:grid;
      gap: 10px;
    }
    .list li{
      display:flex;
      gap: 10px;
      align-items:flex-start;
      color: rgba(244,247,255,.82);
    }
    .spark{
      flex: 0 0 auto;
      width: 10px;
      height: 10px;
      margin-top: 6px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--accent2), var(--accent));
      box-shadow: 0 0 0 6px rgba(42,111,219,.10);
    }

    .mini-cta{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
      margin-top: 12px;
    }

    .footer{
      margin-top: 26px;
      text-align:center;
      color: rgba(244,247,255,.55);
      font-size: .95rem;
    }

    .fineprint{
      margin-top: 6px;
      color: rgba(244,247,255,.45);
      font-size: .88rem;
    }
	
	/* =========================================================
   Studio Productions page styles (scoped)
   ========================================================= */

body.studio header .brand{
  padding: 22px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
  text-align: center;
}

body.studio header .brand::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(900px 420px at 20% 20%, rgba(53,195,255,.12), transparent 62%),
              radial-gradient(900px 520px at 80% 10%, rgba(42,111,219,.18), transparent 60%);
  z-index:0;
}
body.studio header .brand > *{ position:relative; z-index:1; }

body.studio header .brand h1{
  margin:0;
  font-size: clamp(1.7rem, 3.1vw, 2.35rem);
  letter-spacing:.2px;
}
body.studio header .brand p{
  margin: 8px auto 0;
  max-width: 85ch;
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.65;
}

/* Player shell */
body.studio .player-shell{
  margin: 18px 0 20px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  box-shadow: 0 16px 50px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  overflow: hidden;
  position: relative;
}
body.studio .player-head{
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  display: grid;
  gap: 6px;
}
body.studio .player-head .kicker{
  font-size:.86rem;
  color: rgba(244,247,255,.65);
}
body.studio .player-head .title{
  font-weight: 800;
  font-size: 1.08rem;
}
body.studio .player-head .desc{
  color: var(--muted);
  font-size: .98rem;
  line-height: 1.6;
  max-width: 95ch;
}
body.studio .player-body{
  padding: 14px 18px 18px;
  display: grid;
  gap: 10px;
}

/* IMPORTANT: constrain media so it doesn't become "HUGE" */
body.studio audio,
body.studio video{
  width: 100%;
  border-radius: 14px;
  outline: none;
  background: #000;

  /* sane sizing */
  aspect-ratio: 16 / 9;
  height: auto;
  max-height: min(52vh, 440px);
}


/* Story list layout (scoped so it doesn't fight home page grid) */
body.studio section.grid{
  display: grid;
  gap: 14px;
  margin-top: 14px;
}
@media (min-width: 900px){
  body.studio section.grid{
    grid-template-columns: 1fr 1fr;
  }
}

/* Story cards (studio) */
body.studio .card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  box-shadow: 0 16px 50px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  padding: 18px;
  display: grid;
  gap: 10px;
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .18s ease, background .18s ease;
  scroll-margin-top: 120px;
}
body.studio .card:hover{
  transform: translateY(-2px);
  border-color: rgba(53,195,255,.30);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
}

body.studio .badge{
  position:absolute;
  top: 14px;
  right: 14px;
  font-size:.78rem;
  letter-spacing:.35px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  color: rgba(244,247,255,.85);
  user-select:none;
}

body.studio .meta{
  margin:0;
  color: var(--muted);
  font-size: .98rem;
  line-height: 1.6;
}

body.studio .controls{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

/* Studio buttons: keep your existing .btn, add a safe secondary variant */
body.studio .btn.secondary{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.14);
  color: rgba(244,247,255,.92);
  box-shadow:none;
  backdrop-filter: blur(10px);
}
body.studio .btn.secondary:hover{
  background: rgba(255,255,255,.07);
}

/* Utility */
.hidden{ display:none !important; }

/* =========================
   Cartoons (horizontal scroll gallery)
   ========================= */
.cartoons{
  margin-top: 18px;
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: 0 16px 50px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}

.cartoons .section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.cartoons h2{
  margin:0;
  font-size: 1.2rem;
}
.cartoons p{
  margin:0;
  color: var(--muted);
}

.toon{
  flex: 0 0 auto;
  width: min(520px, 86vw);
  aspect-ratio: 3 / 4;

  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);

  /* button reset */
  appearance: none;
  -webkit-appearance: none;
  padding: 0;
  background-color: transparent;
  font: inherit;

  /* cartoon image */
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  position: relative;
  overflow: hidden;
  scroll-snap-align: start;
  cursor: pointer;
  transition: transform .12s ease, border-color .18s ease;
}

/* Accessible focus styling for cartoon tiles */
.toon:focus{
  outline: none;
}

.toon:focus-visible{
  outline: 2px solid rgba(53,195,255,.45);
  outline-offset: 4px;
  box-shadow: 0 0 0 6px rgba(53,195,255,.18);
}


.toon-strip{
  display:flex;
  gap: 12px;
  overflow-x: auto;
  padding: 8px 2px 14px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.toon-strip::-webkit-scrollbar{ height: 10px; }
.toon-strip::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.16);
  border-radius: 999px;
}
.toon-strip::-webkit-scrollbar-track{
  background: rgba(255,255,255,.06);
  border-radius: 999px;
}


.toon:hover{
  transform: translateY(-2px);
  border-color: rgba(53,195,255,.30);
}




/* The watermark overlay (this is the ONLY "real image" to right-click save) */
/* Watermark overlay (intentional save target) */
/* Watermark overlay on thumbnails (save-as target) */
.toon-wm{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;

  opacity: 0.68;            /* slightly stronger */
  mix-blend-mode: multiply; /* fuses with image */
  filter: blur(0.35px);

  pointer-events: auto;     /* right-click save-as target */
  user-select: none;
}

/* Watermark overlay in lightbox (same behavior) */
.lb-wm{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;

  opacity: 0.60;            /* can be a touch lower than thumbs */
  mix-blend-mode: multiply;
  filter: blur(0.35px);

  pointer-events: auto;
  user-select: none;
}

.toon2{
  position: relative;
  width: min(520px, 86vw);
  aspect-ratio: 3 / 4;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
}

.toon2 .toon-img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;   /* ✅ cannot right-click/save this */
  user-select: none;
}

.toon2 .toon-wm{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .72;           /* adjust visibility */
  pointer-events: auto;   /* ✅ right-click targets THIS */
  user-select: none;
}


/* =========================
   Lightbox
   ========================= */
.lightbox{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.lightbox.open{ display: block; }

.lb-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(6px);
}

.lb-panel{
  position: relative;
  max-width: min(1100px, 92vw);
  margin: 6vh auto 0;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(10,14,24,.78);
  box-shadow: 0 28px 90px rgba(0,0,0,.65);
}

.lb-close{
  position:absolute;
  top: 10px;
  right: 10px;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(244,247,255,.92);
  font-weight: 900;
  cursor: pointer;
}

.lb-frame{
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: #000;
  border: 1px solid rgba(255,255,255,.10);
}

/* Auto-fit portrait & landscape */
#lbImg{
  display:block;
  width: 100%;
  height: auto;
  max-height: 78vh;
  object-fit: contain;
  background: #000;
  position: relative;
  z-index: 1;
}


/* Watermark overlay in lightbox too */


.lb-hint{
  margin-top: 10px;
  text-align:center;
  color: rgba(244,247,255,.55);
  font-size: .92rem;
}


/* Force-hide lightbox unless opened */
#lightbox{ display:none !important; }
#lightbox.open{ display:block !important; }








