/* Kaozeal Objects — design system, accent ambre oklch(0.62 0.16 45) */
:root{
  --accent-h:45;
  --accent:oklch(0.62 0.16 var(--accent-h));
  --accent-strong:oklch(0.52 0.16 var(--accent-h));
  --accent-soft:oklch(0.95 0.05 var(--accent-h));
  --accent-ring:oklch(0.62 0.16 var(--accent-h)/.30);
  --on-accent:#fff;
  --surface:#fff; --surface-2:#f5f6fa; --bg:#eef1f7; --line:#e3e7ee; --line-2:#d7dce5;
  --ink:#22262e; --ink-2:#535a66; --ink-3:#8a909c;
  --success:#16985a; --success-soft:#e4f5ec; --warning:#e08a1e; --warning-soft:#fbf0dd; --danger:#dc3b47; --danger-soft:#fbe4e6;
  --r-base:10px; --r-card:14px; --r-window:18px; --r-pill:999px;
  --shadow-soft:0 1px 2px rgba(20,28,46,.04),0 6px 18px rgba(20,28,46,.06);
  --shadow-pop:0 12px 40px rgba(20,28,46,.22);
  --dot-muted:#c3c9d4;
  --font:"Plus Jakarta Sans",system-ui,sans-serif; --mono:"JetBrains Mono",monospace;
}
[data-theme="dark"]{
  --accent:oklch(0.7 0.16 var(--accent-h)); --accent-strong:oklch(0.76 0.15 var(--accent-h)); --accent-soft:oklch(0.34 0.08 var(--accent-h)); --on-accent:#0b0e13;
  --surface:#1a1e25; --surface-2:#20242c; --bg:#121419; --line:#2c313b; --line-2:#353b46; --ink:#eceef2; --ink-2:#b7bdc7; --ink-3:#7e8591;
  --success-soft:#11271d; --warning-soft:#2c2110; --danger-soft:#2c1518; --dot-muted:#424956;
  --shadow-soft:0 1px 2px rgba(0,0,0,.3),0 6px 18px rgba(0,0,0,.35); --shadow-pop:0 12px 40px rgba(0,0,0,.6);
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font-family:var(--font);font-size:13.5px;line-height:1.5;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
h1,h2,h3{margin:0;letter-spacing:-.3px} h1{font-weight:800} h2{font-weight:700;font-size:16px} p{margin:0;color:var(--ink-2)} small{color:var(--ink-3);font-size:12px}
button,input,select,textarea{font-family:inherit}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:38px;padding:0 16px;border-radius:var(--r-base);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;transition:.15s;text-decoration:none}
.btn:hover{background:var(--surface-2)} .btn.primary{background:var(--accent);color:var(--on-accent);border-color:transparent} .btn.primary:hover{background:var(--accent-strong)}
.btn.danger{background:var(--danger);color:#fff;border-color:transparent} .btn.sm{height:30px;padding:0 12px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600;background:var(--success-soft);color:var(--success)}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.pill.gold{background:var(--warning-soft);color:var(--warning)} .pill.red{background:var(--danger-soft);color:var(--danger)} .pill.neutral{background:var(--surface-2);color:var(--ink-2)} .pill.neutral::before{background:var(--ink-3)}
.role{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.4px;padding:3px 8px;border-radius:6px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
.form{display:flex;flex-direction:column;gap:14px} .field{display:flex;flex-direction:column;gap:6px} .field>span{font-size:12px;font-weight:600;color:var(--ink-2)}
input,select,textarea{width:100%;height:40px;padding:0 12px;border-radius:var(--r-base);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:13.5px;transition:.15s}
textarea{height:auto;padding:10px 12px;resize:vertical} input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.notice{padding:11px 14px;border-radius:var(--r-base);font-size:13px;font-weight:500} .notice.error{background:var(--danger-soft);color:var(--danger)} .notice.success{background:var(--success-soft);color:var(--success)}
.meta-row{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--ink-3);font-size:12px}
/* auth */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;max-width:1040px;margin:0 auto;padding:24px;gap:24px;align-items:center}
.auth-visual{position:relative;overflow:hidden;border-radius:var(--r-window);padding:40px;display:flex;flex-direction:column;justify-content:space-between;gap:40px;color:#fff;min-height:480px;background:linear-gradient(150deg,var(--accent-strong),oklch(0.45 0.15 var(--accent-h)));box-shadow:var(--shadow-soft)}
.auth-visual::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1px,transparent 1px);background-size:22px 22px;opacity:.5}
.auth-visual h1{font-size:34px;color:#fff} .auth-visual p{color:rgba(255,255,255,.85);margin-top:12px}
.auth-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-window);padding:36px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:18px}
.brand{display:flex;align-items:center;gap:12px} .brand strong{font-size:15px;font-weight:800;display:block} .brand span{font-size:11.5px;color:var(--ink-3)}
.mark{width:40px;height:40px;border-radius:28%;display:grid;place-items:center;font-weight:800;font-size:19px;color:var(--on-accent);background:linear-gradient(150deg,var(--accent),var(--accent-strong))}
.auth-visual .brand strong,.auth-visual .brand span{color:#fff} .auth-visual .mark{background:rgba(255,255,255,.18)}
/* window/shell */
.app-window{width:100%;min-height:100vh;background:var(--surface);display:flex;flex-direction:column}
.titlebar{height:44px;flex:none;display:flex;align-items:center;gap:12px;padding:0 18px;background:var(--surface-2);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.crumbs{display:flex;align-items:center;gap:10px} .crumb-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.crumb-root{font-weight:700;font-size:13px;color:var(--ink-2)} .crumb-sep{color:var(--ink-3)} .crumb-current{font-weight:700;font-size:13px;color:var(--accent-strong)}
.win-tools{margin-left:auto;display:flex;gap:8px}
.icon-btn{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 11px;border-radius:var(--r-pill);border:1px solid var(--line-2);background:var(--surface);color:var(--ink-2);font-size:11.5px;font-weight:600;cursor:pointer;font-family:var(--mono);text-transform:uppercase}
.shell{display:grid;grid-template-columns:240px 1fr;flex:1;min-height:0}
.sidebar{border-right:1px solid var(--line);background:var(--surface);padding:18px 14px;display:flex;flex-direction:column;gap:16px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav button{display:flex;align-items:center;gap:11px;width:100%;height:40px;padding:0 12px;border:none;border-radius:var(--r-base);background:transparent;color:var(--ink-2);font-weight:600;font-size:13px;cursor:pointer;text-align:left}
.nav button .ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}
.nav button:hover{background:var(--surface-2)} .nav button.active{background:var(--accent-soft);color:var(--accent-strong)} .nav .ico svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.user-strip{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:14px;border-top:1px solid var(--line)}
.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:var(--accent-soft);color:var(--accent-strong)}
.avatar-row{display:flex;align-items:center;gap:10px} .avatar-row strong{font-size:13px} .avatar-row small{font-size:11px}
.main{overflow-y:auto;min-height:0;background:var(--bg)}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 26px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar h1{font-size:22px} .actions{display:flex;gap:10px;flex-wrap:wrap}
.content{padding:24px 26px 40px;display:flex;flex-direction:column;gap:20px;max-width:1040px;margin:0 auto}
.grid{display:grid;gap:16px} .stats{grid-template-columns:repeat(4,1fr)} .two-col{grid-template-columns:1fr 1fr;align-items:start}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:18px;box-shadow:var(--shadow-soft)}
.stat{display:flex;flex-direction:column;gap:6px}
.stat::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);margin-bottom:8px}
.stat span{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-3)} .stat strong{font-size:27px;font-weight:800;letter-spacing:-1px}
.panel{padding:18px;display:flex;flex-direction:column;gap:14px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.section-head h2{display:flex;align-items:center;gap:10px} .section-head h2::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);margin-right:4px}
.table{display:flex;flex-direction:column}
.table-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--line)} .table-row:last-child{border-bottom:none}
.table-row>div:first-child{flex:1;min-width:160px} .table-row strong{font-size:13px} .table-row .actions{margin-left:auto}
.mono{font-family:var(--mono);font-size:11.5px;color:var(--ink-3)}
.empty-state{padding:18px;border:1px dashed var(--line-2);border-radius:var(--r-base);color:var(--ink-3);font-size:12.5px;background:var(--surface-2)}
.qr-box{display:flex;flex-direction:column;align-items:center;gap:14px} .qr-box img{width:240px;height:240px;border:1px solid var(--line);border-radius:var(--r-base);background:#fff;padding:8px}
.modal-backdrop{position:fixed;inset:0;z-index:50;background:rgba(15,20,30,.45);backdrop-filter:blur(3px);display:grid;place-items:center;padding:22px}
.modal{width:100%;max-width:460px;max-height:88vh;overflow-y:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-window);padding:22px;box-shadow:var(--shadow-pop);display:flex;flex-direction:column;gap:16px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:60;background:var(--ink);color:var(--surface);padding:12px 20px;border-radius:var(--r-pill);font-size:13px;font-weight:600;box-shadow:var(--shadow-pop)}
@media(max-width:1000px){.stats{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}}
@media(max-width:760px){.shell{grid-template-columns:1fr}.auth-wrap{grid-template-columns:1fr}}

.admin-tabs{display:flex;gap:6px;flex-wrap:wrap;padding-bottom:4px}
.admin-tabs button{border:1px solid var(--line-2);background:var(--surface);height:32px;padding:0 13px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;color:var(--ink-2);cursor:pointer}
.admin-tabs button:hover{background:var(--surface-2)}
.admin-tabs button.active{background:var(--accent);color:var(--on-accent);border-color:transparent}

.scan-box{position:relative;border-radius:var(--r-base);overflow:hidden;background:#000;aspect-ratio:1/1;display:grid;place-items:center;margin-bottom:4px}
.scan-box video{width:100%;height:100%;object-fit:cover}
.scan-frame{position:absolute;width:62%;height:62%;border:3px solid var(--accent);border-radius:14px}
.scan-box small{position:absolute;bottom:8px;color:#fff;font-size:11px;background:rgba(0,0,0,.55);padding:3px 8px;border-radius:8px}

.cat-thumb{width:36px;height:36px;border-radius:9px;object-fit:cover;border:1px solid var(--line);flex:none;background:var(--surface-2)}
.cat-thumb.cat-empty{display:inline-block;background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 6px,var(--line) 6px,var(--line) 7px)}
.cat-preview{display:flex;justify-content:center}
.cat-preview img{max-width:160px;max-height:160px;border-radius:var(--r-base);border:1px solid var(--line);object-fit:cover}

.admin-search{height:32px;border-radius:var(--r-pill);border:1px solid var(--line-2);padding:0 14px;font-size:12.5px;background:var(--surface);color:var(--ink);min-width:130px;max-width:200px}
.modal.modal-wide{max-width:640px}
.chart{width:100%;height:140px;display:block}
.chart-x{display:flex;justify-content:space-between;font-size:10.5px;color:var(--ink-3);font-family:var(--mono);margin-top:2px}
.bars{display:flex;flex-direction:column;gap:6px}
.bar-row{display:flex;align-items:center;gap:8px;font-size:12px}
.bar-k{width:92px;flex:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-2)}
.bar-track{flex:1;height:8px;background:var(--surface-2);border-radius:var(--r-pill);overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--accent);border-radius:var(--r-pill)}
.bar-n{width:36px;flex:none;text-align:right;font-weight:600;color:var(--ink)}
.qr-designer{display:flex;flex-direction:column;gap:14px;align-items:center}
.qr-preview{width:240px;height:240px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-base);padding:6px}
.qr-preview canvas,.qr-preview svg{max-width:100%;height:auto}
.qr-controls{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
.qr-controls input[type=color]{height:38px;padding:2px;width:100%}
