/* ==========================================================================
   SpaceVision Tab — Cinema Edition (v3)
   Modern dark cinematic theme · Crimson/Cyan accents · Poster-style cards
   ========================================================================== */

:root{
  --bg:#08070d;
  --bg-2:#0f0d18;
  --surface:#16131f;
  --surface-2:#1c1929;
  --surface-3:#241f34;
  --line:rgba(255,255,255,.06);
  --line-2:rgba(255,255,255,.12);

  --text:#f4f1f8;
  --text-2:#bdb6cc;
  --muted:#7a7390;

  --c1:#ff3d6e;
  --c1-2:#ff6a3d;
  --c2:#22d3ee;
  --c2-2:#7c5cff;
  --gold:#ffb547;
  --success:#22c55e;
  --danger:#ef4444;

  --grad-brand:linear-gradient(135deg,#ff3d6e 0%,#ff6a3d 100%);
  --grad-cool:linear-gradient(135deg,#22d3ee 0%,#7c5cff 100%);
  --grad-bg:radial-gradient(1200px 700px at 80% -10%, rgba(255,61,110,.18), transparent 60%),
            radial-gradient(900px 600px at -10% 20%, rgba(124,92,255,.16), transparent 60%),
            radial-gradient(700px 500px at 50% 120%, rgba(34,211,238,.12), transparent 60%);

  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:56px;

  --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:26px; --r-pill:999px;

  --shadow-sm:0 4px 12px rgba(0,0,0,.35);
  --shadow:0 12px 32px rgba(0,0,0,.45);
  --shadow-lg:0 24px 60px rgba(0,0,0,.55);
  --glow-c1:0 0 0 1px rgba(255,61,110,.4), 0 12px 40px rgba(255,61,110,.25);

  --container-max:1240px;
  --container-pad:16px;

  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:"Rubik","Segoe UI",system-ui,sans-serif;
  background:var(--bg);
  background-image:var(--grad-bg);
  background-attachment:fixed;
  color:var(--text);
  min-height:100vh;
  line-height:1.6;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;padding:0;-webkit-appearance:none;appearance:none}
input,select,textarea{font-family:inherit;color:inherit}
::selection{background:var(--c1);color:#fff}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--c1),var(--c2-2));border-radius:8px;border:2px solid var(--bg)}

.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}
.page-main{padding-top:calc(var(--sp-6) + var(--safe-top));padding-bottom:var(--sp-12)}

/* ---------- TOP BAR ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  padding-top:var(--safe-top);
  background:linear-gradient(180deg,rgba(8,7,13,.92) 0%,rgba(8,7,13,.65) 100%);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  max-width:var(--container-max);margin:0 auto;
  padding:12px var(--container-pad);
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);
}
.brand-new{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--text)}
.brand-ic{
  width:38px;height:38px;display:grid;place-items:center;
  background:var(--grad-brand);border-radius:12px;color:#fff;
  box-shadow:var(--glow-c1);
}
.brand-text{
  background:linear-gradient(135deg,#fff 0%,#ffd6e2 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}

.coin-wallet{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  background:linear-gradient(135deg,rgba(255,181,71,.18),rgba(255,61,110,.14));
  border:1px solid rgba(255,181,71,.35);
  border-radius:var(--r-pill);
  font-weight:700;font-size:14px;color:#ffd9a8;
}
.coin-wallet .coin-ic{color:var(--gold);display:inline-flex}
.coin-amount{color:#fff;font-variant-numeric:tabular-nums}
.coin-label{color:#ffd9a8;opacity:.85;font-size:12px}

.top-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--r-pill);
  font-weight:600;font-size:14px;
  transition:transform .2s,box-shadow .2s,background .2s;
  border:1px solid transparent;
}
.top-btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 6px 20px rgba(255,61,110,.35)}
.top-btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(255,61,110,.5)}
.top-btn-ghost{background:rgba(255,255,255,.04);border-color:var(--line-2);color:var(--text-2)}
.top-btn-ghost:hover{background:rgba(255,255,255,.08);color:var(--text)}
.top-btn-ic{display:inline-flex}

/* ---------- HERO ---------- */
.hero{
  position:relative;margin:var(--sp-6) 0;padding:var(--sp-10) var(--sp-6);
  border-radius:var(--r-xl);
  background:
    radial-gradient(800px 400px at 90% 0%, rgba(255,61,110,.22), transparent 60%),
    radial-gradient(600px 400px at 0% 100%, rgba(34,211,238,.18), transparent 60%),
    linear-gradient(135deg,#15101f 0%,#0e0c1a 100%);
  border:1px solid var(--line-2);overflow:hidden;isolation:isolate;
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0 2px,transparent 2px 14px);
  mix-blend-mode:overlay;
}
.hero-title{margin:0 0 10px;font-size:clamp(24px,3.2vw,38px);font-weight:800;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-title__accent{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:14px;background:var(--grad-brand);box-shadow:var(--glow-c1);color:#fff}
.hero-lead{margin:0;color:var(--text-2);max-width:680px;font-size:clamp(14px,1.6vw,16px)}

/* ---------- LIBRARY HEAD + SEARCH + FILTERS ---------- */
.library-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--sp-4);margin:var(--sp-6) 0 var(--sp-4);flex-wrap:wrap}
.library-title{margin:0;font-size:22px;font-weight:800;display:inline-flex;align-items:center;gap:8px}
.library-ic{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:10px;background:rgba(255,61,110,.16);color:var(--c1);border:1px solid rgba(255,61,110,.3)}
.library-subtitle{margin:4px 0 0;color:var(--text-2);font-size:13.5px}
.library-head-meta{display:flex;gap:8px;flex-wrap:wrap}
.count-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--r-pill);color:var(--text-2);font-size:12.5px}
.count-pill strong{color:var(--text);font-weight:700}
.count-pill .muted{color:var(--muted)}

.search-wrap{
  position:relative;margin:var(--sp-4) 0;
  display:flex;align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid var(--line-2);border-radius:var(--r-pill);
  padding:4px 6px 4px 16px;transition:border-color .2s,box-shadow .2s;
}
.search-wrap:focus-within{border-color:rgba(255,61,110,.5);box-shadow:0 0 0 4px rgba(255,61,110,.12)}
.search-wrap .search-ic{color:var(--muted);display:inline-flex;margin-inline-end:8px}
.search-wrap input{flex:1;background:transparent;border:0;outline:0;padding:12px 0;color:var(--text);font-size:15px}
.search-wrap input::placeholder{color:var(--muted)}

.filter-bar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.filter-bar-scroll::-webkit-scrollbar{display:none}
.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;padding:6px 0 12px;min-width:max-content}
.filter-label{color:var(--muted);font-size:12.5px;font-weight:600;margin-inline-end:4px;white-space:nowrap}
.filter-group{display:inline-flex;gap:6px;background:rgba(255,255,255,.03);border:1px solid var(--line);padding:4px;border-radius:var(--r-pill)}
.chip{display:inline-block;padding:8px 16px;border-radius:var(--r-pill);color:var(--text-2);font-size:13px;font-weight:600;transition:all .2s;white-space:nowrap}
.chip:hover{color:var(--text);background:rgba(255,255,255,.05)}
.chip.active{background:var(--grad-brand);color:#fff;box-shadow:0 6px 18px rgba(255,61,110,.32)}

/* ---------- VIDEO GRID + CARDS (POSTER STYLE) ---------- */
.grid,.related-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:var(--sp-5);
  margin-top:var(--sp-4);
}

.vcard{
  position:relative;
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;
  animation:cardIn .5s both ease;
}
@keyframes cardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.vcard:hover{
  transform:translateY(-6px);
  border-color:rgba(255,61,110,.45);
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,61,110,.25);
}

/* Thumb */
.thumb{
  position:relative;
  aspect-ratio:16/10;
  background:
    radial-gradient(at 30% 30%, rgba(255,61,110,.18), transparent 60%),
    radial-gradient(at 70% 70%, rgba(34,211,238,.14), transparent 60%),
    linear-gradient(135deg,#1a1626,#0e0c18);
  overflow:hidden;isolation:isolate;
}
.thumb::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.65) 100%);
}
.thumb-img{width:100%;height:100%;object-fit:cover;opacity:0;transition:transform .6s ease,opacity .4s}
.thumb-img.is-loaded{opacity:1}
.vcard:hover .thumb-img{transform:scale(1.07)}
.thumb-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.18)}
.thumb-ph-ic{font-size:64px}

/* Play button overlay on hover */
.thumb::before{
  content:"";
  position:absolute;left:50%;top:50%;
  width:64px;height:64px;
  transform:translate(-50%,-50%) scale(.6);
  background:rgba(255,61,110,.92);
  border-radius:50%;
  opacity:0;
  transition:opacity .3s ease,transform .3s ease;
  z-index:2;
  box-shadow:0 0 0 8px rgba(255,61,110,.18),0 12px 30px rgba(255,61,110,.5);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M8 5v14l11-7z'/></svg>");
  background-repeat:no-repeat;background-position:center;background-size:28px;
}
.vcard:hover .thumb::before{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* Badges on thumb */
.thumb-badge-price{
  position:absolute;top:10px;inset-inline-start:10px;z-index:3;
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 10px;
  background:linear-gradient(135deg,rgba(255,181,71,.95),rgba(255,106,61,.95));
  color:#fff;font-weight:800;font-size:12.5px;
  border-radius:var(--r-pill);
  box-shadow:0 6px 16px rgba(255,106,61,.4);
  backdrop-filter:blur(8px);
}
.thumb-badge-ic{font-size:14px}
.dur-badge{
  position:absolute;bottom:10px;inset-inline-end:10px;z-index:3;
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 8px;background:rgba(0,0,0,.7);
  color:#fff;font-size:11.5px;font-weight:700;
  border-radius:6px;backdrop-filter:blur(6px);
  font-variant-numeric:tabular-nums;
}
.dur-badge--unknown{opacity:.6}
.owned-tag{
  position:absolute;top:10px;inset-inline-end:10px;z-index:3;
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;font-size:11.5px;font-weight:700;
  background:linear-gradient(135deg,rgba(34,197,94,.95),rgba(16,185,129,.95));
  color:#fff;border-radius:var(--r-pill);
  box-shadow:0 4px 14px rgba(34,197,94,.35);
}
.owned-ic{font-size:13px}

/* Card info */
.vinfo{padding:14px 14px 16px;display:flex;flex-direction:column;gap:10px;flex:1}
.vtitle{
  margin:0;font-size:15px;font-weight:700;line-height:1.4;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;text-overflow:ellipsis;min-height:42px;
}
.vmeta{display:flex;align-items:center;gap:8px}
.vmeta--actions{margin-top:auto;flex-direction:column;align-items:stretch;gap:8px}
.vmeta-top{display:flex;align-items:center;justify-content:space-between;gap:8px}

/* Price chip inside card */
.vprice{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;background:rgba(255,181,71,.12);
  border:1px solid rgba(255,181,71,.3);
  border-radius:var(--r-pill);
  color:var(--gold);font-weight:700;font-size:13px;
}
.vprice__ico{display:inline-flex;color:var(--gold)}
.vprice__num{color:#fff}
.vprice__lbl{font-size:11px;opacity:.85}

/* Action buttons */
.vbtn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:12px 14px;border-radius:var(--r-md);
  font-weight:700;font-size:14px;
  transition:transform .2s,box-shadow .2s,background .2s,filter .2s;
  width:100%;
  border:0;outline:0;cursor:pointer;
  text-decoration:none;line-height:1.2;
  -webkit-appearance:none;appearance:none;
  font-family:inherit;
}
.vbtn-watch{
  background:linear-gradient(135deg,#22d3ee,#7c5cff);
  color:#fff!important;
  box-shadow:0 6px 20px rgba(124,92,255,.35);
}
.vbtn-watch:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(124,92,255,.55);filter:brightness(1.08)}
.vbtn__ic{display:inline-flex}

.vbuy-form{margin:0;width:100%;display:block}
.vbtn-buy{
  position:relative;
  background:var(--grad-brand)!important;
  color:#fff!important;
  padding:11px 14px;
  border-radius:var(--r-md);
  box-shadow:0 6px 20px rgba(255,61,110,.4),inset 0 1px 0 rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;width:100%;
  overflow:hidden;
}
.vbtn-buy::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent 50%);
  pointer-events:none;border-radius:inherit;
}
.vbtn-buy:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,61,110,.55),inset 0 1px 0 rgba(255,255,255,.25);filter:brightness(1.05)}
.vbtn-buy:active{transform:translateY(0);filter:brightness(.97)}
.vbtn-buy__stack{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15;text-align:start;flex:1;min-width:0;position:relative;z-index:1}
.vbtn-buy__cta{font-size:14px;font-weight:800;letter-spacing:.2px}
.vbtn-buy__price-row{display:inline-flex;align-items:baseline;gap:4px;margin-top:3px;font-size:11.5px;opacity:.92}
.vbtn-buy__amount{
  font-weight:800;font-size:13px;
  background:rgba(255,255,255,.22);
  padding:1px 7px;border-radius:var(--r-pill);
  font-variant-numeric:tabular-nums;
}
.vbtn-buy__unit{font-size:11px;opacity:.85}
.vbtn-buy__chev{
  display:inline-grid;place-items:center;
  width:32px;height:32px;flex:0 0 32px;
  background:rgba(255,255,255,.18);
  border-radius:50%;
  opacity:.95;transition:transform .25s,background .25s;
  position:relative;z-index:1;
}
.vbtn-buy__chev-ic{font-size:18px}
.vbtn-buy:hover .vbtn-buy__chev{transform:translateX(-3px);background:rgba(255,255,255,.28)}
.vbtn-buy--compact{padding:9px 12px;gap:8px}
.vbtn-buy--compact .vbtn-buy__cta{font-size:13px}
.vbtn-buy--compact .vbtn-buy__chev{width:28px;height:28px;flex-basis:28px}

/* Empty / no-results */
.empty,.no-results{
  margin:var(--sp-8) 0;padding:var(--sp-10) var(--sp-6);
  text-align:center;color:var(--text-2);
  background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  border:1px dashed var(--line-2);
  border-radius:var(--r-xl);
}
.empty-ic,.no-results-ic{
  display:inline-grid;place-items:center;
  width:80px;height:80px;border-radius:50%;
  background:rgba(255,61,110,.1);color:var(--c1);
  margin-bottom:var(--sp-4);font-size:40px;
  border:1px solid rgba(255,61,110,.25);
}
.empty-actions,.no-results-actions{
  margin-top:var(--sp-5);display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
}

/* ---------- BUTTONS (Generic) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 22px;border-radius:var(--r-pill);
  font-weight:700;font-size:14px;
  transition:transform .2s,box-shadow .2s,background .2s;
  border:1px solid transparent;cursor:pointer;
}
.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 6px 20px rgba(255,61,110,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(255,61,110,.5)}
.btn-secondary{background:rgba(255,255,255,.05);border-color:var(--line-2);color:var(--text)}
.btn-secondary:hover{background:rgba(255,255,255,.1)}
.btn-block{width:100%}

/* ---------- WATCH PAGE ---------- */
.watch-stage{
  margin:var(--sp-4) 0 var(--sp-5);
  background:#000;border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow:var(--shadow-lg);
  aspect-ratio:16/9;position:relative;
}
.watch-stage video,.watch-stage .plyr{
  width:100%!important;height:100%!important;display:block;
}
.watch-info{
  padding:var(--sp-5) var(--sp-6);
  background:linear-gradient(135deg,var(--surface),var(--surface-2));
  border:1px solid var(--line);border-radius:var(--r-lg);
  margin-bottom:var(--sp-6);
}
.watch-title{
  margin:0 0 12px;font-size:clamp(20px,2.4vw,28px);font-weight:800;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.watch-title-ic{
  display:inline-grid;place-items:center;
  width:38px;height:38px;border-radius:10px;
  background:var(--grad-brand);color:#fff;
  box-shadow:var(--glow-c1);
}
.watch-meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--text-2);font-size:13px}
.meta-item{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
}
.meta-ic-wrap{display:inline-flex;color:var(--c1)}
.meta-ic{font-size:14px}

/* Related */
.related-section{margin-top:var(--sp-8)}
.related-head{margin-bottom:var(--sp-4)}
.related-head h3{margin:0;font-size:20px;font-weight:800;display:inline-flex;align-items:center;gap:8px}
.related-desc{margin:4px 0 0;color:var(--text-2);font-size:13px}

/* ---------- AUTH / FORM CARDS (index, code_login, redeem) ---------- */
.auth-wrap,.card{
  max-width:480px;margin:var(--sp-10) auto;
  padding:var(--sp-8);
  background:linear-gradient(135deg,var(--surface),var(--surface-2));
  border:1px solid var(--line-2);border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.auth-wrap::before,.card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,61,110,.35),transparent 40%,rgba(34,211,238,.25));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  padding:1px;opacity:.5;
}
.auth-icon,.card-icon{
  width:64px;height:64px;border-radius:18px;
  display:grid;place-items:center;margin:0 auto var(--sp-4);
  background:var(--grad-brand);color:#fff;
  box-shadow:var(--glow-c1);font-size:32px;
}
.auth-title,.card-title{
  margin:0 0 8px;text-align:center;
  font-size:22px;font-weight:800;
}
.auth-subtitle,.card-subtitle{
  margin:0 0 var(--sp-5);text-align:center;
  color:var(--text-2);font-size:14px;
}

.form-group{margin-bottom:var(--sp-4)}
.form-label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--text-2)}
.form-control,input[type=text],input[type=password],input[type=number],textarea{
  width:100%;padding:13px 16px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line-2);
  border-radius:var(--r-md);
  color:var(--text);font-size:15px;
  transition:border-color .2s,box-shadow .2s,background .2s;
  outline:0;
}
.form-control:focus,input:focus,textarea:focus{
  border-color:var(--c1);
  background:rgba(255,255,255,.05);
  box-shadow:0 0 0 4px rgba(255,61,110,.15);
}
.form-control[type=number]{font-variant-numeric:tabular-nums}

/* Code input (6-digit) */
.code-input{
  text-align:center;
  font-size:28px;font-weight:800;letter-spacing:14px;
  font-variant-numeric:tabular-nums;
  padding:18px 16px;
}

.alert{
  padding:12px 16px;border-radius:var(--r-md);
  margin-bottom:var(--sp-4);font-size:14px;
  border:1px solid transparent;
  display:flex;align-items:center;gap:8px;
}
.alert-error,.alert-danger{
  background:rgba(239,68,68,.1);
  border-color:rgba(239,68,68,.3);color:#fca5a5;
}
.alert-success{
  background:rgba(34,197,94,.1);
  border-color:rgba(34,197,94,.3);color:#86efac;
}
.alert-info{
  background:rgba(34,211,238,.1);
  border-color:rgba(34,211,238,.3);color:#7dd3fc;
}

.auth-footer{
  margin-top:var(--sp-5);text-align:center;
  color:var(--text-2);font-size:13px;
}
.auth-footer a{color:var(--c1);font-weight:600}
.auth-footer a:hover{text-decoration:underline}

/* ---------- FOOTER ---------- */
.site-footer{
  margin-top:var(--sp-12);padding:var(--sp-6) 0 calc(var(--sp-6) + var(--safe-bot));
  border-top:1px solid var(--line);
  text-align:center;color:var(--muted);font-size:13px;
}
.site-footer a{color:var(--c1);font-weight:600}
.site-footer a:hover{text-decoration:underline}

/* ---------- UTILS ---------- */
.muted{color:var(--muted)}
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-2{margin-top:8px}.mt-4{margin-top:16px}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 720px){
  body{font-size:14px}
  .topbar-inner{padding:10px 12px;flex-wrap:wrap;gap:8px}
  .top-btn-text{display:none}
  .top-btn{padding:8px 10px}
  .coin-label{display:none}
  .coin-wallet{padding:7px 11px}
  .brand-text{font-size:16px}
  .grid,.related-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .vinfo{padding:12px}
  .vtitle{font-size:13.5px;min-height:38px}
  .hero{padding:var(--sp-6) var(--sp-5);margin:var(--sp-4) 0}
  .hero-title__accent{width:40px;height:40px}
  .library-head{margin-top:var(--sp-4)}
  .library-title{font-size:18px}
  .auth-wrap,.card{margin:var(--sp-6) var(--container-pad);padding:var(--sp-6)}
  .code-input{font-size:24px;letter-spacing:10px}
  .watch-info{padding:var(--sp-4)}
}
@media (max-width: 420px){
  .grid,.related-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .thumb-badge-price{font-size:11px;padding:4px 8px}
  .vbtn-buy__cta{font-size:13px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ==========================================================================
   Legacy compatibility shims (kept for old class names in PHP pages)
   ========================================================================== */

/* .card variants used in index.php/redeem.php/code_login.php */
.card{max-width:480px;margin:var(--sp-10) auto;padding:var(--sp-8)}
.card h1{margin:0 0 8px;text-align:center;font-size:24px;font-weight:800}
.card p.muted{text-align:center;margin:0 0 var(--sp-5)}
.card .form{display:flex;flex-direction:column;gap:12px;margin-top:var(--sp-4)}
.card .form label{font-size:13px;font-weight:600;color:var(--text-2)}
.center{text-align:center}
.auth-card-icon{
  width:72px;height:72px;border-radius:20px;
  display:grid;place-items:center;margin:0 auto var(--sp-4);
  background:var(--grad-brand);color:#fff;
  box-shadow:var(--glow-c1);font-size:36px;
}
.medium{max-width:720px}

/* legacy buttons */
.btn-ghost{background:transparent;border:1px solid var(--line-2);color:var(--text-2)}
.btn-ghost:hover{background:rgba(255,255,255,.05);color:var(--text)}
.block{width:100%}
.btn-ic{display:inline-flex}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:var(--sp-3)}
.btn-row .btn{flex:1;min-width:140px}

/* legacy alerts */
.alert.ok{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3);color:#86efac}
.alert.err{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:#fca5a5}
.alert.info{background:rgba(34,211,238,.1);border-color:rgba(34,211,238,.3);color:#7dd3fc}
.alert--flex{display:flex;align-items:center;gap:8px}
.alert-ic{display:inline-flex;flex:0 0 auto}

/* legacy hero variants used in home.php */
.hero-title__accent .hero-waves-ic{display:inline-flex}


/* legacy vbtn-buy chev ic helper */
.vbtn-buy__chev-ic{display:inline-flex;font-size:18px}

/* iconify-icon sizing helpers (used as 2nd arg classes) */
iconify-icon[width],iconify-icon{display:inline-block;vertical-align:-2px}
iconify-icon.sm{font-size:16px}
iconify-icon.md{font-size:20px}
iconify-icon.lg{font-size:32px}
iconify-icon.xl{font-size:48px}
