:root{
  --bg:#050816;--bg2:#081230;--panel:rgba(12,18,42,.74);--panel2:rgba(16,28,66,.68);
  --line:rgba(143,183,255,.16);--line2:rgba(80,210,255,.38);--txt:#f7fbff;--muted:#8fa3c7;
  --blue:#3b82f6;--cyan:#22d3ee;--violet:#8b5cf6;--pink:#ec4899;--red:#fb4665;--green:#22c55e;--amber:#f59e0b;
  --shadow:0 28px 80px rgba(0,0,0,.46);--r:24px;--sidebar:292px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,#142b79 0,#07122f 35%,#040712 74%);color:var(--txt);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;overflow-x:hidden}.noise{position:fixed;inset:0;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.65'/%3E%3C/svg%3E")}.orb{position:fixed;border-radius:999px;filter:blur(80px);opacity:.34;pointer-events:none}.orb-one{width:450px;height:450px;background:var(--blue);left:-160px;top:-40px}.orb-two{width:460px;height:460px;background:var(--violet);right:-170px;top:240px}.orb-three{width:360px;height:360px;background:var(--cyan);left:42%;bottom:-190px;opacity:.22}.app-shell{display:grid;grid-template-columns:var(--sidebar) minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:20px;display:flex;flex-direction:column;gap:18px;border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(4,7,18,.86),rgba(6,12,30,.66));backdrop-filter:blur(22px);z-index:40}.brand-card{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--txt);padding:12px;border-radius:22px;background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.11);box-shadow:0 18px 45px rgba(0,0,0,.28)}.brand-card img{width:52px;height:52px;border-radius:16px;object-fit:cover;box-shadow:0 0 0 1px rgba(255,255,255,.2),0 16px 36px rgba(59,130,246,.35)}.brand-card strong{display:block;font-size:17px;letter-spacing:-.3px}.brand-card small{display:block;color:var(--muted);font-size:12px;margin-top:2px}.side-nav{display:flex;flex-direction:column;gap:7px}.side-nav a{position:relative;color:#dbe8ff;text-decoration:none;padding:12px 14px;border-radius:16px;font-weight:800;border:1px solid transparent;transition:.18s ease}.side-nav a:hover,.side-nav a.active{background:linear-gradient(135deg,rgba(59,130,246,.22),rgba(34,211,238,.08));border-color:rgba(117,190,255,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}.side-nav a.active:before{content:"";position:absolute;left:8px;top:50%;width:5px;height:22px;transform:translateY(-50%);border-radius:999px;background:linear-gradient(var(--cyan),var(--blue));box-shadow:0 0 20px rgba(34,211,238,.7)}.nav-section{margin:12px 10px 4px;color:#6f84aa;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:950}.sidebar-bottom{margin-top:auto;display:grid;gap:10px}.security-card{display:flex;gap:10px;align-items:center;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.045)}.security-card strong{display:block;font-size:13px}.security-card small{display:block;color:var(--muted);font-size:12px;margin-top:1px}.dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 18px var(--green);flex:0 0 auto}.privacy .dot{background:var(--cyan);box-shadow:0 0 18px var(--cyan)}.main-shell{min-width:0}.topbar{position:sticky;top:0;z-index:35;height:76px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 26px;border-bottom:1px solid var(--line);background:rgba(5,8,22,.64);backdrop-filter:blur(22px)}.mobile-brand{display:none;align-items:center;gap:10px}.mobile-brand img{width:38px;height:38px;border-radius:12px}.topbar-status,.topbar-user{display:flex;align-items:center;gap:10px}.topbar-user{margin-left:auto}.staff-avatar{width:38px;height:38px;border-radius:14px;object-fit:cover;border:1px solid rgba(255,255,255,.18)}.staff-meta strong{display:block;font-size:14px}.staff-meta small{display:block;color:var(--muted);font-size:12px}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 11px;border-radius:999px;font-size:12px;font-weight:950;border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.06);color:#dbeafe}.status-pill:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 16px var(--cyan)}.status-pill.private{color:#bbf7d0}.status-pill.private:before{background:var(--green);box-shadow:0 0 16px var(--green)}.container{width:min(1360px,calc(100% - 48px));margin:32px auto 70px}.glass{background:linear-gradient(145deg,var(--panel),rgba(8,16,38,.54));border:1px solid var(--line);box-shadow:var(--shadow);backdrop-filter:blur(20px)}.panel,.card{border-radius:var(--r);padding:24px;margin-bottom:20px}.premium-panel{position:relative;overflow:hidden}.premium-panel:before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.75),transparent)}.hero{position:relative;min-height:480px;border-radius:34px;overflow:hidden;border:1px solid var(--line2);box-shadow:0 36px 120px rgba(0,0,0,.55)}.ultra-hero picture,.ultra-hero picture img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(2,6,18,.93) 0%,rgba(3,10,30,.62) 44%,rgba(2,6,18,.88) 100%),radial-gradient(circle at 70% 25%,rgba(34,211,238,.22),transparent 32%)}.hero-content{position:relative;z-index:2;max-width:710px;padding:56px}.eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;padding:7px 11px;border:1px solid rgba(34,211,238,.28);border-radius:999px;background:rgba(34,211,238,.08);color:#a5f3fc;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.1em}.eyebrow:before{content:"";width:7px;height:7px;border-radius:999px;background:var(--cyan);box-shadow:0 0 18px var(--cyan)}.small-eye{font-size:10px;padding:5px 8px;margin:0 0 8px}.hero h1,h1{font-size:clamp(38px,5.4vw,74px);line-height:.92;margin:8px 0 16px;letter-spacing:-2.6px}h2{margin:0;font-size:24px;letter-spacing:-.5px}h3{margin:12px 0 8px}.hero p,.page-head p{max-width:720px;color:var(--muted);font-size:17px;line-height:1.65}.hero-actions,.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.hero-panel{position:absolute;right:34px;bottom:34px;z-index:3;width:360px;border-radius:26px;padding:18px}.panel-mini-title{color:#a5f3fc;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.1em}.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.hero-metrics div{padding:14px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}.hero-metrics b{display:block;font-size:28px}.hero-metrics span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.btn{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--txt);padding:11px 16px;border-radius:14px;text-decoration:none;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.18s ease;white-space:nowrap;font-family:inherit}.btn:hover{transform:translateY(-1px);border-color:rgba(34,211,238,.58);background:rgba(59,130,246,.16)}.btn.primary{background:linear-gradient(135deg,#2f7cff,#20d6f5);border:none;color:#001126;box-shadow:0 16px 36px rgba(34,211,238,.22)}.btn.success{background:linear-gradient(135deg,#16a34a,#2df08f);border:none;color:#03170d}.btn.danger{background:linear-gradient(135deg,#fb4665,#fb7185);border:none;color:#24020a}.btn.ghost,.btn.soft{background:rgba(255,255,255,.055)}.btn.big{padding:14px 19px;border-radius:17px;font-size:15px}.btn.small{padding:8px 11px;border-radius:12px;font-size:12px}.btn.is-loading{opacity:.65;pointer-events:none}.full{width:100%}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:20px 0}.stats.five{grid-template-columns:repeat(5,1fr)}.stat{position:relative;min-height:142px;border-radius:24px;padding:20px;overflow:hidden}.stat:after{content:"";position:absolute;right:-38px;top:-38px;width:130px;height:130px;border-radius:999px;background:rgba(255,255,255,.055)}.stat span{display:block;color:#c6d6f4;font-weight:850}.stat b{display:block;font-size:44px;line-height:1;margin:14px 0 8px;font-weight:950;letter-spacing:-1.5px}.stat small{color:var(--muted)}.stat.danger{border-color:rgba(251,70,101,.28)}.stat.danger b{color:#fecdd3}.stat.warn{border-color:rgba(245,158,11,.28)}.stat.warn b{color:#fde68a}.stat.info{border-color:rgba(59,130,246,.28)}.stat.info b{color:#bfdbfe}.stat.success{border-color:rgba(34,197,94,.28)}.stat.success b{color:#bbf7d0}.grid{display:grid;gap:20px}.grid.two{grid-template-columns:1fr 1fr}.page-head,.panel-title,.table-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.premium-head{padding:8px 2px}.panel-title a{color:#a5f3fc;text-decoration:none;font-weight:900}.muted,small{color:var(--muted)}.small{font-size:13px}.activity-list{display:grid;gap:12px}.activity-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:14px;border-radius:18px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07)}.activity-row strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-row small{display:block;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar-letter{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;font-weight:950;background:linear-gradient(135deg,rgba(59,130,246,.35),rgba(34,211,238,.2));border:1px solid rgba(255,255,255,.12);color:#e0f2fe}.danger-bg{background:linear-gradient(135deg,rgba(251,70,101,.35),rgba(139,92,246,.2))}.status-dot{width:12px;height:12px;border-radius:999px;background:var(--blue);box-shadow:0 0 18px var(--blue)}.status-dot.success{background:var(--green);box-shadow:0 0 18px var(--green)}.status-dot.error,.status-dot.danger{background:var(--red);box-shadow:0 0 18px var(--red)}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:950;text-transform:uppercase;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.1);white-space:nowrap}.badge.ban,.badge.active,.badge.error,.badge.danger{background:rgba(251,70,101,.16);color:#fecdd3}.badge.timeout,.badge.pending,.badge.warning{background:rgba(245,158,11,.16);color:#fde68a}.badge.unbanned,.badge.accepted,.badge.success{background:rgba(34,197,94,.15);color:#bbf7d0}.badge.info{background:rgba(59,130,246,.16);color:#bfdbfe}.filters{display:grid;grid-template-columns:1fr 180px 210px auto;gap:10px}.filters-panel,.quick-add{padding:18px}.add-grid{display:grid;grid-template-columns:1fr 1fr 1.45fr 1fr 1fr auto;gap:10px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}label{display:block;margin:12px 0 7px;color:#dbeafe;font-weight:850}input,select,textarea{width:100%;border:1px solid rgba(143,183,255,.18);background:rgba(2,8,24,.74);color:var(--txt);border-radius:14px;padding:12px 13px;outline:none;font:inherit}input::placeholder,textarea::placeholder{color:#6e81a6}input:focus,select:focus,textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(34,211,238,.12)}textarea{resize:vertical}.table-panel{overflow:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0 10px}.data-table th{text-align:left;color:#8195ba;font-size:11px;padding:0 12px;text-transform:uppercase;letter-spacing:.08em}.data-table td{padding:14px 12px;background:rgba(255,255,255,.046);border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);vertical-align:top}.data-table td:first-child{border-radius:18px 0 0 18px;border-left:1px solid rgba(255,255,255,.07)}.data-table td:last-child{border-radius:0 18px 18px 0;border-right:1px solid rgba(255,255,255,.07)}.data-table small{display:block;margin-top:4px}.user-cell{display:flex;align-items:center;gap:12px}.reason{max-width:420px}.actions-cell{min-width:205px}.stack{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.stack input{max-width:165px;padding:8px 10px;border-radius:11px;font-size:12px}.auth-wrap{display:grid;place-items:center;min-height:calc(100vh - 190px)}.pro-auth-wrap{grid-template-columns:1.05fr .95fr;gap:22px;place-items:stretch}.auth-visual,.pro-login{border-radius:32px;padding:34px}.auth-visual{position:relative;overflow:hidden;min-height:520px;display:flex;flex-direction:column;justify-content:flex-end}.auth-visual:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,211,238,.08),rgba(139,92,246,.1)),url('/static/img/banner.webp') center/cover;opacity:.58}.auth-visual>*{position:relative;z-index:1}.auth-logo{width:84px;height:84px;border-radius:24px;object-fit:cover;box-shadow:0 0 0 1px rgba(255,255,255,.14),0 20px 45px rgba(59,130,246,.32)}.auth-logo.huge{width:104px;height:104px;margin-bottom:22px}.pro-login{align-self:center}.pro-login h2{font-size:34px;margin:4px 0 8px}.role-box{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border-radius:18px;background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.32);margin:18px 0}.role-box span{color:var(--muted);font-weight:850}.security-lines{display:grid;gap:10px;margin-top:20px}.security-lines div{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);font-weight:800}.privacy-note,.privacy-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 11px;border-radius:999px;color:#bbf7d0;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.22);font-size:13px;font-weight:850}.timeline{display:grid;gap:12px}.log-card,.timeline>div{padding:15px 17px;border-left:3px solid var(--blue);background:rgba(255,255,255,.045);border-radius:16px}.log-card span,.timeline span{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}.log-card p,.timeline p{margin:5px 0 0;color:#dcecff}.log-card.error{border-left-color:var(--red)}.log-card.warning{border-left-color:var(--amber)}.appeal-list{display:grid;gap:16px}.decision{display:grid;gap:10px}.check{display:flex;gap:10px;align-items:center}.check input{width:auto}.ok-text{color:#86efac}.error-text{color:#fecdd3}.center{text-align:center}.inline{display:inline}.toast{position:fixed;z-index:100;right:24px;top:90px;max-width:480px;padding:15px 18px;border-radius:18px;border:1px solid var(--line);background:rgba(6,13,33,.95);box-shadow:var(--shadow);animation:toast .25s ease-out}.toast.success{border-color:rgba(34,197,94,.45)}.toast.danger{border-color:rgba(251,70,101,.72)}@keyframes toast{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}code{padding:3px 7px;background:rgba(255,255,255,.08);border-radius:8px;word-break:break-word}.blockcode{display:block;white-space:pre-wrap;word-break:break-word;margin-top:8px}.sep{border:0;border-top:1px solid rgba(96,165,250,.18);margin:18px 0}details{margin-top:8px}summary{cursor:pointer;color:var(--cyan);font-size:13px;font-weight:850}.footer{display:flex;gap:8px;align-items:center;justify-content:center;flex-direction:column;color:var(--muted);padding:30px}.footer span{color:#eaf4ff;font-weight:950}.avatar-mini{width:34px;height:34px;border-radius:12px;object-fit:cover;margin-right:8px;vertical-align:middle}.staff-table{min-width:820px}
@media(max-width:1200px){:root{--sidebar:250px}.stats.five{grid-template-columns:repeat(3,1fr)}.filters,.add-grid{grid-template-columns:1fr 1fr}.hero-panel{position:relative;right:auto;bottom:auto;width:auto;margin:0 28px 28px}.hero-content{padding-bottom:28px}.pro-auth-wrap{grid-template-columns:1fr}}
@media(max-width:900px){.app-shell{display:block}.sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--line)}.side-nav{display:grid;grid-template-columns:repeat(2,1fr)}.sidebar-bottom{grid-template-columns:1fr 1fr}.topbar{top:0}.mobile-brand{display:flex}.topbar-status{display:none}.staff-meta{display:none}.container{width:min(100% - 28px,1360px)}.grid.two{grid-template-columns:1fr}.stats.five,.stats{grid-template-columns:repeat(2,1fr)}.data-table{min-width:980px}.settings-grid{grid-template-columns:1fr}}
@media(max-width:640px){.sidebar{padding:14px}.brand-card span{display:block}.side-nav{grid-template-columns:1fr}.sidebar-bottom{grid-template-columns:1fr}.topbar{height:auto;flex-wrap:wrap;padding:12px 14px}.topbar-user{width:100%;justify-content:space-between}.container{width:min(100% - 20px,1360px);margin-top:18px}.hero{min-height:auto}.hero-content{padding:28px}.hero h1,h1{font-size:38px;letter-spacing:-1.4px}.stats.five,.stats{grid-template-columns:1fr}.filters,.add-grid{grid-template-columns:1fr}.page-head,.panel-title,.table-header{flex-direction:column}.auth-visual{min-height:380px}.toast{right:10px;left:10px;max-width:none}}


/* ===== Ultra animations ===== */
@keyframes bgShift{0%{background-position:0% 0%,0 0,0 0}50%{background-position:8% 6%,0 0,0 0}100%{background-position:0% 0%,0 0,0 0}}
@keyframes noiseMove{0%{transform:translate3d(0,0,0)}25%{transform:translate3d(-1.5%,-2%,0)}50%{transform:translate3d(1.5%,1%,0)}75%{transform:translate3d(-1%,2%,0)}100%{transform:translate3d(0,0,0)}}
@keyframes floatOrb{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(0,-22px,0) scale(1.04)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 rgba(34,211,238,0),0 0 0 rgba(59,130,246,0)}50%{box-shadow:0 0 38px rgba(34,211,238,.22),0 0 68px rgba(59,130,246,.18)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
@keyframes slideDownSoft{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:none}}
@keyframes fadeUpSoft{from{opacity:0;transform:translateY(22px) scale(.985)}to{opacity:1;transform:none}}
@keyframes shimmer{0%{transform:translateX(-130%) skewX(-24deg)}100%{transform:translateX(220%) skewX(-24deg)}}
@keyframes softRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.65}}

body{background-size:120% 120%;animation:bgShift 18s ease-in-out infinite}
.noise{animation:noiseMove 16s steps(10,end) infinite}
.orb{animation:floatOrb 14s ease-in-out infinite}
.orb-two{animation-duration:18s;animation-delay:-3s}
.orb-three{animation-duration:16s;animation-delay:-6s}
.sidebar{animation:slideInLeft .72s cubic-bezier(.2,.8,.2,1)}
.topbar{animation:slideDownSoft .72s cubic-bezier(.2,.8,.2,1)}
.brand-card,.security-card,.hero-panel,.stat,.activity-row,.log-card,.timeline>div,.data-table td,.appeal-list > *, .panel,.card,.table-panel,.hero{transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease}
.brand-card:hover,.security-card:hover,.hero-panel:hover,.panel:hover,.card:hover,.table-panel:hover{transform:translateY(-2px);box-shadow:0 26px 70px rgba(0,0,0,.34)}
.stat:hover,.activity-row:hover,.log-card:hover,.timeline>div:hover{transform:translateY(-4px);box-shadow:0 20px 52px rgba(0,0,0,.28)}
.side-nav a{overflow:hidden}
.side-nav a:after{content:"";position:absolute;inset:0 auto 0 0;width:0;border-radius:inherit;background:linear-gradient(90deg,rgba(59,130,246,.10),rgba(34,211,238,.04));transition:width .28s ease;z-index:-1}
.side-nav a:hover:after,.side-nav a.active:after{width:100%}
.side-nav a:hover{transform:translateX(4px)}
.status-pill:before,.eyebrow:before,.dot{animation:pulseDot 1.9s ease-in-out infinite}
.hero,.premium-panel,.stat{position:relative}
.hero:after,.premium-panel:after,.stat:before{content:"";position:absolute;pointer-events:none}
.hero:after,.premium-panel:after{inset:0;background:linear-gradient(115deg,transparent 10%,rgba(255,255,255,.08) 35%,transparent 60%);transform:translateX(-140%) skewX(-18deg)}
.hero:hover:after,.premium-panel:hover:after{animation:shimmer 1.15s ease}
.stat:before{right:-20px;top:-20px;width:88px;height:88px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.11),transparent 68%);animation:softRotate 9s linear infinite}
.btn{position:relative;overflow:hidden}
.btn:before{content:"";position:absolute;top:-30%;left:-130%;width:55%;height:160%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-22deg)}
.btn:hover:before{animation:shimmer .95s ease}
.btn.primary{animation:pulseGlow 3.2s ease-in-out infinite}
.hero-actions .btn.primary{animation:pulseGlow 2.8s ease-in-out infinite}
.staff-avatar{transition:transform .22s ease, box-shadow .22s ease}
.staff-avatar:hover{transform:scale(1.06) rotate(-2deg);box-shadow:0 12px 26px rgba(59,130,246,.35)}
.toast{animation:toast .25s ease-out, fadeUpSoft .25s ease-out}

.reveal{opacity:0;transform:translateY(22px) scale(.985);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal-stagger-2{transition-delay:.08s}.reveal-stagger-3{transition-delay:.14s}.reveal-stagger-4{transition-delay:.2s}.reveal-stagger-5{transition-delay:.26s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}


/* Discord action panel */
.moderation-actions{align-items:stretch}.add-grid.compact{grid-template-columns:1fr 1fr 1.4fr auto}.staff-welcome{display:flex;align-items:center;justify-content:space-between;gap:18px}.staff-welcome-left{display:flex;align-items:center;gap:16px}.big-avatar{width:72px!important;height:72px!important;border-radius:24px!important;box-shadow:0 16px 42px rgba(88,101,242,.34),0 0 0 1px rgba(255,255,255,.14)}
@media(max-width:900px){.add-grid.compact{grid-template-columns:1fr}.staff-welcome{flex-direction:column;align-items:flex-start}.staff-welcome-left{align-items:flex-start}}


/* ===== Black Pro Theme Override ===== */
:root{
  --bg:#020202;
  --bg2:#080808;
  --panel:rgba(8,8,8,.92);
  --panel2:rgba(12,12,12,.9);
  --line:rgba(255,255,255,.08);
  --line2:rgba(255,255,255,.14);
  --txt:#f5f7fb;
  --muted:#9da3af;
  --blue:#ffffff;
  --cyan:#cfcfcf;
  --violet:#7a7a7a;
  --pink:#f3f4f6;
  --shadow:0 24px 70px rgba(0,0,0,.62);
}
body{background:
 radial-gradient(circle at top left, rgba(255,255,255,.045), transparent 22%),
 radial-gradient(circle at 85% 15%, rgba(255,255,255,.03), transparent 18%),
 linear-gradient(180deg,#020202 0%, #050505 50%, #000000 100%) !important;
 color:var(--txt);
}
.noise{opacity:.03}
.orb{opacity:.12;filter:blur(100px)}
.orb-one{background:#ffffff}
.orb-two{background:#6b7280}
.orb-three{background:#d1d5db}
.sidebar{background:linear-gradient(180deg,rgba(0,0,0,.94),rgba(8,8,8,.92)) !important;border-right:1px solid rgba(255,255,255,.06)}
.brand-card,.security-card,.glass,.panel,.card,.table-panel,.hero-panel,.activity-row,.data-table td,.log-card,.timeline>div,.role-box{background:linear-gradient(180deg,rgba(14,14,14,.96),rgba(8,8,8,.96)) !important;border-color:rgba(255,255,255,.08) !important;box-shadow:0 16px 42px rgba(0,0,0,.45)}
.brand-card img,.auth-logo,.staff-avatar,.big-avatar{box-shadow:0 0 0 1px rgba(255,255,255,.12),0 18px 40px rgba(0,0,0,.45)!important}
.topbar{background:rgba(0,0,0,.8)!important;border-bottom:1px solid rgba(255,255,255,.06)!important}
.side-nav a{color:#f3f4f6}
.side-nav a:hover,.side-nav a.active{background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03)) !important;border-color:rgba(255,255,255,.10)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 10px 30px rgba(0,0,0,.24)}
.side-nav a.active:before{background:linear-gradient(#ffffff,#9ca3af)!important;box-shadow:0 0 16px rgba(255,255,255,.35)}
.nav-section,.muted,small,.hero p,.page-head p,.staff-meta small,.activity-row small,.log-card span,.timeline span,.hero-metrics span,.stat small,.panel-mini-title{color:#a1a1aa!important}
.hero{border-color:rgba(255,255,255,.08)!important;box-shadow:0 34px 100px rgba(0,0,0,.68)}
.hero-overlay{background:linear-gradient(90deg,rgba(0,0,0,.92) 0%,rgba(8,8,8,.72) 45%,rgba(0,0,0,.9) 100%),radial-gradient(circle at 70% 25%,rgba(255,255,255,.08),transparent 28%) !important}
.eyebrow,.privacy-note,.privacy-chip,.status-pill,.role-box{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.1)!important;color:#f5f5f5!important}
.eyebrow:before,.status-pill:before,.dot{background:#ffffff!important;box-shadow:0 0 14px rgba(255,255,255,.4)!important}
.btn{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.1)!important;color:#fafafa!important}
.btn:hover{background:rgba(255,255,255,.1)!important;border-color:rgba(255,255,255,.18)!important}
.btn.primary{background:linear-gradient(135deg,#ffffff,#bfbfbf)!important;color:#050505!important;box-shadow:0 18px 44px rgba(255,255,255,.12)}
.btn.success{background:linear-gradient(135deg,#d4d4d8,#ffffff)!important;color:#050505!important}
.btn.danger{background:linear-gradient(135deg,#ef4444,#f87171)!important;color:#fff!important}
input,select,textarea{background:rgba(5,5,5,.95)!important;border-color:rgba(255,255,255,.09)!important;color:#f9fafb!important}
input:focus,select:focus,textarea:focus{border-color:rgba(255,255,255,.22)!important;box-shadow:0 0 0 4px rgba(255,255,255,.06)!important}
.data-table th{color:#a3a3a3}
.badge,.status-pill{border-color:rgba(255,255,255,.1)!important}
.stat:after,.stat:before{opacity:.4}
.footer{color:#9ca3af}.footer span{color:#ffffff}
.toast{background:rgba(5,5,5,.98)!important;border-color:rgba(255,255,255,.1)!important}


/* FIX /bans : les lignes du tableau ne doivent jamais disparaître après le chargement JS */
.data-table tbody tr,
.data-table tbody tr.reveal,
.data-table tbody tr.is-visible {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
}


/* ============================
   VERSION TÉLÉPHONE / RESPONSIVE
   ============================ */
html { -webkit-text-size-adjust: 100%; }
body { overflow-x: hidden; }
img, video, canvas { max-width: 100%; height: auto; }
input, select, textarea, button { font-size: 16px !important; }

@media (max-width: 900px) {
  .app-shell, .layout {
    display: block !important;
    width: 100% !important;
    min-height: 100vh !important;
  }

  .sidebar, aside.sidebar, .side {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    top: auto !important;
    left: auto !important;
    padding: 14px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    overflow: visible !important;
  }

  .brand-card, .brand {
    margin-bottom: 12px !important;
  }

  .side-nav, .nav {
    display: flex !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding-bottom: 8px !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .side-nav a, .side-nav span, .nav a {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    margin: 0 !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
  }

  .nav-section { display: none !important; }

  .main, main.main, .content, .page-content {
    width: 100% !important;
    padding: 14px !important;
    margin: 0 !important;
    overflow-x: hidden !important;
  }

  .page-head, .premium-head, .table-header, .panel-title {
    display: block !important;
  }

  .page-head h1, .premium-head h1, h1 {
    font-size: 28px !important;
    line-height: 1.1 !important;
    word-break: break-word !important;
  }

  h2 { font-size: 21px !important; }

  p, .muted {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  .actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 14px !important;
    width: 100% !important;
  }

  .btn, button.btn, a.btn {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    min-height: 44px !important;
  }

  .actions .btn, .actions form, .actions form .btn {
    flex: 1 1 145px !important;
    width: auto !important;
  }

  .panel, .glass, .premium-panel, .filters-panel, .table-panel {
    border-radius: 16px !important;
    padding: 14px !important;
    margin-bottom: 14px !important;
    width: 100% !important;
  }

  .grid, .grid.two, .grid2, .two, .stats-grid, .moderation-actions, .cards-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .filters, .add-grid, form.filters, form.add-grid, .compact {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }

  input, select, textarea {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .table-panel {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  table, .data-table, .pro-table {
    min-width: 760px !important;
    width: 100% !important;
    font-size: 13px !important;
  }

  thead th, tbody td {
    padding: 10px 8px !important;
  }

  .user-cell { min-width: 170px !important; }
  .avatar-letter, .avatar {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
  }

  .actions-cell, .stack { min-width: 145px !important; }
  .stack { gap: 6px !important; }

  .badge, .status-pill {
    font-size: 11px !important;
    padding: 5px 8px !important;
  }

  .orb, .noise { display: none !important; }
}

@media (max-width: 520px) {
  .main, main.main, .content, .page-content { padding: 10px !important; }
  .sidebar, aside.sidebar, .side { padding: 10px !important; }
  .page-head h1, .premium-head h1, h1 { font-size: 24px !important; }
  .panel, .glass, .premium-panel { padding: 12px !important; }
  .brand-card img, .brand img { width: 42px !important; height: 42px !important; }
}


/* ACCUEIL VIEWER CLEAN MOBILE */
@media(max-width:900px){
  .viewer-grid,
  .viewer-steps {
    grid-template-columns: 1fr !important;
  }
  .viewer-action {
    width: 100% !important;
  }
}
