/* ============================================================
   SCARYMU GALLERY — App CSS
   Dark Fantasy · Gamer UI
   ============================================================ */

:root {
  --bg:         #050508;
  --bg2:        #0a0a12;
  --card:       #0f0f1a;
  --card2:      #13131f;
  --glass:      rgba(15,15,26,.9);

  --border:     rgba(120,80,255,.14);
  --border-b:   rgba(120,80,255,.4);

  --purple:     #7c3aed;
  --purple-l:   #a855f7;
  --purple-p:   #c084fc;
  --blue:       #38bdf8;
  --cyan:       #06b6d4;
  --gold:       #f59e0b;
  --red:        #ef4444;
  --green:      #22c55e;

  --text:       #e2e8f0;
  --text2:      #94a3b8;
  --muted:      #4b5563;

  --glow-pur:   0 0 20px rgba(124,58,237,.5),0 0 60px rgba(124,58,237,.15);
  --glow-gold:  0 0 20px rgba(245,158,11,.6),0 0 60px rgba(245,158,11,.2);

  --r:          12px;
  --rl:         20px;
  --tr:         all .22s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Exo 2',system-ui,sans-serif;font-size:15px;overflow-x:hidden;min-height:100vh}

/* ── CANVAS FX ── */
#fx-canvas{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:100;background:rgba(5,5,8,.96);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.header-inner{max-width:1400px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-sword{font-size:20px;filter:drop-shadow(0 0 8px rgba(124,58,237,.8));animation:sword 3s ease-in-out infinite}
@keyframes sword{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-main{font-family:'Cinzel',serif;font-weight:900;font-size:17px;letter-spacing:2px;background:linear-gradient(135deg,#a855f7,#38bdf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-sub{font-family:'Cinzel',serif;font-size:8px;letter-spacing:4px;color:var(--gold);text-shadow:0 0 8px rgba(245,158,11,.6)}
.main-nav{display:flex;gap:4px;flex:1}
.nav-btn{padding:7px 14px;border-radius:8px;background:none;border:none;color:var(--text2);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:var(--tr)}
.nav-btn:hover{color:var(--text);background:rgba(124,58,237,.1)}
.nav-btn.active{color:var(--purple-p);background:rgba(124,58,237,.15);box-shadow:inset 0 0 0 1px rgba(124,58,237,.3)}
.header-right{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0}

/* Auth area */
.user-pill{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--card2);border:1px solid var(--border);border-radius:40px;cursor:pointer;transition:var(--tr)}
.user-pill:hover{border-color:var(--border-b);box-shadow:var(--glow-pur)}
.user-pill-name{font-size:13px;font-weight:600}
.user-pill-rank{font-size:10px;color:var(--gold)}
.btn-login-header{padding:7px 18px;background:var(--card2);border:1px solid var(--border-b);border-radius:8px;color:var(--purple-p);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}
.btn-login-header:hover{background:rgba(124,58,237,.12)}
.btn-upload-hdr{padding:7px 18px;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:8px;color:#fff;font-family:'Exo 2',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}
.btn-upload-hdr:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(124,58,237,.4)}

/* ── HERO ── */
.hero{position:relative;z-index:1;background:linear-gradient(180deg,#0a0618,var(--bg));padding:44px 24px;text-align:center;border-bottom:1px solid rgba(245,158,11,.08);overflow:hidden}
.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:300px;background:radial-gradient(ellipse,rgba(124,58,237,.15) 0%,transparent 70%);pointer-events:none}
.hero-inner{position:relative;max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:18px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 18px;background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.04));border:1px solid rgba(245,158,11,.4);border-radius:40px;font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gold);text-shadow:0 0 10px rgba(245,158,11,.4);animation:pbadge 2s ease-in-out infinite}
@keyframes pbadge{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.3)}50%{box-shadow:0 0 0 8px rgba(245,158,11,0)}}
.hero-photo-wrap{position:relative;width:340px;height:220px}
.hero-crown{position:absolute;top:-26px;left:50%;transform:translateX(-50%);font-size:30px;z-index:3;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(245,158,11,.7))}
@keyframes float{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}}
.hero-img{width:100%;height:100%;object-fit:cover;border-radius:16px;border:2px solid rgba(245,158,11,.5);position:relative;z-index:2}
.hero-ring{position:absolute;inset:-4px;border-radius:20px;background:linear-gradient(135deg,rgba(245,158,11,.4),rgba(124,58,237,.4),rgba(56,189,248,.4));z-index:1;animation:ring 4s linear infinite;opacity:.6}
@keyframes ring{to{filter:hue-rotate(360deg)}}
.hero-player{font-family:'Cinzel',serif;font-size:26px;font-weight:700;background:linear-gradient(135deg,#f59e0b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{color:var(--text2);font-size:14px;max-width:400px}
.hero-votes{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:700}
.fire{animation:flicker 1.5s ease-in-out infinite}
@keyframes flicker{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}

/* ── MAIN LAYOUT ── */
.app-main{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:28px 24px}

/* ── FEED BAR ── */
.feed-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.filter-tabs{display:flex;gap:4px;padding:4px;background:var(--card);border-radius:12px;border:1px solid var(--border)}
.ftab{padding:7px 14px;background:none;border:none;border-radius:8px;color:var(--text2);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:var(--tr)}
.ftab.active{background:rgba(124,58,237,.2);color:var(--purple-p);box-shadow:inset 0 0 0 1px rgba(124,58,237,.3)}
.ftab:hover:not(.active){color:var(--text);background:rgba(255,255,255,.04)}
.search-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;transition:var(--tr)}
.search-wrap:focus-within{border-color:var(--border-b);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.search-wrap input{background:none;border:none;outline:none;color:var(--text);font-family:'Exo 2',sans-serif;font-size:13px;width:190px}
.search-wrap input::placeholder{color:var(--muted)}

/* ── TOP10 STRIP ── */
.top10-block{margin-bottom:26px}
.top10-label{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gold);margin-bottom:8px;text-shadow:0 0 8px rgba(245,158,11,.4)}
.top10-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.3) transparent}
.t10-item{flex-shrink:0;width:78px;cursor:pointer;transition:var(--tr)}
.t10-item:hover{transform:translateY(-4px)}
.t10-thumb{width:78px;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block;transition:var(--tr)}
.t10-item:hover .t10-thumb{border-color:var(--gold);box-shadow:0 0 12px rgba(245,158,11,.4)}
.t10-item:first-child .t10-thumb{border-color:rgba(245,158,11,.5);box-shadow:0 0 14px rgba(245,158,11,.3)}
.t10-rank{font-size:10px;font-weight:700;color:var(--gold);text-align:center;margin-top:3px}

/* ── PHOTO GRID ── */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-bottom:24px}
.photo-card{background:var(--card);border-radius:var(--rl);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:var(--tr);position:relative;animation:cardIn .35s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.photo-card:hover{transform:translateY(-5px);border-color:rgba(124,58,237,.4);box-shadow:0 20px 50px rgba(0,0,0,.4),var(--glow-pur)}
.card-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/10}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.photo-card:hover .card-img-wrap img{transform:scale(1.06)}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,8,.9) 0%,transparent 55%);opacity:0;transition:var(--tr);display:flex;align-items:flex-end;padding:14px}
.photo-card:hover .card-overlay{opacity:1}
.btn-vote-card{display:flex;align-items:center;gap:5px;padding:7px 14px;background:rgba(124,58,237,.8);border:none;border-radius:8px;color:#fff;font-family:'Exo 2',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:var(--tr);backdrop-filter:blur(8px)}
.btn-vote-card:hover{background:var(--purple-l);transform:scale(1.05)}
.btn-vote-card.voted{background:rgba(245,158,11,.7)}
.rank-badge-abs{position:absolute;top:10px;left:10px;z-index:2}
.rn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;font-size:11px;font-weight:800;font-family:'Cinzel',serif}
.rn1{background:linear-gradient(135deg,#f59e0b,#d97706);color:#000;box-shadow:0 0 14px rgba(245,158,11,.6)}
.rn2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#000}
.rn3{background:linear-gradient(135deg,#cd7f32,#a0522d);color:#fff}
.rntop{background:rgba(124,58,237,.8);color:#fff}
.card-foot{padding:12px 14px}
.card-prow{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.card-pname{font-weight:600;font-size:13px}
.card-votes{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--purple-p)}
.card-desc{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-date{font-size:10px;color:var(--muted);margin-top:3px}
.load-more-wrap{text-align:center;padding:16px}
.btn-more{padding:11px 28px;background:var(--card2);border:1px solid var(--border-b);border-radius:10px;color:var(--purple-p);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}
.btn-more:hover{background:rgba(124,58,237,.1);box-shadow:var(--glow-pur)}

/* ── RANKING VIEW ── */
.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.view-header h2{font-family:'Cinzel',serif;font-size:22px;background:linear-gradient(135deg,var(--purple-p),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.month-nav{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600}
.mnav-btn{width:30px;height:30px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text2);font-size:15px;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.mnav-btn:hover{border-color:var(--border-b);color:var(--text)}
.podium{display:flex;justify-content:center;align-items:flex-end;gap:14px;margin-bottom:32px;padding:20px;background:var(--card);border-radius:var(--rl);border:1px solid var(--border)}
.podium-slot{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:var(--tr)}
.podium-slot:hover{transform:translateY(-4px)}
.podium-slot:nth-child(1){order:2}
.podium-slot:nth-child(2){order:1}
.podium-slot:nth-child(3){order:3}
.pod-img{border-radius:10px;object-fit:cover;border:2px solid var(--border)}
.podium-slot:nth-child(1) .pod-img{width:145px;height:96px;border-color:rgba(245,158,11,.6);box-shadow:0 0 22px rgba(245,158,11,.4)}
.podium-slot:nth-child(2) .pod-img{width:118px;height:78px;border-color:rgba(148,163,184,.5)}
.podium-slot:nth-child(3) .pod-img{width:108px;height:72px;border-color:rgba(205,127,50,.5)}
.pod-info{text-align:center}
.pod-pos{font-family:'Cinzel',serif;font-weight:900;line-height:1}
.pod-pos.p1{font-size:22px;color:var(--gold);text-shadow:0 0 14px rgba(245,158,11,.6)}
.pod-pos.p2{font-size:18px;color:#94a3b8}
.pod-pos.p3{font-size:16px;color:#cd7f32}
.pod-name{font-size:12px;font-weight:600;margin-top:2px}
.pod-votes{font-size:11px;color:var(--purple-p)}
.rank-list{display:flex;flex-direction:column;gap:6px}
.rank-row{display:flex;align-items:center;gap:14px;padding:12px 18px;background:var(--card);border-radius:var(--r);border:1px solid var(--border);transition:var(--tr);cursor:pointer}
.rank-row:hover{border-color:var(--border-b);transform:translateX(4px)}
.rpos{font-family:'Cinzel',serif;font-weight:800;width:28px;text-align:center;color:var(--muted)}
.rthumb{width:60px;height:40px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}
.rinfo{flex:1}
.rname{font-weight:600;font-size:13px}
.rplayer{font-size:11px;color:var(--text2)}
.rvotes{font-weight:700;font-size:15px;color:var(--purple-p)}

/* ── UPLOAD VIEW ── */
.upload-container{max-width:640px;margin:0 auto}
.upload-container h2{font-family:'Cinzel',serif;font-size:22px;margin-bottom:6px;background:linear-gradient(135deg,var(--purple-p),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.up-sub{color:var(--text2);margin-bottom:22px}
.upload-zone{border:2px dashed rgba(124,58,237,.3);border-radius:var(--rl);padding:56px 40px;text-align:center;background:var(--card);cursor:pointer;transition:var(--tr)}
.upload-zone.dragover{border-color:var(--purple-l);background:rgba(124,58,237,.05);box-shadow:0 0 40px rgba(124,58,237,.1)}
.uz-icon{font-size:44px;margin-bottom:10px}
.upload-zone p{font-size:14px;color:var(--text2);margin-bottom:12px}
.uz-hint{font-size:12px;color:var(--muted)!important;margin-top:10px!important}
.btn-browse{padding:9px 22px;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:9px;color:#fff;font-family:'Exo 2',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}
.btn-browse:hover{transform:translateY(-1px);box-shadow:var(--glow-pur)}
.preview-block{display:flex;flex-direction:column;gap:18px;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.preview-img-wrap{position:relative;border-radius:var(--rl);overflow:hidden;max-height:300px}
.preview-img-wrap img{width:100%;max-height:300px;object-fit:contain;background:#0a0a12;display:block}
.btn-clear{position:absolute;top:10px;right:10px;width:30px;height:30px;background:rgba(239,68,68,.8);border:none;border-radius:50%;color:#fff;font-size:13px;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.btn-clear:hover{background:var(--red);transform:scale(1.1)}
.upload-form{display:flex;flex-direction:column;gap:10px;padding:22px;background:var(--card);border-radius:var(--rl);border:1px solid var(--border)}
.upload-form label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.upload-form input,.upload-form textarea{padding:10px 13px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Exo 2',sans-serif;font-size:13px;outline:none;transition:var(--tr);resize:vertical}
.upload-form input:focus,.upload-form textarea:focus{border-color:var(--border-b);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.upload-limit-info{font-size:12px;color:var(--muted)}
.upload-limit-info strong{color:var(--green)}
.btn-publish{padding:13px;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:10px;color:#fff;font-family:'Exo 2',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:var(--tr);letter-spacing:.3px}
.btn-publish:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(124,58,237,.5)}
.login-required-msg{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);border-radius:8px;font-size:13px;color:var(--gold)}
.login-required-msg button{padding:6px 14px;background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.4);border-radius:6px;color:var(--gold);font-family:'Exo 2',sans-serif;font-size:12px;cursor:pointer}

/* ── PROFILE VIEW ── */
.profile-card{display:flex;align-items:center;gap:22px;padding:26px 28px;background:var(--card);border-radius:var(--rl);border:1px solid var(--border);margin-bottom:24px}
.profile-avatar{font-size:52px;width:76px;height:76px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:50%;border:2px solid var(--border-b);box-shadow:var(--glow-pur);flex-shrink:0}
.profile-data h2{font-family:'Cinzel',serif;font-size:20px;font-weight:700;margin-bottom:8px}
.prof-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.badge{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.5px}
.badge-top1{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.4);color:var(--gold)}
.badge-top10{background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.3);color:var(--purple-p)}
.prof-stats{display:flex;gap:16px}
.ps-box{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 18px;background:var(--bg2);border-radius:10px;border:1px solid var(--border)}
.ps-val{font-family:'Cinzel',serif;font-size:20px;font-weight:700;color:var(--purple-p)}
.ps-lbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}
.modal-card{background:var(--card);border-radius:20px;border:1px solid var(--border-b);width:100%;position:relative;box-shadow:0 40px 100px rgba(0,0,0,.6),var(--glow-pur);animation:modalIn .3s cubic-bezier(.4,0,.2,1)}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(16px)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:12px;right:12px;z-index:10;width:34px;height:34px;background:rgba(255,255,255,.08);border:none;border-radius:50%;color:var(--text2);font-size:15px;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:rgba(239,68,68,.3);color:#fff}

/* Photo modal */
.photo-modal{max-width:920px;max-height:90vh;overflow:hidden}
.photo-modal-layout{display:grid;grid-template-columns:1fr 340px;height:100%}
.pm-left{background:#000;display:flex;flex-direction:column}
.pm-left img{flex:1;width:100%;max-height:520px;object-fit:contain;display:block}
.pm-img-actions{padding:10px;display:flex;gap:8px}
.btn-action{padding:7px 14px;background:var(--card2);border:1px solid var(--border);border-radius:7px;color:var(--text2);font-family:'Exo 2',sans-serif;font-size:12px;cursor:pointer;transition:var(--tr)}
.btn-action:hover{color:var(--text);border-color:var(--border-b)}
.pm-right{padding:22px;border-left:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column;gap:14px;max-height:90vh}
.pm-player-row{display:flex;align-items:center;gap:10px}
.pm-avatar{font-size:26px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:50%;border:1px solid var(--border);flex-shrink:0}
.pm-player{font-weight:700;font-size:15px}
.pm-date{font-size:11px;color:var(--muted)}
.pm-desc{font-size:13px;color:var(--text2);line-height:1.6;padding:10px 12px;background:var(--bg2);border-radius:7px;border-left:3px solid rgba(124,58,237,.4)}
.btn-vote-big{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:14px;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:12px;color:#fff;font-family:'Exo 2',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:var(--tr);letter-spacing:.3px}
.btn-vote-big:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(124,58,237,.5)}
.btn-vote-big.voted{background:linear-gradient(135deg,rgba(245,158,11,.5),rgba(217,119,6,.5));cursor:default}
.vi{font-size:17px}
.pm-comments h4{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}
.comments-list{display:flex;flex-direction:column;gap:6px;max-height:160px;overflow-y:auto;margin-bottom:8px}
.cm-item{padding:7px 10px;background:var(--bg2);border-radius:7px;font-size:12px}
.cm-author{font-weight:600;color:var(--purple-p);font-size:11px;margin-bottom:2px}
.cm-text{color:var(--text2)}
.comment-row{display:flex;gap:6px}
.comment-row input{flex:1;padding:7px 10px;background:var(--bg2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-family:'Exo 2',sans-serif;font-size:12px;outline:none}
.comment-row input:focus{border-color:var(--border-b)}
.comment-row button{padding:7px 12px;background:var(--purple);border:none;border-radius:7px;color:#fff;font-size:13px;cursor:pointer;transition:var(--tr)}
.comment-row button:hover{background:var(--purple-l)}

/* Auth modal */
.auth-modal{max-width:380px;padding:28px}
.auth-tabs{display:flex;gap:4px;padding:4px;background:var(--bg2);border-radius:10px;margin-bottom:22px}
.atab{flex:1;padding:8px;background:none;border:none;border-radius:7px;color:var(--text2);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}
.atab.active{background:var(--card);color:var(--text);box-shadow:0 0 0 1px var(--border)}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.auth-field input{width:100%;padding:10px 13px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Exo 2',sans-serif;font-size:14px;outline:none;transition:var(--tr)}
.auth-field input:focus{border-color:var(--border-b);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.auth-error{min-height:16px;font-size:12px;color:var(--red);margin-bottom:10px}
.btn-auth{width:100%;padding:12px;background:linear-gradient(135deg,var(--purple),#5b21b6);border:none;border-radius:10px;color:#fff;font-family:'Exo 2',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:var(--tr)}
.btn-auth:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(124,58,237,.4)}

/* ── TOASTS ── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{padding:11px 18px;border-radius:9px;font-size:13px;font-weight:500;animation:toastIn .3s ease,toastOut .3s ease 2.8s forwards;pointer-events:none;max-width:280px}
@keyframes toastIn{from{opacity:0;transform:translateX(16px) scale(.95)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(16px)}}
.toast-ok{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.4);color:var(--green)}
.toast-err{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.4);color:var(--red)}
.toast-info{background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.4);color:var(--purple-p)}

/* ── VOTE BURST ── */
.vote-burst-container{position:fixed;inset:0;pointer-events:none;z-index:9999}
.vburst{position:fixed;font-size:22px;pointer-events:none;animation:vburst .8s ease forwards}
@keyframes vburst{0%{opacity:1;transform:scale(.5) translateY(0)}100%{opacity:0;transform:scale(2) translateY(-70px)}}

/* ── EMPTY STATES ── */
.empty-state{text-align:center;padding:56px 20px;color:var(--muted);grid-column:1/-1}
.empty-state .ei{font-size:44px;margin-bottom:10px}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(124,58,237,.3);border-radius:3px}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .photo-modal-layout{grid-template-columns:1fr}
  .pm-right{border-left:none;border-top:1px solid var(--border);max-height:380px}
  .pm-left img{max-height:260px}
  .podium{flex-direction:column;align-items:center}
  .hero-photo-wrap{width:280px;height:180px}
}
@media(max-width:680px){
  .main-nav{display:none}
  .photo-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .profile-card{flex-direction:column;text-align:center}
  .prof-stats{justify-content:center}
  .feed-bar{flex-direction:column;align-items:flex-start}
}
