:root{--bg:#171717;--bg-2:#1c1c1c;--surface:#ffffff0a;--surface-2:#ffffff12;--card:#1c1c1c;--fg:#f4f7fc;--muted:#c9cdd2;--border:#ffffff1a;--border-strong:#fff3;--accent:#b6ff3b;--accent-2:#2a2a2a;--accent-grad:linear-gradient(135deg, #b6ff3b 0%, #a6f028 100%);--accent-soft:#b6ff3b29;--glow:0 10px 28px #00000057;--ok:#36e0a4;--warn:#ffc24b;--danger:#ff5d6c;--radius:12px;--radius-sm:9px;--sidebar-w:232px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans TC", "PingFang TC", sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{font-family:var(--font);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0;line-height:1.5}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:#caff7a}.muted{color:var(--muted)}::selection{background:#b6ff3b40}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);-webkit-backdrop-filter:saturate(140%)blur(12px);background:#090b12d1;flex-direction:column;flex-shrink:0;gap:4px;height:100vh;padding:18px 14px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:9px;margin-bottom:4px;padding:4px 8px 14px;display:flex}.sidebar-brand .logo{background:var(--accent-grad);color:#171717;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;font-weight:900;display:flex;box-shadow:0 10px 26px #00000052}.sidebar-brand .logo-mark{object-fit:cover;border-radius:9px;flex-shrink:0;width:30px;height:30px;display:block;box-shadow:0 4px 14px #00000059}.sidebar-brand .brand-text{flex-direction:column;line-height:1.2;display:flex}.sidebar-brand .brand-name{letter-spacing:.01em;font-size:14px;font-weight:800}.sidebar-brand .brand-sub{color:var(--muted);letter-spacing:.06em;font-size:11px}.sidebar-scroll{flex-direction:column;flex:1;gap:2px;min-height:0;display:flex}.nav-group-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:14px 10px 6px;font-size:10.5px;font-weight:700}.navlink{border-radius:var(--radius-sm);color:var(--fg);align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:background .14s,color .14s;display:flex;position:relative}.navlink .nav-ico{text-align:center;opacity:.85;flex-shrink:0;width:18px;font-size:15px}.navlink:hover{color:var(--fg);background:var(--surface)}.navlink.active{color:var(--fg);background:linear-gradient(90deg,#b6ff3b29,#0000001a);font-weight:700}.navlink.active:before{content:"";background:var(--accent-grad);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.navlink .nav-badge{background:var(--danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:11px;font-weight:800;display:inline-flex}.sidebar-foot{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:8px;padding-top:12px;display:flex}.sidebar-user{flex-direction:column;gap:2px;padding:0 4px;display:flex}.sidebar-user .u-email{color:var(--fg);word-break:break-all;font-size:12px}.sidebar-user .u-role{color:var(--muted);font-size:11px}.sidebar-user .u-role .role-pill{border:1px solid var(--border-strong);color:var(--accent);border-radius:999px;padding:1px 7px;font-size:10.5px;font-weight:700;display:inline-block}.btn-logout{justify-content:center;width:100%}.content{flex-direction:column;flex:1;min-width:0;display:flex}.container{width:100%;max-width:1120px;margin:0 auto;padding:26px 26px 72px}.mobile-bar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:saturate(140%)blur(12px);z-index:40;background:#090b12d9;align-items:center;gap:12px;padding:11px 16px;display:none;position:sticky;top:0}.mobile-bar .hamburger{background:var(--surface);border:1px solid var(--border-strong);color:var(--fg);width:38px;height:38px;box-shadow:none;border-radius:10px;padding:0;font-size:18px}.mobile-bar .mb-title{background:var(--accent-grad);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:800}.scrim{z-index:49;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#03040899;display:none;position:fixed;inset:0}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.stat-card{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--fg);text-align:left;cursor:pointer;flex-direction:column;gap:8px;padding:18px;transition:transform .14s,border-color .16s,background .16s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--border-strong);opacity:.7;height:2px;position:absolute;inset:0 0 auto}.stat-card:hover{background:var(--surface-2);border-color:#b6ff3b73;transform:translateY(-2px);box-shadow:0 10px 26px #00000052}.stat-card.alert:before{background:var(--accent-grad);opacity:1}.stat-card.alert{border-color:#b6ff3b4d}.stat-top{align-items:center;gap:8px;display:flex}.stat-ico{font-size:17px;line-height:1}.stat-label{color:var(--muted);font-size:12.5px;font-weight:600}.stat-value{font-size:34px;font-weight:800;line-height:1.05;font-family:var(--mono);letter-spacing:-.02em}.stat-card.alert .stat-value{background:var(--accent-grad);color:#0000;-webkit-background-clip:text;background-clip:text}.stat-value.money{font-size:26px}.stat-sub{color:var(--muted);font-size:12px}.stat-sub.live{color:var(--ok);font-weight:600}.stat-card.wide{grid-column:span 2}@media (width<=560px){.stat-card.wide{grid-column:span 1}}.dash-empty{color:var(--muted)}button,.btn{background:var(--accent-grad);color:#171717;font:inherit;cursor:pointer;letter-spacing:.01em;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:8px 15px;font-size:13.5px;font-weight:700;transition:filter .15s,box-shadow .16s,border-color .14s,transform .1s;display:inline-flex;box-shadow:0 10px 26px #00000052}button:hover,.btn:hover{filter:brightness(1.06);box-shadow:0 5px 18px #00000038}button:active,.btn:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;filter:none}button.ghost,.btn.ghost{background:var(--surface);color:var(--fg);border-color:var(--border-strong);box-shadow:none}button.ghost:hover,.btn.ghost:hover{border-color:var(--accent);color:#caff7a;filter:none}button.danger,button.ghost.danger{background:var(--surface);color:var(--danger);box-shadow:none;border-color:#ff5d6c80}button.danger:hover,button.ghost.danger:hover{border-color:var(--danger);color:var(--danger);filter:none;background:#ff5d6c1f}input,select,textarea{width:100%;color:var(--fg);border:1px solid var(--border-strong);font:inherit;background:#00000057;border-radius:10px;padding:9px 12px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #b6ff3b26}label{color:var(--muted);margin-bottom:5px;font-size:12.5px;font-weight:500;display:block}.col{flex-direction:column;gap:12px;display:flex}.row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}table{border-collapse:collapse;width:100%;font-size:13.5px}th,td{text-align:left;border-bottom:1px solid var(--border);vertical-align:middle;padding:9px 12px}thead th{background:#ffffff05;position:sticky;top:0}th{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}tbody tr:hover{background:#ffffff05}td select{width:auto;min-width:108px}@media (width<=760px){thead{display:none}table,tbody,tr,td{width:100%;display:block}tbody tr{border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--surface-2);margin:10px;padding:10px 12px}td{border:none;align-items:center;gap:10px;padding:7px 0;display:flex}td[data-label]:before{content:attr(data-label);color:var(--muted);letter-spacing:.04em;flex-shrink:0;min-width:64px;font-size:11px;font-weight:700}td input,td select{font-size:16px;width:100%!important;min-width:0!important}td .row{flex-wrap:wrap;flex:1}td .row button{min-height:38px}}.thumb{object-fit:cover;border:1px solid var(--border);background:#0a0c12;border-radius:8px;width:40px;height:40px}.thumbs{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.code-chip{color:var(--accent);font-family:var(--mono);letter-spacing:.04em;background:#b6ff3b14;border:1px solid #b6ff3b66;border-radius:8px;padding:3px 10px;font-size:12.5px;font-weight:700;display:inline-block}.badge{letter-spacing:.03em;border:1px solid var(--border-strong);color:var(--muted);background:var(--surface);border-radius:999px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:700;display:inline-flex}.badge.on{color:var(--ok);border-color:#36e0a480}.badge.off{color:var(--muted);border-color:var(--border-strong)}.toast{z-index:60;border-radius:11px;padding:11px 20px;font-size:13.5px;font-weight:600;position:fixed;bottom:22px;left:50%;transform:translate(-50%);box-shadow:0 8px 28px #00000073}.toast.ok{background:var(--ok);color:#03281b}.toast.err{background:var(--danger);color:#2c0708}h1{letter-spacing:-.01em;margin:0 0 18px;font-size:23px;font-weight:800}h2{margin:26px 0 12px;font-size:15px;font-weight:700}.error-text{color:var(--danger);font-size:13.5px}.ok-text{color:var(--ok);font-size:13.5px}.field-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.center{max-width:440px;margin:12vh auto;padding:26px}.center h1{background:var(--accent-grad);color:#0000;-webkit-background-clip:text;background-clip:text}@media (width<=880px){.mobile-bar{display:flex}.sidebar{z-index:50;height:100vh;transition:transform .22s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 0 40px #00000080}.sidebar.open{transform:translate(0)}.scrim.open{display:block}.container{padding:20px 16px 64px}}@media (width<=640px){.field-grid{grid-template-columns:1fr}}
