@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
  --accent:#ff6b00;--accent-dim:rgba(255,107,0,.11);--accent-dark:#cc5500;--accent-glow:rgba(255,107,0,.24);--border-accent:rgba(255,107,0,.28);
  --bg:#060608;--bg-2:#0d0d10;--bg-3:#141418;--bg-4:#1a1a1f;--bg-5:#212128;--bg-glass:rgba(255,255,255,.028);
  --border:rgba(255,255,255,.058);--border-2:rgba(255,255,255,.096);
  --text:#f0f0f0;--text-2:#888;--text-3:#444;--text-4:#2a2a30;--text-inv:#060608;
  --green:#22c55e;--green-dim:rgba(34,197,94,.11);--red:#ef4444;--red-dim:rgba(239,68,68,.11);
  --yellow:#eab308;--yellow-dim:rgba(234,179,8,.11);--blue:#3b82f6;--blue-dim:rgba(59,130,246,.11);
  --purple:#a855f7;--purple-dim:rgba(168,85,247,.11);
  --font-display:'Syne',sans-serif;
  --font-body:'Geist',system-ui,sans-serif;
  --font-mono:'Geist Mono',monospace;
  --r-sm:5px;--r:8px;--r-lg:12px;--r-xl:18px;--r-full:9999px;
  --shadow:0 4px 24px rgba(0,0,0,.5);--shadow-lg:0 16px 64px rgba(0,0,0,.7);--shadow-accent:0 4px 24px var(--accent-glow);
  --t:all .16s ease;--t-fast:all .1s ease;
  --nav-h:56px;--side-w:204px;--mob-nav-h:58px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}

/* Grain overlay — adds depth without noise in the pejorative sense */
body::after{
  content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  opacity:.6;
}

body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-5);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ── TOP NAV ── */
.top-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:rgba(6,6,8,.92);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 1rem;gap:.5rem;
}
.top-nav .logo{
  font-family:var(--font-display);font-size:1.35rem;font-weight:800;letter-spacing:.06em;
  flex-shrink:0;transition:opacity .15s;
  background:linear-gradient(90deg,var(--text) 55%,var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.top-nav .logo span{-webkit-text-fill-color:var(--accent)}
.top-nav .logo:hover{opacity:.8}
.site-links{display:flex;gap:.15rem;margin-left:.2rem}
.site-links a{
  font-size:.775rem;font-weight:500;color:var(--text-2);
  padding:.3rem .7rem;border-radius:var(--r-full);transition:var(--t);letter-spacing:.01em;
}
.site-links a:hover{color:var(--text);background:var(--bg-glass)}
.site-links a.active{color:var(--accent);background:var(--accent-dim)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:.4rem}
.nav-icon-btn{
  position:relative;width:32px;height:32px;border-radius:var(--r-full);
  background:var(--bg-glass);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);transition:var(--t);flex-shrink:0;
}
.nav-icon-btn:hover{color:var(--text);background:var(--bg-4);border-color:var(--border-2)}
.nav-icon-btn .dot{
  position:absolute;top:6px;right:6px;width:6px;height:6px;
  background:var(--accent);border-radius:50%;border:1.5px solid var(--bg);
  animation:pulse-dot 2.5s ease infinite;
}
.nav-avatar{
  width:30px;height:30px;border-radius:50%;object-fit:cover;
  border:1.5px solid var(--border);cursor:pointer;transition:var(--t);
  background:var(--bg-4);flex-shrink:0;
}
.nav-avatar:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}

/* ── SIDE NAV ── */
.side-nav{
  position:fixed;left:0;top:var(--nav-h);bottom:0;width:var(--side-w);
  background:var(--bg);border-right:1px solid var(--border);
  padding:.5rem .45rem;overflow-y:auto;z-index:100;
  display:flex;flex-direction:column;gap:1px;
}
.side-nav-item{
  display:flex;align-items:center;gap:.55rem;
  padding:.52rem .72rem;border-radius:var(--r);
  color:var(--text-3);font-size:.815rem;font-weight:500;
  transition:background .12s,color .12s,border-color .12s;
  cursor:pointer;border:1px solid transparent;user-select:none;
  position:relative;
}
.side-nav-item:hover{background:var(--bg-glass);color:var(--text-2)}
.side-nav-item.active{
  background:var(--accent-dim);color:var(--accent);
  border-color:var(--border-accent);
}
.side-nav-item.active::before{
  content:'';position:absolute;left:0;top:22%;bottom:22%;
  width:2px;border-radius:0 2px 2px 0;background:var(--accent);
  margin-left:-1px;
}
.side-nav-item .icon{
  width:15px;height:15px;flex-shrink:0;opacity:.6;
  display:flex;align-items:center;justify-content:center;
}
.side-nav-item.active .icon{opacity:1}
.side-nav-item:hover .icon{opacity:.85}
.side-nav-divider{height:1px;background:var(--border);margin:.3rem .45rem}
.side-nav-label{
  font-size:.6rem;font-weight:700;color:var(--text-4);
  text-transform:uppercase;letter-spacing:.1em;
  padding:.5rem .72rem .18rem;
}
.side-nav-spacer{flex:1}

/* ── MAIN CONTENT ── */
.main-content{margin-left:var(--side-w);padding-top:var(--nav-h);min-height:100vh}
.page-section{padding:1.25rem}

/* ── TAB SECTIONS ── */
.tab-sec{display:none;animation:tab-in .2s ease}
.tab-sec.on{display:block}
@keyframes tab-in{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── BUTTONS ── */
.rz-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.38rem;
  padding:.58rem 1.1rem;border-radius:var(--r);
  font-size:.835rem;font-weight:600;transition:var(--t);
  white-space:nowrap;cursor:pointer;letter-spacing:.01em;
}
.rz-btn-primary{background:var(--accent);color:#000}
.rz-btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:var(--shadow-accent)}
.rz-btn-secondary{background:var(--bg-3);color:var(--text);border:1px solid var(--border)}
.rz-btn-secondary:hover{background:var(--bg-4);border-color:var(--border-accent)}
.rz-btn-ghost{color:var(--text-2)}
.rz-btn-ghost:hover{color:var(--text);background:var(--bg-glass)}
.rz-btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.22)}
.rz-btn-danger:hover{background:var(--red);color:#fff}
.rz-btn-outline{background:transparent;color:var(--accent);border:1px solid var(--border-accent)}
.rz-btn-outline:hover{background:var(--accent-dim)}
.rz-btn-sm{padding:.3rem .7rem;font-size:.76rem}
.rz-btn-lg{padding:.8rem 1.9rem;font-size:.95rem}
.rz-btn-full{width:100%}
.rz-btn:disabled{opacity:.3;pointer-events:none}

/* ── INPUTS ── */
.rz-input{
  width:100%;background:var(--bg-3);border:1px solid var(--border);
  border-radius:var(--r);padding:.64rem .95rem;color:var(--text);
  font-size:.865rem;transition:border-color .14s,background .14s;outline:none;
}
.rz-input:focus{border-color:var(--accent);background:var(--bg-4)}
.rz-input::placeholder{color:var(--text-3)}
select.rz-input{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem;
}

/* ── CARDS ── */
.rz-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:var(--t)}
.rz-card:hover{border-color:var(--border-2)}
.rz-card-interactive:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:var(--shadow)}

/* ── MEDIA CARDS ── */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}
.media-grid-lg{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
.media-grid-xl{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.media-grid-sm{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}
.media-card{
  position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;
  background:var(--bg-3);aspect-ratio:2/3;
  transition:transform .2s ease,box-shadow .2s ease;
}
.media-card:hover{transform:scale(1.04) translateY(-3px);box-shadow:0 18px 44px rgba(0,0,0,.68)}
.media-card img{width:100%;height:100%;object-fit:cover;transition:filter .2s}
.media-card:hover img{filter:brightness(.38)}
.media-card-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:var(--bg-4);color:var(--text-3);
}
.mc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.97) 0%,rgba(0,0,0,.2) 50%,transparent 100%);
  opacity:0;transition:opacity .2s;
  display:flex;flex-direction:column;justify-content:flex-end;padding:.65rem;
}
.media-card:hover .mc-overlay{opacity:1}
.mc-title{font-size:.76rem;font-weight:600;color:var(--text);line-height:1.3}
.mc-sub{font-size:.67rem;color:var(--text-2);margin-top:2px}
.mc-score{
  position:absolute;top:.4rem;right:.4rem;
  background:rgba(0,0,0,.88);border-radius:4px;
  padding:2px 6px;font-size:.68rem;font-weight:700;color:var(--yellow);font-family:var(--font-mono);
}
.mc-rz-score{
  position:absolute;top:.4rem;left:.4rem;
  background:rgba(255,107,0,.88);border-radius:4px;
  padding:2px 5px;font-size:.66rem;font-weight:700;color:#000;font-family:var(--font-mono);
  opacity:0;transition:opacity .2s;
}
.media-card:hover .mc-rz-score{opacity:1}
.mc-vault-btn{
  position:absolute;top:.4rem;left:.4rem;width:26px;height:26px;
  background:rgba(0,0,0,.88);border:1px solid var(--border);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);opacity:0;transition:var(--t);
}
.media-card:hover .mc-vault-btn{opacity:1}
.mc-vault-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}
.mc-vault-btn.saved{opacity:1;color:var(--accent);border-color:var(--accent)}
.mc-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.media-card:hover .mc-play-btn{opacity:1}
.mc-play-icon{
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.7);border:2px solid rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  color:#fff;backdrop-filter:blur(4px);
  transition:transform .14s,border-color .14s;
}
.mc-play-icon:hover{transform:scale(1.1);border-color:#fff}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:1rem;
  animation:fadeIn .14s ease;
}
.modal-box{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xl);
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  box-shadow:var(--shadow-lg);animation:modal-in .2s cubic-bezier(.34,1.2,.64,1);
}
@keyframes modal-in{
  from{opacity:0;transform:scale(.95) translateY(14px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.modal-hd{
  display:flex;align-items:center;padding:.9rem 1.2rem;
  border-bottom:1px solid var(--border);gap:.65rem;
  position:sticky;top:0;background:var(--bg-2);z-index:1;
}
.modal-hd h3{font-size:.94rem;font-weight:600;flex:1;font-family:var(--font-display);letter-spacing:.03em}
.modal-close{
  width:26px;height:26px;border-radius:var(--r-sm);
  background:var(--bg-3);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);transition:var(--t);flex-shrink:0;cursor:pointer;
}
.modal-close:hover{color:var(--text);background:var(--bg-4)}
.modal-body{padding:1.15rem}
.modal-backdrop{min-height:200px;background-size:cover;background-position:center;position:relative}
.modal-backdrop-fade{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-2) 0%,transparent 55%)}
.modal-poster{width:92px;height:138px;object-fit:cover;border-radius:var(--r);flex-shrink:0;border:2px solid var(--border);background:var(--bg-4)}
.modal-poster-raised{margin-top:-3.5rem;position:relative;z-index:1}

/* ── REVIEW WIDGET ── */
.rz-review-stars{display:flex;gap:3px;align-items:center}
.rz-star{
  width:18px;height:18px;cursor:pointer;color:var(--text-4);
  transition:color .1s,transform .12s;
}
.rz-star:hover,.rz-star.on{color:var(--yellow);transform:scale(1.15)}
.rz-review-block{
  background:var(--bg-3);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:.85rem 1rem;margin-top:.65rem;
}
.rz-score-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--accent-dim);border:1px solid var(--border-accent);
  border-radius:var(--r-sm);padding:3px 8px;
  font-family:var(--font-mono);font-size:.72rem;font-weight:500;color:var(--accent);
}

/* ── AUTH ── */
.auth-modal-overlay{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:1rem;
}
.auth-modal{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:2rem;width:100%;max-width:380px;box-shadow:var(--shadow-lg);
  animation:modal-in .2s cubic-bezier(.34,1.2,.64,1);
}
.auth-modal h2{font-family:var(--font-display);font-size:2rem;margin-bottom:.2rem;letter-spacing:.04em}
.auth-modal h2 span{color:var(--accent)}
.auth-tabs{display:flex;gap:.35rem;background:var(--bg-3);border-radius:var(--r);padding:3px;margin-bottom:1.15rem}
.auth-tab{
  flex:1;padding:.44rem;border-radius:var(--r-sm);font-size:.82rem;font-weight:500;
  color:var(--text-2);transition:var(--t);text-align:center;cursor:pointer;
}
.auth-tab.active{background:var(--bg-4);color:var(--text);box-shadow:var(--shadow)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:var(--r-full);font-size:.67rem;font-weight:600}
.badge-admin{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-accent)}
.badge-mod{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(168,85,247,.22)}
.badge-dev{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(59,130,246,.22)}
.badge-verified{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(59,130,246,.22)}
.badge-cinephile{background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.22)}
.badge-critic{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(234,179,8,.22)}
.badge-binge{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(168,85,247,.22)}
.badge-social{background:var(--green-dim);color:var(--green);border:1px solid rgba(34,197,94,.22)}
.badge-new{background:var(--bg-4);color:var(--text-2);border:1px solid var(--border)}

/* ── STATUS ── */
.status-chip{display:inline-block;padding:2px 7px;border-radius:var(--r-full);font-size:.67rem;font-weight:600}
.status-plan{background:var(--bg-4);color:var(--text-2)}
.status-watching,.status-playing,.status-listening{background:var(--blue-dim);color:var(--blue)}
.status-completed{background:var(--green-dim);color:var(--green)}
.status-dropped{background:var(--red-dim);color:var(--red)}

/* ── TAB BAR ── */
.tab-bar{display:flex;gap:.15rem;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;position:relative}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{
  padding:.64rem .9rem;font-size:.825rem;font-weight:500;color:var(--text-2);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .14s,border-color .14s;white-space:nowrap;flex-shrink:0;cursor:pointer;
}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}

/* ── SECTION HEADER ── */
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.sec-hd h2{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.04em}
.sec-hd h2 span{color:var(--accent)}

/* ── MISC ── */
.progress-bar{height:2px;background:var(--bg-4);border-radius:var(--r-full);overflow:hidden}
.progress-bar-fill{height:100%;background:var(--accent);border-radius:var(--r-full);transition:width .4s ease}
.online-dot{width:7px;height:7px;border-radius:50%;background:var(--green);border:2px solid var(--bg);flex-shrink:0}
.avatar{border-radius:50%;object-fit:cover;background:var(--bg-4);flex-shrink:0}
.avatar-xs{width:20px;height:20px}
.avatar-sm{width:26px;height:26px}
.avatar-md{width:36px;height:36px}
.avatar-lg{width:50px;height:50px}
.avatar-xl{width:76px;height:76px}

/* ── TOAST ── */
#toast-area{
  position:fixed;bottom:1.2rem;right:1.2rem;z-index:9999;
  display:flex;flex-direction:column;gap:.35rem;pointer-events:none;
}
.toast{
  background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);
  padding:.55rem .9rem;font-size:.82rem;color:var(--text);
  box-shadow:var(--shadow);animation:toast-in .18s ease;
  pointer-events:all;display:flex;align-items:center;gap:.4rem;max-width:280px;
}
@keyframes toast-in{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
.toast.success{border-color:rgba(34,197,94,.35)}
.toast.error{border-color:rgba(239,68,68,.35)}
.toast.info{border-color:var(--border-accent)}

/* ── DROPDOWN ── */
.rz-dropdown{
  position:absolute;background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;
  z-index:500;min-width:170px;animation:fadeIn .12s ease;
}
.rz-dropdown-item{
  display:flex;align-items:center;gap:.5rem;padding:.58rem .9rem;
  font-size:.83rem;color:var(--text-2);transition:var(--t-fast);cursor:pointer;
}
.rz-dropdown-item:hover{background:var(--bg-3);color:var(--text)}
.rz-dropdown-item.danger:hover{color:var(--red)}
.rz-dropdown-divider{height:1px;background:var(--border)}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--text-3)}
.empty-state .empty-icon{width:40px;height:40px;margin:0 auto .75rem;opacity:.3}
.empty-state h3{font-size:.94rem;color:var(--text-2);margin-bottom:.28rem;font-family:var(--font-display);letter-spacing:.03em}
.empty-state p{font-size:.82rem;line-height:1.65}

/* ── MOBILE NAV ── */
.mobile-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;
  height:var(--mob-nav-h);background:rgba(6,6,8,.98);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid var(--border);z-index:1000;
  padding:0 .2rem;justify-content:space-around;align-items:center;
}
.mob-nav-btn{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:.35rem .4rem;border-radius:var(--r);
  color:var(--text-3);font-size:.56rem;font-weight:500;
  transition:color .14s;flex:1;cursor:pointer;
}
.mob-nav-btn .mn-icon{
  width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  transition:transform .16s;
}
.mob-nav-btn.active{color:var(--accent)}
.mob-nav-btn.active .mn-icon{transform:scale(1.12)}

/* ── GENRE TAG ── */
.genre-tag{display:inline-block;padding:2px 7px;border-radius:var(--r-full);font-size:.67rem;font-weight:600}

/* ── UPLOAD ── */
.upload-btn{
  display:inline-flex;align-items:center;gap:.38rem;padding:.4rem .8rem;
  background:var(--bg-3);border:1px dashed var(--border-2);border-radius:var(--r);
  font-size:.78rem;color:var(--text-2);cursor:pointer;transition:var(--t);
}
.upload-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── ANIMATIONS ── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}60%{box-shadow:0 0 0 4px transparent}}
.spin{animation:spin .7s linear infinite}

/* ── STAGGER ── */
.stagger-in>*{opacity:0;transform:translateY(8px);animation:slideUp .26s ease forwards}
.stagger-in>*:nth-child(1){animation-delay:.04s}
.stagger-in>*:nth-child(2){animation-delay:.09s}
.stagger-in>*:nth-child(3){animation-delay:.14s}
.stagger-in>*:nth-child(4){animation-delay:.19s}
.stagger-in>*:nth-child(5){animation-delay:.23s}
.stagger-in>*:nth-child(6){animation-delay:.27s}
.stagger-in>*:nth-child(n+7){animation-delay:.3s}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .side-nav{display:none}
  .main-content{margin-left:0;padding-bottom:var(--mob-nav-h)}
  .mobile-nav{display:flex}
  .top-nav .site-links{display:none}
  .page-section{padding:.85rem}
  .media-grid{grid-template-columns:repeat(auto-fill,minmax(106px,1fr));gap:.5rem}
}
@media(max-width:480px){
  .media-grid{grid-template-columns:repeat(3,1fr)}
  .modal-box{border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:94vh;margin-top:auto}
  .modal-overlay{align-items:flex-end;padding:0}
}

/* ── GLOBAL PLAYER BAR ADJUSTMENT ── */
:root { --player-bar-h: 0px; }
body.player-active .main-content,
body.player-active .culture-main { padding-bottom: calc(var(--mob-nav-h) + 68px); }
