:root{
  --bg:#ffffff; --bg-soft:#f6f6f7; --ink:#0b0b0d; --ink-2:#1c1d22;
  --muted:#737682; --line:#ececee; --line-2:#e3e3e6;
  --dark:#0c0c0e; --dark-2:#16171b;
  --accent:#111114; --red:#e4002b; --green:#16a34a; --gold:#d9a400; --blue:#2563eb;
  --radius:22px; --radius-sm:14px;
  --shadow-sm:0 2px 10px rgba(16,18,24,.06);
  --shadow:0 18px 50px rgba(16,18,24,.12);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  min-height:100vh; -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3{letter-spacing:-.02em;}
::-webkit-scrollbar{height:8px;width:8px;}
::-webkit-scrollbar-thumb{background:#dcdce0;border-radius:8px;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav-inner{max-width:1240px;margin:0 auto;padding:13px 24px;display:flex;align-items:center;gap:30px;}
.brand{display:flex;align-items:center;gap:9px;font-weight:900;font-size:20px;}
.brand-mark{color:var(--ink);transform:rotate(0deg);}
.nav-links{display:flex;gap:26px;align-items:center;}
.nav-links a{color:#3b3d44;font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:6px;}
.nav-links a:hover,.nav-links a.active{color:var(--ink);}
.nav-links .more{color:var(--muted);}
.pill-new{background:#d6fbe4;color:#0f8a43;font-size:10px;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:.4px;}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px;}

.icon-btn{display:flex;align-items:center;gap:7px;border:1px solid var(--line-2);background:#fff;border-radius:11px;padding:9px 13px;font-weight:700;font-size:13.5px;color:var(--ink);}
.icon-btn:hover{background:var(--bg-soft);}
.bal-chip{display:flex;align-items:center;gap:10px;font-weight:800;font-size:14px;}
.bal-chip .bal{padding:9px 12px;}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#00d3b8);display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;}

/* ---------- buttons ---------- */
.btn{border:1px solid var(--line-2);background:#fff;color:var(--ink);padding:11px 18px;border-radius:999px;font-weight:700;font-size:14px;transition:transform .08s,background .15s,box-shadow .15s;}
.btn:hover{transform:translateY(-1px);}
.btn-dark{background:var(--accent);color:#fff;border:none;box-shadow:var(--shadow-sm);}
.btn-dark:hover{filter:brightness(1.12);}
.btn-white{background:#fff;color:var(--ink);border:none;}
.btn-sm{padding:8px 13px;font-size:13px;}
.btn-block{width:100%;text-align:center;}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;}

/* ---------- layout ---------- */
.wrap{max-width:1240px;margin:0 auto;padding:30px 24px 70px;}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 0 20px;flex-wrap:wrap;}
.section-head h2{font-size:30px;font-weight:900;margin:0;}
.section-head .link{color:var(--muted);font-weight:700;font-size:13.5px;}
.center-head{text-align:center;margin:54px 0 26px;}
.center-head .eyebrow{font-size:12px;font-weight:800;letter-spacing:2px;color:var(--muted);text-transform:uppercase;}
.center-head h2{font-size:34px;font-weight:900;margin:8px 0 4px;}
.center-head p{color:var(--muted);margin:0;}
.muted{color:var(--muted);}

/* ---------- hero ---------- */
.hero-wrap{width:calc(100vw - 40px);max-width:none;margin:18px auto 0;padding:0;}
.hero{position:relative;background:radial-gradient(120% 140% at 85% 10%,#26262c 0%,#0c0c0e 55%);border-radius:16px;overflow:hidden;padding:64px 72px;min-height:380px;display:flex;align-items:center;color:#fff;}
.hero>div:first-child{position:relative;z-index:2;}
.hero .eyebrow{font-size:12px;font-weight:800;letter-spacing:2px;color:#a7a7 b3;text-transform:uppercase;color:#9a9aa4;}
.hero h1{font-size:64px;font-weight:900;line-height:1;margin:14px 0 16px;letter-spacing:-.03em;}
.hero p{color:#b9b9c2;font-size:17px;max-width:430px;margin:0 0 26px;line-height:1.5;}
.hero .btn-white{padding:14px 26px;font-size:15px;}
/* rotating hero artwork (Phygitals-style) */
.hero-artwork{position:absolute;right:6%;bottom:-28px;width:38%;height:115%;overflow:visible;z-index:1;}
.hero-blur-bg{position:absolute;inset:-30%;z-index:0;background-position:center;background-size:cover;transform:scale(1.25);filter:blur(20px) saturate(1.5);opacity:.35;transition:background-image .7s ease;border-radius:24px;}
.hero-pack-stack{position:absolute;inset:0;opacity:0;transform:translateY(10px);transition:opacity .7s ease,transform .7s ease;pointer-events:none;z-index:1;}
.hero-pack-stack.active{opacity:1;transform:translateY(0);}
.hero-pack-item{position:absolute;bottom:0;height:90%;width:36%;filter:drop-shadow(0 22px 44px rgba(0,0,0,.5));}
.hero-pack-item img{position:absolute;left:50%;transform:translateX(-50%);width:auto;object-fit:contain;}
.hero-slab{top:5%;height:95%;z-index:0;border-radius:6px;box-shadow:0 14px 30px rgba(0,0,0,.5);}
.hero-pack{bottom:-45%;height:100%;z-index:1;}
.hero-pack-item.center{left:36%;width:42%;height:100%;z-index:3;}
.hero-pack-item.left{left:8%;width:34%;height:84%;z-index:2;transform:rotate(-8deg) translateY(18px);}
.hero-pack-item.right{right:4%;left:auto;width:34%;height:84%;z-index:2;transform:rotate(8deg) translateY(18px);}
@media(max-width:1280px){.hero-artwork{width:44%;right:2%;}}
@media(max-width:980px){.hero-artwork{display:none;}.hero h1{font-size:44px;}.hero{padding:48px 36px;}}
@media(max-width:900px){.hero-art{display:none;}.hero h1{font-size:42px;}.hero{padding:44px 30px;}}

/* ---------- ticker / pills ---------- */
.buyback{color:var(--muted);font-weight:700;font-size:13.5px;}

/* ---------- grids ---------- */
.grid{display:grid;gap:18px;}
.grid-cats{grid-template-columns:repeat(6,1fr);}
.grid-packs{grid-template-columns:repeat(auto-fill,minmax(225px,1fr));}
.grid-slabs{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));}
@media(max-width:1050px){.grid-cats{grid-template-columns:repeat(3,1fr);}}
@media(max-width:620px){.grid-cats{grid-template-columns:repeat(2,1fr);}}


/* ---------- graded slab ---------- */
.slab{position:relative;border-radius:11px;background:linear-gradient(160deg,#ffffff,#eef0f4);padding:7px 7px 9px;border:1px solid #e6e7eb;box-shadow:0 10px 24px rgba(15,18,26,.14),inset 0 0 0 1px rgba(255,255,255,.7);}
.slab .label{display:flex;align-items:stretch;gap:5px;height:26px;margin-bottom:6px;}
.slab .label .lt{flex:1;background:#fff;border-radius:4px;border:1px solid #e8e8ec;padding:3px 5px;overflow:hidden;}
.slab .label .lt .l1{font-size:6.5px;font-weight:800;line-height:1.15;color:#222;text-transform:uppercase;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.slab .label .lt .l2{font-size:6px;color:#888;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.slab .label .gr{width:40px;border-radius:4px;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;}
.slab .label .gr .gname{font-size:6.5px;font-weight:800;letter-spacing:.3px;}
.slab .label .gr .gnum{font-size:13px;font-weight:900;}
.slab .art{aspect-ratio:5/7;border-radius:7px;display:grid;place-items:center;position:relative;overflow:hidden;background:linear-gradient(155deg,var(--c1,#e8eaf0),var(--c2,#cfd3dd));}
.slab .art .emoji{font-size:46px;filter:drop-shadow(0 6px 10px rgba(0,0,0,.18));}
.slab .art .sheen{position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.45) 48%,transparent 60%);}
.slab .art .rwm{position:absolute;bottom:6px;right:7px;font-size:6.5px;font-weight:800;letter-spacing:.4px;color:rgba(0,0,0,.35);text-transform:uppercase;}
.slab.glow{box-shadow:0 0 0 2px var(--glow),0 14px 30px var(--glow);}

/* slab meta row (used in grids) */
.slab-row{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.slab-row .nm{font-weight:800;font-size:13.5px;line-height:1.15;}
.slab-row .vl{font-weight:900;font-size:14px;}
.slab-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px;box-shadow:var(--shadow-sm);}
.slab-card .rar{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;}
.slab-card .actions{display:flex;gap:6px;margin-top:9px;}
.slab-card .actions .btn{flex:1;}
.tag-listed{position:absolute;top:-6px;right:-6px;background:var(--gold);color:#241c00;font-size:9.5px;font-weight:900;padding:3px 7px;border-radius:6px;z-index:2;}

/* ---------- pack card (packs page) ---------- */
.pack{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .15s;cursor:pointer;display:flex;flex-direction:column;gap:10px;}
.pack:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.pack .tier{position:absolute;top:12px;right:12px;font-size:10px;font-weight:900;letter-spacing:.5px;text-transform:uppercase;background:var(--bg-soft);border:1px solid var(--line);padding:3px 8px;border-radius:999px;color:#555;}
.pack .pk{height:120px;display:grid;place-items:center;}
.pack .pk .foil{width:84px;height:108px;border-radius:10px 10px 7px 7px;box-shadow:0 12px 26px rgba(0,0,0,.2);display:grid;place-items:end center;padding-bottom:8px;color:#fff;font-weight:900;font-size:11px;letter-spacing:.5px;}
.pack .pcat{font-size:12px;color:var(--muted);font-weight:700;}
.pack .pname{font-weight:800;font-size:15.5px;line-height:1.2;}
.pack .odds-bar{display:flex;height:6px;border-radius:999px;overflow:hidden;background:#eee;}
.pack .odds-bar span{height:100%;}
.pack .foot{display:flex;align-items:center;justify-content:space-between;margin-top:2px;}
.pack .price{font-weight:900;font-size:18px;}

/* ---------- recent pulls strip ---------- */
.pull-strip{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 16px;scroll-snap-type:x proximity;}
.pull-tile{flex:0 0 200px;scroll-snap-align:start;background:radial-gradient(120% 80% at 50% 0%,#1b1c20,#0b0b0d);border-radius:18px;padding:16px 14px 14px;position:relative;color:#fff;box-shadow:var(--shadow-sm);}
.pull-tile .time{position:absolute;top:10px;right:10px;font-size:10.5px;font-weight:700;background:rgba(255,255,255,.1);padding:3px 8px;border-radius:999px;color:#cfcfd6;}
.pull-tile .stage{display:grid;place-items:center;padding:10px 14px 6px;position:relative;}
.pull-tile .stage .slab{width:118px;}
.pull-tile .stage::after{content:"";position:absolute;bottom:2px;width:120px;height:16px;border-radius:50%;background:radial-gradient(closest-side,rgba(255,255,255,.18),transparent);}
.pull-tile .pname{font-size:12.5px;font-weight:700;margin-top:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pull-tile .badge{margin-top:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:7px 9px;display:flex;align-items:center;gap:8px;font-size:11px;}
.pull-tile .badge .who{color:#b8b8c0;}

/* ---------- how it works ---------- */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:900px){.how-grid{grid-template-columns:1fr;}}
.how-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;padding:26px;}
.how-card .n{width:26px;height:26px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:900;font-size:13px;}
.how-card h3{font-size:19px;margin:14px 0 8px;font-weight:800;}
.how-card p{color:var(--muted);font-size:14px;line-height:1.55;margin:0;}
.how-card .mini{margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 13px;display:flex;align-items:center;justify-content:space-between;font-size:12.5px;font-weight:700;}

/* ---------- community ---------- */
.comm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:900px){.comm-grid{grid-template-columns:repeat(2,1fr);}}
.comm{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);}
.comm .pic{aspect-ratio:4/3;display:grid;place-items:center;font-size:48px;}
.comm .cap{padding:13px;font-size:13px;color:#33343a;line-height:1.4;}
.comm .who{padding:0 13px 14px;display:flex;align-items:center;gap:9px;font-size:13px;font-weight:700;}
.comm .who .av{width:24px;height:24px;border-radius:50%;}

/* ---------- table ---------- */
.lb-panel{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);}
.table{width:100%;border-collapse:collapse;}
.table th,.table td{text-align:left;padding:15px 18px;font-size:14px;}
.table th{color:var(--muted);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;}
.table tbody tr{border-top:1px solid var(--line);}
.table tbody tr:nth-child(even){background:#fafafb;}
.table .num{text-align:right;font-variant-numeric:tabular-nums;}
.table .rk{color:var(--muted);font-weight:800;width:30px;}
.table .who{display:flex;align-items:center;gap:11px;font-weight:700;}
.table .who .av{width:28px;height:28px;border-radius:50%;}

/* ---------- stocked CTA ---------- */
.stocked{background:var(--bg-soft);border:1px solid var(--line);border-radius:26px;padding:54px 24px 20px;text-align:center;position:relative;overflow:hidden;margin-top:50px;}
.stocked h2{font-size:34px;font-weight:900;margin:0 0 6px;}
.stocked p{color:var(--muted);margin:0 0 20px;}
.stocked .row{display:flex;justify-content:space-between;align-items:flex-end;gap:10px;margin-top:30px;padding:0 10px;}
.stocked .row .slab{width:90px;opacity:.96;}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);background:#fff;}
.foot-inner{max-width:1240px;margin:0 auto;padding:46px 24px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:30px;}
@media(max-width:900px){.foot-inner{grid-template-columns:1fr 1fr;}}
.foot-inner h4{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 14px;}
.foot-inner a{display:block;color:#33343a;font-size:14px;margin-bottom:10px;font-weight:600;}
.foot-brand{font-weight:900;font-size:22px;margin-bottom:10px;}
.foot-desc{color:var(--muted);font-size:13.5px;line-height:1.55;max-width:320px;}
.foot-bottom{border-top:1px solid var(--line);text-align:center;padding:18px;color:var(--muted);font-size:12.5px;}
.foot-social{display:flex;gap:10px;}
.foot-social a{width:36px;height:36px;border-radius:10px;background:var(--ink);color:#fff;display:grid;place-items:center;margin:0;}

/* ---------- modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(12,12,16,.55);backdrop-filter:blur(5px);z-index:60;display:grid;place-items:center;padding:20px;animation:fade .18s ease;overflow-y:auto;}
@keyframes fade{from{opacity:0;}}
.modal{width:100%;max-width:440px;background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:26px;animation:pop .22s cubic-bezier(.2,.9,.3,1.2);}
.modal.wide{max-width:680px;}
@keyframes pop{from{transform:scale(.94) translateY(8px);opacity:0;}}
.modal h3{margin:0 0 3px;font-size:23px;font-weight:900;}
.modal .sub{color:var(--muted);font-size:14px;margin-bottom:18px;}
.modal .close{float:right;background:none;border:none;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:6px;font-weight:700;}
.input{width:100%;background:#fff;border:1px solid var(--line-2);color:var(--ink);padding:12px 14px;border-radius:12px;font-size:15px;}
.input:focus{outline:none;border-color:var(--ink);}
.tabs{display:flex;gap:6px;background:var(--bg-soft);padding:5px;border-radius:13px;margin-bottom:18px;}
.tabs button{flex:1;padding:10px;border-radius:9px;border:none;background:transparent;color:var(--muted);font-weight:800;}
.tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm);}
.err{color:#c81e3c;font-size:13px;min-height:16px;margin-top:2px;}

.odds-list{display:flex;flex-direction:column;gap:9px;margin:8px 0 16px;}
.odds-row{display:flex;align-items:center;gap:10px;font-size:13.5px;}
.odds-row .lbl{width:92px;font-weight:800;}
.odds-row .meter{flex:1;height:8px;background:#eee;border-radius:999px;overflow:hidden;}
.odds-row .meter i{display:block;height:100%;}
.odds-row .pct{width:56px;text-align:right;color:var(--muted);font-weight:700;}

/* ---------- opening animation ---------- */
.opening{display:grid;place-items:center;gap:16px;min-height:360px;position:relative;}
.rip-foil{width:150px;height:196px;border-radius:14px 14px 9px 9px;display:grid;place-items:center;color:#fff;font-weight:900;font-size:15px;letter-spacing:1px;box-shadow:0 22px 50px rgba(0,0,0,.28);animation:wobble .5s ease-in-out infinite;}
.rip-foil.charging{animation:charge 1.05s ease-in forwards;}
@keyframes wobble{0%,100%{transform:rotate(-4deg);}50%{transform:rotate(4deg);}}
@keyframes charge{0%{transform:scale(1);}55%{transform:scale(1.2) rotate(7deg);}78%{transform:scale(.5) rotate(-12deg);opacity:.8;}100%{transform:scale(0);opacity:0;}}
.reveal-wrap{position:relative;display:grid;place-items:center;gap:14px;}
.reveal-slab{width:230px;animation:revealIn .6s cubic-bezier(.2,.9,.3,1.3);}
@keyframes revealIn{0%{transform:scale(.4) rotateY(90deg);opacity:0;}60%{transform:scale(1.05) rotateY(0);}100%{transform:scale(1);opacity:1;}}
.reveal-rar{font-size:13px;font-weight:900;letter-spacing:2px;text-transform:uppercase;}
.rays{position:absolute;width:560px;height:560px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0 8deg,var(--glow) 8deg 12deg,transparent 12deg 20deg,var(--glow) 20deg 24deg,transparent 24deg);opacity:.10;animation:spin 14s linear infinite;pointer-events:none;}
@keyframes spin{to{transform:rotate(360deg);}}
.confetti{position:absolute;width:9px;height:9px;top:-10px;border-radius:2px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(430px) rotate(560deg);opacity:0;}}

/* ---------- fairness ---------- */
.kv{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px;}
.kv .k{color:var(--muted);font-weight:700;}
.kv .v{font-family:ui-monospace,Menlo,monospace;word-break:break-all;text-align:right;font-size:12.5px;}

/* ---------- toasts ---------- */
.toasts{position:fixed;bottom:22px;right:22px;z-index:90;display:flex;flex-direction:column;gap:10px;}
.toast{background:var(--ink);color:#fff;padding:13px 17px;border-radius:13px;box-shadow:var(--shadow);font-size:14px;font-weight:600;min-width:230px;animation:slideIn .25s ease;}
.toast.ok{background:#0f7a3a;}
.toast.bad{background:#c81e3c;}
@keyframes slideIn{from{transform:translateX(40px);opacity:0;}}

/* ---------- misc ---------- */
.empty{text-align:center;padding:80px 20px;color:var(--muted);}
.empty .big{font-size:50px;margin-bottom:12px;}
.center{text-align:center;}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite;margin:70px auto;}
.cat-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px;}
.cat-tab{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line-2);padding:9px 15px;border-radius:999px;font-weight:700;font-size:14px;color:#555;}
.cat-tab.active{color:#fff;background:var(--ink);border-color:var(--ink);}

/* ===== Privy-style auth modal ===== */
.modal.auth{max-width:420px;padding:30px 26px 22px;}
.auth-head{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:14px;}
.auth-logo{width:30px;height:30px;}
.auth-brand{font-weight:900;font-size:26px;letter-spacing:-.02em;}
.auth-title{text-align:center;font-size:23px;font-weight:800;margin-bottom:22px;}
.auth-sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:16px;}
.prov-list{display:flex;flex-direction:column;gap:12px;}
.prov{display:flex;align-items:center;gap:14px;width:100%;border:1px solid var(--line-2);background:#fff;border-radius:14px;padding:14px 16px;font-size:15px;font-weight:600;color:var(--ink);transition:background .12s,border-color .12s;text-align:left;}
.prov:hover{background:var(--bg-soft);border-color:#cfd0d6;}
.prov .ic{width:34px;height:34px;border-radius:9px;background:var(--bg-soft);display:grid;place-items:center;font-size:18px;flex:0 0 auto;}
.prov .ic-g{font-weight:900;color:#4285f4;background:#fff;border:1px solid var(--line);}
.prov .ic-dark{background:#111;color:#fff;}
.prov .pl{flex:1;}
.prov .recent{font-size:12px;font-weight:700;color:var(--muted);background:var(--bg-soft);padding:5px 10px;border-radius:8px;}
.prov-email{padding:6px 6px 6px 16px;}
.prov-email .prov-input{flex:1;border:none;outline:none;font-size:15px;font-family:inherit;background:transparent;padding:10px 0;}
.prov-email .em-submit{border:none;background:var(--ink);color:#fff;font-weight:700;border-radius:10px;padding:10px 16px;font-size:14px;}
.auth-passkey{display:block;width:100%;text-align:center;background:none;border:none;color:var(--ink);font-weight:700;font-size:14.5px;margin:18px 0 4px;}
.auth-classic{display:block;width:100%;text-align:center;background:none;border:none;color:var(--muted);font-weight:600;font-size:13px;margin-top:10px;}
.auth-foot{text-align:center;color:var(--muted);font-size:12.5px;margin-top:14px;}
.auth-foot u{cursor:pointer;}
.auth-prot{text-align:center;color:var(--muted);font-size:12.5px;margin-top:10px;}
.auth-prot b{color:#5b53e0;}
.sms-back{color:var(--muted);font-weight:700;font-size:13px;cursor:pointer;margin-bottom:10px;}
.code-input{text-align:center;letter-spacing:8px;font-size:22px;font-weight:800;}
.demo-code{background:var(--bg-soft);border:1px dashed var(--line-2);border-radius:10px;padding:10px 12px;font-size:13px;margin-bottom:12px;text-align:center;}

/* ===== Pack Party ===== */
.party-intro{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:16px 18px;font-size:14px;color:#33343a;margin-bottom:20px;line-height:1.5;}
.seg{display:flex;gap:8px;}
.seg button{flex:1;border:1px solid var(--line-2);background:#fff;border-radius:11px;padding:11px;font-weight:700;color:#555;}
.seg button.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.party-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin-top:6px;}
.party-slot{position:relative;text-align:center;padding:8px;border:1px solid var(--line);border-radius:14px;background:#fff;}
.party-slot.win{border-color:#0f8a43;box-shadow:0 0 0 2px rgba(15,138,67,.2);}
.party-name{font-size:12.5px;font-weight:600;margin-bottom:8px;color:#444;}
.party-val{font-weight:900;margin-top:8px;}
.party-tag{position:absolute;top:-8px;left:50%;transform:translateX(-50%);background:#0f8a43;color:#fff;font-size:10px;font-weight:900;padding:3px 9px;border-radius:999px;}

/* ===== Open Packs — full-width dark band, Phygitals-style ===== */
.op-band{width:calc(100vw - 40px);max-width:none;margin:26px auto 10px;background:#101012;border-radius:16px;padding:24px 24px 32px;border:1px solid rgba(255,255,255,.05);}
.op-inner{width:100%;max-width:none;margin:0;}
.op-head{display:flex;align-items:center;justify-content:space-between;margin:0 2px 18px;}
.op-title{color:#f5f5f7;font-size:18px;font-weight:800;letter-spacing:.2px;}
.op-buy{color:#8c92a0;font-size:12.5px;font-weight:600;}
.op-grid{display:grid;grid-template-columns:repeat(6,minmax(280px,1fr));gap:20px;}
@media(max-width:1700px){.op-grid{grid-template-columns:repeat(4,minmax(240px,1fr));}}
@media(max-width:1100px){.op-grid{grid-template-columns:repeat(3,minmax(220px,1fr));}}
@media(max-width:780px){.op-grid{grid-template-columns:repeat(2,minmax(150px,1fr));}}

.pc{position:relative;aspect-ratio:3/4;background:#161618;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:transform .2s cubic-bezier(.2,.8,.3,1),box-shadow .2s,border-color .2s;}
.pc-glow{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(58% 46% at 50% 38%,rgba(120,150,255,.16),rgba(255,255,255,.05) 42%,transparent 72%);opacity:.7;transition:opacity .2s;}
.pc:hover .pc-glow{opacity:1;}
.pc:hover{transform:translateY(-8px) scale(1.012);box-shadow:0 30px 60px rgba(0,0,0,.6);border-color:rgba(255,255,255,.14);}
.pc-slab{position:absolute;top:5%;left:50%;transform:translateX(-50%);height:95%;width:auto;object-fit:contain;z-index:0;border-radius:6px;box-shadow:0 16px 32px rgba(0,0,0,.55);transition:transform .2s;}
.pc:hover .pc-slab{transform:translateX(-50%) translateY(-14px);}
.pc-wrap{position:absolute;bottom:-45%;left:50%;transform:translateX(-50%);height:100%;width:auto;object-fit:contain;display:block;z-index:1;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45));transition:transform .2s;}
.pc:hover .pc-wrap{transform:translateX(-50%) scale(1.03);}
.pc-bar{position:absolute;bottom:0;left:0;width:100%;height:68px;background:#2b2b2b;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:0 14px;}
.pc-cat{color:#f2f2f4;font-size:13.5px;font-weight:700;}
.pc-btn{width:100%;background:#3a3a3d;color:#e8e8ee;border:none;border-radius:8px;height:30px;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s;}
.pc-btn:hover{background:#47474b;}
@media(max-width:780px){.pc-bar{height:60px;}}

/* ===== live image helpers (slab photo variant, pack/foil imagery) ===== */
.slab .art{background-size:cover;background-position:center;}
.slab .art .emoji{display:none;}
.slab .art .rtint{position:absolute;inset:0;mix-blend-mode:soft-light;opacity:.12;}
.slab.photo{padding:0;border:none;background:none;box-shadow:none;border-radius:12px;}
.slab.photo .photo-img{display:block;width:100%;height:auto;border-radius:12px;box-shadow:0 10px 24px rgba(15,18,26,.2);}
.slab.photo.glow{box-shadow:0 0 0 2px var(--glow),0 16px 34px var(--glow);border-radius:12px;}
.slab.photo.glow .photo-img{box-shadow:none;}
.pack-img{width:100%;max-width:96px;filter:drop-shadow(0 12px 22px rgba(0,0,0,.22));}
.pack .pk .pack-img{max-width:90px;}

/* Packs page product lineup (Trainer/Rookie/Elite/Legend) */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
@media(max-width:1100px){.prod-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.prod-grid{grid-template-columns:1fr;}}

.pack.product{min-height:392px;padding:24px;position:relative;overflow:hidden;display:block;}
.pack.product .pk{height:220px;display:grid;place-items:center;margin:4px 0 20px;}
.pack.product .pk .pack-img{height:220px;width:auto;max-width:100%;object-fit:contain;margin:0;}
.pack.product .tier{top:18px;right:18px;z-index:20;}
.pack .tier.live{background:var(--green);color:#fff;border-color:var(--green);}
.pack .tier.soon{background:#1c1d22;color:#fff;border-color:#1c1d22;}
.pack.product .prod-info{position:relative;z-index:5;}
.pack.product .prod-info .pname{font-weight:800;font-size:17px;line-height:1.2;}
.pack.product .prod-info .price{margin-top:12px;font-weight:900;font-size:20px;}
.pack.product .prod-open{position:absolute;right:24px;bottom:24px;z-index:20;}
.pack.product.is-soon{cursor:default;}
.pack.product.is-soon:hover{transform:none;box-shadow:var(--shadow-sm);}
.pack.product.is-soon .pack-img{opacity:.5;}
.pack.product.is-soon .prod-open{background:#c9ccd2;color:#fff;border:none;cursor:not-allowed;}

/* ===== Trainer Pack detail page ===== */
.tp-hero{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:center;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:28px;}
.tp-hero-img{display:grid;place-items:center;}
.tp-hero-img img{width:100%;max-width:240px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.28));}
.tp-hero-info .tier{display:inline-block;font-size:11px;font-weight:900;letter-spacing:.5px;text-transform:uppercase;padding:4px 10px;border-radius:999px;}
.tp-price{font-size:30px;font-weight:900;margin:6px 0;}
.tp-statline{display:flex;flex-wrap:wrap;gap:18px;color:var(--muted);font-size:13.5px;font-weight:600;margin-top:6px;}
.tp-statline b{color:var(--ink);font-weight:900;}
@media(max-width:740px){.tp-hero{grid-template-columns:1fr;text-align:center;}.tp-hero-img img{max-width:180px;}}
.tp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;}
.tp-card{background:transparent;border:none;border-radius:0;padding:0;box-shadow:none;cursor:pointer;}
/* Shared CardImage — fixed aspect canvas, object-fit:contain (admin + frontend) */
.card-img{position:relative;aspect-ratio:660/860;border-radius:12px;overflow:hidden;background:var(--bg-soft);display:block;}
.card-img img{width:100%;height:100%;object-fit:contain;display:block;}
/* frontend Top Hits showcase treatment */
.tp-card .card-img{background:transparent;border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.16);transition:transform .15s,box-shadow .15s;}
.tp-card:hover .card-img{transform:translateY(-5px);box-shadow:0 22px 48px rgba(0,0,0,.26);}
.tp-meta{margin-top:8px;}
.tp-name{font-weight:800;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tp-row{display:flex;align-items:center;justify-content:space-between;margin-top:5px;}
.tp-rar{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;}
.tp-val{font-weight:900;font-size:13.5px;}
.tp-odds{color:var(--muted);font-size:11px;font-weight:700;margin-top:3px;}
.tp-reveal{text-align:center;padding:8px 4px;}
.tp-reveal-img{width:180px;aspect-ratio:3/4;margin:14px auto 0;border-radius:12px;overflow:hidden;display:grid;place-items:center;background:var(--bg-soft);}
.tp-reveal-img img{width:100%;height:100%;object-fit:contain;}

/* ===== Admin: Trainer Pack tab ===== */
.tp-admin-stats{display:flex;flex-wrap:wrap;gap:10px;}
.tp-admin-stats .stat{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:10px 14px;min-width:120px;}
.tp-admin-stats .stat span{display:block;font-size:11.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;}
.tp-admin-stats .stat b{font-size:18px;font-weight:900;}
.tp-admin-stats .stat input{font-size:16px;font-weight:900;border:1px solid var(--line);border-radius:8px;padding:2px 6px;}
.tp-table th,.tp-table td{vertical-align:middle;}
.tp-table .input{padding:7px 9px;font-size:13px;width:100%;}
.tp-thumb{width:38px;height:50px;object-fit:contain;border-radius:6px;background:var(--bg-soft);}
.tp-odds-cell{font-weight:800;white-space:nowrap;}
.tp-add{border-top:1px solid var(--line);margin-top:18px;}
.tp-add-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.tp-add-row .input{flex:1;min-width:140px;}

.tp-bulk textarea#tpBulk{width:100%;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;padding:10px 12px;border:1px solid var(--line);border-radius:10px;resize:vertical;}

/* ===== value-band odds tiles (Phygitals-style) ===== */
.tp-bands{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;}
.tp-bands-admin{margin:6px 2px 4px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));}
.tp-band{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:12px 14px;}
.tp-band-range{font-size:12.5px;color:var(--muted);font-weight:700;}
.tp-band-odds{font-size:22px;font-weight:900;margin-top:4px;}
.tp-q{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;border:1px solid var(--line-2);background:#fff;color:var(--muted);font-size:11px;font-weight:800;line-height:1;vertical-align:middle;cursor:pointer;}
.tp-q:hover{color:var(--ink);border-color:var(--muted);}

/* ===== EV explainer modal ===== */
.ev-modal{padding:4px 2px;}
.ev-head{display:flex;align-items:center;gap:12px;margin-bottom:6px;}
.ev-head h3{margin:0;font-size:22px;}
.ev-dot{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 50% 50%,var(--green) 0 42%,rgba(22,163,74,.18) 44%);flex:0 0 auto;}
.ev-rows{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:6px 16px;margin:16px 0;}
.ev-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;font-size:15px;}
.ev-row span{color:var(--muted);font-weight:600;}
.ev-row b{font-size:16px;}
.ev-row.ev-adv{border-top:1px solid var(--line);}

/* ===== Trainer Pack rarity tiers + admin extras ===== */
.tp-band-top{display:flex;align-items:center;gap:7px;margin-bottom:4px;}
.tp-dot{width:9px;height:9px;border-radius:50%;display:inline-block;}
.tp-band-name{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;}
.tp-band{border-top:3px solid var(--rc,var(--line));}

/* dark modal variant (EV / Live odds / buyback explainers — match the dark mockups) */
.modal.dark{background:#1c1c20;color:#e8e8ee;}
.modal.dark h3{color:#fff;}
.modal.dark .close{color:#9a9aa4;}
.modal.dark .ev-modal p.muted,.modal.dark p.muted{color:#9a9aa4;}
.modal.dark .ev-rows{background:#26262c;border-color:rgba(255,255,255,.07);}
.modal.dark .ev-row span{color:#9a9aa4;}
.modal.dark .ev-row b{color:#fff;}
.modal.dark .ev-row.ev-adv{border-top-color:rgba(255,255,255,.08);}
.modal.dark .btn-dark{background:#fff;color:#111;border-color:#fff;}
.modal.dark .btn-dark:hover{background:#eee;}

/* customer pack "Live odds" value-band panel (dark) */
.lo-panel{background:#1c1c20;color:#e8e8ee;border-radius:18px;padding:18px 20px;margin-top:26px;}
.lo-ev{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08);}
.lo-ev-label{color:#9a9aa4;font-weight:600;font-size:14px;}
.lo-ev-val{font-size:22px;font-weight:900;color:#fff;}
.lo-ev-val span{color:#9a9aa4;font-size:13px;font-weight:600;}
.lo-title{color:#9a9aa4;font-weight:700;font-size:13px;margin:16px 0 12px;display:flex;align-items:center;gap:7px;}
.lo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;}
.lo-tile{background:#26262c;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px 14px;}
.lo-range{font-size:12px;color:#9a9aa4;font-weight:700;}
.lo-pct{font-size:23px;font-weight:900;color:#fff;margin-top:4px;}
.lo-empty{color:#9a9aa4;grid-column:1/-1;}
.lo-q{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:transparent;color:#9a9aa4;font-size:11px;font-weight:800;line-height:1;cursor:pointer;vertical-align:middle;}
.lo-q:hover{color:#fff;border-color:#fff;}
.tp-meta{margin-top:11px;}
.tp-name{font-size:14px;}
.tp-val{font-size:15px;}
.tp-badge{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;padding:3px 8px;border-radius:999px;white-space:nowrap;}
.tp-show{font-size:11px;font-weight:800;padding:3px 8px;border-radius:999px;white-space:nowrap;}
.tp-show.yes{background:#e6f7ee;color:#0f8a43;}
.tp-show.no{background:#f0f0f2;color:#8a8a90;}
.tp-need{margin:4px 2px 12px;padding:11px 14px;border-radius:10px;font-size:13px;font-weight:600;}
.tp-need.ok{background:#e6f7ee;color:#0f6b36;border:1px solid #b7e6c8;}
.tp-need.under{background:#fdecef;color:#a3203a;border:1px solid #f3c6cd;}
.tp-upload{display:inline-flex;align-items:center;gap:6px;border:1px dashed var(--line-2);background:#fff;font-weight:700;}
.tp-upload:hover{background:var(--bg-soft);}

/* ===== admin dashboard KPIs + checklist (restored) ===== */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:6px;}
@media(max-width:900px){.kpi-row{grid-template-columns:repeat(2,1fr);}}
.kpi{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:14px 16px;}
.kpi-label{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;}
.kpi-val{font-size:24px;font-weight:900;margin-top:4px;}
.kpi-val.good{color:#16a34a;}
.kpi-val.bad{color:#e4002b;}
.kpi-sub{font-size:12.5px;color:var(--muted);margin-top:2px;}
.chk{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-top:1px solid var(--line);}
.chk input{margin-top:3px;}
td.num,.table .num{text-align:right;}

/* ===== Trainer admin: sort/filter bar + row number ===== */
.tp-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:6px 2px 12px;}
.tp-controls .lbl{font-size:12.5px;color:var(--muted);font-weight:700;}
.tp-controls select{padding:7px 10px;border:1px solid var(--line-2);border-radius:9px;font-weight:600;font-size:13px;background:#fff;}
.tp-table td.tp-rownum{color:var(--muted);font-weight:700;width:34px;text-align:right;}

/* ===== full-screen card detail overlay ===== */
.tpd-overlay{position:fixed;inset:0;z-index:120;background:rgba(11,11,13,.93);backdrop-filter:blur(16px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;overflow:auto;}
.tpd-close{position:fixed;top:18px;right:22px;width:44px;height:44px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:background .15s;}
.tpd-close:hover{background:rgba(255,255,255,.24);}
.tpd-inner{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:560px;width:100%;}
.tpd-img{max-height:62vh;border-radius:14px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.6);border-top:4px solid var(--rc,#888);}
.tpd-img img{max-height:62vh;max-width:90vw;width:auto;display:block;}
.tpd-name{color:#fff;font-size:22px;font-weight:900;line-height:1.3;margin:24px 0 18px;max-width:520px;}
.tpd-meta{display:flex;gap:48px;justify-content:center;flex-wrap:wrap;}
.tpd-meta .lbl{color:#9a9aa4;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.tpd-meta .val{color:#fff;font-size:20px;font-weight:900;margin-top:5px;}

/* ===== PackReveal 3D cutscene overlay ===== */
.pr-overlay{position:fixed;inset:0;z-index:200;background:radial-gradient(circle at 50% 45%,#15151c 0%,#050507 72%);}
.pr-canvas{width:100%;height:100%;display:block;}

/* ===== admin thumbnail lightbox ===== */
.img-lb{position:fixed;inset:0;z-index:210;background:rgba(8,8,10,.92);display:flex;align-items:center;justify-content:center;padding:30px;cursor:zoom-out;}
.img-lb img{max-width:92vw;max-height:92vh;border-radius:10px;box-shadow:0 30px 70px rgba(0,0,0,.6);}

/* ===== marketplace controls + reveal action buttons ===== */
.mkt-controls{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px;}
.mkt-controls .input{flex:0 0 auto;}
.mkt-controls #mktQ{flex:1;min-width:200px;}
.mkt-controls select.input{min-width:170px;}
.tp-reveal-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;}
.tp-reveal-actions .btn{width:100%;}
@media(max-width:480px){.tp-reveal-actions{grid-template-columns:1fr;}}

/* ===== Vault (dark premium) ===== */
.vault-band{width:calc(100vw - 40px);max-width:none;margin:22px auto 30px;background:#101012;border-radius:16px;padding:24px 26px 30px;border:1px solid rgba(255,255,255,.05);}
.vault-inner{max-width:1320px;margin:0 auto;}
.vault-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:16px;}
.vault-head h2{color:#fff;font-size:26px;margin:0;}
.vault-sub{color:#9a9aa4;font-size:13px;font-weight:600;}
.vault-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:18px;}
@media(max-width:900px){.vault-stats{grid-template-columns:repeat(3,1fr);}}
@media(max-width:520px){.vault-stats{grid-template-columns:repeat(2,1fr);}}
.vstat{background:#17171b;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px 14px;}
.vstat-l{font-size:11px;color:#8c8c96;font-weight:700;text-transform:uppercase;letter-spacing:.4px;}
.vstat-v{font-size:20px;font-weight:900;color:#fff;margin-top:3px;}
.vault-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;}
.vault-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-right:auto;}
.vault-tab{background:#1b1b20;color:#b9b9c2;border:1px solid rgba(255,255,255,.07);border-radius:999px;padding:7px 14px;font-weight:700;font-size:13px;cursor:pointer;}
.vault-tab.active{background:#fff;color:#111;border-color:#fff;}
.vault-q,.vault-sortsel{background:#17171b;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:9px 12px;font-size:13px;}
.vault-q{min-width:180px;flex:1;}
.vault-q::placeholder{color:#777;}
.vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;}
.vault-card{position:relative;background:#161618;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px;}
.vault-img{margin-bottom:10px;}
.vc-name{color:#f2f2f5;font-weight:800;font-size:13.5px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vc-row{display:flex;justify-content:space-between;align-items:center;margin-top:5px;}
.vc-rar{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;}
.vc-val{color:#fff;font-weight:900;font-size:14px;}
.vc-sub{color:#8c8c96;font-size:11.5px;margin-top:3px;}
.vault-card .actions{margin-top:9px;display:flex;gap:6px;}
.vault-card .actions .btn{flex:1;}
.vstatus{position:absolute;top:10px;left:10px;z-index:2;font-size:9.5px;font-weight:900;letter-spacing:.4px;padding:3px 7px;border-radius:6px;color:#fff;}
.st-vault{background:#16a34a;}
.st-listed{background:#d9a400;color:#241c00;}
.st-sold{background:#6b7280;}
.st-buyback{background:#7c3aed;}

/* ===== Marketplace v2 (Phygitals-style: sidebar + tabs + dense dark grid) ===== */
.m2{display:grid;grid-template-columns:248px 1fr;width:calc(100vw - 32px);max-width:none;margin:16px auto 30px;background:#0c0c0e;border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;min-height:78vh;color:#e8e8ee;}
.m2-side{background:#102013;background:#101013;border-right:1px solid rgba(255,255,255,.06);padding:16px 14px;}
.m2-side-h{display:flex;justify-content:space-between;align-items:center;font-weight:800;color:#fff;font-size:14px;margin-bottom:8px;}
.m2-clear{background:none;border:none;color:#8c8c96;font-size:12px;cursor:pointer;}
.m2-clear:hover{color:#fff;}
.m2-acc{border-top:1px solid rgba(255,255,255,.06);}
.m2-acc summary{cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:#cfcfd6;list-style:none;padding:11px 2px;}
.m2-acc summary::-webkit-details-marker{display:none;}
.m2-caret{color:#6f6f78;transform:rotate(90deg);transition:transform .15s;font-size:14px;}
.m2-acc[open] .m2-caret{transform:rotate(-90deg);}
.m2-acc-body{padding:0 2px 12px;}
.m2-opt{display:flex;align-items:center;gap:8px;font-size:13px;color:#b9b9c2;padding:4px 0;cursor:pointer;}
.m2-opt:hover{color:#fff;}
.m2-muted{color:#6f6f78;font-size:12.5px;padding:2px 0;}
.m2-range{display:flex;align-items:center;gap:6px;}
.m2-in{width:100%;background:#17171b;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:8px;padding:6px 8px;font-size:12.5px;}
.m2-main{padding:14px 18px 24px;min-width:0;}
.m2-tabs{display:flex;gap:18px;overflow-x:auto;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:14px;}
.m2-tabs::-webkit-scrollbar{height:6px;}
.m2-tab{flex:0 0 auto;background:transparent;border:none;color:#9a9aa4;font-weight:700;font-size:14px;padding:6px 2px;cursor:pointer;display:flex;align-items:center;gap:6px;border-bottom:2px solid transparent;margin-bottom:-11px;}
.m2-tab.active{color:#fff;border-bottom-color:#fff;}
.m2-tab:hover{color:#e8e8ee;}
.m2-bar{display:flex;gap:10px;align-items:center;margin-bottom:16px;}
.m2-search{flex:1;background:#17171b;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:10px 13px;font-size:13px;}
.m2-search::placeholder{color:#777;}
.m2-sort{background:#17171b;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:10px 13px;font-size:13px;}
.m2-count{color:#8c8c96;font-size:12.5px;white-space:nowrap;}
.m2-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
@media(max-width:1500px){.m2-grid{grid-template-columns:repeat(5,1fr);}}
@media(max-width:1200px){.m2-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:900px){.m2{grid-template-columns:1fr;}.m2-side{display:none;}.m2-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){.m2-grid{grid-template-columns:repeat(2,1fr);}}
.m2-empty{grid-column:1/-1;color:#8c8c96;padding:40px 0;text-align:center;}
.mc2{background:#161618;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;}
.mc2:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.55);border-color:rgba(255,255,255,.14);}
.mc2-img{position:relative;border-radius:9px;overflow:hidden;}
.mc2-fmv{position:absolute;top:8px;right:8px;z-index:3;font-size:10.5px;font-weight:800;padding:3px 7px;border-radius:6px;}
.mc2-fmv.good{background:#0f3a24;color:#46d18a;}
.mc2-fmv.over{background:#3a2a10;color:#e0a23a;}
.mc2-buy{position:absolute;left:50%;bottom:12px;transform:translateX(-50%) translateY(8px);z-index:3;background:#fff;color:#111;border:none;border-radius:999px;padding:9px 22px;font-weight:800;font-size:13px;cursor:pointer;opacity:0;transition:opacity .15s,transform .15s;white-space:nowrap;box-shadow:0 8px 20px rgba(0,0,0,.4);}
.mc2:hover .mc2-buy{opacity:1;transform:translateX(-50%);}
.mc2-buy.mine{background:#2b2b2f;color:#fff;}
.mc2-name{color:#e8e8ee;font-weight:700;font-size:13px;margin-top:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mc2-meta{display:flex;justify-content:space-between;align-items:center;margin-top:4px;}
.mc2-price{color:#fff;font-weight:900;font-size:15px;}
.mc2-seller{color:#8c8c96;font-size:11.5px;}
.mc2-rar{position:absolute;top:8px;left:8px;z-index:3;font-size:9.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:3px 7px;border-radius:6px;color:#fff;background:var(--rc,#555);box-shadow:0 2px 8px rgba(0,0,0,.4);}
.mc2-fee{margin-top:6px;font-size:10.5px;color:#9a9aa4;}
.mc2-fee b{color:#cdcdd6;font-weight:800;}
.mc2-fee span{opacity:.7;}

/* ===== pack status badges: LIVE pulsing dot + SOLD OUT ===== */
.tier.live{display:inline-flex;align-items:center;gap:6px;background:rgba(34,197,94,.14);color:#16a34a;border-color:rgba(34,197,94,.4);}
.live-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:livePulse 1.9s ease-out infinite;}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.55);}70%{box-shadow:0 0 0 7px rgba(34,197,94,0);}100%{box-shadow:0 0 0 0 rgba(34,197,94,0);}}
.tier.soldout{background:#34343a;color:#c9c9d2;border-color:#34343a;}

/* ===== Admin pack manager (grid/table/drawer/dashboard) ===== */
.auth-or{text-align:center;color:var(--muted);font-size:12px;font-weight:700;margin:12px 0 8px;position:relative;}
.lang-toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;margin-left:8px;}
.lang-toggle button{background:#fff;border:none;padding:6px 9px;font-weight:800;font-size:12px;color:var(--muted);cursor:pointer;}
.lang-toggle button.active{background:var(--ink);color:#fff;}
.ap-evbanner{border-radius:12px;padding:11px 15px;font-weight:800;font-size:13.5px;margin-bottom:12px;border:1px solid;}
.ap-evbanner.good{background:#0f3a24;background:rgba(34,197,94,.12);color:#16a34a;border-color:rgba(34,197,94,.4);}
.ap-evbanner.warn{background:rgba(234,179,8,.12);color:#b45309;border-color:rgba(234,179,8,.4);}
.ap-evbanner.high{background:rgba(228,0,43,.10);color:#e4002b;border-color:rgba(228,0,43,.35);}
.ap-dash{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:14px;}

/* ===== Pack Health Dashboard ===== */
.ph-safety{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;border-radius:14px;padding:12px 18px;margin-bottom:14px;border:1px solid;}
.ph-safety-v{font-size:18px;font-weight:900;letter-spacing:.5px;}
.ph-safety-sub{font-size:12.5px;font-weight:600;opacity:.92;}
.ph-safety.good{background:rgba(34,197,94,.12);color:#15803d;border-color:rgba(34,197,94,.4);}
.ph-safety.warn{background:rgba(234,179,8,.14);color:#a15c07;border-color:rgba(234,179,8,.45);}
.ph-safety.high{background:rgba(228,0,43,.10);color:#c2002b;border-color:rgba(228,0,43,.4);}
.ph-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
@media(max-width:860px){.ph-grid2{grid-template-columns:1fr;}}
.ph-panel{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:14px;}
.ph-h{font-weight:800;font-size:14px;margin-bottom:10px;}
.ph-table{width:100%;border-collapse:collapse;font-size:13px;}
.ph-table th{text-align:left;font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:4px 6px;border-bottom:1px solid var(--line);}
.ph-table th.num,.ph-table td.num{text-align:right;}
.ph-table td{padding:8px 6px;border-bottom:1px solid var(--line);font-weight:700;}
.ph-table tr:last-child td{border-bottom:none;}
.ph-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle;}
.ph-range{color:var(--muted);font-weight:600;font-size:11px;margin-left:6px;}
.ph-row-empty{background:rgba(228,0,43,.05);}.ph-row-empty td{color:#c2002b;}
.ph-need{color:#c2002b;}.ph-ok{color:#16a34a;}
.ph-warn{font-size:12.5px;font-weight:600;padding:6px 10px;border-radius:8px;margin-bottom:6px;}
.ph-warn.error{background:rgba(228,0,43,.08);color:#c2002b;}
.ph-warn.warn{background:rgba(234,179,8,.12);color:#9a6400;}
.ph-warn.info{background:#fff;color:var(--muted);border:1px solid var(--line);}
.ph-oor-row{display:flex;justify-content:space-between;gap:10px;padding:6px 10px;border:1px solid #f3c6cd;border-radius:8px;margin-bottom:5px;background:#fdf2f4;font-size:12.5px;font-weight:700;}
.ap-m{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:10px 13px;}
.ap-m-l{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;}
.ap-m-v{font-size:19px;font-weight:900;margin-top:3px;}
.ap-m-v.pos{color:#16a34a;} .ap-m-v.neg{color:#e4002b;}
.ap-m-v input{font-size:17px;font-weight:900;border:1px solid var(--line);border-radius:8px;padding:2px 6px;width:78px;}
.ap-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:6px;}
.ap-views{display:flex;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;}
.ap-view{background:#fff;border:none;padding:8px 14px;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;}
.ap-view.active{background:var(--ink);color:#fff;}
.ap-search{flex:1;min-width:180px;}
.ap-count{color:var(--muted);font-size:12.5px;font-weight:600;margin:8px 2px;}
.ap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;}
.ap-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s;}
.ap-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2);}
.ap-card.inactive{opacity:.55;}
.ap-card-img{position:relative;height:270px;border-radius:9px;overflow:hidden;background:var(--bg-soft);display:grid;place-items:center;}
.ap-card-img img{max-width:100%;max-height:100%;object-fit:contain;}
.ap-card.imgerr .ap-card-img img{display:none;}
.ap-card.imgerr .ap-card-img::after{content:"⚠ broken image";color:#b3261e;font-size:11px;font-weight:800;}
.ap-hit{position:absolute;top:7px;left:7px;background:#111;color:#fff;font-size:9px;font-weight:900;letter-spacing:.4px;padding:2px 6px;border-radius:5px;}
.ap-warn{position:absolute;top:7px;right:7px;background:#fdecef;color:#b3261e;font-size:9.5px;font-weight:800;padding:2px 6px;border-radius:5px;border:1px solid #f3c6cd;}
.ap-card-name{font-weight:800;font-size:13px;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ap-card-row{display:flex;justify-content:space-between;align-items:center;margin-top:4px;}
.ap-rar{font-size:11px;font-weight:800;text-transform:uppercase;}
.ap-val{font-weight:900;font-size:14px;}
.ap-card-sub{color:var(--muted);font-size:11.5px;margin-top:3px;}
.ap-tablewrap{max-height:70vh;overflow:auto;border:1px solid var(--line);border-radius:12px;}
.ap-table{width:100%;}
.ap-table thead th{position:sticky;top:0;background:#fff;z-index:2;box-shadow:0 1px 0 var(--line);}
.ap-table td,.ap-table th{padding:8px 10px;}
.ap-table tr{cursor:pointer;}
.ap-table tbody tr:hover{background:var(--bg-soft);}
.ap-table .num{text-align:right;}
.ap-table .rowoff{opacity:.55;}
.ap-thumb{width:34px;height:46px;object-fit:contain;border-radius:5px;background:var(--bg-soft);}
.ap-thumb.err{outline:2px solid #f3c6cd;}
.ap-warn-i{color:#b3261e;}
.ap-pager{display:flex;align-items:center;justify-content:center;gap:14px;margin:16px 0;font-size:13px;font-weight:600;color:var(--muted);}
.ap-tools{display:flex;gap:8px;margin-top:18px;border-top:1px solid var(--line);padding-top:14px;}
/* right-side drawer */
.ap-drawer{position:fixed;top:0;right:0;height:100vh;width:380px;max-width:92vw;background:#fff;border-left:1px solid var(--line);box-shadow:-20px 0 50px rgba(0,0,0,.18);transform:translateX(105%);transition:transform .2s cubic-bezier(.2,.8,.3,1);z-index:120;overflow-y:auto;}
.ap-drawer.open{transform:translateX(0);}
.ap-drawer-in{padding:18px;}
.ap-d-head{display:flex;justify-content:space-between;align-items:center;font-weight:800;font-size:15px;margin-bottom:12px;}
.ap-drawer-x{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--muted);}
.ap-d-img{aspect-ratio:3/4;max-width:230px;margin:0 auto 14px;border-radius:12px;overflow:hidden;background:var(--bg-soft);display:grid;place-items:center;}
.ap-d-img img{width:100%;height:100%;object-fit:contain;}
.ap-d-img.imgerr img{display:none;}
.ap-d-field{margin-bottom:10px;flex:1;}
.ap-d-field label{display:block;font-size:11.5px;color:var(--muted);font-weight:700;margin-bottom:4px;}
.ap-d-static{font-weight:800;padding:8px 0;}
.ap-d-row{display:flex;gap:12px;}
.ap-d-up{display:inline-flex;margin:2px 0 12px;}
.ap-d-active{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px;margin:10px 0;}

/* ===== Card Intake (Shopify-style inventory) ===== */
.ci-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:14px;}
.ci-st{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:12px 14px;text-align:center;}
.ci-st-v{font-size:24px;font-weight:900;}.ci-st-l{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-top:2px;}
.ci-st.pos .ci-st-v{color:#16a34a;}.ci-st.neg .ci-st-v{color:#e4002b;}
.ci-drop{display:flex;align-items:center;gap:16px;flex-wrap:wrap;border:2px dashed var(--line-2);border-radius:16px;padding:20px 22px;background:var(--bg-soft);margin-bottom:14px;transition:border-color .15s,background .15s;}
.ci-drop.over{border-color:var(--ink);background:#eef0ff;}
.ci-drop-ic{font-size:30px;}.ci-drop-t{flex:1;min-width:200px;}.ci-drop-btns{display:flex;gap:8px;}
.ci-prog{flex-basis:100%;}.ci-prog:empty{display:none;}
.ci-pbar{height:8px;background:#e6e6ea;border-radius:6px;overflow:hidden;margin:8px 0 4px;}.ci-pbar i{display:block;height:100%;background:var(--ink);transition:width .2s;}
.ci-url{display:flex;gap:8px;align-items:flex-start;margin-bottom:8px;}
.ci-url-ic{font-size:18px;margin-top:8px;}
.ci-url .input{flex:1;min-width:200px;}
.ci-urls{resize:vertical;font-family:inherit;line-height:1.5;}
.ci-url .btn{margin-top:2px;}
.ci-urlprog{margin-bottom:8px;}.ci-urlprog:empty{display:none;}
.ci-urlfail{margin-bottom:12px;}.ci-urlfail:empty{display:none;}
.ci-failh{font-size:12.5px;font-weight:800;color:#c2002b;margin-bottom:6px;}
.ci-failrow{display:flex;justify-content:space-between;gap:12px;font-size:11.5px;padding:4px 8px;border:1px solid #f3c6cd;border-radius:7px;margin-bottom:4px;background:#fdf2f4;}
.ci-failrow span{word-break:break-all;}.ci-failrow em{color:#c2002b;white-space:nowrap;font-style:normal;font-weight:700;}
.ci-bar{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap;}
.ci-search{flex:1;min-width:240px;}.ci-count{font-size:12.5px;white-space:nowrap;}
.ci-act{position:sticky;top:60px;z-index:20;display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:8px 10px;border-radius:12px;background:#fff;border:1px solid var(--line);margin-bottom:12px;}
.ci-act.on{background:#0b0b0d;border-color:#0b0b0d;color:#fff;box-shadow:0 8px 24px rgba(0,0,0,.25);}
.ci-act.on .btn{background:#26262c;color:#fff;border-color:#3a3a42;}
.ci-act .ci-mini{min-width:130px;padding:7px 9px;font-size:13px;}
.ci-selall{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;}
.ci-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
@media(max-width:1400px){.ci-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:1050px){.ci-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:720px){.ci-grid{grid-template-columns:repeat(2,1fr);}}
.ci-c{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;transition:border-color .12s,box-shadow .12s;}
.ci-c.sel{border-color:var(--ink);box-shadow:0 0 0 2px var(--ink);}
.ci-chk{position:absolute;top:14px;left:14px;z-index:3;background:#fff;border-radius:6px;padding:2px 3px;line-height:0;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.ci-chk input{width:17px;height:17px;cursor:pointer;}
.ci-img{aspect-ratio:3/4;border-radius:10px;overflow:hidden;background:var(--bg-soft);display:grid;place-items:center;margin-bottom:8px;}
.ci-img img{width:100%;height:100%;object-fit:contain;}.ci-img img.err{display:none;}
.ci-img img.err+*,.ci-img:has(img.err)::after{content:"⚠ no image";color:#b3261e;font-size:11px;font-weight:800;}
.ci-bds{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px;min-height:18px;}
.ci-bd{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;padding:2px 6px;border-radius:5px;}
.ci-bd.draft{background:#eef;color:#3b3bdb;}.ci-bd.warn{background:#fdeccd;color:#9a6400;}.ci-bd.mut{background:#eee;color:#666;}.ci-bd.off{background:#fde4e8;color:#c2002b;}
.ci-f{width:100%;border:1px solid var(--line-2);border-radius:8px;padding:6px 8px;font-size:13px;font-weight:600;background:#fff;}
.ci-name{font-weight:800;margin-bottom:6px;}
.ci-2{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px;}
.ci-tg{display:flex;align-items:center;gap:10px;font-size:11.5px;font-weight:700;color:var(--muted);flex-wrap:wrap;}
.ci-tg label{display:flex;align-items:center;gap:4px;cursor:pointer;}
.ci-stt{margin-left:auto;font-size:10.5px;}
.ci-imgops{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line);}
.ci-op{font-size:11px;font-weight:700;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);border-radius:7px;padding:4px 8px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;}
.ci-op:hover{color:var(--ink);}
.ci-frlbl{margin-left:auto;}
.ci-more{text-align:center;margin:16px 0;}
