/* ══════════════════════════════════════════════════════
   RomX v4 — LEGENDARY Design System
   Dark-first · RTL · Glassmorphism · Cinematic Animations
   Mobile-first · Fluid Responsive · Micro-interactions
   ══════════════════════════════════════════════════════ */

/* ── Variables ──────────────────────────────────────── */
:root {
  --primary:      #1d9bf0;
  --primary-dim:  rgba(29,155,240,0.10);
  --primary-glow: rgba(29,155,240,0.25);
  --bg:           #050509;
  --bg2:          #0a0a14;
  --bg3:          #10101e;
  --card:         rgba(255,255,255,0.03);
  --card-h:       rgba(255,255,255,0.06);
  --border:       rgba(255,255,255,0.06);
  --border-h:     rgba(255,255,255,0.12);
  --text:         #f0f0f8;
  --text2:        #a8a8c4;
  --muted:        #5c5c7a;
  --danger:       #ef4444;
  --warn:         #f97316;
  --ok:           #22c55e;
  --radius:       18px;
  --radius-sm:    12px;
  --radius-xs:    8px;
  --shadow:       0 8px 40px rgba(0,0,0,.55);
  --shadow-lg:    0 24px 64px rgba(0,0,0,.65);
  --tb:           62px;
  --easing:       cubic-bezier(.22,1,.36,1);
  --easing-bounce:cubic-bezier(.34,1.56,.64,1);
  --dur:          .25s;
  --dur-slow:     .5s;
}

[data-mode="light"] {
  --bg:#f4f5fa; --bg2:#eaecf4; --bg3:#dfe1ed;
  --card:rgba(0,0,0,.025); --card-h:rgba(0,0,0,.05);
  --border:rgba(0,0,0,.07); --border-h:rgba(0,0,0,.14);
  --text:#0a0a18; --text2:#4a4a6a; --muted:#8888aa;
  --shadow:0 4px 24px rgba(0,0,0,.08); --shadow-lg:0 14px 44px rgba(0,0,0,.12);
}

/* ── Reset ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:"Cairo","Segoe UI",system-ui,sans-serif;
  background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;
  direction:rtl;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.6;
}
a{color:var(--primary);text-decoration:none;transition:color var(--dur) var(--easing);}
a:hover{opacity:.85;}
img{max-width:100%;display:block;object-fit:cover;}
button,input,select,textarea{font-family:inherit;outline:none;}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:var(--primary-glow);}

/* ── Selection ─────────────────────────────────────── */
::selection{background:var(--primary);color:#fff;}

/* ══════════════════════════════════════════════════════
   TOPBAR — Frosted glass with glow underline
   ══════════════════════════════════════════════════════ */
#topbar{
  position:fixed;top:0;right:0;left:0;z-index:200;height:var(--tb);
  background:rgba(5,5,9,.75);backdrop-filter:blur(28px) saturate(1.6);
  -webkit-backdrop-filter:blur(28px) saturate(1.6);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  transition:background var(--dur) var(--easing);
}
#topbar::after{
  content:"";position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);
  width:40%;height:1px;
  background:linear-gradient(90deg,transparent,var(--primary-glow),transparent);
  opacity:.6;
}
[data-mode="light"] #topbar{background:rgba(244,245,250,.82);}

.topbar-logo{
  background:none;border:none;cursor:pointer;
  font-size:1.3rem;font-weight:900;letter-spacing:-.6px;color:var(--text);
  display:flex;align-items:center;gap:5px;white-space:nowrap;
  transition:all var(--dur) var(--easing);
  position:relative;
}
.topbar-logo span{
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.topbar-logo:hover{transform:scale(1.04);}

.topbar-nav{display:flex;gap:4px;flex:1;overflow:hidden;}
.nav-link{
  padding:8px 16px;border-radius:var(--radius-xs);border:none;background:none;
  color:var(--muted);font-size:.85rem;font-weight:700;cursor:pointer;
  white-space:nowrap;transition:all var(--dur) var(--easing);
  position:relative;
}
.nav-link:hover{color:var(--text);background:var(--card-h);}
.nav-link.active{color:var(--primary);}
.nav-link.active::after{
  content:"";position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
  width:16px;height:2px;border-radius:99px;
  background:var(--primary);
  box-shadow:0 0 8px var(--primary-glow);
}

.topbar-actions{display:flex;align-items:center;gap:10px;margin-right:auto;flex-shrink:0;}
.icon-action-btn{
  width:38px;height:38px;border-radius:var(--radius-xs);
  border:1px solid var(--border);
  background:var(--card);color:var(--text2);cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur) var(--easing);
  position:relative;overflow:hidden;
}
.icon-action-btn::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at center,var(--primary-dim),transparent 70%);
  opacity:0;transition:opacity var(--dur);
}
.icon-action-btn:hover{background:var(--card-h);border-color:var(--border-h);transform:scale(1.05);}
.icon-action-btn:hover::before{opacity:1;}
.logout-btn{color:var(--muted);}
.logout-btn:hover{color:var(--danger);border-color:rgba(239,68,68,.3);}
.user-av{
  width:38px;height:38px;border-radius:50%;
  border:2px solid transparent;
  background-origin:border-box;background-clip:content-box,border-box;
  background-image:linear-gradient(var(--bg),var(--bg)),linear-gradient(135deg,var(--primary),#38bdf8);
  cursor:pointer;transition:all var(--dur) var(--easing);object-fit:cover;flex-shrink:0;
}
.user-av:hover{transform:scale(1.1);box-shadow:0 0 16px var(--primary-glow);}

/* ══════════════════════════════════════════════════════
   BOTTOM NAV — Floating pill with glass effect
   ══════════════════════════════════════════════════════ */
#bottomNav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;
  padding:0 12px env(safe-area-inset-bottom,8px);
  pointer-events:none;
}
.bnav-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:rgba(5,5,9,.88);backdrop-filter:blur(28px) saturate(1.6);
  -webkit-backdrop-filter:blur(28px) saturate(1.6);
  border:1px solid var(--border);
  border-radius:20px;
  padding:6px 4px;
  pointer-events:auto;
  box-shadow:0 -4px 32px rgba(0,0,0,.3);
  margin-bottom:4px;
}
[data-mode="light"] .bnav-inner{background:rgba(244,245,250,.9);}
.bnav-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:8px 4px;font-size:.68rem;color:var(--muted);
  background:none;border:none;cursor:pointer;
  transition:all var(--dur) var(--easing);
  border-radius:var(--radius-sm);
  position:relative;
}
.bnav-item:hover,.bnav-item.active{color:var(--primary);}
.bnav-item.active{background:var(--primary-dim);}
.bnav-item.active::after{
  content:"";position:absolute;top:2px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 6px var(--primary);
}
.bnav-item>span:first-child{font-size:1.3rem;transition:transform var(--dur) var(--easing-bounce);}
.bnav-item.active>span:first-child{transform:scale(1.15) translateY(-1px);}
.bnav-av{width:26px;height:26px;border-radius:50%;object-fit:cover;border:1.5px solid var(--primary);}

@media(max-width:767px){
  #bottomNav{display:block;}
  .topbar-nav .nav-link:not(:first-child){display:none;}
  #main{padding-bottom:84px;}
}

/* ══════════════════════════════════════════════════════
   MAIN AREA
   ══════════════════════════════════════════════════════ */
#main{
  max-width:1200px;margin:0 auto;
  padding:calc(var(--tb)+20px) 20px 56px;
  min-height:100vh;min-height:100dvh;
}
@media(max-width:480px){#main{padding:calc(var(--tb)+14px) 12px 84px;}}

/* ══════════════════════════════════════════════════════
   FLASH MESSAGES
   ══════════════════════════════════════════════════════ */
#flash{
  position:fixed;top:calc(var(--tb)+12px);left:50%;transform:translateX(-50%);z-index:9999;
  background:var(--bg3);border:1px solid var(--border);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:10px 24px;border-radius:99px;font-weight:700;font-size:.88rem;
  box-shadow:var(--shadow);white-space:nowrap;pointer-events:none;
  animation:flashIn .4s var(--easing-bounce) both;
}
#flash.ok {border-color:var(--ok);  color:var(--ok);box-shadow:0 4px 20px rgba(34,197,94,.15);}
#flash.err{border-color:var(--danger);color:var(--danger);box-shadow:0 4px 20px rgba(239,68,68,.15);}
@keyframes flashIn{
  from{opacity:0;transform:translateX(-50%) translateY(-16px) scale(.94);}
  to{opacity:1;transform:translateX(-50%) translateY(0) scale(1);}
}

/* ══════════════════════════════════════════════════════
   SPINNER — Pulsating ring
   ══════════════════════════════════════════════════════ */
.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 20px;gap:16px;}
.spinner{
  width:40px;height:40px;
  border:3px solid var(--primary-dim);border-top-color:var(--primary);
  border-radius:50%;animation:spin .7s linear infinite;
  box-shadow:0 0 16px var(--primary-glow);
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ══════════════════════════════════════════════════════
   BUTTONS — Glow + ripple + micro-bounce
   ══════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 20px;border-radius:var(--radius-sm);font-weight:700;font-size:.88rem;
  cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--text);
  transition:all var(--dur) var(--easing);white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(255,255,255,.08) 0%,transparent 60%);
  opacity:0;transition:opacity var(--dur);pointer-events:none;
}
.btn:hover{background:var(--card-h);border-color:var(--border-h);transform:translateY(-1px);}
.btn:hover::after{opacity:1;}
.btn:active{transform:translateY(0) scale(.97);}
.btn.primary{
  background:var(--primary);border-color:var(--primary);color:#fff;
  box-shadow:0 0 24px var(--primary-glow),0 4px 12px rgba(0,0,0,.2);
}
.btn.primary:hover{filter:brightness(1.12);box-shadow:0 0 32px var(--primary-glow),0 6px 16px rgba(0,0,0,.25);}
.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff;box-shadow:0 0 20px rgba(239,68,68,.2);}
.btn.warn{background:var(--warn);border-color:var(--warn);color:#fff;}
.btn.small{padding:6px 14px;font-size:.8rem;}
.btn.tiny{padding:4px 10px;font-size:.74rem;}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none !important;}
.btn.w100{width:100%;}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;padding:4px;transition:all var(--dur) var(--easing);}
.icon-btn:hover{color:var(--danger);transform:scale(1.1);}
.link-btn{background:none;border:none;cursor:pointer;color:var(--primary);font-size:.82rem;padding:0;transition:all var(--dur);}
.link-btn:hover{opacity:.75;}
.back-btn{margin-bottom:18px;}

/* ══════════════════════════════════════════════════════
   PORTAL — Cinematic entrance with aurora effect
   ══════════════════════════════════════════════════════ */
.portal-wrap{
  min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  margin:calc(var(--tb)*-1) -20px 0;padding:20px 16px;
}
.portal-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.portal-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.25;will-change:transform;}
.orb1{
  width:700px;height:700px;
  background:var(--primary);
  top:-250px;right:-200px;
  animation:orbFloat1 10s ease-in-out infinite;
}
.orb2{
  width:550px;height:550px;
  background:#6366f1;
  bottom:-200px;left:-150px;
  animation:orbFloat2 12s ease-in-out infinite;
}
.orb3{
  width:400px;height:400px;
  background:var(--ok);
  top:40%;left:50%;transform:translate(-50%,-50%);
  animation:orbFloat3 14s ease-in-out infinite;
}
@keyframes orbFloat1{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(-30px,-20px) scale(1.05);}
  66%{transform:translate(20px,15px) scale(.95);}
}
@keyframes orbFloat2{
  0%,100%{transform:translate(0,0) rotate(0deg);}
  50%{transform:translate(25px,-30px) rotate(10deg);}
}
@keyframes orbFloat3{
  0%,100%{transform:translate(-50%,-50%) scale(1);}
  50%{transform:translate(-50%,-50%) scale(1.15);}
}

.portal-card{
  position:relative;width:min(460px,100%);padding:48px 40px;
  background:rgba(10,10,20,.78);border:1px solid var(--border);
  border-radius:28px;backdrop-filter:blur(40px) saturate(1.5);
  -webkit-backdrop-filter:blur(40px) saturate(1.5);
  box-shadow:var(--shadow-lg),0 0 80px rgba(29,155,240,.06);
  text-align:center;
  animation:cardReveal .6s var(--easing) both;
}
[data-mode="light"] .portal-card{background:rgba(255,255,255,.85);}
@keyframes cardReveal{
  from{opacity:0;transform:translateY(40px) scale(.96);filter:blur(4px);}
  to{opacity:1;transform:none;filter:blur(0);}
}

.portal-logo{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px;}
.portal-icon{
  width:62px;height:62px;border-radius:20px;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  display:flex;align-items:center;justify-content:center;font-size:2rem;
  box-shadow:0 0 36px var(--primary-glow);
  animation:iconPulse 3s ease-in-out infinite;
}
@keyframes iconPulse{
  0%,100%{box-shadow:0 0 36px var(--primary-glow);}
  50%{box-shadow:0 0 52px var(--primary-glow),0 0 80px rgba(29,155,240,.1);}
}
.portal-wordmark{font-size:2.4rem;font-weight:900;letter-spacing:-1.5px;}
.portal-title{font-size:1.8rem;font-weight:900;margin-bottom:10px;animation:textSlide .6s .15s var(--easing) both;}
.portal-sub{color:var(--text2);line-height:1.7;margin-bottom:32px;font-size:.95rem;animation:textSlide .6s .25s var(--easing) both;}
@keyframes textSlide{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}

.portal-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:32px;}
.pf-row{display:contents;}
.pf-item{
  display:flex;align-items:center;gap:10px;padding:13px 14px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:.85rem;font-weight:600;
  transition:all var(--dur) var(--easing);
  animation:featureIn .5s var(--easing) both;
}
.pf-item:nth-child(1){animation-delay:.3s;}
.pf-item:nth-child(2){animation-delay:.38s;}
.pf-item:nth-child(3){animation-delay:.46s;}
.pf-item:nth-child(4){animation-delay:.54s;}
@keyframes featureIn{from{opacity:0;transform:scale(.92);}to{opacity:1;transform:none;}}
.pf-item:hover{background:var(--card-h);border-color:var(--primary-glow);transform:translateY(-2px);}
.pf-icon{font-size:1.2rem;flex-shrink:0;}

.portal-signin-btn{
  width:100%;padding:15px 24px;font-size:1rem;margin-bottom:16px;
  background:var(--card-h);border:1px solid var(--border-h);
  border-radius:var(--radius-sm);
  transition:all var(--dur) var(--easing);
  animation:textSlide .6s .6s var(--easing) both;
}
.portal-signin-btn:hover{
  background:var(--primary);border-color:var(--primary);color:#fff;
  box-shadow:0 0 32px var(--primary-glow);transform:translateY(-2px);
}
.portal-terms-txt{font-size:.76rem;color:var(--muted);animation:textSlide .6s .7s var(--easing) both;}
.portal-terms-link{color:var(--primary);}
@media(max-width:420px){
  .portal-card{padding:36px 24px;}
  .portal-features{grid-template-columns:1fr;}
}

/* ══════════════════════════════════════════════════════
   HERO — Cinematic glow with stagger animations
   ══════════════════════════════════════════════════════ */
.hero{
  position:relative;padding:56px 0 48px;text-align:center;overflow:hidden;
  border-radius:var(--radius);margin-bottom:8px;
}
.hero-bg-glow{
  position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  width:min(900px,120vw);height:500px;
  background:radial-gradient(ellipse at center,var(--primary-glow) 0%,rgba(29,155,240,.06) 40%,transparent 70%);
  pointer-events:none;animation:glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse{
  0%,100%{opacity:.7;transform:translateX(-50%) scale(1);}
  50%{opacity:1;transform:translateX(-50%) scale(1.06);}
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 18px;border-radius:99px;
  background:var(--primary-dim);border:1px solid rgba(29,155,240,.2);
  color:var(--primary);font-size:.8rem;font-weight:800;
  margin-bottom:22px;
  animation:badgeIn .5s var(--easing-bounce) both;
}
@keyframes badgeIn{from{opacity:0;transform:translateY(16px) scale(.9);}to{opacity:1;transform:none;}}

.hero-title{
  font-size:clamp(1.8rem,5vw,3rem);font-weight:900;line-height:1.15;
  margin-bottom:14px;
  background:linear-gradient(180deg,var(--text) 0%,var(--text2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:heroTitleIn .6s .1s var(--easing) both;
}
@keyframes heroTitleIn{from{opacity:0;transform:translateY(24px);filter:blur(6px);}to{opacity:1;transform:none;filter:blur(0);}}

.hero-sub{color:var(--text2);font-size:1.05rem;margin-bottom:32px;animation:heroSubIn .6s .2s var(--easing) both;}
@keyframes heroSubIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

.hero-stats{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;
  animation:statsIn .6s .35s var(--easing) both;
}
@keyframes statsIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.hstat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 28px;}
.hstat-num{
  font-size:1.7rem;font-weight:900;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hstat-lbl{font-size:.75rem;color:var(--muted);font-weight:600;}
.hstat-div{width:1px;height:36px;background:var(--border);}
@media(max-width:480px){
  .hero{padding:36px 0 28px;}
  .hstat{padding:0 16px;}
  .hstat-num{font-size:1.3rem;}
}

/* ══════════════════════════════════════════════════════
   FILTERS — Polished search with animated focus
   ══════════════════════════════════════════════════════ */
.home-section{padding:16px 0 48px;}
.filters-bar{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;}
.search-wrap{position:relative;}
.search-icon{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  pointer-events:none;font-size:1.05rem;color:var(--muted);
  transition:color var(--dur);
}
.search-input{
  width:100%;padding:12px 44px 12px 16px;
  background:var(--bg3);border:1px solid var(--border);color:var(--text);
  border-radius:var(--radius-sm);font-size:.92rem;font-weight:500;
  transition:all var(--dur) var(--easing);
}
.search-input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-dim),0 4px 16px rgba(0,0,0,.15);
}
.search-input:focus~.search-icon{color:var(--primary);}

.filter-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.sort-tabs{display:flex;gap:5px;flex-wrap:wrap;}
.sort-tab{
  padding:8px 16px;border-radius:99px;border:1px solid var(--border);
  background:var(--card);color:var(--muted);font-size:.82rem;font-weight:700;cursor:pointer;
  transition:all var(--dur) var(--easing);
}
.sort-tab:hover{color:var(--text);border-color:var(--border-h);}
.sort-tab.active{
  color:#fff;border-color:var(--primary);
  background:var(--primary);
  box-shadow:0 0 16px var(--primary-glow);
}
.filter-selects{display:flex;gap:8px;flex-wrap:wrap;}
.filter-select{
  padding:8px 14px;border-radius:99px;border:1px solid var(--border);
  background:var(--bg3);color:var(--text);font-size:.82rem;cursor:pointer;
  transition:all var(--dur) var(--easing);
}
.filter-select:hover,.filter-select:focus{border-color:var(--primary);}
.filter-select option{background:var(--bg2);}

/* ══════════════════════════════════════════════════════
   ROM GRID — Animated card entrance with hover effects
   ══════════════════════════════════════════════════════ */
.roms-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px;
}
.roms-grid.mini{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));}
@media(max-width:600px){.roms-grid{grid-template-columns:repeat(2,1fr);gap:12px;}}
@media(max-width:360px){.roms-grid{grid-template-columns:1fr;}}

.rom-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;cursor:pointer;
  transition:all .35s var(--easing);
  animation:cardIn .5s var(--easing) both;
  position:relative;
}
.rom-card::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  border-radius:var(--radius);
  background:radial-gradient(circle 200px at var(--mx,50%) var(--my,50%),rgba(29,155,240,.06),transparent);
  opacity:0;transition:opacity .35s;
}
.rom-card:hover::before{opacity:1;}
.rom-card:hover{
  transform:translateY(-6px);
  border-color:rgba(29,155,240,.25);
  box-shadow:0 12px 40px rgba(0,0,0,.25),0 0 32px var(--primary-glow);
}
@keyframes cardIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}

.rom-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg2);}
.rom-thumb img{width:100%;height:100%;transition:transform .5s var(--easing);}
.rom-card:hover .rom-thumb img{transform:scale(1.08);}
.rom-thumb::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:50%;
  background:linear-gradient(transparent,rgba(5,5,9,.6));
  pointer-events:none;
}
.rom-badges{position:absolute;top:8px;right:8px;display:flex;gap:4px;flex-wrap:wrap;z-index:2;}
.badge{
  padding:3px 9px;border-radius:99px;font-size:.65rem;font-weight:800;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);
}
.badge.hot{background:rgba(239,68,68,.85);color:#fff;}
.badge.newb{background:rgba(29,155,240,.85);color:#fff;}
.badge.android{background:rgba(34,197,94,.85);color:#fff;}
.badge.feat{background:rgba(245,158,11,.85);color:#fff;}
.fav-btn{
  position:absolute;top:8px;left:8px;width:30px;height:30px;border-radius:50%;z-index:2;
  background:rgba(5,5,9,.6);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
  cursor:pointer;font-size:1rem;color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur) var(--easing-bounce);
}
.fav-btn.active{color:var(--danger);background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);}
.fav-btn:hover{transform:scale(1.2);}
.fav-btn.active:hover{animation:heartBeat .4s var(--easing-bounce);}
@keyframes heartBeat{
  0%{transform:scale(1.2);}
  30%{transform:scale(1.4);}
  100%{transform:scale(1.2);}
}

.rom-info{padding:14px 14px 16px;}
.rom-name{font-weight:800;font-size:.92rem;margin-bottom:5px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.rom-device{font-size:.78rem;color:var(--text2);margin-bottom:3px;}
.rom-dev{font-size:.75rem;color:var(--muted);margin-bottom:8px;}
.rom-stats{display:flex;gap:10px;font-size:.74rem;color:var(--muted);font-weight:600;}
.empty-state{text-align:center;padding:72px 20px;color:var(--muted);grid-column:1/-1;}
.empty-state.small{padding:28px;}
.empty-state h3{color:var(--text);margin-bottom:10px;}

/* ══════════════════════════════════════════════════════
   DETAIL PAGE — Immersive layout
   ══════════════════════════════════════════════════════ */
.detail-wrap{max-width:880px;margin:0 auto;animation:pageIn .5s var(--easing) both;}
@keyframes pageIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

.detail-hero{display:grid;grid-template-columns:1fr 1.5fr;gap:28px;margin-bottom:32px;align-items:start;}
@media(max-width:640px){.detail-hero{grid-template-columns:1fr;gap:20px;}}
.detail-thumb{
  border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;background:var(--bg2);
  box-shadow:var(--shadow);
  transition:transform var(--dur) var(--easing);
}
.detail-thumb:hover{transform:scale(1.02);}
.detail-thumb img{width:100%;height:100%;}
.detail-badges{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px;}
.detail-title{
  font-size:1.4rem;font-weight:900;margin-bottom:12px;line-height:1.3;
  animation:textSlide .5s .1s var(--easing) both;
}
.detail-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.82rem;color:var(--text2);margin-bottom:14px;}
.detail-dev{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  margin-bottom:14px;cursor:pointer;
  transition:all var(--dur) var(--easing);
}
.detail-dev:hover{border-color:var(--primary);background:var(--primary-dim);transform:translateX(4px);}
.dev-av{width:40px;height:40px;border-radius:50%;object-fit:cover;}
.dev-name{font-weight:800;font-size:.9rem;}
.dev-role{font-size:.74rem;color:var(--muted);}
.detail-counts{display:flex;gap:16px;font-size:.84rem;color:var(--text2);margin-bottom:16px;flex-wrap:wrap;}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap;}

.detail-section{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;margin-bottom:22px;
  animation:sectionIn .5s var(--easing) both;
}
.detail-section:nth-child(2){animation-delay:.1s;}
.detail-section:nth-child(3){animation-delay:.2s;}
.detail-section:nth-child(4){animation-delay:.3s;}
@keyframes sectionIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.detail-section h3{font-size:1rem;margin-bottom:14px;color:var(--text);font-weight:800;}
.desc-body{color:var(--text2);line-height:1.85;font-size:.9rem;white-space:pre-wrap;word-break:break-word;}
.desc-body.changelog{
  font-family:"Cairo",monospace;font-size:.84rem;
  background:var(--bg2);padding:16px;border-radius:var(--radius-xs);
  border:1px solid var(--border);
}
.ss-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;}
.ss-thumb{
  flex-shrink:0;width:200px;height:120px;border-radius:var(--radius-xs);
  cursor:pointer;transition:all var(--dur) var(--easing);
  scroll-snap-align:start;border:2px solid transparent;
}
.ss-thumb:hover{transform:scale(1.04);border-color:var(--primary);box-shadow:0 4px 16px var(--primary-glow);}

/* ══════════════════════════════════════════════════════
   COMMENTS — Refined conversation layout
   ══════════════════════════════════════════════════════ */
.comment-form{display:flex;gap:12px;margin-top:16px;align-items:flex-start;}
.comment-input-wrap{flex:1;display:flex;flex-direction:column;gap:8px;}
.comment-input-wrap textarea{
  width:100%;padding:12px 14px;background:var(--bg2);border:1px solid var(--border);
  color:var(--text);border-radius:var(--radius-sm);resize:vertical;min-height:72px;
  transition:all var(--dur) var(--easing);
}
.comment-input-wrap textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);}
.comment-input-wrap .btn{align-self:flex-end;}
.comment-av,.reply-av{border-radius:50%;object-fit:cover;flex-shrink:0;}
.comment-av{width:38px;height:38px;}
.reply-av{width:30px;height:30px;}
.comment-item{display:flex;gap:12px;margin-bottom:20px;animation:commentIn .4s var(--easing) both;}
@keyframes commentIn{from{opacity:0;transform:translateX(8px);}to{opacity:1;transform:none;}}
.comment-body{flex:1;min-width:0;}
.comment-hdr{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.82rem;flex-wrap:wrap;}
.comment-hdr strong{font-size:.88rem;}
.comment-text{line-height:1.7;font-size:.88rem;word-break:break-word;color:var(--text2);}
.comment-foot{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap;}
.replies-area{margin-top:12px;display:none;}
.replies-area.open{display:block;}
.reply-item{
  display:flex;gap:10px;margin-bottom:14px;padding-right:16px;
  border-right:2px solid var(--primary-dim);
}
.reply-body{flex:1;min-width:0;}
.inline-form{display:flex;gap:8px;align-items:center;}
.reply-input{
  padding:7px 12px;font-size:.82rem;background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius-xs);color:var(--text);width:180px;
  transition:all var(--dur) var(--easing);
}
.reply-input:focus{border-color:var(--primary);width:260px;box-shadow:0 0 0 3px var(--primary-dim);}
.login-comment-cta{
  padding:20px;background:var(--card);border:1px dashed var(--border);
  border-radius:var(--radius-sm);text-align:center;color:var(--muted);font-size:.88rem;
}
.login-comment-cta .btn{margin-top:10px;}

/* ══════════════════════════════════════════════════════
   UPLOAD PAGE — Clean two-column form
   ══════════════════════════════════════════════════════ */
.upload-wrap{max-width:920px;margin:0 auto;animation:pageIn .5s var(--easing) both;}
.page-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px;}
.page-hdr h2{font-size:1.45rem;font-weight:900;}
.upload-grid{display:grid;grid-template-columns:280px 1fr;gap:24px;}
@media(max-width:700px){.upload-grid{grid-template-columns:1fr;}}

.upload-media{display:flex;flex-direction:column;gap:14px;}
.thumb-drop{
  position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;
  border:2px dashed var(--border);cursor:pointer;background:var(--bg2);
  transition:all var(--dur) var(--easing);
}
.thumb-drop:hover,.thumb-drop.drag-over{border-color:var(--primary);box-shadow:0 0 20px var(--primary-glow);}
.thumb-drop img{width:100%;height:100%;}
.thumb-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.88rem;color:#fff;
  opacity:0;transition:opacity var(--dur);backdrop-filter:blur(2px);
}
.thumb-drop:hover .thumb-overlay{opacity:1;}
.ss-drop-area{
  border:2px dashed var(--border);border-radius:var(--radius);padding:16px;
  cursor:pointer;transition:all var(--dur) var(--easing);min-height:76px;
}
.ss-drop-area:hover,.ss-drop-area.drag-over{border-color:var(--primary);box-shadow:0 0 20px var(--primary-glow);}
.ss-placeholder{color:var(--muted);font-size:.82rem;text-align:center;padding:10px 0;}
.ss-preview-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.ss-item{position:relative;}
.ss-item img{width:72px;height:46px;border-radius:var(--radius-xs);}
.ss-del{
  position:absolute;top:-6px;right:-6px;width:18px;height:18px;
  background:var(--danger);border:none;border-radius:50%;cursor:pointer;
  color:#fff;font-size:.6rem;display:flex;align-items:center;justify-content:center;
  transition:transform var(--dur) var(--easing-bounce);
}
.ss-del:hover{transform:scale(1.15);}
.upload-form{display:flex;flex-direction:column;gap:16px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:.82rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;}
.field input,.field select,.field textarea{
  width:100%;padding:11px 14px;background:var(--bg3);border:1px solid var(--border);
  color:var(--text);border-radius:var(--radius-sm);font-size:.9rem;
  transition:all var(--dur) var(--easing);
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);
}
.field textarea{resize:vertical;min-height:96px;}
.field select option{background:var(--bg2);}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:480px){.field-row{grid-template-columns:1fr;}}
.upload-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:6px;flex-wrap:wrap;}
.upload-progress{margin-top:8px;}
.progress-bar{height:5px;background:var(--bg2);border-radius:99px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#38bdf8);transition:width .3s;border-radius:99px;}
.upload-status{font-size:.78rem;color:var(--muted);margin-top:5px;}

/* ══════════════════════════════════════════════════════
   PROFILE PAGE — Immersive hero with glassmorphism
   ══════════════════════════════════════════════════════ */
.profile-wrap{max-width:840px;margin:0 auto;animation:pageIn .5s var(--easing) both;}
.profile-cover{
  height:180px;border-radius:var(--radius);overflow:hidden;margin-bottom:-54px;
  position:relative;
  background:linear-gradient(135deg,var(--bg2) 0%,var(--bg3) 50%,var(--bg2) 100%);
}
.profile-cover::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--primary-dim) 0%,transparent 50%,rgba(99,102,241,.1) 100%);
}
.profile-cover-glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 50%,var(--primary-glow),transparent 70%);
  animation:coverGlow 5s ease-in-out infinite alternate;
}
@keyframes coverGlow{
  from{opacity:.5;}to{opacity:.9;}
}
.profile-card{
  display:flex;gap:22px;align-items:flex-start;padding:0 18px 28px;margin-bottom:18px;
  flex-wrap:wrap;
}
.profile-av-wrap{position:relative;flex-shrink:0;}
.profile-av{
  width:100px;height:100px;border-radius:50%;border:4px solid var(--bg);
  box-shadow:0 0 0 2px var(--primary),0 0 24px var(--primary-glow);
  object-fit:cover;
  transition:all var(--dur) var(--easing);
}
.profile-av:hover{box-shadow:0 0 0 2px var(--primary),0 0 36px var(--primary-glow);transform:scale(1.04);}
.av-edit-btn{
  position:absolute;bottom:4px;right:4px;width:28px;height:28px;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  border:2px solid var(--bg);border-radius:50%;cursor:pointer;
  font-size:.78rem;display:flex;align-items:center;justify-content:center;color:#fff;
  transition:transform var(--dur) var(--easing-bounce);
}
.av-edit-btn:hover{transform:scale(1.15);}
.profile-info{flex:1;min-width:200px;padding-top:18px;}
.profile-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px;}
.profile-name{
  font-size:1.35rem;font-weight:900;
  border-bottom:1px dashed transparent;transition:all var(--dur);
}
.profile-name[contenteditable="true"]:focus,.profile-bio[contenteditable="true"]:focus{
  border-bottom-color:var(--primary);outline:none;
}
.profile-bio{color:var(--text2);font-size:.9rem;line-height:1.7;margin-bottom:12px;
  border-bottom:1px dashed transparent;transition:border-color var(--dur);}
.profile-meta{display:flex;gap:14px;font-size:.78rem;color:var(--muted);flex-wrap:wrap;}

.profile-stats-row{
  display:flex;gap:0;
  border:1px solid var(--border);border-radius:var(--radius);
  padding:0;margin-bottom:20px;overflow:hidden;
  background:var(--card);
}
.pstat{
  flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:16px 12px;border-right:1px solid var(--border);
  transition:background var(--dur);
}
.pstat:last-child{border-right:none;}
.pstat:hover{background:var(--card-h);}
.pstat-n{
  font-size:1.35rem;font-weight:900;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.pstat-l{font-size:.72rem;color:var(--muted);text-align:center;font-weight:600;}
.profile-actions{display:flex;gap:10px;flex-wrap:wrap;padding:0 18px;margin-bottom:24px;}
.profile-roms h3{margin-bottom:16px;font-weight:800;}

/* ── Role Badges ────────────────────────────────────── */
.role-badge{
  display:inline-flex;align-items:center;padding:3px 12px;
  border-radius:99px;font-size:.72rem;font-weight:800;
}
.role-owner    {background:rgba(245,158,11,.12);color:#f59e0b;border:1px solid rgba(245,158,11,.3);}
.role-admin    {background:rgba(99,102,241,.12);color:#818cf8;border:1px solid rgba(99,102,241,.3);}
.role-moderator{background:rgba(6,182,212,.12); color:#06b6d4;border:1px solid rgba(6,182,212,.3);}
.role-verifiedDev{background:rgba(34,197,94,.12);color:#22c55e;border:1px solid rgba(34,197,94,.3);}
.role-user     {background:var(--card);color:var(--muted);border:1px solid var(--border);}

/* ══════════════════════════════════════════════════════
   ADMIN PANEL — Dashboard aesthetic
   ══════════════════════════════════════════════════════ */
.admin-wrap{max-width:1020px;margin:0 auto;animation:pageIn .5s var(--easing) both;}
.admin-header{
  display:flex;align-items:center;gap:22px;padding:28px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:24px;
  position:relative;overflow:hidden;
}
.admin-header::before{
  content:"";position:absolute;top:-50%;right:-20%;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,var(--primary-glow),transparent 70%);
  opacity:.3;pointer-events:none;
}
.admin-logo{font-size:3rem;position:relative;z-index:1;}
.admin-header h1{font-size:1.45rem;font-weight:900;position:relative;z-index:1;}
.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;}
.admin-tab{
  padding:10px 22px;border-radius:99px;border:1px solid var(--border);
  background:var(--card);color:var(--muted);cursor:pointer;font-weight:700;font-size:.86rem;
  transition:all var(--dur) var(--easing);
}
.admin-tab:hover{color:var(--text);border-color:var(--border-h);}
.admin-tab.active{
  color:#fff;border-color:var(--primary);
  background:var(--primary);
  box-shadow:0 0 16px var(--primary-glow);
}

.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:28px;}
.stat-card{
  padding:22px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  text-align:center;
  transition:all var(--dur) var(--easing);
  position:relative;overflow:hidden;
}
.stat-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,var(--primary-dim),transparent 70%);
  opacity:0;transition:opacity var(--dur);
}
.stat-card:hover{border-color:var(--primary-glow);transform:translateY(-3px);}
.stat-card:hover::before{opacity:1;}
.stat-icon{font-size:1.8rem;margin-bottom:8px;position:relative;}
.stat-val{
  font-size:1.7rem;font-weight:900;position:relative;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-lbl{font-size:.74rem;color:var(--muted);margin-top:4px;font-weight:600;position:relative;}
.section-title{font-size:1.05rem;font-weight:800;margin-bottom:14px;}

.admin-rom-list{display:flex;flex-direction:column;gap:10px;}
.admin-rom-row{
  display:flex;align-items:center;gap:14px;padding:12px 14px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.86rem;
  transition:all var(--dur) var(--easing);
}
.admin-rom-row:hover{border-color:var(--primary-glow);background:var(--card-h);}
.admin-thumb{width:58px;height:36px;border-radius:var(--radius-xs);object-fit:cover;flex-shrink:0;}
.admin-rom-info{flex:1;display:flex;flex-direction:column;gap:2px;}
.admin-rom-stats{font-size:.78rem;color:var(--muted);white-space:nowrap;}

.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);}
.admin-table{width:100%;border-collapse:collapse;font-size:.84rem;min-width:580px;}
.admin-table th{
  padding:12px 14px;background:var(--bg2);text-align:right;
  font-weight:700;color:var(--muted);font-size:.76rem;
  text-transform:uppercase;letter-spacing:.4px;
}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.admin-table tr{transition:background var(--dur);}
.admin-table tr:hover td{background:var(--card-h);}
.banned-row td{opacity:.45;}
.user-cell{display:flex;align-items:center;gap:10px;}
.uav-sm{width:34px;height:34px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.text-sm{font-size:.74rem;}
.actions-cell{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.role-select{
  padding:5px 10px;font-size:.78rem;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);
  transition:border-color var(--dur);
}
.role-select:focus{border-color:var(--primary);}

.report-row{
  padding:18px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);margin-bottom:12px;
  transition:all var(--dur) var(--easing);
}
.report-row:hover{border-color:var(--primary-glow);}
.report-row.resolved{opacity:.5;}
.report-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px;font-size:.82rem;}
.report-desc{font-size:.88rem;color:var(--text2);margin-bottom:10px;line-height:1.6;}
.report-ss{max-height:120px;border-radius:var(--radius-xs);margin-bottom:10px;}
.report-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ══════════════════════════════════════════════════════
   SETTINGS MODAL — Smooth glass overlay
   ══════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:500;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  animation:overlayIn .25s var(--easing) both;
}
@keyframes overlayIn{from{opacity:0;}to{opacity:1;}}
.modal-box{
  width:min(480px,100%);background:var(--bg2);border:1px solid var(--border);
  border-radius:24px;padding:28px;box-shadow:var(--shadow-lg);
  animation:modalIn .35s var(--easing-bounce) both;
}
@keyframes modalIn{from{opacity:0;transform:translateY(24px) scale(.96);}to{opacity:1;transform:none;}}
.settings-box{max-height:90vh;overflow-y:auto;}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:1.1rem;font-weight:900;}
.modal-x{
  background:var(--card);border:1px solid var(--border);cursor:pointer;
  font-size:1.1rem;color:var(--muted);transition:all var(--dur) var(--easing);
  width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
}
.modal-x:hover{color:var(--text);background:var(--card-h);transform:rotate(90deg);}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;}
.settings-sec{margin-bottom:22px;}
.settings-lbl{
  font-size:.76rem;font-weight:800;color:var(--muted);margin-bottom:10px;
  text-transform:uppercase;letter-spacing:.5px;
}
.mode-row{display:flex;gap:10px;}
.mode-btn{
  flex:1;padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--card);color:var(--muted);cursor:pointer;font-weight:700;
  transition:all var(--dur) var(--easing);
}
.mode-btn:hover{background:var(--card-h);}
.mode-btn.active{color:var(--primary);border-color:var(--primary);background:var(--primary-dim);}
.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
@media(max-width:400px){.theme-grid{grid-template-columns:repeat(3,1fr);}}
.swatch-btn{
  display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px;
  border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--card);cursor:pointer;font-size:.72rem;
  transition:all var(--dur) var(--easing);
}
.swatch-btn:hover{background:var(--card-h);transform:translateY(-2px);}
.swatch-btn.active{border-color:var(--primary);background:var(--primary-dim);box-shadow:0 0 12px var(--primary-glow);}
.swatch-dot{
  width:26px;height:26px;border-radius:50%;
  box-shadow:0 0 8px currentColor;
  transition:transform var(--dur) var(--easing-bounce);
}
.swatch-btn:hover .swatch-dot{transform:scale(1.15);}
.lang-grid{display:flex;flex-wrap:wrap;gap:8px;}
.lang-opt{
  display:flex;align-items:center;gap:7px;padding:8px 14px;
  border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--card);cursor:pointer;font-size:.82rem;
  transition:all var(--dur) var(--easing);
}
.lang-opt:hover{background:var(--card-h);transform:translateY(-1px);}
.lang-opt.active{color:var(--primary);border-color:var(--primary);background:var(--primary-dim);}

/* ══════════════════════════════════════════════════════
   NOTIFICATIONS — Glass dropdown with smooth reveal
   ══════════════════════════════════════════════════════ */
.notif-wrap{position:relative;}
.notif-bell-btn{
  position:relative;background:var(--card);border:1px solid var(--border);
  cursor:pointer;font-size:1.1rem;padding:6px;border-radius:var(--radius-xs);
  color:var(--text2);transition:all var(--dur) var(--easing);
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
}
.notif-bell-btn:hover{background:var(--card-h);transform:scale(1.05);}
.notif-badge{
  position:absolute;top:-5px;left:-5px;
  background:var(--danger);color:#fff;
  font-size:.6rem;font-weight:800;border-radius:99px;padding:1px 5px;
  min-width:17px;text-align:center;display:none;
  animation:badgePop .35s var(--easing-bounce);
  box-shadow:0 0 8px rgba(239,68,68,.3);
}
@keyframes badgePop{from{transform:scale(0);}to{transform:scale(1);}}
.notif-badge.show{display:block;}
.notif-panel{
  position:absolute;top:calc(100% + 10px);left:-200px;width:320px;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);display:none;flex-direction:column;z-index:300;
  animation:panelIn .3s var(--easing) both;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
@keyframes panelIn{from{opacity:0;transform:translateY(-8px) scale(.97);}to{opacity:1;transform:none;}}
.notif-panel.open{display:flex;}
.notif-hdr{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;border-bottom:1px solid var(--border);
  font-weight:800;font-size:.88rem;
}
.notif-list{max-height:360px;overflow-y:auto;}
.notif-item{
  display:flex;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);
  cursor:pointer;transition:all var(--dur) var(--easing);
  text-decoration:none;color:var(--text);
}
.notif-item:hover{background:var(--card-h);}
.notif-item.unread{background:var(--primary-dim);border-right:3px solid var(--primary);}
.notif-av{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.notif-txt{display:flex;flex-direction:column;gap:3px;font-size:.8rem;flex:1;}
.notif-txt strong{font-size:.85rem;}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;align-self:center;box-shadow:0 0 6px var(--primary);}
.notif-empty{padding:28px;text-align:center;color:var(--muted);font-size:.88rem;}

/* ══════════════════════════════════════════════════════
   GLOBAL ANIMATIONS & UTILITIES
   ══════════════════════════════════════════════════════ */
.muted{color:var(--muted);}

/* Light mode overrides */
[data-mode="light"] .search-input,
[data-mode="light"] .field input,
[data-mode="light"] .field select,
[data-mode="light"] .field textarea{background:#fff;border-color:rgba(0,0,0,.1);}
[data-mode="light"] .reply-input,
[data-mode="light"] .comment-input-wrap textarea{background:#f8f8fc;}
[data-mode="light"] .portal-card{background:rgba(255,255,255,.88);}
[data-mode="light"] .stat-card{background:rgba(255,255,255,.5);}
[data-mode="light"] .profile-stats-row{background:rgba(255,255,255,.4);}

/* ── Responsive fine-tuning ────────────────────────── */
@media(max-width:767px){
  .hero-stats{gap:0;}
  .hstat{padding:0 14px;}
  .detail-hero{gap:18px;}
  .profile-stats-row{flex-wrap:wrap;}
  .pstat{min-width:33.33%;border-bottom:1px solid var(--border);}
  .stat-cards{grid-template-columns:repeat(2,1fr);}
  .admin-tabs{gap:5px;}
  .admin-tab{padding:8px 14px;font-size:.82rem;}
  .modal-box{padding:22px;}
}
@media(max-width:480px){
  .filters-bar .filter-row{flex-direction:column;gap:8px;}
  .sort-tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;}
  .sort-tab{flex-shrink:0;}
  .filter-selects{width:100%;}
  .filter-select{flex:1;min-width:0;}
  .detail-actions{flex-direction:column;}
  .detail-actions .btn{width:100%;justify-content:center;}
  .profile-card{flex-direction:column;align-items:center;text-align:center;}
  .profile-info{padding-top:8px;width:100%;}
  .profile-name-row{justify-content:center;}
  .profile-meta{justify-content:center;}
  .profile-actions{justify-content:center;}
}

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

/* ── Focus visible ─────────────────────────────────── */
:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
button:focus-visible,.btn:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
  box-shadow:0 0 0 4px var(--primary-dim);
}

/* ── Smooth page transitions ───────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}
@keyframes fadeDown{from{opacity:0;transform:translateX(-50%) translateY(-12px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
