:root{color-scheme:light;--bg: #f8f9fa;--bg-deep: #f1f3f5;--card-bg: rgba(255, 255, 255, .45);--card-strong: rgba(255, 255, 255, .55);--card-solid: rgba(255, 255, 255, .75);--border: rgba(0, 0, 0, .06);--border-strong: rgba(0, 0, 0, .1);--primary: #374151;--primary-hover: #1f2937;--accent: #6b7280;--danger: #dc2626;--text: #111827;--muted: #6b7280;--shadow: 0 8px 32px rgba(0, 0, 0, .08);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .06);--sidebar-w: 260px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-height:100vh;color:var(--text);background:#e5e7eb}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url(/bg.jpg);background-size:cover;background-position:center top;opacity:.55;transform:scale(1.02);z-index:-3;pointer-events:none}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#f1f3f559;z-index:-2;pointer-events:none}a{color:inherit}button,input,select,textarea{font:inherit}button{border:1px solid rgba(255,255,255,.45);background:#ffffff73;color:var(--text);padding:.72rem 1rem;border-radius:10px;cursor:pointer;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease;box-shadow:0 1px 3px #0000000a}button:hover:not(:disabled){border-color:#ffffffb3;background:#ffffffa6}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav-link:focus-visible,.auth-footer a:focus-visible{outline:2px solid rgba(55,65,81,.35);outline-offset:2px}button:disabled{opacity:.45;cursor:not-allowed}.btn-danger{color:#991b1b;border-color:#f871714d;background:#fef2f28c}.btn-danger:hover:not(:disabled){border-color:#dc262673;background:#fee2e2b3}input,select,textarea{width:100%;padding:.72rem .9rem;border:1px solid rgba(255,255,255,.5);border-radius:10px;color:var(--text);background:#fff6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:inset 0 1px 2px #0000000a}input::placeholder,textarea::placeholder{color:#11182766}.app-shell,.auth-page{position:relative;min-height:100vh;overflow:hidden}.app-background,.app-background-glow{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}.app-background{z-index:0}.app-background-glow{filter:blur(20px);opacity:.4;z-index:0}.glow-primary{background:radial-gradient(circle at 12% 18%,rgba(107,114,128,.12),transparent 20%)}.glow-secondary{background:radial-gradient(circle at 88% 12%,rgba(107,114,128,.08),transparent 18%)}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr);gap:1rem;padding:1rem;transition:grid-template-columns .24s ease}.app-shell.is-collapsed{grid-template-columns:72px minmax(0,1fr)}.sidebar,.main-content,.auth-card,.page,.balance-card,.redeem-card,.profile-header,.balance-summary,.info-card,.modal,.toast{position:relative;z-index:1;background:#fff9;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 30px #0000000f;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}.sidebar{display:flex;flex-direction:column;gap:1.25rem;padding:1.1rem;border-radius:16px;min-height:calc(100vh - 2rem);position:sticky;top:1rem}.sidebar-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-brand{display:flex;align-items:center;gap:.75rem;min-width:0}.sidebar-brand-text{min-width:0;display:flex;flex-direction:column;gap:.15rem;overflow:hidden}.sidebar-brand-text h2{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand-text p{font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-badge{width:40px;height:40px;flex-shrink:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-family:Inter,monospace;font-size:.82rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#374151,#6b7280);box-shadow:0 4px 10px #11182726;letter-spacing:.04em}.sidebar-toggle{width:34px;height:34px;flex-shrink:0;padding:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff59;border:1px solid rgba(255,255,255,.4);box-shadow:none;color:var(--muted)}.sidebar-toggle:hover:not(:disabled){background:#ffffff8c;color:var(--text)}.sidebar-toggle svg{width:18px;height:18px}.mobile-topbar{display:none;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .9rem;margin-bottom:.75rem;border-radius:12px;background:#ffffff8c;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 24px #0000000f;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}.mobile-topbar .sidebar-brand{gap:.6rem}.mobile-topbar .sidebar-badge{width:34px;height:34px;font-size:.75rem;border-radius:8px}.mobile-topbar h2{margin:0;font-size:.95rem;font-weight:600}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#11182759;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40}.sidebar h2,.header-bar h1,.page h2,.auth-card h2{margin:0;font-weight:600}.header-bar h1{font-size:1.15rem}.sidebar p,.auth-subtitle,.balance-label,.balance-summary .label,.balance-summary .sub,.info-list .label,.eyebrow,.auth-eyebrow,.user-pill,.auth-footer,.toast,.header-actions,.sidebar nav,.modal-body label,.auth-card label{color:var(--muted)}.sidebar p,.auth-subtitle,.auth-footer{margin:0}.sidebar nav{display:flex;flex-direction:column;gap:.3rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;border-radius:10px;text-decoration:none;background:transparent;transition:background-color .18s ease,border-color .18s ease,color .18s ease;border:1px solid transparent;color:var(--muted);font-size:.92rem;white-space:nowrap;overflow:hidden}.nav-link:hover{color:var(--text);background:#ffffff4d}.nav-link.active{color:var(--text);background:#fff6;border-color:#ffffff80}.nav-link .nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis}.icon{width:1.65rem;height:1.65rem;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff4d;color:var(--muted);transition:background-color .18s ease,color .18s ease}.nav-link:hover .icon,.nav-link.active .icon{background:#ffffff73;color:var(--text)}.icon svg{width:16px;height:16px}.is-collapsed .sidebar-brand-text,.is-collapsed .nav-link .nav-label{display:none}.is-collapsed .sidebar{align-items:stretch}.is-collapsed .sidebar-head{flex-direction:column;gap:.75rem}.is-collapsed .nav-link{justify-content:center;padding:.65rem}.status-dot,.user-pill__dot{width:.55rem;height:.55rem;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px #22c55e26}.main-content{display:flex;flex-direction:column;gap:1rem}.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.1rem;border-radius:14px}.eyebrow,.auth-eyebrow{margin:0 0 .35rem;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase}.header-actions{display:flex;gap:.75rem;align-items:center}.header-actions--layout{justify-content:flex-end}.user-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .85rem;border-radius:999px;background:#fff6;border:1px solid rgba(255,255,255,.45);font-size:.85rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.content-area{flex:1;overflow:auto}.page{padding:1.25rem;border-radius:14px}.table-scroll{max-height:calc(100vh - 220px);overflow:auto;border-radius:12px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.page-header h2{font-size:1.15rem;font-weight:600}.page-header--stacked{justify-content:flex-start}.header-actions input{width:220px}.data-table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:12px;background:#ffffff59;border:1px solid rgba(255,255,255,.45);font-size:.9rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.data-table th,.data-table td{padding:.8rem .95rem;border-bottom:1px solid rgba(255,255,255,.35);text-align:left}.data-table tr:last-child td{border-bottom:none}.data-table th{background:#ffffff40;color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.data-table tbody tr:hover{background:#ffffff40}.actions{display:flex;flex-wrap:wrap;gap:.45rem}.status-active{color:#047857}.status-disabled,.status-used,.status-expired{color:#b91c1c}.code-cell{display:flex;align-items:center;gap:.5rem;font-family:SF Mono,Consolas,Menlo,monospace;font-size:.85rem}.auth-page{display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:min(400px,100%);padding:1.75rem;border-radius:14px;display:flex;flex-direction:column;gap:.9rem}.auth-card label,.modal-body label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem}.modal-body label.checkbox-label{flex-direction:row;align-items:center}.modal-body label.checkbox-label input[type=checkbox]{width:auto}.auth-card button[type=submit]{background:var(--primary);color:#fff;border-color:transparent}.auth-card button[type=submit]:hover:not(:disabled){background:var(--primary-hover)}.auth-footer{text-align:center;font-size:.92rem}.auth-footer a{color:var(--primary);text-decoration:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118274d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal{width:min(440px,100%);border-radius:14px;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.15rem;border-bottom:1px solid rgba(255,255,255,.3)}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.9rem}.modal-actions{display:flex;justify-content:flex-end;gap:.65rem;margin-top:.35rem}.toast-container{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:.65rem;z-index:100}.toast{min-width:240px;padding:.8rem 1rem;border-radius:10px;color:var(--text);background:#ffffffbf;border:1px solid rgba(255,255,255,.6);box-shadow:0 8px 24px #0000001a;font-size:.9rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.toast-error{background:#fef2f2cc;border-color:#f8717159;color:#991b1b}.toast-info{background:#eff6ffcc;border-color:#60a5fa59;color:#1e3a8a}.wallet-page .balance-card{padding:1.75rem;border-radius:14px;text-align:center;margin-bottom:1rem;background:#ffffff80}.wallet-page .balance-amount,.balance-summary .amount{font-size:2.25rem;font-weight:700;margin-top:.35rem;color:var(--text)}.wallet-page .redeem-card{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;padding:1.15rem;border-radius:14px}.wallet-page .redeem-card h3{width:100%;margin:0 0 .35rem;font-size:1rem;font-weight:600}.wallet-page .redeem-card input{flex:1;min-width:200px}.profile-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.15rem;border-radius:14px;margin-bottom:.9rem}.profile-info{display:flex;align-items:center;gap:.9rem}.profile-info .avatar{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#374151,#6b7280);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:700;box-shadow:0 4px 12px #11182726}.profile-info .name{font-size:1rem;font-weight:600}.role-tag,.id-tag{display:inline-flex;align-items:center;padding:.28rem .65rem;border-radius:999px;font-size:.78rem;font-weight:500}.role-tag{margin-top:.35rem;background:#ffffff59;color:var(--muted);border:1px solid rgba(255,255,255,.5)}.id-tag{background:#ffffff59;color:var(--muted);border:1px solid rgba(255,255,255,.5)}.balance-summary,.info-card{border-radius:14px}.balance-summary{padding:1.15rem;margin-bottom:.9rem}.info-header{margin:0;padding:.9rem 1.15rem;border-bottom:1px solid rgba(255,255,255,.35);font-size:.95rem;font-weight:600}.info-list{list-style:none;padding:0;margin:0}.info-list li{display:flex;align-items:center;gap:1rem;padding:.9rem 1.15rem;border-bottom:1px solid rgba(255,255,255,.3)}.info-list li:last-child{border-bottom:none}.info-list .label{width:100px;flex-shrink:0}.info-list .value{flex:1}@media (max-width: 1100px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.app-shell.is-collapsed{grid-template-columns:64px minmax(0,1fr)}}@media (max-width: 860px){.app-shell{display:block;padding:.75rem}.mobile-topbar{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:50;width:260px;max-width:82vw;border-radius:0 14px 14px 0;min-height:100vh;transform:translate(-105%);transition:transform .26s ease;box-shadow:0 20px 60px #00000026;background:#ffffffd9;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4)}.app-shell.is-mobile-open .sidebar{transform:translate(0)}.app-shell.is-mobile-open .sidebar-backdrop{display:block}.sidebar-head .sidebar-toggle.desktop-only{display:none}.is-collapsed .sidebar-brand-text,.is-collapsed .nav-link .nav-label{display:flex}.is-collapsed .sidebar-head{flex-direction:row}.is-collapsed .nav-link{justify-content:flex-start;padding:.7rem .85rem}}@media (max-width: 768px){.auth-page{padding:.9rem}.header-bar,.profile-header,.page-header,.info-list li{flex-direction:column;align-items:flex-start}.header-actions,.header-actions--layout,.modal-actions{width:100%;justify-content:stretch;flex-wrap:wrap}.header-actions>*,.header-actions--layout>*,.modal-actions>*{flex:1 1 auto}.header-actions input{width:100%}.data-table{display:block;overflow-x:auto}.info-list .label{width:auto}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
