/* ============================================================
   RESET + TOKENS
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#080B18;
  --surf:rgba(255,255,255,0.055);
  --surf2:rgba(255,255,255,0.11);
  --border:rgba(255,255,255,0.09);
  --border2:rgba(255,255,255,0.18);
  --t1:#F0F4FF;
  --t2:#94A3B8;
  --t3:#475569;
  --brand:#7C3AED;
  --brand-l:#A78BFA;
  --brand-g:rgba(124,58,237,0.28);
  --green:#10B981;
  --green-g:rgba(16,185,129,0.18);
  --amber:#F59E0B;
  --amber-g:rgba(245,158,11,0.18);
  --red:#EF4444;
  --red-g:rgba(239,68,68,0.18);
  --r:14px;
  --r-sm:8px;
  --r-pill:9999px;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--t1);min-height:100vh;overflow-x:hidden}

/* ============================================================
   VIEW SWITCHER
============================================================ */
.view{display:none;min-height:100vh}
.view.active{display:block;animation:fadeV .35s ease}
@keyframes fadeV{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   LOGIN PAGE
============================================================ */
#login-view{
  background:linear-gradient(150deg,#388E3C 0%,#1B5E20 60%,#0a3d10 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:100vh;padding:30px 20px;
}
#login-view.active{display:grid!important;place-items:center}
.login-wrap{width:100%;max-width:340px;position:relative;margin:auto}
.panda-stage{position:relative;display:flex;justify-content:center;height:110px;margin-bottom:-18px;z-index:20}
.panda-face{position:relative;width:110px;height:95px;background:#fff;border-radius:50%;box-shadow:0 12px 40px rgba(0,0,0,0.25);z-index:5}
.ear{width:30px;height:30px;background:#111;border-radius:50%;position:absolute;top:-8px}
.ear.l{left:10px;transform:rotate(-30deg)}.ear.r{right:10px;transform:rotate(30deg)}
.ep{width:34px;height:28px;background:#111;border-radius:50%;position:absolute;top:22px}
.ep.l{left:10px}.ep.r{right:10px}
.ew{width:14px;height:14px;background:#fff;border-radius:50%;position:absolute;top:8px;left:10px}
.ew::after{content:'';width:7px;height:7px;background:#111;border-radius:50%;position:absolute;top:3.5px;left:3.5px}
.panda-nose{width:13px;height:9px;background:#2d1a0e;border-radius:50%;position:absolute;bottom:22px;left:50%;transform:translateX(-50%)}
.blush{width:20px;height:11px;background:#ff8bb1;border-radius:50%;position:absolute;bottom:22px;opacity:.65}
.blush.l{left:11px;transform:rotate(20deg)}.blush.r{right:11px;transform:rotate(-20deg)}
.panda-mouth{width:16px;height:7px;border:2.5px solid #2d1a0e;border-top:none;border-radius:0 0 8px 8px;position:absolute;bottom:12px;left:50%;transform:translateX(-50%)}
.arms{position:absolute;width:150px;height:112px;left:50%;top:0;transform:translateX(-50%);z-index:10;pointer-events:none}
.arm{position:absolute;top:56px;width:32px;height:74px;background:#111;border-radius:18px;transform-origin:50% 8px;transition:left .48s cubic-bezier(.34,1.4,.64,1),right .48s cubic-bezier(.34,1.4,.64,1),top .48s cubic-bezier(.34,1.4,.64,1),transform .48s cubic-bezier(.34,1.4,.64,1);box-shadow:0 8px 14px rgba(0,0,0,.14)}
.arm.l{left:0;transform:rotate(-34deg)}.arm.r{right:0;transform:rotate(34deg)}
.panda-stage.covering .arm.l{left:30px;top:34px;transform:rotate(82deg)}
.panda-stage.covering .arm.r{right:30px;top:34px;transform:rotate(-82deg)}
.paws{display:flex;justify-content:center;gap:22px;position:relative;z-index:20;margin-top:-4px}
.paw{width:42px;height:36px;background:#111;border-radius:50%;position:relative}
.paw::before{content:'';position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:13px;height:13px;background:#111;border-radius:50%;box-shadow:-10px 0 0 #111,10px 0 0 #111}

/* Login Card */
.login-card{background:#fff;border-radius:20px;padding:36px 28px 28px;box-shadow:0 24px 70px rgba(0,0,0,0.35);position:relative;z-index:5}
.role-tabs{display:flex;gap:6px;background:#f1f1f1;padding:4px;border-radius:10px;margin-bottom:22px}
.rtab{flex:1;padding:8px 0;border:none;border-radius:7px;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:#666;transition:all .2s}
.rtab.active{background:#fff;color:#111;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.login-label{display:block;font-family:'Space Grotesk',sans-serif;font-size:12.5px;font-weight:700;color:#444;margin-bottom:6px;letter-spacing:.3px}
.login-input{width:100%;padding:11px 14px;border:2px solid #e0e0e0;border-radius:10px;font-family:'Inter',sans-serif;font-size:15px;color:#111;margin-bottom:16px;outline:none;transition:border-color .2s;background:#fafafa}
.login-input:focus{border-color:#43A047;background:#fff}
.pw-wrap{position:relative}
.pw-wrap .login-input{margin-bottom:0;padding-right:44px}
.pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:17px;color:#888;line-height:1}
.login-btn{width:100%;padding:13px;margin-top:18px;background:linear-gradient(135deg,#43A047,#1B5E20);color:#fff;border:none;border-radius:10px;font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(27,94,32,.4)}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(27,94,32,.55)}
.login-hint{text-align:center;font-size:11px;color:#aaa;margin-top:14px;line-height:1.6}

/* ============================================================
   ANIMATED BLOB BACKGROUND
============================================================ */
.bg-mesh{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.28;animation:bfloat 9s ease-in-out infinite alternate}
.b1{width:440px;height:440px;background:radial-gradient(ellipse,#FF6B9D,#C9184A);top:-120px;right:-80px;animation-delay:0s}
.b2{width:360px;height:360px;background:radial-gradient(ellipse,#7C3AED,#4C1D95);bottom:-80px;left:-60px;animation-delay:-4s}
.b3{width:280px;height:280px;background:radial-gradient(ellipse,#38BDF8,#818CF8);top:40%;left:38%;animation-delay:-7s}
@keyframes bfloat{0%{transform:translate(0,0) scale(1)}100%{transform:translate(25px,15px) scale(1.08)}}

/* ============================================================
   LIQUID GLASS NAV
============================================================ */
.nav-wrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:1000}
.liq-nav{background:rgba(255,255,255,0.13);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid rgba(255,255,255,0.22);border-radius:var(--r-pill);padding:5px;display:flex;align-items:center;gap:4px;position:relative;box-shadow:0 8px 32px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.28)}
.liq-nav::before{content:'';position:absolute;top:0;left:10%;right:10%;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 100%);border-radius:var(--r-pill) var(--r-pill) 0 0;pointer-events:none}
.nav-items{display:flex;align-items:center;gap:2px;position:relative}
.a-pill{position:absolute;background:rgba(255,255,255,.9);border-radius:var(--r-pill);box-shadow:0 2px 10px rgba(0,0,0,.14);transition:all .38s cubic-bezier(.34,1.56,.64,1);pointer-events:none;z-index:0}
.nbtn{background:none;border:none;cursor:pointer;border-radius:var(--r-pill);padding:8px 15px;display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.88);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;position:relative;z-index:1;transition:color .2s;white-space:nowrap}
.nbtn.active{color:rgba(0,0,0,.8)}
.nbtn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-divider{width:1px;height:22px;background:rgba(255,255,255,.2);margin:0 3px}
.n-icon-btn{background:none;border:none;cursor:pointer;padding:8px 10px;color:rgba(255,255,255,.8);display:flex;align-items:center}
.n-icon-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ============================================================
   MAIN CONTENT
============================================================ */
.main{position:relative;z-index:1;padding-top:88px;padding-bottom:50px;min-height:100vh}
.container{max-width:680px;margin:0 auto;padding:0 18px}
.container.wide{max-width:960px}
.pg-hdr{text-align:center;margin-bottom:30px;padding-top:10px}
.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(167,139,250,.12);border:1px solid rgba(167,139,250,.3);border-radius:var(--r-pill);padding:4px 13px;font-size:11.5px;font-weight:600;color:var(--brand-l);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px}
.pg-title{font-family:'Space Grotesk',sans-serif;font-size:30px;font-weight:800;line-height:1.2;color:var(--t1)}
.pg-sub{font-size:14px;color:var(--t2);margin-top:7px}

/* ============================================================
   GLASS CARDS + FORM
============================================================ */
.gc{background:var(--surf);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--border);border-radius:var(--r);padding:26px;position:relative;overflow:hidden}
.gc::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent)}
.fgrp{margin-bottom:18px}
.flabel{display:block;font-size:12.5px;font-weight:600;color:var(--t2);margin-bottom:7px;letter-spacing:.3px}
.finput{width:100%;background:rgba(255,255,255,.05);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:11px 15px;color:var(--t1);font-family:'Inter',sans-serif;font-size:14.5px;outline:none;transition:all .2s}
.finput::placeholder{color:var(--t3)}
.finput:focus{border-color:var(--brand);background:rgba(124,58,237,.07);box-shadow:0 0 0 3px var(--brand-g)}
.fhint{font-size:11.5px;color:var(--t3);margin-top:5px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.seg{display:flex;gap:6px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--r-sm);padding:5px}
.seg button{flex:1;border:none;border-radius:6px;background:transparent;color:var(--t2);padding:9px 8px;font-family:'Space Grotesk',sans-serif;font-size:12.5px;font-weight:700;cursor:pointer;transition:all .2s}
.seg button.active{background:rgba(255,255,255,.9);color:#111}
.file-actions{display:flex;gap:8px;justify-content:flex-start;margin-top:8px;flex-wrap:wrap}
.price-box{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.price-chip{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px}
.price-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:3px}
.price-val{font-family:'Space Grotesk',sans-serif;font-weight:800;color:var(--t1)}
.pay-note{background:rgba(124,58,237,.08);border:1px solid rgba(124,58,237,.2);border-radius:var(--r-sm);padding:12px 14px;margin-top:14px;font-size:12.5px;color:var(--brand-l);line-height:1.5}
.upload-z{border:2px dashed var(--border);border-radius:var(--r-sm);padding:26px;text-align:center;cursor:pointer;transition:all .2s;background:rgba(255,255,255,.02)}
.upload-z:hover,.upload-z.filled{border-color:var(--brand);background:rgba(124,58,237,.06)}
.up-icon{font-size:30px;margin-bottom:7px}
.up-text{font-size:13.5px;color:var(--t2)}
.up-text span{color:var(--brand-l);font-weight:600}
.up-sub{font-size:11.5px;color:var(--t3);margin-top:3px}

/* ============================================================
   CAPACITY BAR
============================================================ */
.cap-bar{background:var(--surf);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;display:flex;align-items:center;gap:14px;margin-bottom:18px}
.cap-lbl{font-size:12.5px;color:var(--t2);white-space:nowrap}
.cap-track{flex:1;height:6px;background:rgba(255,255,255,.07);border-radius:var(--r-pill);overflow:hidden}
.cap-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--green),var(--brand));transition:width .5s ease}
.cap-cnt{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;color:var(--t1);white-space:nowrap}
.full-alert{background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.25);border-radius:var(--r);padding:14px 18px;color:var(--red);font-size:13.5px;text-align:center;margin-bottom:18px}

/* ============================================================
   BUTTONS
============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 22px;border:none;border-radius:var(--r-sm);font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-pri{background:linear-gradient(135deg,#7C3AED,#5B21B6);color:#fff;width:100%;padding:14px;font-size:15px;box-shadow:0 4px 18px rgba(124,58,237,.38)}
.btn-pri:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,58,237,.5)}
.btn-pri:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-grn{background:linear-gradient(135deg,#10B981,#059669);color:#fff;box-shadow:0 2px 8px var(--green-g)}
.btn-amb{background:linear-gradient(135deg,#F59E0B,#D97706);color:#fff;box-shadow:0 2px 8px var(--amber-g)}
.btn-ghost{background:var(--surf);color:var(--t1);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--surf2)}
.btn-sm{padding:7px 13px;font-size:12px;border-radius:6px}
.btn-danger{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.btn-wa{background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;display:inline-flex;align-items:center;gap:5px}

/* ============================================================
   DIGITAL TICKET
============================================================ */
.ticket{background:linear-gradient(145deg,#1C1040 0%,#2D1B69 50%,#1C1040 100%);border:1px solid rgba(167,139,250,.35);border-radius:20px;padding:26px;position:relative;overflow:hidden;margin-bottom:16px}
.ticket::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--brand-l),transparent)}
.ticket::after{content:'';position:absolute;inset:0;background-image:radial-gradient(1.5px 1.5px at 20% 30%,rgba(255,255,255,.2) 0%,transparent 100%),radial-gradient(1px 1px at 60% 20%,rgba(255,255,255,.15) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 80% 60%,rgba(255,255,255,.18) 0%,transparent 100%);pointer-events:none}
.t-logo{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:18px}
.t-logo-icon{width:30px;height:30px;background:var(--brand);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:17px}
.t-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.t-token-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:4px}
.t-token{font-family:'Courier New',monospace;font-size:40px;font-weight:700;color:#fff;letter-spacing:3px;line-height:1}
.t-qr{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
#qr-box{background:#fff;padding:8px;border-radius:10px;width:108px;height:108px;overflow:hidden}
.qr-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.3);margin-top:7px}
.t-divider{border:none;border-top:2px dashed rgba(167,139,250,.25);margin:18px 0;position:relative}
.t-divider::before,.t-divider::after{content:'';width:18px;height:18px;background:var(--bg);border-radius:50%;position:absolute;top:-10px}
.t-divider::before{left:-36px}.t-divider::after{right:-36px}
.t-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.t-meta-item{background:rgba(255,255,255,.06);border-radius:10px;padding:11px}
.t-meta-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.35);margin-bottom:4px}
.t-meta-val{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:#fff}
.t-bottom{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-top:2px}
.t-name{font-family:'Space Grotesk',sans-serif;font-size:15.5px;font-weight:600;color:#fff}
.t-doc{font-size:11.5px;color:rgba(255,255,255,.45);margin-top:2px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.t-issued{font-size:11px;color:rgba(255,255,255,.3);margin-top:4px;line-height:1.5}

/* ============================================================
   STATUS BADGES
============================================================ */
.sbadge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600}
.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.s-pending{background:rgba(245,158,11,.12);color:var(--amber);border:1px solid rgba(245,158,11,.28)}
.s-pending .sdot{background:var(--amber);animation:pulse-a 1.5s infinite}
.s-printing{background:rgba(167,139,250,.12);color:var(--brand-l);border:1px solid rgba(167,139,250,.28)}
.s-printing .sdot{background:var(--brand-l);animation:pulse-b 1s infinite}
.s-ready{background:var(--green-g);color:var(--green);border:1px solid rgba(16,185,129,.3)}
.s-ready .sdot{background:var(--green)}
.s-collected{background:rgba(71,85,105,.2);color:var(--t2);border:1px solid rgba(71,85,105,.3)}
.s-collected .sdot{background:var(--t2)}
@keyframes pulse-a{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}
@keyframes pulse-b{0%,100%{opacity:1}50%{opacity:.3}}

/* ============================================================
   COUNTDOWN + BANNERS
============================================================ */
.cdown{background:var(--surf);border:1px solid var(--border);border-radius:var(--r);padding:18px;display:flex;align-items:center;gap:16px;margin-bottom:14px}
.cdown-icon{font-size:30px}
.cdown-lbl{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:3px}
.cdown-val{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;color:var(--brand-l)}
.cdown-sub{font-size:12px;color:var(--t2);margin-top:2px}
.ready-banner{background:linear-gradient(135deg,rgba(5,150,105,.2),rgba(16,185,129,.1));border:1px solid rgba(16,185,129,.35);border-radius:var(--r);padding:18px 22px;display:flex;align-items:center;gap:15px;margin-bottom:16px;animation:slideD .45s cubic-bezier(.34,1.56,.64,1)}
.collected-banner{background:linear-gradient(135deg,rgba(71,85,105,.2),rgba(100,116,139,.1));border:1px solid rgba(71,85,105,.3);border-radius:var(--r);padding:18px 22px;display:flex;align-items:center;gap:15px;margin-bottom:16px}
.rb-icon{font-size:34px}
.rb-title{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:var(--green)}
.rb-sub{font-size:12.5px;color:rgba(255,255,255,.65);margin-top:2px}
.collected-banner .rb-title{color:var(--t2)}
@keyframes slideD{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   MY JOBS LIST (Student)
============================================================ */
.job-history{margin-top:4px;display:grid;gap:10px}
.mini-job{background:rgba(255,255,255,.045);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 16px;display:flex;align-items:center;gap:12px;justify-content:space-between;transition:background .15s}
.mini-job:hover{background:rgba(255,255,255,.07)}
.mini-info{flex:1;min-width:0}
.mini-title{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;color:var(--t1)}
.mini-sub{font-size:12px;color:var(--t2);margin-top:3px}
.mini-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
.empty-jobs{text-align:center;padding:40px 20px;color:var(--t3);font-size:14px}

/* ============================================================
   SHOPKEEPER DASHBOARD
============================================================ */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px}
.sc{background:var(--surf);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center}
.sc-num{font-family:'Space Grotesk',sans-serif;font-size:30px;font-weight:700}
.sc-lbl{font-size:11.5px;color:var(--t3);margin-top:3px}
.sc.amb .sc-num{color:var(--amber)}.sc.brd .sc-num{color:var(--brand-l)}.sc.grn .sc-num{color:var(--green)}
.q-table{background:var(--surf);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.q-thead{display:grid;grid-template-columns:95px 1fr 115px 180px;gap:10px;padding:11px 18px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--border);font-size:10.5px;text-transform:uppercase;letter-spacing:.9px;color:var(--t3);font-weight:600}
.q-row{display:grid;grid-template-columns:95px 1fr 115px 180px;gap:10px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.04);align-items:center;transition:background .12s}
.q-row:last-child{border-bottom:none}
.q-row:hover{background:rgba(255,255,255,.03)}
.q-token{font-family:'Courier New',monospace;font-size:13px;font-weight:700;color:var(--brand-l)}
.q-name{font-size:13.5px;font-weight:600;color:var(--t1)}
.q-doc{font-size:11.5px;color:var(--t3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.q-time{font-size:10.5px;color:var(--t3);margin-top:3px}
.q-acts{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.empty-q{text-align:center;padding:55px 20px;color:var(--t3)}
.empty-q-icon{font-size:46px;margin-bottom:12px}
.search-row{display:flex;gap:10px;margin-bottom:18px}
.s-input{flex:1;background:var(--surf);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:11px 16px;color:var(--t1);font-family:'Inter',sans-serif;font-size:14px;outline:none;transition:all .2s}
.s-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-g)}
.s-input::placeholder{color:var(--t3)}

/* ============================================================
   TOAST NOTIFICATIONS
============================================================ */
.toast-wrap{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:rgba(15,18,40,.96);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--r);padding:11px 18px;color:var(--t1);font-size:13.5px;box-shadow:0 8px 32px rgba(0,0,0,.5);animation:tin .3s ease,tout .3s ease 3.8s forwards;display:flex;align-items:center;gap:10px;max-width:400px;white-space:nowrap}
.toast.ok{border-color:rgba(16,185,129,.3)}
.toast.err{border-color:rgba(239,68,68,.3)}
.toast.info{border-color:rgba(124,58,237,.3)}
@keyframes tin{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes tout{from{opacity:1}to{opacity:0;pointer-events:none}}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:760px){
  .q-thead,.q-row{grid-template-columns:80px 1fr 95px}
  .q-thead>*:nth-child(4),.q-row>*:nth-child(4){display:none}
}
@media(max-width:600px){
  .t-token{font-size:30px;letter-spacing:2px}
  .pg-title{font-size:24px}
  .nbtn span{display:none}
  .nbtn{padding:8px 10px}
  .two-col{grid-template-columns:1fr}
  .price-box{grid-template-columns:1fr 1fr 1fr}
}
@media(min-width:601px){.nbtn span{display:inline}}
