:root {
  --bg:#020509;--bg2:#060d16;--bg3:#0b1525;
  --s:rgba(255,255,255,0.03);--s2:rgba(255,255,255,0.06);
  --b:rgba(255,255,255,0.07);--b2:rgba(0,212,255,0.22);
  --c:#00d4ff;--v:#7c3aed;--pk:#f72585;
  --g:#00ff9d;--o:#ff6b35;--y:#ffd60a;--pu:#a855f7;
  --t:#eef2f7;--t2:#7a8fa6;--t3:#2d3d4f;
  --gc:0 0 40px rgba(0,212,255,.2);--gv:0 0 40px rgba(124,58,237,.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Syne',sans-serif;background:var(--bg);color:var(--t);min-height:100vh;overflow-x:hidden}

/* ─── CUSTOM CURSOR ─── */
.cursor{position:fixed;pointer-events:none;z-index:99999;mix-blend-mode:screen}
.cursor-dot{width:8px;height:8px;background:var(--c);border-radius:50%;transform:translate(-50%,-50%);transition:transform .1s;box-shadow:0 0 10px var(--c)}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(0,212,255,.5);border-radius:50%;transform:translate(-50%,-50%);transition:all .12s ease;top:0;left:0}
body:hover .cursor-dot{opacity:1}

/* ─── BG CANVAS ─── */
#bgCanvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.7}

/* ─── NOISE ─── */
.noise{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.018;
  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='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px}

#app{position:relative;z-index:1}

/* ═══════════════════════
   LOGIN
═══════════════════════ */
#loginScreen{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;
  background:var(--bg);overflow:hidden}
#loginScreen.out{animation:loginOut .7s ease forwards}
@keyframes loginOut{to{opacity:0;transform:scale(1.08) translateY(-20px)}}

/* Particles canvas behind login */
#loginCanvas{position:absolute;inset:0;pointer-events:none}

.login-card{position:relative;z-index:1;width:min(440px,90vw);
  background:rgba(6,13,22,.9);border:1px solid var(--b2);border-radius:24px;
  padding:48px 40px;text-align:center;overflow:hidden;
  box-shadow:0 0 100px rgba(0,212,255,.07),0 60px 120px rgba(0,0,0,.7),
  inset 0 1px 0 rgba(255,255,255,.06);backdrop-filter:blur(30px)}

/* Scanline sweep on card */
.login-card::before{content:'';position:absolute;top:-100%;left:0;right:0;height:200%;
  background:linear-gradient(180deg,transparent 45%,rgba(0,212,255,.04) 50%,transparent 55%);
  animation:scanline 4s linear infinite;pointer-events:none}
@keyframes scanline{0%{transform:translateY(0)}100%{transform:translateY(100%)}}

/* Top / bottom glow lines */
.login-card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--c) 50%,transparent 100%);
  animation:glowPulse 3s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.6}50%{opacity:1}}

.login-logo{width:72px;height:72px;margin:0 auto 18px;position:relative}
.logo-hex{width:72px;height:72px;background:linear-gradient(135deg,var(--v),var(--c));
  border-radius:16px;display:flex;align-items:center;justify-content:center;
  font-family:'Orbitron',sans-serif;font-size:20px;font-weight:900;
  animation:logoBeat 2.5s ease-in-out infinite;box-shadow:0 0 0 0 rgba(0,212,255,.4)}
@keyframes logoBeat{0%,100%{box-shadow:0 0 0 0 rgba(0,212,255,.4),0 0 30px rgba(124,58,237,.4)}
  50%{box-shadow:0 0 0 12px rgba(0,212,255,0),0 0 50px rgba(0,212,255,.5)}}
.logo-ring{position:absolute;inset:-6px;border:1px solid rgba(0,212,255,.2);border-radius:20px;
  animation:ringRotate 8s linear infinite}
@keyframes ringRotate{to{transform:rotate(360deg)}}
.logo-ring2{position:absolute;inset:-12px;border:1px dashed rgba(124,58,237,.15);border-radius:24px;
  animation:ringRotate 12s linear infinite reverse}

.login-title{font-family:'Orbitron',sans-serif;font-size:18px;font-weight:900;letter-spacing:3px;
  margin-bottom:5px;background:linear-gradient(135deg,#fff,var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-sub{color:var(--t2);font-size:11px;font-family:'JetBrains Mono',monospace;margin-bottom:32px;letter-spacing:1px}

.inp-wrap{position:relative;margin-bottom:12px;text-align:left}
.inp-wrap label{font-size:9px;color:var(--t2);letter-spacing:3px;text-transform:uppercase;
  display:block;margin-bottom:6px;font-family:'JetBrains Mono',monospace}
.inp{width:100%;padding:12px 40px 12px 14px;background:rgba(255,255,255,.04);
  border:1px solid var(--b);border-radius:10px;color:var(--t);font-size:14px;
  font-family:'Syne',sans-serif;outline:none;transition:all .3s;letter-spacing:.3px}
.inp:focus{border-color:var(--c);background:rgba(0,212,255,.04);box-shadow:0 0 0 3px rgba(0,212,255,.08),0 0 20px rgba(0,212,255,.05)}
.eye{position:absolute;right:12px;bottom:12px;background:none;border:none;cursor:pointer;color:var(--t2);font-size:14px;transition:color .2s}
.eye:hover{color:var(--c)}

.login-btn{width:100%;padding:14px;margin-top:6px;
  background:linear-gradient(135deg,var(--v) 0%,var(--c) 100%);
  border:none;border-radius:11px;color:#fff;font-family:'Orbitron',sans-serif;
  font-size:13px;font-weight:700;letter-spacing:2px;cursor:pointer;
  position:relative;overflow:hidden;transition:transform .2s,box-shadow .3s}
.login-btn:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(124,58,237,.4)}
.login-btn:active{transform:translateY(0)}
.login-btn-sweep{position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  animation:btnSweep 3s ease-in-out infinite}
@keyframes btnSweep{0%,100%{left:-100%}50%{left:140%}}

.login-err{color:var(--pk);font-size:11px;margin-top:9px;font-family:'JetBrains Mono',monospace;
  display:none;text-align:center;letter-spacing:.5px}
.login-err.on{display:block;animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}

.pub-hint{margin-top:16px;font-size:11px;color:var(--t2);font-family:'JetBrains Mono',monospace}
.pub-link{color:var(--c);cursor:pointer;position:relative}
.pub-link::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;
  background:var(--c);transform:scaleX(0);transition:transform .2s;transform-origin:left}
.pub-link:hover::after{transform:scaleX(1)}

/* ═══════════════════════
   MODE BANNER
═══════════════════════ */
#banner{display:none;padding:7px 40px;background:rgba(0,212,255,.06);
  border-bottom:1px solid rgba(0,212,255,.12);z-index:200;
  align-items:center;justify-content:space-between;font-size:11px;font-family:'JetBrains Mono',monospace}
#banner.vis{display:flex}
.bn-dot{width:6px;height:6px;border-radius:50%;background:var(--c);
  animation:bnPulse 2s ease-in-out infinite;display:inline-block;margin-right:8px}
@keyframes bnPulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,212,255,.4)}
  50%{opacity:.5;box-shadow:0 0 0 4px rgba(0,212,255,0)}}
.bn-txt{color:var(--c);display:flex;align-items:center}
.bn-cta{color:var(--t2);cursor:pointer;padding:4px 12px;border:1px solid var(--b);border-radius:6px;transition:all .2s}
.bn-cta:hover{color:var(--c);border-color:var(--c)}

/* ═══════════════════════
   HEADER
═══════════════════════ */
header{position:sticky;top:0;z-index:100;padding:13px 40px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(2,5,9,.82);backdrop-filter:blur(28px);
  border-bottom:1px solid var(--b);transition:top .3s}
header.shifted{top:37px}
.h-brand{display:flex;align-items:center;gap:13px}
.h-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--v),var(--c));
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:'Orbitron',sans-serif;font-weight:900;font-size:12px;box-shadow:var(--gc);
  position:relative;overflow:hidden}
.h-logo::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent)}
.h-title{font-family:'Orbitron',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px}
.h-sub{font-size:10px;color:var(--t2);font-family:'JetBrains Mono',monospace;margin-top:2px}
.h-actions{display:flex;align-items:center;gap:8px}

/* Header live indicator */
.live-pill{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;
  background:rgba(0,255,157,.08);border:1px solid rgba(0,255,157,.2);
  font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--g)}
.live-dot{width:5px;height:5px;border-radius:50%;background:var(--g);animation:bnPulse 2s ease-in-out infinite}

.btn-g{padding:7px 15px;border-radius:8px;border:1px solid var(--b);background:var(--s);
  color:var(--t2);font-size:11px;font-family:'Syne',sans-serif;font-weight:600;
  cursor:pointer;transition:all .2s;letter-spacing:.5px}
.btn-g:hover{border-color:var(--c);color:var(--c);background:rgba(0,212,255,.05)}
.btn-p{padding:7px 15px;border-radius:8px;background:linear-gradient(135deg,var(--v),var(--c));
  border:none;color:#fff;font-size:11px;font-family:'Syne',sans-serif;font-weight:700;
  cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,212,255,.25)}
.btn-p::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent)}
.btn-publish{padding:7px 16px;border-radius:8px;background:linear-gradient(135deg,#00ff9d44,#00ff9d22);
  border:1px solid #00ff9d66;color:#00ff9d;font-size:11px;font-family:'Syne',sans-serif;font-weight:700;
  cursor:pointer;transition:all .2s;letter-spacing:.5px;display:none}
.btn-publish:hover{background:rgba(0,255,157,.15);border-color:#00ff9d;box-shadow:0 0 16px rgba(0,255,157,.2)}
.btn-publish.syncing{animation:publishPulse 1s ease-in-out infinite}
@keyframes publishPulse{0%,100%{opacity:1}50%{opacity:.5}}
.adm-only{display:none}
body.admin .adm-only{display:inline-flex}
body.admin .adm-only-flex{display:flex}

/* ═══════════════════════
   HERO
═══════════════════════ */
.hero{padding:60px 40px 44px;max-width:1360px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto;align-items:end;gap:40px}
.hero-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--c);
  letter-spacing:4px;text-transform:uppercase;margin-bottom:12px;
  display:flex;align-items:center;gap:10px;opacity:0;animation:fadeUp .6s .2s ease forwards}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--c)}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.hero-name{font-family:'Orbitron',monospace;font-size:clamp(26px,4vw,54px);font-weight:900;
  line-height:1;letter-spacing:-1px;margin-bottom:5px;
  background:linear-gradient(135deg,#fff 0%,var(--c) 45%,var(--v) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  opacity:0;animation:fadeUp .6s .35s ease forwards}
.hero-role{font-size:clamp(12px,1.6vw,15px);color:var(--t2);margin-bottom:24px;
  font-family:'JetBrains Mono',monospace;opacity:0;animation:fadeUp .6s .5s ease forwards}
.hero-role em{color:var(--y);font-style:normal}

.hero-stats{display:flex;gap:24px;flex-wrap:wrap;opacity:0;animation:fadeUp .6s .65s ease forwards}
.stat{text-align:center;position:relative}
.stat-n{font-family:'Orbitron',sans-serif;font-size:28px;font-weight:900;
  background:linear-gradient(135deg,var(--c),var(--v));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-l{font-size:9px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;margin-top:3px;font-family:'JetBrains Mono',monospace}
/* Stat separator */
.stat:not(:last-child)::after{content:'';position:absolute;right:-12px;top:20%;bottom:20%;width:1px;background:var(--b)}

.hero-badge{background:rgba(124,58,237,.07);border:1px solid rgba(124,58,237,.22);
  border-radius:14px;padding:20px 24px;text-align:center;min-width:160px;
  position:relative;overflow:hidden;opacity:0;animation:fadeUp .6s .8s ease forwards}
.hero-badge::before{content:'ISEA';position:absolute;font-family:'Orbitron',sans-serif;
  font-size:50px;font-weight:900;color:rgba(124,58,237,.04);top:-8px;left:-4px;pointer-events:none}
/* Rotating border */
.hero-badge::after{content:'';position:absolute;inset:-1px;border-radius:14px;
  background:conic-gradient(from var(--angle,0deg),transparent 0%,rgba(124,58,237,.3) 10%,transparent 20%);
  animation:borderSpin 6s linear infinite;z-index:-1}
@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false}
@keyframes borderSpin{to{--angle:360deg}}
.badge-lbl{font-size:9px;color:var(--t2);letter-spacing:3px;text-transform:uppercase;font-family:'JetBrains Mono',monospace}
.badge-ph{font-family:'Orbitron',sans-serif;font-size:24px;font-weight:900;color:var(--v);margin:3px 0}
.badge-pj{font-size:10px;color:var(--t2)}

/* ═══════════════════════
   SEARCH + FILTER
═══════════════════════ */
.sfbar{max-width:1360px;margin:0 auto;padding:20px 40px 0;display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp .6s .9s ease forwards}
.sw{flex:1;min-width:200px;position:relative}
.si{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--t2);font-size:14px;pointer-events:none}
.sinp{width:100%;padding:10px 36px 10px 38px;background:var(--bg2);border:1px solid var(--b);
  border-radius:10px;color:var(--t);font-size:13px;font-family:'Syne',sans-serif;outline:none;transition:all .25s}
.sinp:focus{border-color:var(--c);box-shadow:0 0 0 3px rgba(0,212,255,.07)}
.sinp::placeholder{color:var(--t3)}
.sc{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--t2);cursor:pointer;font-size:13px;display:none}
.sc.on{display:block}
.fg{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.fl{font-size:9px;color:var(--t2);font-family:'JetBrains Mono',monospace;letter-spacing:2px;white-space:nowrap}
.fsel{padding:9px 12px;background:var(--bg2);border:1px solid var(--b);border-radius:9px;
  color:var(--t);font-size:11px;font-family:'JetBrains Mono',monospace;outline:none;cursor:pointer;transition:all .2s;min-width:130px}
.fsel:focus{border-color:var(--v);box-shadow:0 0 0 3px rgba(124,58,237,.08)}
.fsel option{background:var(--bg2)}
.freset{padding:9px 13px;border-radius:9px;border:1px solid var(--b);background:transparent;
  color:var(--t2);font-size:10px;font-family:'JetBrains Mono',monospace;cursor:pointer;transition:all .2s}
.freset:hover{border-color:var(--pk);color:var(--pk)}

.rmeta{max-width:1360px;margin:10px auto 0;padding:0 40px;font-size:10px;color:var(--t2);font-family:'JetBrains Mono',monospace;display:flex;align-items:center;gap:6px}
.rmeta span{color:var(--c)}

/* ═══════════════════════
   TABS
═══════════════════════ */
.tabs{max-width:1360px;margin:18px auto 28px;padding:0 40px;display:flex;gap:3px;overflow-x:auto}
.tabs::-webkit-scrollbar{height:2px}.tabs::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
.tab{padding:8px 16px;border-radius:8px;border:1px solid var(--b);background:transparent;
  color:var(--t2);font-size:11px;font-family:'Syne',sans-serif;font-weight:600;
  cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}
.tdot{width:5px;height:5px;border-radius:50%;background:var(--t3);transition:all .25s}
.tab:hover{color:var(--t);border-color:var(--b2)}
.tab.on{background:var(--s2);border-color:var(--c);color:var(--c)}
.tab.on .tdot{background:var(--c);box-shadow:0 0 8px var(--c)}
.tcnt{background:rgba(0,212,255,.1);border-radius:20px;padding:1px 7px;font-size:9px;font-family:'JetBrains Mono',monospace;color:var(--c)}

/* ═══════════════════════
   CONTENT
═══════════════════════ */
.content{max-width:1360px;margin:0 auto;padding:0 40px 120px}

/* ═══════════════════════
   CARDS
═══════════════════════ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px}

.card{background:rgba(6,13,22,.88);border:1px solid var(--b);border-radius:18px;
  overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);
  animation:cardIn .55s ease both;transform-style:preserve-3d}
@keyframes cardIn{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Hover tilt effect handled via JS */
.card:hover{border-color:var(--b2);box-shadow:0 28px 70px rgba(0,0,0,.55),0 0 0 1px rgba(0,212,255,.07)}

/* Glowing accent bar */
.card-bar{height:2px;width:100%;position:relative;overflow:visible}
.card-bar::after{content:'';position:absolute;top:-4px;left:10%;right:10%;height:8px;
  background:inherit;filter:blur(6px);opacity:.8}

/* Corner glow on hover */
.card::before{content:'';position:absolute;inset:0;border-radius:18px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(0,212,255,.06) 0%,transparent 60%);
  opacity:0;transition:opacity .3s;pointer-events:none;z-index:0}
.card:hover::before{opacity:1}

.card-img{width:100%;height:154px;overflow:hidden;position:relative;background:var(--bg3);cursor:pointer}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.card-img:hover img{transform:scale(1.06)}
.card-img-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--t3)}
.card-img-ph .phi{font-size:24px;opacity:.4}
.card-img-ph span{font-size:10px;font-family:'JetBrains Mono',monospace}
/* Admin img hover overlay */
.img-add-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px;
  background:rgba(0,212,255,.07);opacity:0;transition:opacity .2s;cursor:pointer;
  font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--c)}
.card-img:hover .img-add-ov{opacity:1}
body:not(.admin) .img-add-ov{display:none}
.img-cnt{position:absolute;bottom:8px;right:8px;background:rgba(2,5,9,.75);
  border:1px solid var(--b);border-radius:5px;padding:2px 7px;
  font-size:9px;font-family:'JetBrains Mono',monospace;color:var(--t2)}

.card-body{padding:18px;position:relative;z-index:1}
.card-row1{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.card-ic{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;position:relative;overflow:hidden}
.card-ic::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent)}
.cbadges{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.badge{padding:2px 8px;border-radius:20px;font-size:9px;font-weight:600;font-family:'JetBrains Mono',monospace;letter-spacing:1px;text-transform:uppercase}
.b-done{background:rgba(0,255,157,.1);color:var(--g);border:1px solid rgba(0,255,157,.2)}
.b-up{background:rgba(255,107,53,.1);color:var(--o);border:1px solid rgba(255,107,53,.2)}
.b-on{background:rgba(0,212,255,.1);color:var(--c);border:1px solid rgba(0,212,255,.2)}

.ctag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;
  font-size:9px;font-weight:600;font-family:'JetBrains Mono',monospace;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.ctitle{font-size:14px;font-weight:700;margin-bottom:5px;line-height:1.35;
  transition:color .2s}
.card:hover .ctitle{color:var(--c)}
.corg{font-size:11px;color:var(--t2);font-family:'JetBrains Mono',monospace;margin-bottom:9px}
.cmeta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.cmi{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--t2);font-family:'JetBrains Mono',monospace}
.cdesc{font-size:11.5px;color:var(--t2);line-height:1.65;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

.cfoot{margin:12px 0 0;padding:12px 0 0;border-top:1px solid var(--b);display:flex;align-items:center}
.pbar{flex:1;margin-right:8px}
.pb-lbl{font-size:9px;color:var(--t3);font-family:'JetBrains Mono',monospace;margin-bottom:4px}
.pb-track{height:3px;background:var(--b);border-radius:2px;overflow:hidden}
.pb-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--c),var(--v));
  transition:width 1.4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.pb-fill::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  animation:pbShimmer 2.5s ease-in-out infinite}
@keyframes pbShimmer{0%{left:-100%}100%{left:200%}}
.pnum{font-family:'Orbitron',sans-serif;font-size:15px;font-weight:700;text-align:right}
.punit{font-size:9px;color:var(--t3);text-align:right}
.cbtns{display:flex;gap:5px;margin-left:8px}
.cbtn{width:30px;height:30px;border-radius:7px;border:1px solid var(--b);background:var(--s);
  color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .2s}
.cbtn:hover{border-color:var(--c);color:var(--c);background:rgba(0,212,255,.05);transform:scale(1.1)}
.cbtn.del:hover{border-color:var(--pk);color:var(--pk);background:rgba(247,37,133,.05)}
body:not(.admin) .cbtns{display:none}

/* ═══════════════════════
   EMPTY
═══════════════════════ */
.empty{text-align:center;padding:60px 20px;grid-column:1/-1}
.empty-ic{font-size:40px;margin-bottom:12px;opacity:.2;animation:floatIc 3s ease-in-out infinite}
@keyframes floatIc{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.empty-t{font-size:17px;font-weight:700;color:var(--t2);margin-bottom:5px}
.empty-s{font-size:11px;color:var(--t3);font-family:'JetBrains Mono',monospace}

/* ═══════════════════════
   LIGHTBOX
═══════════════════════ */
#lb{position:fixed;inset:0;z-index:3000;background:rgba(2,5,9,.96);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity .3s}
#lb.on{opacity:1;pointer-events:all}
#lb img{max-width:88vw;max-height:82vh;border-radius:12px;object-fit:contain;
  box-shadow:0 0 80px rgba(0,0,0,.8);transition:transform .3s}
.lb-x{position:absolute;top:18px;right:22px;background:none;border:none;color:var(--t2);font-size:26px;cursor:pointer;transition:all .2s}
.lb-x:hover{color:var(--pk);transform:rotate(90deg)}
.lbn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.06);
  border:1px solid var(--b);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--t);font-size:16px;transition:all .2s}
.lbn:hover{background:rgba(0,212,255,.12);border-color:var(--c)}
.lbp{left:18px}.lbn2{right:18px}

/* ═══════════════════════
   ADMIN MODAL
═══════════════════════ */
#adminPanel{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;
  background:rgba(2,5,9,.88);backdrop-filter:blur(16px);padding:20px;
  opacity:0;pointer-events:none;transition:opacity .3s}
#adminPanel.on{opacity:1;pointer-events:all}
.amodal{background:var(--bg2);border:1px solid var(--b2);border-radius:22px;width:100%;
  max-width:640px;max-height:92vh;overflow-y:auto;box-shadow:0 0 120px rgba(0,212,255,.06);position:relative}
.amodal::-webkit-scrollbar{width:4px}.amodal::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
/* Modal glow top */
.amodal::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c),var(--v),transparent)}
.mhdr{padding:24px 28px 20px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:var(--bg2);z-index:1;border-radius:22px 22px 0 0}
.mtitle{font-family:'Orbitron',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px}
.mtitle em{color:var(--c);font-style:normal}
.mx{background:none;border:none;color:var(--t2);font-size:17px;cursor:pointer;
  width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.mx:hover{color:var(--pk);background:rgba(247,37,133,.08)}
.mbody{padding:24px 28px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg2{margin-bottom:14px}
.fg2.full{grid-column:1/-1}
.flbl{font-size:9px;color:var(--t2);letter-spacing:2px;text-transform:uppercase;
  display:block;margin-bottom:6px;font-family:'JetBrains Mono',monospace}
.finp,.fsel,.ftxt{width:100%;padding:11px 13px;background:rgba(255,255,255,.04);
  border:1px solid var(--b);border-radius:9px;color:var(--t);font-size:13px;
  font-family:'Syne',sans-serif;outline:none;transition:all .25s}
.finp:focus,.fsel:focus,.ftxt:focus{border-color:var(--c);background:rgba(0,212,255,.03);box-shadow:0 0 0 3px rgba(0,212,255,.07)}
.fsel option{background:var(--bg2)}
.ftxt{resize:vertical;min-height:78px}
.mftr{padding:16px 28px 24px;display:flex;gap:8px;justify-content:flex-end}

/* Image upload */
.iuz{border:1px dashed var(--b2);border-radius:11px;padding:16px;text-align:center;
  cursor:pointer;transition:all .2s;position:relative;margin-top:5px}
.iuz:hover{border-color:var(--c);background:rgba(0,212,255,.03)}
.iuz input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.iuz-ic{font-size:22px;margin-bottom:5px}
.iuz-t{font-size:11px;color:var(--t2);font-family:'JetBrains Mono',monospace}
.iuz-h{font-size:9px;color:var(--t3);font-family:'JetBrains Mono',monospace;margin-top:2px}
.iprev{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.ithw{position:relative;display:inline-block}
.ith{width:68px;height:68px;border-radius:8px;object-fit:cover;border:1px solid var(--b);cursor:pointer;transition:transform .2s}
.ith:hover{transform:scale(1.05)}
.ithr{position:absolute;top:-4px;right:-4px;width:17px;height:17px;border-radius:50%;
  background:var(--pk);border:none;color:#fff;font-size:9px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-weight:700;transition:transform .2s}
.ithr:hover{transform:scale(1.15)}

/* ═══════════════════════
   DOWNLOAD FAB
═══════════════════════ */
#dlFab{position:fixed;bottom:26px;right:26px;z-index:300}
.dlt{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--v),var(--c));
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 8px 28px rgba(0,212,255,.28);transition:all .3s;position:relative;overflow:hidden}
.dlt:hover{transform:scale(1.12) rotate(10deg);box-shadow:0 14px 40px rgba(0,212,255,.5)}
.dlt::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent)}
.dlm{position:absolute;bottom:64px;right:0;background:var(--bg2);border:1px solid var(--b2);
  border-radius:15px;padding:7px;min-width:215px;
  opacity:0;transform:translateY(8px) scale(.95);pointer-events:none;transition:all .22s;
  box-shadow:0 24px 60px rgba(0,0,0,.6)}
.dlm::before{content:'';position:absolute;bottom:-1px;right:0;left:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c),transparent)}
.dlm.on{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.dli{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s;font-size:12px}
.dli:hover{background:var(--s2);transform:translateX(2px)}
.dlic{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.dlic-pdf{background:rgba(247,37,133,.1)}
.dlic-word{background:rgba(0,212,255,.1)}
.dlic-pro{background:rgba(255,214,10,.1)}
.dli-t{font-weight:600;font-size:12px}
.dli-s{font-size:9px;color:var(--t2);font-family:'JetBrains Mono',monospace}

/* Admin FAB */
.afab{position:fixed;bottom:26px;left:26px;z-index:300;width:46px;height:46px;border-radius:50%;
  background:var(--s2);border:1px solid var(--b);color:var(--t2);font-size:17px;cursor:pointer;
  display:none;align-items:center;justify-content:center;transition:all .2s;
  box-shadow:0 4px 18px rgba(0,0,0,.3)}
.afab:hover{border-color:var(--v);color:var(--v);box-shadow:var(--gv);transform:rotate(90deg)}
body.admin .afab{display:flex}

/* ═══════════════════════
   TOAST
═══════════════════════ */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(14px);
  background:rgba(6,13,22,.97);border:1px solid var(--b2);border-radius:9px;
  padding:10px 20px;font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--c);
  z-index:9999;opacity:0;transition:all .3s;white-space:nowrap;pointer-events:none;
  box-shadow:0 10px 40px rgba(0,0,0,.5)}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══════════════════════
   EXPORT PREVIEW MODAL
═══════════════════════ */
#expModal{position:fixed;inset:0;z-index:4000;display:flex;align-items:center;justify-content:center;
  background:rgba(2,5,9,.92);backdrop-filter:blur(20px);padding:20px;
  opacity:0;pointer-events:none;transition:opacity .3s}
#expModal.on{opacity:1;pointer-events:all}
.exp-card{background:var(--bg2);border:1px solid var(--b2);border-radius:20px;
  width:min(500px,92vw);padding:32px;text-align:center;position:relative;overflow:hidden}
.exp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--y),transparent)}
.exp-title{font-family:'Orbitron',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;margin-bottom:6px}
.exp-sub{color:var(--t2);font-size:12px;font-family:'JetBrains Mono',monospace;margin-bottom:24px}
.exp-progress{width:100%;height:4px;background:var(--b);border-radius:2px;overflow:hidden;margin-bottom:8px}
.exp-bar{height:100%;background:linear-gradient(90deg,var(--c),var(--v),var(--pk));
  border-radius:2px;width:0%;transition:width .3s;background-size:200% 100%;
  animation:gradMove 2s linear infinite}
@keyframes gradMove{0%{background-position:0%}100%{background-position:200%}}
.exp-status{font-size:11px;color:var(--t2);font-family:'JetBrains Mono',monospace}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:3px}

/* RESPONSIVE */
@media(max-width:800px){
  header,.hero,.tabs,.content,.sfbar,.rmeta{padding-left:18px;padding-right:18px}
  .hero{grid-template-columns:1fr;padding-top:32px}.hero-badge{display:none}
  .grid{grid-template-columns:1fr}.frow{grid-template-columns:1fr}
  #dlFab{bottom:16px;right:16px}.afab{bottom:16px;left:16px}
  #banner,.bn-cta{padding-left:18px;padding-right:18px}
}

/* Highlight match */
mark{background:rgba(0,212,255,.22);color:#fff;border-radius:3px;padding:0 2px;font-style:normal}
