/* ── ROOT VARS ── */
:root {
  --void:  #0A0A0F;
  --surf:  #12121A;
  --surf2: #1A1A28;
  --v:     #7C3AED;
  --vl:    #9D5FF5;
  --pk:    #EC4899;
  --cy:    #1AFFD5;
  --tx:    #F8F8FF;
  --mu:    #8B8BA0;
  --bd:    rgba(124,58,237,.2);
}

*  { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--void); color:var(--tx); font-family:'Inter',sans-serif; overflow-x:hidden; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-thumb { background:var(--v); border-radius:2px; }

/* ── NAVBAR ── */

/* ── BUTTONS ── */
.btn-p {
  background:linear-gradient(135deg,var(--v),var(--pk));
  color:#fff; border:none; padding:.8rem 2rem; border-radius:50px;
  font-weight:600; font-size:.9rem; cursor:pointer; transition:all .3s;
  box-shadow:0 0 28px rgba(124,58,237,.4); text-decoration:none; display:inline-block;
}
.btn-p:hover { transform:translateY(-2px); box-shadow:0 0 50px rgba(124,58,237,.6); color:#fff; }
.btn-g {
  background:transparent; color:var(--tx); border:1px solid rgba(255,255,255,.14);
  padding:.8rem 2rem; border-radius:50px; font-weight:500; font-size:.9rem;
  cursor:pointer; transition:all .3s; text-decoration:none; display:inline-block;
  backdrop-filter:blur(10px);
}
.btn-g:hover { border-color:rgba(124,58,237,.5); background:rgba(124,58,237,.1); color:var(--tx); }

/* ── SECTION ── */
.sec { padding:6rem 0; position:relative; }
.sec-eye {
  display:inline-block; font-size:.68rem; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; color:var(--cy); margin-bottom:.8rem;
}
.sec-h {
  font-family:'Orbitron',sans-serif; font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:700; line-height:1.15; margin-bottom:.8rem;
}
.sec-sub { color:var(--mu); font-size:.95rem; line-height:1.75; max-width:520px; }
.grad {
  background:linear-gradient(135deg,var(--vl) 0%,var(--pk) 50%,var(--cy) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-size:200%; animation:gs 4s ease infinite;
}
@keyframes gs { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* ── HERO ── */
.hero {
  position:relative; height:100vh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.hero-slides { position:absolute; inset:0; }
.hero-slide {
  position:absolute; inset:0; opacity:0; background-size:cover;
  background-position:center; transform:scale(1.08);
  transition:opacity 1.4s ease, transform 8s ease;
}
.hero-slide.active { opacity:1; transform:scale(1); }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(10,10,15,.3) 0%,rgba(10,10,15,.55) 60%,rgba(10,10,15,.95) 100%);
}
.hero-aurora {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 55% at 20% 50%,rgba(124,58,237,.22) 0%,transparent 60%),
    radial-gradient(ellipse 55% 45% at 80% 40%,rgba(236,72,153,.14) 0%,transparent 60%);
  animation:aurora 9s ease-in-out infinite alternate; mix-blend-mode:screen;
}
@keyframes aurora { 0%{opacity:.7;transform:scale(1)} 100%{opacity:1;transform:scale(1.04)} }
#pcv { position:absolute; inset:0; pointer-events:none; }

.hero-content {
  position:relative; z-index:2; text-align:center; padding:2rem; max-width:860px;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(124,58,237,.13); border:1px solid rgba(124,58,237,.3);
  border-radius:50px; padding:.38rem 1rem; font-size:.72rem; font-weight:600;
  letter-spacing:2px; text-transform:uppercase; color:var(--cy); margin-bottom:1.5rem;
  animation:fadeUp .8s ease both;
}
.dot-pulse {
  width:6px; height:6px; background:var(--cy); border-radius:50%;
  animation:dp 1.6s ease-in-out infinite;
}
@keyframes dp { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.6)} }
.hero-title {
  font-family:'Orbitron',sans-serif;
  font-size:clamp(2.6rem,7vw,5.5rem); font-weight:900; line-height:1.05;
  margin-bottom:.5rem; animation:fadeUp .8s .2s ease both;
}
.hero-sub {
  font-size:clamp(.9rem,2vw,1.15rem); color:rgba(248,248,255,.85); max-width:520px;
  margin:1.2rem auto 2.5rem; line-height:1.75; font-weight:300;
  animation:fadeUp .8s .4s ease both;
}
.hero-cta { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; animation:fadeUp .8s .6s ease both; }

.slide-dots {
  position:absolute; bottom:5rem; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; gap:.5rem;
}
.sdot {
  width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.3);
  cursor:pointer; transition:all .4s;
}
.sdot.active { background:var(--cy); width:22px; border-radius:3px; }

.scroll-hint {
  position:absolute; bottom:1.6rem; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; flex-direction:column; align-items:center;
  gap:.4rem; color:var(--mu); font-size:.65rem; letter-spacing:2px;
  text-transform:uppercase; animation:fadeUp 1s 1.2s ease both;
}
.sline {
  width:1px; height:40px; background:linear-gradient(to bottom,var(--v),transparent);
  animation:sp 2s ease-in-out infinite;
}
@keyframes sp { 0%,100%{opacity:.3} 50%{opacity:1} }

/* ── GLOWING DIVIDER ── */
.gdiv { height:1px; background:linear-gradient(to right,transparent,var(--v),var(--pk),transparent); opacity:.35; }

/* ── SCROLL REVEAL ── */
.rv { opacity:0; transform:translateY(36px); transition:opacity .75s ease,transform .75s ease; }
.rv.vis { opacity:1; transform:translateY(0); }
.rl { opacity:0; transform:translateX(-36px); transition:opacity .75s ease,transform .75s ease; }
.rl.vis { opacity:1; transform:translateX(0); }
.rr { opacity:0; transform:translateX(36px); transition:opacity .75s ease,transform .75s ease; }
.rr.vis { opacity:1; transform:translateX(0); }

@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

/* ── STATS BAR ── */
.stats-bar {
  background:var(--surf); border-top:1px solid var(--bd);
  border-bottom:1px solid var(--bd); padding:3rem 0;
}
.stat-val {
  font-family:'Orbitron',sans-serif; font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:900; background:linear-gradient(135deg,var(--vl),var(--pk));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1.1;
}
.stat-lbl { color:var(--mu); font-size:.78rem; font-weight:500; margin-top:.3rem; }

/* ── ABOUT / DESCRIPTION ── */
.about-card {
  background:var(--surf); border:1px solid var(--bd); border-radius:16px;
  padding:2rem; height:100%; transition:border-color .3s;
}
.about-card:hover { border-color:rgba(124,58,237,.5); }

/* ── AUTHOR ── */
.author-avatar {
  width:110px; height:110px; border-radius:50%; margin:0 auto 1.25rem;
  background:var(--surf); border:1px solid var(--bd);
  display:flex; align-items:center; justify-content:center;
}
.author-tags { display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; margin-top:.75rem; }
.author-tag {
  font-size:.72rem; font-weight:600; padding:.25rem .75rem; border-radius:50px;
  background:rgba(26,255,213,.08); border:1px solid rgba(26,255,213,.2); color:var(--cy);
}

/* ── TIMELINE / ROADMAP ── */
.timeline { position:relative; padding-left:2rem; }
.timeline::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:2px; background:linear-gradient(to bottom,var(--v),var(--pk),transparent);
}
.tl-item { position:relative; margin-bottom:2rem; }
.tl-item::before {
  content:''; position:absolute; left:-2.35rem; top:.35rem;
  width:12px; height:12px; border-radius:50%;
  background:var(--v); border:2px solid var(--void);
  box-shadow:0 0 10px rgba(124,58,237,.7);
}
.tl-date { font-size:.7rem; color:var(--mu); font-weight:600; letter-spacing:1px; text-transform:uppercase; margin-bottom:.25rem; }
.tl-title { font-weight:600; font-size:.95rem; margin-bottom:.2rem; }
.tl-desc { font-size:.85rem; color:var(--mu); line-height:1.6; }

/* ── GALLERY PAGE ── */
.char-tabs {
  display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:2rem;
}
.char-tab {
  background:var(--surf); border:1px solid var(--bd); color:var(--mu);
  padding:.45rem 1.1rem; border-radius:50px; font-size:.82rem; font-weight:500;
  cursor:pointer; transition:all .3s; text-decoration:none;
}
.char-tab:hover, .char-tab.active {
  border-color:var(--v); color:var(--tx); background:rgba(124,58,237,.12);
}

.section-label {
  font-size:.68rem; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  margin-bottom:1.2rem; display:flex; align-items:center; gap:.6rem;
}
.section-label.sfw-label  { color:var(--cy); }
.section-label.nsfw-label { color:var(--pk); }

/* masonry grid */
.masonry { columns:4; column-gap:.75rem; }
@media(max-width:1100px) { .masonry { columns:3; } }
@media(max-width:700px)  { .masonry { columns:2; } }
@media(max-width:420px)  { .masonry { columns:1; } }

.m-item {
  break-inside:avoid; margin-bottom:.75rem; position:relative;
  border-radius:10px; overflow:hidden; cursor:pointer;
}
.m-item img {
  width:100%; display:block; border-radius:10px;
  transition:transform .5s ease, filter .5s ease;
  filter:brightness(.88) saturate(1.1);
}
.m-item:hover img { transform:scale(1.05); filter:brightness(1) saturate(1.4); }
.m-ov {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(to top,rgba(10,10,15,.95) 0%,transparent 100%);
  padding:1.2rem .8rem .65rem; transform:translateY(100%);
  transition:transform .4s ease; border-radius:0 0 10px 10px;
}
.m-item:hover .m-ov { transform:translateY(0); }
.m-ttl { font-family:'Orbitron',sans-serif; font-size:.75rem; font-weight:700; margin-bottom:.15rem; }
.m-sub { color:var(--cy); font-size:.65rem; font-weight:500; }

/* ── OLD MASONRY (kept for index.php hero if used) ── */

/* ── NSFW LOCK ── */
.nsfw-locked {
  background:var(--surf2); border:1px solid rgba(236,72,153,.25);
  border-radius:14px; padding:3rem 2rem; text-align:center; margin-bottom:2rem;
}
.nsfw-locked-icon { font-size:2.5rem; margin-bottom:.75rem; }
.nsfw-locked h3 {
  font-family:'Orbitron',sans-serif; font-size:1rem; font-weight:700;
  margin-bottom:.5rem; color:var(--pk);
}
.nsfw-locked p { color:var(--mu); font-size:.85rem; line-height:1.65; max-width:380px; margin:0 auto 1.5rem; }

/* ── AGE GATE MODAL ── */
.agegate {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(10,10,15,.97); backdrop-filter:blur(20px);
  align-items:center; justify-content:center;
}
.agegate.on { display:flex; }
.age-box {
  background:var(--surf2); border:1px solid var(--bd);
  border-radius:20px; padding:3rem; max-width:420px; width:90%; text-align:center;
}
.age-icon { font-size:2.8rem; margin-bottom:.8rem; }
.age-title { font-family:'Orbitron',sans-serif; font-size:1.1rem; font-weight:700; margin-bottom:.6rem; }
.age-txt { color:var(--mu); font-size:.875rem; line-height:1.7; margin-bottom:1.8rem; }
.age-acts { display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap; }

/* ── LIGHTBOX ── */
.lb {
  display:none; position:fixed; inset:0; z-index:9000;
  background:rgba(10,10,15,.97); backdrop-filter:blur(16px);
  align-items:center; justify-content:center; flex-direction:column;
}
.lb.open { display:flex; }
.lb img { max-width:90vw; max-height:82vh; border-radius:12px; box-shadow:0 0 80px rgba(124,58,237,.3); }
.lb-close {
  position:absolute; top:1.5rem; right:1.5rem;
  font-size:1.5rem; color:var(--mu); cursor:pointer; transition:color .3s;
}
.lb-close:hover { color:var(--tx); }
.lb-nav { display:flex; gap:1.5rem; margin-top:1.2rem; }
.lb-btn {
  background:rgba(124,58,237,.15); border:1px solid var(--bd);
  color:var(--tx); padding:.5rem 1.2rem; border-radius:50px;
  cursor:pointer; transition:all .3s; font-size:.85rem;
}
.lb-btn:hover { background:rgba(124,58,237,.3); }

/* ── FOOTER ── */
.footer { background:var(--surf); border-top:1px solid var(--bd); padding:3rem 0 2rem; }
.foot-logo {
  font-family:'Orbitron',sans-serif; font-weight:900; font-size:1.2rem;
  background:linear-gradient(135deg,var(--v),var(--pk));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; letter-spacing:2px;
}
.foot-desc { color:var(--mu); font-size:.84rem; line-height:1.7; max-width:300px; }
.foot-links { list-style:none; padding:0; }
.foot-links li { margin-bottom:.45rem; }
.foot-links a { color:var(--mu); text-decoration:none; font-size:.84rem; transition:color .3s; }
.foot-links a:hover { color:var(--tx); }
.foot-h { font-size:.68rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--tx); margin-bottom:.8rem; }
.socials { display:flex; gap:.6rem; }
.soc {
  width:36px; height:36px; border:1px solid var(--bd); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--mu); text-decoration:none; transition:all .3s; font-size:.8rem;
}
.soc:hover { border-color:var(--v); color:var(--v); background:rgba(124,58,237,.1); }
.foot-bot {
  border-top:1px solid var(--bd); padding-top:1.2rem; margin-top:2rem;
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:.5rem;
}
.foot-bot p { color:var(--mu); font-size:.78rem; margin:0; }
.nsfw-note {
  background:rgba(236,72,153,.08); border:1px solid rgba(236,72,153,.2);
  border-radius:8px; padding:.35rem .8rem; color:var(--pk); font-size:.68rem; font-weight:600;
}

/* ── PROGRESS BARS ── */
.progress-wrap { margin-bottom:1rem; }
.progress-label { display:flex; justify-content:space-between; font-size:.8rem; margin-bottom:.35rem; color:var(--mu); }
.progress-track { background:var(--surf2); border-radius:50px; height:6px; overflow:hidden; }
.progress-fill {
  height:100%; border-radius:50px;
  background:linear-gradient(90deg,var(--v),var(--pk));
  transition:width 1.2s ease;
}

/* ── WHAT'S NEXT CARDS ── */
.next-card {
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.1rem 1.25rem; margin-bottom:.75rem;
  background:var(--surf); border:1px solid var(--bd); border-radius:14px;
  transition:border-color .3s, transform .3s;
}
.next-card:hover { border-color:rgba(124,58,237,.45); transform:translateX(4px); }
.next-icon {
  flex-shrink:0; width:38px; height:38px; border-radius:10px;
  background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(236,72,153,.15));
  border:1px solid rgba(124,58,237,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem;
  background-clip:padding-box;
  color:var(--v);
}
.next-title { font-weight:600; font-size:.88rem; margin-bottom:.2rem; color:var(--tx); }
.next-desc  { font-size:.78rem; color:var(--mu); line-height:1.55; }

/* ════════════════════════════════════════
   GALLERY — CHARACTER SELECTION
════════════════════════════════════════ */
.char-page-header {
  padding:7rem 0 2.5rem;
  background:linear-gradient(to bottom, var(--surf) 0%, var(--void) 100%);
  border-bottom:1px solid var(--bd);
}
.char-name {
  font-family:'Orbitron',sans-serif;
  font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:900; margin-bottom:.6rem;
}
.char-meta { display:flex; gap:.5rem; flex-wrap:wrap; align-items:center; }

.meta-pill {
  display:inline-block; font-size:.72rem; font-weight:700;
  letter-spacing:.5px; padding:.22rem .7rem; border-radius:50px;
}
.sfw-pill  { background:rgba(26,255,213,.1);  border:1px solid rgba(26,255,213,.3);  color:var(--cy); }
.nsfw-pill { background:rgba(236,72,153,.1);  border:1px solid rgba(236,72,153,.3);  color:var(--pk); }
.lock-pill { background:rgba(139,139,160,.08);border:1px solid rgba(139,139,160,.2); color:var(--mu); }

.breadcrumb-row { margin-bottom:1rem; display:flex; align-items:center; gap:.5rem; }
.breadcrumb-sep { color:var(--mu); font-size:.75rem; opacity:.5; }
.breadcrumb-link {
  color:var(--mu); text-decoration:none; font-size:.82rem;
  font-weight:500; transition:color .25s; display:inline-flex;
  align-items:center; gap:.4rem;
}
.breadcrumb-link:hover { color:var(--tx); }

/* Character selection grid */
.char-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:1.2rem;
  padding:2.5rem 0 4rem;
}
.char-card {
  text-decoration:none; color:inherit;
  border-radius:14px; overflow:hidden;
  border:1px solid var(--bd);
  background:var(--surf);
  transition:transform .3s, border-color .3s, box-shadow .3s;
  display:flex; flex-direction:column;
}
.char-card:hover {
  transform:translateY(-5px);
  border-color:rgba(124,58,237,.5);
  box-shadow:0 16px 48px rgba(0,0,0,.45), 0 0 32px rgba(124,58,237,.12);
}
.char-card-img {
  position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--surf2);
}
.char-card-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease, filter .5s ease;
  filter:brightness(.85) saturate(1.1);
}
.char-card:hover .char-card-img img {
  transform:scale(1.07); filter:brightness(1) saturate(1.3);
}
.char-card-img img.cover-blur {
  filter:brightness(.7) blur(18px) saturate(.6);
}
.char-card:hover .char-card-img img.cover-blur {
  filter:brightness(.8) blur(14px) saturate(.7);
}
.char-card-placeholder {
  width:100%; height:100%; display:flex; align-items:center;
  justify-content:center; font-size:2rem; color:var(--mu);
}
.char-card-gradient {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(10,10,15,.7) 0%,transparent 60%);
}
.char-card-body { padding:.9rem 1rem 1rem; }
.char-card-name {
  font-family:'Orbitron',sans-serif; font-size:.88rem; font-weight:700;
  margin-bottom:.5rem; color:var(--tx);
}
.char-card-counts { display:flex; gap:.4rem; flex-wrap:wrap; }

/* ════════════════════════════════════════
   GALLERY — FILTER BAR
════════════════════════════════════════ */
.filter-bar {
  position:sticky; top:56px; z-index:500;
  background:rgba(10,10,15,.92); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--bd); padding:.8rem 0;
}
.filter-bar .container {
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
}
.filter-group { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; }
.filter-label {
  font-size:.68rem; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--mu); margin-right:.2rem;
}
.filter-btn {
  background:transparent; border:1px solid var(--bd);
  color:var(--mu); padding:.3rem .85rem; border-radius:50px;
  font-size:.78rem; font-weight:500; cursor:pointer;
  transition:all .25s; text-decoration:none; display:inline-block;
}
.filter-btn:hover { border-color:rgba(124,58,237,.5); color:var(--tx); }
.filter-btn.active {
  background:rgba(124,58,237,.18); border-color:var(--v);
  color:var(--tx); font-weight:600;
}
.filter-btn.nsfw-btn.active {
  background:rgba(236,72,153,.15); border-color:var(--pk); color:var(--pk);
}
.filter-divider {
  width:1px; height:20px; background:var(--bd); flex-shrink:0;
}
.filter-results {
  margin-left:auto; font-size:.75rem; color:var(--mu);
  white-space:nowrap;
}

/* ════════════════════════════════════════
   GALLERY — IMAGE GRID
════════════════════════════════════════ */
.gallery-wrap { padding:2rem 0 4rem; }

/* Portrait grid — many narrow columns */
.img-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(160px, 1fr));
  gap:.75rem;
}
@media(min-width:640px)  { .img-grid { grid-template-columns:repeat(auto-fill, minmax(175px, 1fr)); } }
@media(min-width:1100px) { .img-grid { grid-template-columns:repeat(5, 1fr); } }
@media(max-width:480px)  { .img-grid { grid-template-columns:repeat(2, 1fr); } }

/* Landscape grid — fewer, wider columns */
.img-grid--landscape {
  grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));
}
@media(min-width:900px)  { .img-grid--landscape { grid-template-columns:repeat(3, 1fr); } }
@media(min-width:1400px) { .img-grid--landscape { grid-template-columns:repeat(4, 1fr); } }
@media(max-width:600px)  { .img-grid--landscape { grid-template-columns:repeat(1, 1fr); } }

.img-card {
  position:relative; border-radius:10px; overflow:hidden;
  cursor:pointer; background:var(--surf2);
  border:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, transform .3s;
}
.img-card:hover {
  border-color:rgba(124,58,237,.45);
  box-shadow:0 8px 32px rgba(0,0,0,.5), 0 0 20px rgba(124,58,237,.1);
  transform:translateY(-3px);
  z-index:2;
}
.img-card img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .5s ease, filter .5s ease;
  filter:brightness(.88) saturate(1.05);
  /* fixed heights by orientation */
}
.card-port img { aspect-ratio:2/3; }
.card-land img { aspect-ratio:16/9; }
.img-card:not(.card-port):not(.card-land) img { aspect-ratio:1/1; }
.img-card:hover img { transform:scale(1.06); filter:brightness(1) saturate(1.25); }

.img-card-ov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(10,10,15,.88) 0%,rgba(10,10,15,.15) 55%,transparent 100%);
  opacity:0; transition:opacity .3s ease;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:.6rem;
}
.img-card:hover .img-card-ov { opacity:1; }

.ov-top { display:flex; gap:.3rem; flex-wrap:wrap; }
.res-tag {
  font-size:.6rem; font-weight:600; letter-spacing:.3px;
  padding:.15rem .45rem; border-radius:50px;
  background:rgba(10,10,15,.55); color:rgba(248,248,255,.6);
  border:1px solid rgba(255,255,255,.1);
}

.orient-tag, .rating-tag {
  font-size:.6rem; font-weight:700; letter-spacing:.5px;
  padding:.15rem .45rem; border-radius:50px; text-transform:uppercase;
}
.orient-tag { background:rgba(10,10,15,.6); color:var(--mu); border:1px solid rgba(255,255,255,.12); }
.sfw-tag  { background:rgba(26,255,213,.18);  color:var(--cy); border:1px solid rgba(26,255,213,.3); }
.nsfw-tag { background:rgba(236,72,153,.18);  color:var(--pk); border:1px solid rgba(236,72,153,.3); }

.ov-actions { display:flex; gap:.4rem; justify-content:flex-end; }
.ov-btn {
  width:30px; height:30px; border-radius:50%;
  background:rgba(10,10,15,.7); border:1px solid rgba(255,255,255,.15);
  color:var(--tx); display:flex; align-items:center; justify-content:center;
  font-size:.72rem; cursor:pointer; transition:all .2s;
  text-decoration:none;
}
.ov-btn:hover { background:rgba(124,58,237,.5); border-color:var(--v); color:#fff; }

/* ── EMPTY STATE ── */
.empty-state {
  text-align:center; padding:5rem 1rem; color:var(--mu);
}
.empty-state i { font-size:3rem; margin-bottom:1rem; display:block; opacity:.4; }
.empty-state p  { font-size:.95rem; }

/* ── NSFW LOCK (inline) ── */
.nsfw-locked {
  background:var(--surf2); border:1px solid rgba(236,72,153,.25);
  border-radius:14px; padding:3rem 2rem; text-align:center; margin:2rem 0;
}
.nsfw-locked-icon { font-size:2.5rem; margin-bottom:.75rem; }
.nsfw-locked h3 {
  font-family:'Orbitron',sans-serif; font-size:1rem; font-weight:700;
  margin-bottom:.5rem; color:var(--pk);
}
.nsfw-locked p {
  color:var(--mu); font-size:.85rem; line-height:1.65;
  max-width:380px; margin:0 auto 1.5rem;
}

/* ── ORIENTATION SECTIONS ── */
.orient-section { margin-bottom:2.5rem; }
.orient-section-label {
  display:flex; align-items:center; gap:.6rem;
  font-size:.72rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  color:var(--mu); margin-bottom:.9rem; padding-bottom:.6rem;
  border-bottom:1px solid var(--bd);
}
.orient-section-label i { color:var(--v); }
.orient-count {
  margin-left:.3rem; font-size:.65rem; background:rgba(124,58,237,.12);
  border:1px solid var(--bd); border-radius:50px; padding:.1rem .5rem;
  color:var(--mu); font-weight:500;
}

/* ── PAGINATION ── */
.pagination {
  display:flex; justify-content:center; align-items:center;
  gap:.4rem; padding:2.5rem 0 1rem; flex-wrap:wrap;
}
.pg-btn {
  min-width:36px; height:36px; padding:0 .55rem;
  border-radius:8px; border:1px solid var(--bd);
  background:var(--surf); color:var(--mu);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:.82rem; font-weight:500; text-decoration:none;
  transition:all .22s; cursor:pointer;
}
.pg-btn:hover { border-color:var(--v); color:var(--tx); background:rgba(124,58,237,.12); }
.pg-btn.pg-current {
  background:linear-gradient(135deg,var(--v),var(--pk));
  border-color:transparent; color:#fff; font-weight:700;
}
.pg-btn.pg-disabled { opacity:.3; cursor:default; pointer-events:none; }
.pg-ellipsis { color:var(--mu); font-size:.85rem; padding:0 .2rem; }

/* ── LIGHTBOX (extended with download) ── */
.lb {
  display:none; position:fixed; inset:0; z-index:9000;
  background:rgba(10,10,15,.97); backdrop-filter:blur(16px);
  align-items:center; justify-content:center; flex-direction:column;
}
.lb.open { display:flex; }
.lb img {
  max-width:90vw; max-height:80vh; border-radius:10px;
  box-shadow:0 0 80px rgba(124,58,237,.3); object-fit:contain;
}
.lb-info {
  display:flex; align-items:center; gap:.75rem; margin-top:.7rem; min-height:1.2rem;
}
.lb-info-item { font-size:.75rem; color:var(--mu); }
.lb-res {
  font-family:'Orbitron',sans-serif; font-size:.68rem; color:var(--cy);
  letter-spacing:.5px;
}
.lb-close {
  position:absolute; top:1.2rem; right:1.2rem; font-size:1.4rem;
  color:var(--mu); cursor:pointer; transition:color .3s;
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.05); border-radius:50%; border:1px solid var(--bd);
}
.lb-close:hover { color:var(--tx); background:rgba(255,255,255,.1); }
.lb-nav { display:flex; gap:.75rem; margin-top:1rem; align-items:center; }
.lb-btn {
  background:rgba(124,58,237,.15); border:1px solid var(--bd);
  color:var(--tx); padding:.45rem 1.1rem; border-radius:50px;
  cursor:pointer; transition:all .25s; font-size:.82rem;
  text-decoration:none; display:inline-flex; align-items:center; gap:.4rem;
}
.lb-btn:hover { background:rgba(124,58,237,.35); color:#fff; }
.lb-dl-btn { background:rgba(26,255,213,.1); border-color:rgba(26,255,213,.3); color:var(--cy); }
.lb-dl-btn:hover { background:rgba(26,255,213,.25); color:var(--cy); }
