/* ======================================================
   IKIGAI — CHARACTER SECTION (CLEAN, CONSOLIDATED)
   - Single-source rules (no patchy overrides)
   - Mobile-first tweaks with minimal duplication
   - LeftTop (video+title+models), Center hero, Right selector
   - Left stack (Profile + Credits) with glass cards
   - Wipe overlay for transition engine
   - Safe z-layers
====================================================== */

/* ---------- Base vars ---------- */
:root{
  --tr-dur: 700ms;
  --tr-ease: cubic-bezier(.2,.7,0,1);
  --wipe-bg: #0a0a0f;
}

/* ---------- Characters section container ---------- */
#characters{
  position: relative;
  height: clamp(720px, 100vh, 1000px);
  background: center bottom / cover no-repeat transparent;
  isolation: isolate;
  overflow: hidden;                /* or: overflow: clip (modern) */
  margin-top: clamp(16px, 4vh, 40px);
  transition: transform .25s ease;
  --char-x-adjust: 2vh;            /* tweak global posisi hero */
  --char-y-adjust: 0px;
  --char-scale-adjust: 0;
  --right-offset: 0vh;             /* used by .char-right vertical shift */
}

/* Background transition stack */
#characters .bg-stack{ position:absolute; inset:0; z-index:0; pointer-events:none; }
#characters .bg-layer{
  position:absolute; inset:0; background-position:center bottom; background-repeat:no-repeat; background-size:cover;
  will-change: transform, opacity;
}

/* ---------- Layout wrapper ---------- */
.char-container{
  position:relative; width:100%; height:100%;
  display:flex; justify-content:space-between; align-items:center;
  padding: clamp(16px, 4vw, 40px);
}

/* =================================================================
   LEFT TOP: video + title + models (NO credit here)
================================================================= */
.left-top{
  position:absolute;
  top: clamp(24px, 10vh, 288px);
  left: clamp(16px, 6vw, 140px);
  display:grid; grid-template-columns: auto 1fr; grid-template-rows: auto auto;
  grid-template-areas: "video title" "video models";
  column-gap:16px; row-gap:10px; align-items:start; z-index:45;
}
.video-box { grid-area: video; }
.title-box { grid-area: title; }
.models-bar{ grid-area: models; }

/* Video tile */
.video-box{
  position: relative; width: clamp(152px, 16vw, 260px); aspect-ratio: 16/9;
  border-radius: 14px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,.35);
  cursor: pointer;
}
.video-box video, .video-box .poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.video-box .poster{ z-index:2; transition:opacity .18s ease; }
.video-box.playing .poster, .video-box:hover .poster{ opacity:0; }
.video-box .v-overlay{
  position:absolute; inset:0; z-index:3; pointer-events:none;
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(133, 76, 255, .60), rgba(133, 76, 255, .53) 45%, transparent 70%),
    linear-gradient(0deg, rgba(0,0,0,.42), rgba(0,0,0,.60));
  mix-blend-mode: screen; transition: opacity .15s ease, transform .25s ease; opacity:.9;
}
.video-box:hover .v-overlay{ opacity:1; transform:scale(1.02); }

/* Title */
.title-box h4{
  margin:0 0 4px; font-size: clamp(13px, 1.1vw, 18px); font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase; color:#eaeaf3;
}
.title-box p{ margin:0; font-size: clamp(16px, 1.4vw, 50px); font-weight: 600; color:#ffffffd9; }
.title-box .new{
  margin-left: 8px; padding: 2px 8px; border-radius: 999px; background: linear-gradient(90deg, #8a63ff, #c06bff);
  color:#111; font-weight: 800; letter-spacing:.03em; font-size: .8em; box-shadow: 0 2px 10px rgba(147,92,255,.45);
}

/* Models bar */
.models-bar{
  --tileW:84px; --tileH:52px; --gap:10px; --radius:14px; --ring:#ff66d1; --tint:rgba(225,60,200,.35);
  display:flex; flex-wrap:wrap; gap:var(--gap); position: static; margin-top: 4px;
}
.models-bar[data-theme="himachii"]{ --ring:#ff4d4d; --tint:rgba(200,30,40,.34); }

/* tampilkan only set aktif */
.models-bar .model-tile{ display:none; }
.models-bar[data-char="nekoko"]   .model-tile[data-char="nekoko"],
.models-bar[data-char="himachii"] .model-tile[data-char="himachii"]{ display:inline-block; }

.model-tile{
  position:relative; width:var(--tileW); height:var(--tileH);
  border-radius:var(--radius); overflow:hidden; background:#1b1b1b; border:2px solid transparent;
  padding:0; cursor:pointer; box-shadow:0 6px 20px rgba(0,0,0,.26);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.model-tile img{ width:100%; height:100%; display:block; object-fit:cover; object-position: var(--ox, 50%) var(--oy, 50%); }
.model-tile::after{ content:""; inset:0; position:absolute; pointer-events:none; background:var(--tint); mix-blend-mode:multiply; opacity:0; transition:opacity .25s ease; }
.model-tile:hover::after{ opacity:.85; }
.model-tile[aria-checked="true"]{
  border-color:var(--ring);
  box-shadow:0 0 0 2px color-mix(in oklab, var(--ring) 45%, transparent), 0 10px 26px rgba(0,0,0,.28);
  transform:translateY(-2px);
}

/* =================================================================
   CENTER: hero image
================================================================= */
#characters .center{ position:relative; flex:1; height:100%; }
#characters .character{
  position:absolute; left:50%; bottom:0;
  transform: translate(calc(-50% + var(--char-x, 0px) + var(--char-x-adjust)), calc(var(--char-y, 0px) + var(--char-y-adjust)))
             scale(calc(var(--char-scale, 1) + var(--char-scale-adjust)));
  transform-origin:50% 100%; height:min(82vh, 760px); width:auto; z-index:1; pointer-events:none;
  will-change:transform; transition:transform .35s ease, opacity .25s ease;
}

/* =================================================================
   RIGHT: character selector
================================================================= */
.char-right{
  position:absolute; right: clamp(16px, 6vw, 120px); top: calc(50% - var(--right-offset)); transform: translateY(-50%);
  text-align:center; z-index:50;
}
.char-right .char-box{
  position: relative; width: 90px; height: 90px; border-radius: 12px; overflow: hidden; background:#1b1b1b; border:2px solid transparent;
  cursor:pointer; transition: transform .2s ease, border-color .2s ease; margin-top: 30px;
}
.char-right .char-box img{ position: relative; z-index: 0; width:100%; height:100%; object-fit:cover; display:block; }
.char-right .char-box::after{ content:""; position:absolute; inset:0; z-index: 1; pointer-events:none; background: var(--tint, transparent); mix-blend-mode:multiply; opacity: 0; transition: opacity .25s ease; }
.char-right .char-box:has(.nekoko){   --tint: rgba(225, 60, 200, .45); --ring:#ff66d1; }
.char-right .char-box:has(.himachii){ --tint: rgba(200, 30, 40,  .48); --ring:#ff4d4d; }
.char-right .char-box:hover::after, .char-right .char-box.active::after{ opacity:1; }
.char-right .char-box:hover, .char-right .char-box.active{ border-color: var(--ring, #ffb400); transform: translateY(-2px); }

/* crop helper utk preview */
.char-img.nekoko  { transform: scale(8) translate(6px, 19px);  object-position: 60% 40%; }
.char-img.himachii{ transform: scale(8) translate(-2px, 27px); object-position: 60% 40%; }

/* =================================================================
   LEFT STACK: Profile card + Credits card (same width)
   - Always grid 1col; responsive just compresses safely
================================================================= */
.char-left{
  position:absolute; left: clamp(16px, 6vw, 140px);
  bottom: clamp(24px, 10vh, 100px);
  width: clamp(260px, 28vw, 420px);
  z-index:40;
  display: grid; grid-template-columns: 1fr; grid-auto-rows: auto; gap: 12px; text-align: left;
  --accent: #ff66d1;                 /* default: Nekoko */
  --accent-2: #ffa7e9; --wipe-bleed: 1rem; /* for wipe transition */
}
.char-left[data-theme="himachii"]{ --accent:#ff4d4d; --accent-2:#ff8b8b; }

/* shared card look (profile & credits) */
.char-left .char-info, .char-left .credits-card{
  position: relative; width: 100%; box-sizing: border-box; margin: 0;
  padding: 16px 18px 18px; border-radius: 16px; color:#fff;
  background: rgba(25,12,25,.50); border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px) saturate(1.2); -webkit-backdrop-filter: blur(10px) saturate(1.2);
  box-shadow: 0 10px 30px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.02) inset;
}

/* chip/label header (reusable) */
.char-left .chip, .char-left .credits-card .head{
  display:inline-block; margin-bottom: 8px; padding: 4px 10px; border-radius: 999px; font-size:.78rem; font-weight:800; letter-spacing:.02em;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)); color:#111;
  box-shadow: 0 2px 10px color-mix(in oklab, var(--accent) 45%, transparent);
}

/* intro + lore */
.char-info .intro{
  margin:10px 0 12px; font-size: clamp(12px, .95rem, 16px); font-weight:600; line-height:1.35; color:#f6eaf6;
  border-left: 3px solid var(--accent); padding-left:10px;
}
.char-info .lore .label{ font-size:.78rem; opacity:.8; margin-bottom:4px; letter-spacing:.06em; text-transform:uppercase; }
.char-info .lore p{ margin:0 0 10px; font-size: clamp(12px, .92rem, 15px); color:#e9ddea; }

/* dt/dd rows (shared) */
.char-left .meta .row, .char-left .credits-card .row{
  display:grid; grid-template-columns: 1fr auto; gap:10px; align-items:center; padding:8px 0;
  border-top: 1px dashed rgba(255,255,255,.08);
}
.char-left .meta .row:first-child, .char-left .credits-card .row:first-child{ border-top:none; }
.char-left dt{ font-size:.86rem; opacity:.85; }
.char-left dd{ margin:0; font-weight:700; font-size:.95rem; }
.credits-card dl{ margin:0; }

/* extras: swatch + glitch text */
.char-info .swatch{ --c:#EEA0BF; display:inline-block; vertical-align:middle; width:14px; height:14px; border-radius:50%; background: var(--c); box-shadow: 0 0 0 2px rgba(255,255,255,.6) inset; margin-right:8px; }
.char-info .glitch{ position:relative; display:inline-block; text-transform:uppercase; letter-spacing:.04em; animation: glitchFlicker 2.2s infinite steps(1); }
.char-info .glitch::before, .char-info .glitch::after{ content: attr(data-text); position:absolute; left:0; top:0; opacity:.9; pointer-events:none; }
.char-info .glitch::before{ transform: translate(1px,0);  color:#42f7ff; mix-blend-mode:screen; }
.char-info .glitch::after { transform: translate(-1px,0); color:var(--accent); mix-blend-mode:screen; }
@keyframes glitchFlicker{
  0%,100%{ text-shadow:0 0 0 transparent; transform:none; }
  10%{ transform: skewX(2deg); }
  15%{ transform: skewX(-2deg) translateY(-1px); }
  18%{ transform:none; }
  40%{ text-shadow:-1px 0 #42f7ff, 1px 0 var(--accent); }
  42%{ text-shadow: 1px 0 #42f7ff,-1px 0 var(--accent); }
  44%{ text-shadow:0 0 0 transparent; }
  70%{ transform: translateY(1px); }
}

/* Voice pill (di header Profile) */
.char-info .info-head{ display:flex; align-items:center; gap:8px; }
.char-info .info-head .voice-pill{
  --ring: color-mix(in oklab, var(--accent) 70%, white 10%);
  display:inline-flex; align-items:center; gap:0; height:28px; width: clamp(120px, 18ch, 180px);
  padding:0 6px; border-radius:999px; overflow: visible; /* allow mic */
  background:
    radial-gradient(120% 200% at 0% 0%, rgba(255,255,255,.05), transparent 60%),
    repeating-linear-gradient(45deg, #0e0e12, #0e0e12 6px, #111 6px, #111 12px);
  border:1.5px solid rgba(255,255,255,.14); box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
  cursor:pointer; transition: transform .15s ease, border-color .2s ease, box-shadow .2s ease;
}
.char-info .info-head .voice-pill:hover{ transform: translateY(-1px); border-color: var(--ring); box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 0 0 2px color-mix(in oklab, var(--accent) 26%, transparent); }
.char-info .info-head .voice-pill .wave{ flex:1; min-width:0; height:12px; display:flex; align-items:flex-end; gap:2px; margin:0; }
.char-info .info-head .voice-pill .wave i{ display:block; flex:0 0 3px; height:4px; border-radius:2px; background:#ffffff33; transform-origin:bottom; animation: waveIdle 1.6s ease-in-out infinite; }
@keyframes waveIdle{ 0%,100%{height:4px} 50%{height:8px} }
.char-info .info-head .voice-pill.playing .wave i{ background:#ffffff88; animation: wavePlay 1s ease-in-out infinite; }
@keyframes wavePlay{ 0%,100%{ transform:scaleY(.35)} 50%{ transform:scaleY(1)} }
.char-info .info-head .voice-pill.playing .wave i:nth-child(odd){ animation-delay:.1s; }
.char-info .info-head .voice-pill .wave i:nth-child(3n){ animation-duration:1.1s; }
.char-info .info-head .voice-pill .mic{ flex:0 0 auto; width:22px; height:22px; margin-left:6px; border-radius:50%; display:grid; place-items:center; box-shadow: inset 0 0 0 2px #fff; }
.char-info .info-head .voice-pill .mic i{ display: inline-block; background: none !important; animation: none !important; flex: 0 0 auto !important; width: auto; height: auto; font-size: 12px; line-height: 1; color: #fff; font-family: "uicons-solid-straight" !important; }
.char-info .info-head .voice-pill.playing .mic{ box-shadow: inset 0 0 0 2px var(--accent), 0 0 10px color-mix(in oklab, var(--accent) 55%, transparent); }

/* =================================================================
   MORE button
================================================================= */
.more-btn{
  position: absolute; bottom: clamp(24px, 6vh, 56px); left: 90%; transform: translateX(-50%);
  display:flex; align-items:center; justify-content:center; gap:12px; padding:10px 24px;
  font-size: clamp(14px, 1.05rem, 18px); font-weight:600; border:3px solid #fff; border-radius:999px; background:#111; color:#fff; cursor:pointer;
  box-shadow: inset 0 0 4px rgba(255,255,255,.15); transition: transform .2s ease, background .2s ease;
}
.more-btn::after{ content:"›"; display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; background:#fff; color:#111; font-size:16px; font-weight:700; }
.more-btn:hover{  transform: translateX(-50%) translateY(-3px); background:#222; }
.more-btn:active{ transform: translateX(-50%) translateY(0); }

/* =================================================================
   Wipe overlay (for transition engine)
================================================================= */
.wipe-overlay{
  position:absolute; --wipe-bleed: 6vmax; inset: calc(var(--wipe-bleed) * -1);
  background: var(--wipe-bg); transform-origin:left center; transform: scaleX(0);
  pointer-events:none; z-index:999;
}
.left-top{           --wipe-bleed: 1.25rem; }
.char-left{          --wipe-bleed: 1rem; }
#characters .center{ --wipe-bleed: 9vmax; }
@media (prefers-reduced-motion: reduce){ .wipe-overlay{ inset: -20vmax; } }


/* ---------- Z layer safety ---------- */
nav{ z-index:100; }
.char-right{ z-index:50; }
.left-top{ z-index:45; }
#characters .character{ z-index:35; }
.char-left{ z-index:40; }


/* ---------- Responsive: sizes & spacing ---------- */
@media (max-width: 1200px){ .models-bar{ --tileW:76px; --tileH:46px; } }

@media (max-width: 1024px){
  .char-right{ right: clamp(12px, 3vw, 40px); }
  .char-right .char-box{ width:80px; height:80px; margin-top:20px; }
  .char-img.nekoko  { transform: scale(7) translate(5px,18px); }
  .char-img.himachii{ transform: scale(7) translate(-2px,24px); }
  .char-left{ left: clamp(12px, 4vw, 32px); bottom: max(12px, env(safe-area-inset-bottom) + 12px); width: min(86vw, 360px); max-width: calc(100vw - (env(safe-area-inset-left) + env(safe-area-inset-right) + 24px)); }
}

@media (max-width: 900px){
  #characters .character{ height: min(74vh, 640px); }
  .models-bar{ --tileW:68px; --tileH:42px; }
}

@media (max-width: 768px){
  #characters{ --right-offset: 25vh; }
  .char-right{ right: clamp(8px, 3vw, 24px); }
  .char-right .char-box{ width:68px; height:68px; margin-top:16px; }
  .char-img.nekoko  { transform: scale(6) translate(4px,16px); }
  .char-img.himachii{ transform: scale(6) translate(-2px,22px); }

  .char-left{ left: max(12px, env(safe-area-inset-left) + 12px); bottom: max(10px, env(safe-area-inset-bottom) + 10px); width: min(90vw, 340px); }
  .char-left .chip, .char-left .credits-card .head{ font-size:.72rem; padding:3px 8px; }
  .char-info .intro{ font-size: clamp(12px, 3.4vw, 14px); padding-left: 8px; border-left-width: 2px; }
  .char-info .lore p{ font-size: clamp(12px, 3.3vw, 14px); margin-bottom: 8px; }
  .char-left dt{ font-size:.82rem; }
  .char-left dd{ font-size:.9rem; }
  .char-info .info-head .voice-pill{ height:26px; width: clamp(110px, 46vw, 160px); }
}

@media (max-width: 600px){ .models-bar{ --tileW:62px; --tileH:38px; } }
@media (max-width: 380px){ .models-bar{ --tileW:56px; --tileH:34px; } }

@media (max-width: 480px){
  #characters{ --right-offset: 8vh; }
  .char-right{ right: clamp(6px, 3vw, 16px); }
  .char-right .char-box{ width:56px; height:56px; margin-top:12px; border-radius:10px; }
  .char-img.nekoko  { transform: scale(5) translate(3px,14px); }
  .char-img.himachii{ transform: scale(5) translate(-2px,18px); }

  .char-left{
    --pad-l: max(10px, env(safe-area-inset-left) + 10px);
    --pad-r: max(10px, env(safe-area-inset-right) + 10px);
    left: var(--pad-l); right: var(--pad-r); width: auto; max-width: 300px; bottom: max(8px, env(safe-area-inset-bottom) + 8px);
  }
  .char-left .char-info, .char-left .credits-card{ padding: 12px 12px 14px; border-radius: 12px; }
  .char-left .meta .row, .char-left .credits-card .row{ gap: 8px; }
  .char-left .meta .row > *, .char-left .credits-card .row > *{ min-width: 0; }
  .char-left dd{ white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .char-info .info-head .voice-pill{ width: clamp(96px, 40vw, 128px); height: 24px; }
  .char-left .chip, .char-left .credits-card .head{ font-size: .68rem; padding: 2px 7px; }
  .char-info .intro{ font-size: clamp(11px, 3.2vw, 13px); }
  .char-info .lore p{ font-size: clamp(11px, 3vw, 13px); }
  .char-left dt{ font-size: .78rem; }
  .char-left dd{ font-size: .86rem; }
}

/* Phone sempit (≤360px) — lebih ketat lagi */
@media (max-width: 360px){ .char-left{ max-width: 240px; } .char-left .meta .row, .char-left .credits-card .row{ grid-template-columns: 1fr; gap: 4px; } .char-left dd{ justify-self: start; } }
/* === Satu sumber padding kiri/kanan untuk semua elemen kiri === */
#characters{ --side-pad: clamp(16px, 6vw, 140px); }
@media (max-width: 1024px){ #characters{ --side-pad: clamp(12px, 4vw, 32px); } }

.left-top{ left: var(--side-pad); }
.char-left{
  left: var(--side-pad);
  right: var(--side-pad);
  width: auto;
  max-width: min(420px, calc(100vw - (var(--side-pad) * 2)));
}

/* === HP: hide aside saja, credits tetap tampil === */
@media (max-width: 900px){
  .char-left .char-info{ display:none; }                 /* sembunyikan Profile */
  .char-left{
    bottom: max(10px, env(safe-area-inset-bottom) + 10px);
    max-width: min(360px, calc(100vw - (var(--side-pad) * 2)));
  }
  #creditsCard{ padding:14px 16px; }                     /* rapikan spacing kartu */
}

/* === Jendela pendek (desktop/laptop): hindari tabrakan atas-bawah === */
@media (max-height: 700px) and (min-width: 901px){
  #characters{ height:auto; min-height:720px; }
  .char-container{ display:block; padding-bottom:24px; }
  .left-top{ position:static; margin:12px var(--side-pad) 8px; }
  .char-left{ position:static; margin:8px var(--side-pad) 12px; }
  #characters .character{ height:min(62vh, 560px); }
}

/* === Mobile hero recentre === */
@media (max-width: 900px){
  /* geser sedikit ke kiri & naik, kecilkan dikit biar napas */
  #characters{
    --char-x-adjust: -4.5vw;   /* ← geser ke kiri (negatif = kiri) */
    --char-y-adjust: -5vh;     /* ← geser ke atas (negatif = atas)  */
    --char-scale-adjust: -.06; /* ← sedikit mengecilkan */
  }
  .more-btn{ left: 50%; }      /* tombol More ke tengah */
}

@media (max-width: 480px){
  /* layar sangat kecil: tambah sedikit offset */
  #characters{
    --char-x-adjust: -6vw;
    --char-y-adjust: -8vh;
    --char-scale-adjust: -.10;
  }
  .more-btn{ left: 50%; }
}

/* === Kunci More di kanan-bawah semua ukuran === */
.more-btn{
  left: auto;                         /* jangan pakai left:90% lagi */
  right: clamp(16px, 4vw, 40px);      /* sejajar padding kanan */
  transform: none;                    /* state normal */
  z-index: 51;                        /* di atas karakter & cards */
}

/* Hover/active tetap jalan tanpa translateX */
.more-btn:hover{  transform: translateY(-3px); }
.more-btn:active{ transform: translateY(0); }

/* Tablet & phone: jaga jarak aman dari notch/bottom bar */
@media (max-width: 900px){
  .more-btn{
    right: clamp(12px, 4vw, 28px);
    bottom: max(18px, env(safe-area-inset-bottom) + 12px);
  }
}
@media (max-width: 480px){
  .more-btn{
    right: clamp(10px, 5vw, 24px);
    bottom: max(14px, env(safe-area-inset-bottom) + 10px);
  }
}


/* =================================================================
   RECRUITMENT BANNER + ANIMATIONS
================================================================= */
.event-banner{
  --img-fade-start: 42%;
  --img-fade-end: 95%;
  --title-nudge: clamp(28px, 7vw, 140px);
  --nudge-dur: 600ms;
  --nudge-ease: cubic-bezier(.22,1.4,.18,1);
  --line-max: clamp(140px, 28vw, 420px);
  --line-extra: calc(var(--title-nudge) * .12);
  --line-spring: 1.25;

  position: relative;
  display: grid;
  grid-template-columns: var(--left-w) 1fr;
  align-items: stretch;
  height: var(--banner-h);
  overflow: hidden;
  cursor: pointer;
  margin-top: 20vh;
  background:
    radial-gradient(80% 120% at 70% 50%,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,1) 60%,
      rgba(0,0,0,1) 100%),
    var(--bg) center/cover no-repeat,
    #000;
}

/* ===== Left image + fade ===== */
.event-banner .thumb{
  grid-column: 1 / 2;
  position: relative;
  width: calc(var(--left-w) + var(--img-bleed));
  margin-right: calc(var(--img-bleed) * -1);
  height: 100%;
  overflow: hidden;
  margin: 0;
  z-index: 0;
}
.event-banner .thumb img{
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transform: translateX(16px);
  clip-path: inset(0 0 0 100%);
  transition: opacity 500ms var(--nudge-ease),
             transform 500ms var(--nudge-ease),
             clip-path 500ms var(--nudge-ease);
  -webkit-mask-image: linear-gradient(90deg,#000 0%,#000 var(--img-fade-start),transparent var(--img-fade-end));
          mask-image: linear-gradient(90deg,#000 0%,#000 var(--img-fade-start),transparent var(--img-fade-end));
  -webkit-mask-size: 100% 100%; mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
}
.event-banner .thumb::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(90deg, transparent var(--img-fade-start), #000 var(--img-fade-end));
}
.event-banner:hover .thumb img,
.event-banner:focus-within .thumb img{ opacity:1; transform:none; clip-path: inset(0 0 0 0); }

/* ===== Right column (center) ===== */
.event-banner .right{
  grid-column: 2 / 3;
  position: relative;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 10px;
  height: 100%; text-align: center;
  z-index: 1;           /* inline / inline-flex akan ketengah */
}

.event-banner > .right{
  position: absolute !important;   /* netralkan anchor ke kanan */
  top: clamp(12px, 2.5vw, 28px);
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%);
  width: 100%;                     /* biar title-line/garis tetap penuh */
  display: grid;
  justify-items: center;           /* pill + title ketengah */
  gap: 10px;
  z-index: 3;                      /* di atas gambar */
  /* kalau parent pakai grid, ini aman: */
  grid-column: 1 / -1 !important;
  justify-self: center;
}

/* Pill — sekarang di tengah, di atas title */
.event-banner .watch-pill{
  position: static;                 /* override posisi absolut lama */
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.06);
  font-size: .9rem; opacity: .95;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.event-banner .watch-pill .dot{
  width: 9px; height: 9px; border-radius: 50%;
  background:#ff0037; box-shadow: 0 0 8px #ff0c49;
}
.event-banner .watch-pill:hover{
  transform: translateY(-4px);
  border-color: rgba(145, 0, 48, 0.45);
  background: rgba(255, 77, 130, 0.12);
}

/* Title + line */
.event-banner .title-line{
  margin: 0;
  display: inline-flex; align-items: center; gap: 16px;
  font-size: clamp(20px, 2.6vw, 36px); font-weight: 700;
  transform: translateX(var(--title-offset));
  transition: transform var(--nudge-dur) var(--nudge-ease);
  will-change: transform;
}
.event-banner .title-line::after{
  content:""; flex: 0 0 var(--line-max);
  height: 2px; border-radius: 999px;
  background: linear-gradient(90deg,
    rgba(124,77,255,.85) 0%,
    rgba(124,77,255,.45) 35%,
    rgba(255,255,255,.18) 65%,
    rgba(0,0,0,0) 100%);
  transform-origin: left center;
  will-change: transform;
}

/* Bounce */
@keyframes line-bounce{
  0%{ transform: translateX(0) scaleX(1); }
  60%{ transform: translateX(var(--line-extra)) scaleX(var(--line-spring)); }
  82%{ transform: translateX(calc(var(--line-extra)*.92)) scaleX(.98); }
  100%{ transform: translateX(var(--line-extra)) scaleX(1); }
}
@media (hover:hover){
  .event-banner:hover .title-line{
    transform: translateX(calc(var(--title-offset) + var(--title-nudge)));
  }
  .event-banner:hover .title-line::after{
    animation: line-bounce var(--nudge-dur) var(--nudge-ease) forwards;
  }
}
.event-banner:focus-within .title-line{
  transform: translateX(calc(var(--title-offset) + var(--title-nudge)));
}
.event-banner:focus-within .title-line::after{
  animation: line-bounce var(--nudge-dur) var(--nudge-ease) forwards;
}

/* Date */
.event-banner .event-date{
  position: absolute; right: 16px; bottom: 12px;
  margin: 0; opacity: .85;
}

/* Responsive title offset (tablet/phone) */
@media (max-width:1200px){ .event-banner{ --title-offset:-120px; } }
@media (max-width:1024px){ .event-banner{ --title-offset:-80px; } }
@media (max-width:900px){
  .event-banner{
    grid-template-columns: 1fr;
    height: auto;
    --title-offset:-24px;
    --title-nudge: clamp(12px, 4vw, 36px);
    --line-max: clamp(100px, 40vw, 220px);
  }
  .event-banner .thumb{
    height: clamp(160px, 40vw, 260px);
  }
  .event-banner .right{
    padding: 16px 16px 48px;
  }
}
@media (max-width:600px){ .event-banner{ --title-offset:-8px; } }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .event-banner *, .event-banner *::before, .event-banner *::after{
    animation:none !important; transition:none !important;
    transform:none !important; opacity:1 !important; clip-path:none !important;
  }
}


/* — FIX: pill + title selalu di ATAS TENGAH — */
.event-banner{ position: relative; }

.event-banner > .right{
  position: absolute !important;
  top: clamp(12px, 2.5vw, 28px);
  left: 0 !important;
  right: 0 !important;
  transform: none !important;

  /* buang efek tinggi 100% & flex-centering lama */
  height: auto !important;
  display: grid !important;
  place-items: start center !important;   /* vertikal: start (atas), horizontal: center */
  text-align: center !important;
  gap: 10px;
  z-index: 3;
}

/* jarak kecil antara pill dan judul */
.event-banner .watch-pill{ margin-bottom: 50px; }

/* ===== MOBILE OVERLAY (≤900px): teks & pill di TENGAH GAMBAR ===== */
@media (max-width: 900px){
  .event-banner{
    /* tumpuk elemen di area yang sama */
    display: grid !important;
    grid-template-columns: 1fr;
    grid-template-areas: "media";
    overflow: hidden;
    height: auto !important;

    /* netralkan offset judul yang bikin geser */
    --title-offset: 0px !important;
  }

  /* gambar jadi area 'media' penuh */
  .event-banner .thumb{
    grid-area: media;
    width: 100% !important;
    margin: 0 !important;
    height: clamp(170px, 48vw, 280px) !important;
  }

  /* konten kanan menumpuk di atas gambar & di-center */
  .event-banner > .right{
    grid-area: media;
    position: static !important;     /* batalkan absolute sebelumnya */
    inset: auto !important;
    width: 100% !important;

    display: grid !important;
    place-items: center !important;  /* center horizontal + vertical */
    text-align: center !important;
    z-index: 2;
    padding: 0 16px;
    gap: 8px;
  }

  /* judul aman (nggak ke-offset & nggak melebar) */
  .event-banner .title-line{
    transform: none !important;
    max-width: 92vw;
    margin: 0 auto;
    line-height: 1.15;
    font-size: clamp(18px, 6.5vw, 26px);
    word-break: break-word;
  }
  /* opsional: hilangkan garis supaya nggak nyenggol pinggir */
  .event-banner .title-line::after{ display: none; }

  .event-banner .watch-pill{ margin-bottom: 1px; }
}


/* =================================================================
   Section 5 - VIDEO
================================================================= */
.s5-video{
  position: relative;
  background:#000;
  isolation:isolate;    /* rapi tempel dengan section sebelumnya */
}

.s5-wrap{
  position: relative;
  height: clamp(320px, 30vh, 450px); /* full section feel */
  overflow: clip;                     /* cegah bleed */
}

/* Video full cover + siap parallax */
.s5-media{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transform: translateY(var(--s5-offset, 0px)) scale(1.08); /* scale kecil biar aman saat bergerak */
  will-change: transform;
  pointer-events: none;               /* supaya klik kena CTA di atasnya */
}

/* Vignette/gradient biar teks kebaca */
.s5-vignette{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(120% 120% at 50% 50%, transparent 0%, rgba(0,0,0,.15) 60%, rgba(0,0,0,.35) 100%),
    linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 30%, rgb(0, 0, 0) 100%);
}

/* Copy/CTA di tengah */
.s5-content{
  position:absolute; inset:0; z-index:2;
  display:grid; place-items:center;
  text-align:center; padding: 0 16px;
}

.s5-content .eyebrow{
  letter-spacing:.18em; font-weight:600; opacity:.9; margin:0 0 6px;
}

.s5-content h2{
  margin:.1em 0 .6em; line-height:1.05;
  font-size: clamp(28px, 6.5vw, 56px);
}

.s5-cta.btn{ padding:.8rem 1.1rem; }

/* Mobile fine-tune */
@media (max-width: 600px){
  .s5-wrap{ height: clamp(440px, 72vh, 680px); }
  .s5-content h2{ font-size: clamp(24px, 8vw, 36px); }
}

/* Respect prefers-reduced-motion: non-parallax */
@media (prefers-reduced-motion: reduce){
  .s5-media{ transform: none !important; }
}

/* === Section 5: full-bleed ke tepi viewport (hilangin gap samping) === */
.s5-video{
  width: 100vw;
  max-width: 100vw;
  padding-inline: 0 !important;      /* kalau base .section kasih padding */
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;                 /* breakout dari container */
  margin-right: -50vw;
  filter: opacity(20%);
}

/* Overscan hanya vertikal (atas/bawah), bukan kiri/kanan */
.s5-wrap{ --s5-overscan: 12vh; }      /* 8–16vh enak, sesuaikan */
.s5-media{
  position: absolute;
  top: calc(var(--s5-overscan) * -1);
  left: 0; right: 0;
  height: calc(100% + var(--s5-overscan) * 2);  /* tambah tinggi */
  width: 100%;
  object-fit: cover;
  transform: translateY(var(--s5-offset, 0));
  will-change: transform;
}

/* Jaga-jaga: tidak ada sela antar section */
.event-banner{ margin-bottom: 0; }
.s5-video{ margin-top: 0; }

/* Kalau masih ada scroll horizontal dari breakout */
html, body{ overflow-x: hidden; }

/* tint + vignette lebih dramatis (hitam -> ungu gelap) */
.s5-vignette{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    /* vignette halus di tepi */
    radial-gradient(130% 130% at 50% 50%,
      transparent 0%,
      rgba(0,0,0,.15) 60%,
      rgba(0, 0, 0, 0.658) 100%),
    /* tint utama: hitam -> ungu gelap */
    linear-gradient(180deg,
      rgba(5,5,8,.55) 0%,
      rgba(18,0,36,.62) 45%,
      rgba(58, 0, 116, 0.822) 100%);
  opacity:.95;           /* feel lebih gelap */
  transition: opacity .25s ease;
}
/* =========================
   Footer
========================= */
.site-footer{
  --muted: #b9bcc6;
  --fg: #e9eaed;
  background:#000; color:var(--fg);
  text-align:center;
  padding:56px 16px 72px;
  border-top:1px solid #ffffff14;
}
.footer-nav{ max-width:1100px; margin:0 auto; }

.footer-nav ul{ list-style:none; padding:0; margin:0; }
.footer-nav .primary{
  display:flex; flex-wrap:wrap; justify-content:center;
  gap: clamp(14px, 4vw, 36px);
  font-weight:600; letter-spacing:.06em; text-transform:uppercase;
}
.footer-nav .primary a.fx{
  position:relative; display:inline-flex; align-items:center; gap:10px;
  padding:8px 4px; color:var(--fg); text-decoration:none;
  opacity:.9; transition:opacity .2s ease;
}
.footer-nav .primary a.fx:hover,
.footer-nav .primary a.fx:focus-visible{ opacity:1; }

/* ikon panah muncul saat hover */
.footer-nav .primary a.fx .icon{
  width:1.1em; line-height:1; pointer-events:none;
  transform: translateX(-8px) scale(.85);
  opacity:0; transition: transform .28s cubic-bezier(.2,.7,0,1), opacity .28s;
}
.footer-nav .primary a.fx:hover .icon,
.footer-nav .primary a.fx:focus-visible .icon{
  transform:translateX(0) scale(1); opacity:1;
}

/* Social row */
.footer-nav .social{
  display:flex; justify-content:center; gap: clamp(18px, 6vw, 40px);
  margin:18px 0 26px;
}
.footer-nav .social .fx-mini{
  position:relative; display:inline-block; padding:6px 2px;
  color:var(--muted); text-decoration:none; letter-spacing:.1em;
  transition: color .2s ease;
}
.footer-nav .social .fx-mini::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px;
  background: currentColor; transform:scaleX(0); transform-origin:left;
  transition: transform .28s cubic-bezier(.2,.7,0,1);
  opacity:.6;
}
.footer-nav .social .fx-mini:hover,
.footer-nav .social .fx-mini:focus-visible{ color:var(--fg); }
.footer-nav .social .fx-mini:hover::after,
.footer-nav .social .fx-mini:focus-visible::after{ transform:scaleX(1); }

/* Back to top */
.backtop{
  display:inline-flex; align-items:center; gap:12px;
  font-weight:600; letter-spacing:.06em; color:var(--fg);
  margin:12px 0 24px; text-decoration:none;
}
.backtop .btn{
  width:34px; height:34px; display:grid; place-items:center;
  background:#fff; color:#000; border-radius:6px;
  box-shadow: 0 0 0 0 rgba(255,255,255,.2);
  transition: transform .22s ease, box-shadow .22s ease;
}
.backtop:hover .btn, .backtop:focus-visible .btn{
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(255,255,255,.12);
}

/* copyright line */
.legal{ color:var(--muted); }
.legal a{ color:var(--fg); text-decoration:none; opacity:.9; }
.legal a:hover{ opacity:1; text-decoration:underline; }

/* Mobile tweaks */
@media (max-width: 640px){
  .footer-nav .primary{ gap:18px; }
  .footer-nav .social{ gap:22px; }
}


/* tombol & ukuran tetap */
.social-icons .icon-btn{
  width:40px; height:40px; display:grid; place-items:center;
  border-radius:999px; background:#0f0f12; color:var(--fg);
  opacity:.9; text-decoration:none;
  transition: transform .2s ease, opacity .2s ease, box-shadow .2s ease;
}
.social-icons .icon-btn:hover,
.social-icons .icon-btn:focus-visible{
  opacity:1; transform:translateY(-2px);
  box-shadow:0 8px 18px rgba(255,255,255,.08);
}

/* pakai SVG sebagai mask → ikut warna currentColor (putih) */
.icon-btn .ico{
  width:20px; height:20px; display:block;
  background: currentColor;
  -webkit-mask: var(--ico) center/contain no-repeat;
          mask: var(--ico) center/contain no-repeat;
}

/* sembunyikan teks aksesibel */
.sr-only{
  position:absolute;width:1px;height:1px;margin:-1px;padding:0;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* --- Force baris & center untuk ikon di FOOTER saja --- */
.site-footer .social-icons{
  position: static !important;
  top: auto !important; left: auto !important; right: auto !important; bottom: auto !important;
  transform: none !important;

  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  gap: clamp(14px, 3.5vw, 22px);
  margin: 12px 0 18px;
  width: 100%;
}

/* tombolnya tetap */
.site-footer .social-icons .icon-btn{
  width:40px; height:40px; display:grid; place-items:center;
  border-radius:999px; background:#0f0f12; color:var(--fg);
  opacity:.9; text-decoration:none;
  transition: transform .2s ease, opacity .2s ease, box-shadow .2s ease;
}
.site-footer .social-icons .icon-btn:hover,
.site-footer .social-icons .icon-btn:focus-visible{
  opacity:1; transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(255,255,255,.08);
}

/* SVG pakai mask (dari versi sebelumnya) */
.site-footer .social-icons .icon-btn .ico{
  width:20px; height:20px; display:block;
  background: currentColor;
  -webkit-mask: var(--ico) center/contain no-repeat;
          mask: var(--ico) center/contain no-repeat;
}
:root{ --bt-arrow-dur: 1.25s; }

/* tombol + chevron mask */
.backtop .btn{
  position: relative; overflow: hidden;
  --chev: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpolyline points='6,14 12,8 18,14' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.backtop .btn i{ display:none; }

/* === IDLE: satu panah statis di tengah === */
.backtop .btn::before,
.backtop .btn::after{
  content:""; position:absolute; inset:0;
  background: currentColor;
  -webkit-mask: var(--chev) center/42% 42% no-repeat;
          mask: var(--chev) center/42% 42% no-repeat;
  transform: translateY(0); opacity:1;              /* di tengah */
}
.backtop .btn::after{ opacity:0; }                  /* panah kedua disembunyikan */

/* === HOVER/FOCUS: langsung start di keyframe awal (di bawah), lalu animasi === */
.backtop:hover .btn::before,
.backtop:focus-visible .btn::before,
.backtop:hover .btn::after,
.backtop:focus-visible .btn::after{
  transform: translateY(38%); opacity:0;            /* pos awal = 0% keyframe */
  animation: arrow-rise var(--bt-arrow-dur, 1.25s) cubic-bezier(.2,.7,0,1) infinite;
  animation-fill-mode: both;                         /* terapkan 0% segera */
  will-change: transform, opacity;
}

/* panah kedua offset setengah siklus → menyusul yang pertama */
.backtop:hover .btn::after,
.backtop:focus-visible .btn::after{
  animation-delay: calc(var(--bt-arrow-dur, 1.25s) / 2);
}

/* (opsional) sedikit percepat saat hover */
.backtop:hover .btn::before,
.backtop:hover .btn::after,
.backtop:focus-visible .btn::before,
.backtop:focus-visible .btn::after{
  animation-duration: calc(var(--bt-arrow-dur, 1.25s) * 0.9);
}

/* keyframes: naik → hilang → respawn bawah → ulang */
@keyframes arrow-rise{
  0%     { transform: translateY(38%); opacity: 0; }
  15%    { opacity: 1; }
  50%    { transform: translateY(-38%); opacity: 0; } /* di atas, fade out */
  50.01% { transform: translateY(38%); opacity: 0; }  /* respawn bawah */
  100%   { transform: translateY(-38%); opacity: 0; }
}

/* aksesibilitas */
@media (prefers-reduced-motion: reduce){
  .backtop:hover .btn::before,
  .backtop:hover .btn::after,
  .backtop:focus-visible .btn::before,
  .backtop:focus-visible .btn::after{ animation:none; transform:translateY(0); opacity:1; }
}

/* ===== Social icons: brand-based hover ===== */
/* base tetap seperti punyamu — putih saat idle, mask pakai .ico */

/* Transisi halus pada isi ikon */
.site-footer .social-icons .icon-btn .ico{
  transition: background .28s ease, filter .28s ease;
}

/* ---------- Discord ---------- */
.site-footer .social-icons .icon-btn[aria-label="Discord"]:hover .ico,
.site-footer .social-icons .icon-btn[aria-label="Discord"]:focus-visible .ico{
  background:#5865F2;                /* brand */
}
.site-footer .social-icons .icon-btn[aria-label="Discord"]:hover,
.site-footer .social-icons .icon-btn[aria-label="Discord"]:focus-visible{
  box-shadow:
    0 6px 18px rgba(88,101,242,.45),
    0 0 0 2px rgba(88,101,242,.35) inset;
}

/* ---------- YouTube ---------- */
:root{ --yt: #FF0033; } /* boleh ganti ke #FF0000 kalau mau */
.site-footer .social-icons .icon-btn[aria-label="YouTube"]:hover .ico,
.site-footer .social-icons .icon-btn[aria-label="YouTube"]:focus-visible .ico{
  background: var(--yt);
}
.site-footer .social-icons .icon-btn[aria-label="YouTube"]:hover,
.site-footer .social-icons .icon-btn[aria-label="YouTube"]:focus-visible{
  box-shadow:
    0 6px 18px rgba(255,0,51,.45),
    0 0 0 2px rgba(255,0,51,.35) inset;
}

/* ---------- Instagram (gradient) ---------- */
/* Gradient mendekati IG official */
.site-footer .social-icons .icon-btn[aria-label="Instagram"]:hover .ico,
.site-footer .social-icons .icon-btn[aria-label="Instagram"]:focus-visible .ico{
  background:
    radial-gradient(circle at 30% 107%,
      #FEDA77 0%, #FEDA77 5%, #FD5949 45%, #D6249F 60%, #285AEB 90%);
  background-size: 120% 120%;         /* sedikit penuh */
}
.site-footer .social-icons .icon-btn[aria-label="Instagram"]:hover,
.site-footer .social-icons .icon-btn[aria-label="Instagram"]:focus-visible{
  box-shadow:
    0 6px 18px rgba(214,36,159,.45),
    0 0 0 2px rgba(253,89,73,.35) inset;
}

/* ---------- X (Twitter) ---------- */
/* Ikon tetap putih, hanya glow putih */
.site-footer .social-icons .icon-btn[aria-label="X"]:hover .ico,
.site-footer .social-icons .icon-btn[aria-label="X"]:focus-visible .ico{
  background: #fff;
  filter: drop-shadow(0 0 6px rgba(255,255,255,.60));
}
.site-footer .social-icons .icon-btn[aria-label="X"]:hover,
.site-footer .social-icons .icon-btn[aria-label="X"]:focus-visible{
  box-shadow:
    0 6px 18px rgba(255,255,255,.28),
    0 0 0 2px rgba(255,255,255,.35) inset;
}
.site-footer .social-icons .icon-btn[aria-label="Instagram"]:hover .ico{
  animation: igShift 2.4s ease-in-out infinite alternate;
}
@keyframes igShift{
  to { background-position: 72% 28%; }
}

/* === Fix header "Profile" + Voice sejajar & center === */
.char-info .info-head{
  display:flex;
  align-items:center;          /* vertical center */
  gap:8px;
  width:100%;
  min-height:28px;             /* jaga tinggi baris */
}

/* samakan tinggi chip dengan pill & hilangkan margin bawaan */
.char-info .info-head .chip{
  display:inline-flex;
  align-items:center;
  height:28px;                 /* = voice-pill */
  padding:0 12px;
  margin:0;                    /* <— ini yang bikin nggak sejajar */
  line-height:1;
}
.char-info .info-head audio{ display:none; }

/* sinkron di breakpoint kamu (voice-pill sudah turun tinggi) */
@media (max-width:768px){
  .char-info .info-head .chip,
  .char-info .info-head .voice-pill{ height:26px; }
}
@media (max-width:480px){
  .char-info .info-head .chip,
  .char-info .info-head .voice-pill{ height:24px; }
}

.char-info .glitch-rand{
  position:relative; display:inline-block; letter-spacing:.08em;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
}
.char-info .glitch-rand::before,
.char-info .glitch-rand::after{
  content:attr(data-text); position:absolute; left:0; top:0; opacity:.9; pointer-events:none;
}
.char-info .glitch-rand::before{ transform:translate(1px,0);  color:#42f7ff; mix-blend-mode:screen; }
.char-info .glitch-rand::after { transform:translate(-1px,0); color:var(--accent); mix-blend-mode:screen; }

@keyframes randJitter{
  0%,100%{ transform:none; }
  20%{ transform:translateY(-1px); }
  40%{ transform:translateX(1px); }
  60%{ transform:translateY(1px); }
  80%{ transform:translateX(-1px); }
}
.char-info .glitch-rand{ animation: randJitter 2.2s steps(1) infinite; }
@media (prefers-reduced-motion: reduce){ .char-info .glitch-rand{ animation:none; } }

.char-info .info-head{ display:flex; align-items:center; gap:8px; min-height:28px; }
.char-info .info-head .chip{
  display:inline-flex; align-items:center; height:28px; padding:0 12px; margin:0; line-height:1;
}
.char-info .info-head .voice-pill{ height:28px; }

@media (max-width:768px){
  .char-info .info-head .chip, .char-info .info-head .voice-pill{ height:26px; }
}
@media (max-width:480px){
  .char-info .info-head .chip, .char-info .info-head .voice-pill{ height:24px; }
}

/* === GAP antara video (left-top) & infografis (char-left) === */
#characters{ --info-gap: 20px; }  /* atur suka-suka: 12–32px enak */

.char-left{
  /* default kamu: bottom: clamp(24px, 10vh, 100px);
     kita dorong turun dengan menguranginya pakai var(--info-gap) */
  bottom: calc(clamp(24px, 10vh, 100px) - var(--info-gap));
}

/* Responsif: bisa kecilkan gap biar aman di layar sempit */
@media (max-width: 1024px){
  #characters{ --info-gap: 14px; }
}
@media (max-width: 600px){
  #characters{ --info-gap: 10px; }
}

