.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text2);font-size:12px;font-weight:500;font-family:var(--font-zh)}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-select,.form-textarea{border:1px solid var(--border2);border-radius:var(--radius);font-size:13px;font-family:var(--font-zh);color:var(--text);background:var(--surface);outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s}.form-input,.form-select{height:41px;line-height:1.4}.form-input::placeholder,.form-textarea::placeholder{color:var(--text3)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e9456014}.form-textarea{resize:vertical;min-height:80px;font-family:var(--font-zh)}.form-hint{color:var(--text3);font-size:11px;font-family:var(--font-zh)}.toggle-wrap{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.toggle{background:var(--border2);border-radius:10px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.toggle:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:left .2s;position:absolute;top:3px;left:3px}.toggle.on{background:var(--success)}.toggle.on:after{left:19px}.toggle-label{color:var(--text);font-size:13px;font-family:var(--font-zh)}.login-btn{border-radius:var(--radius);background:var(--accent);color:#fff;width:100%;font-size:14px;font-weight:600;font-family:var(--font-zh);cursor:pointer;border:none;padding:12px;transition:background .15s}.login-btn:hover{background:#d03c54}.login-btn:disabled{opacity:.6;cursor:not-allowed}.btn{border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-zh);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#d03c54}.btn-secondary{background:var(--surface);border:1px solid var(--border2);color:var(--text)}.btn-secondary:hover{background:var(--surface3)}.btn-ghost{color:var(--text2);background:0 0}.btn-ghost:hover{background:var(--surface3)}.btn-sm{padding:5px 10px;font-size:12px}.btn-danger{color:var(--danger);background:#e24b4a1a}.btn-danger:hover{background:#e24b4a33}.btn-success{color:var(--success);background:#1d9e751a}.btn-success:hover{background:#1d9e7533}.btn:disabled{opacity:.6;cursor:not-allowed}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));column-gap:16px;display:grid}@media (width<=600px){.form-grid{grid-template-columns:1fr}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-title{color:var(--text);font-size:22px;font-weight:700}.page-subtitle{color:var(--text3);margin-top:2px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text);font-size:14px;font-weight:600}.card-subtitle{color:var(--text3);margin-top:2px;font-size:12px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:var(--info)}.stat-card.green:before{background:var(--success)}.stat-card.amber:before{background:var(--warning)}.stat-card.red:before{background:var(--danger)}.stat-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:12px;font-size:16px;display:flex}.stat-icon.blue{background:#378add1a}.stat-icon.green{background:#1d9e751a}.stat-icon.amber{background:#ef9f271a}.stat-icon.red{background:#e24b4a1a}.stat-value{font-size:26px;font-weight:700;font-family:var(--font-en);color:var(--text)}.stat-label{color:var(--text3);margin-top:4px;font-size:12px}.stat-change{align-items:center;gap:4px;margin-top:6px;font-size:11px;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--text3);letter-spacing:.8px;text-transform:uppercase;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;font-family:var(--font-en);white-space:nowrap;padding:10px 14px}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface2)}tbody td{color:var(--text2);vertical-align:middle;padding:12px 14px}.avatar-sm{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:600;display:flex}.cell-user{align-items:center;gap:10px;display:flex}.cell-user-name{color:var(--text);font-size:13px;font-weight:500}.cell-user-email{color:var(--text3);font-size:11px}.badge{font-size:11px;font-weight:500;font-family:var(--font-en);border-radius:6px;align-items:center;padding:3px 8px;display:inline-flex}.badge-success{color:#0f6e56;background:#1d9e751a}.badge-warning{color:#854f0b;background:#ef9f271a}.badge-danger{color:#a32d2d;background:#e24b4a1a}.badge-info{color:#185fa5;background:#378add1a}.badge-gray{color:var(--text2);background:#0000000f}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--text3);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font-zh);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.chart-bar-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.chart-bar-label{color:var(--text2);text-align:right;min-width:60px;font-size:12px}.chart-bar-track{background:var(--surface3);border-radius:4px;flex:1;height:8px;overflow:hidden}.chart-bar-fill{border-radius:4px;height:100%;transition:width .6s}.chart-bar-val{color:var(--text3);min-width:36px;font-size:12px;font-family:var(--font-en)}.filter-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-chip{border:1px solid var(--border2);cursor:pointer;color:var(--text2);background:var(--surface);-webkit-user-select:none;user-select:none;border-radius:20px;padding:5px 12px;font-size:12px;transition:all .15s}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.gap-2{gap:8px;display:flex}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.text-muted{color:var(--text3);font-size:12px}.text-sm{font-size:13px}.fw-500{font-weight:500}.color-accent{color:var(--accent)}.dot{border-radius:50%;width:7px;height:7px;display:inline-block}.dot-green{background:var(--success)}.dot-red{background:var(--danger)}.dot-gray{background:var(--text3)}.section-divider{border:none;border-top:1px solid var(--border);margin:20px 0}@media (width<=700px){.grid-2{grid-template-columns:1fr}}@media (width<=600px){.stats-grid{grid-template-columns:1fr 1fr}}@media (width<=400px){.stats-grid{grid-template-columns:1fr}}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;padding:28px;display:flex;overflow:hidden}.modal-header{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-body{flex:1;min-height:0;margin-right:-28px;padding-right:28px;overflow-y:auto}.modal-title{font-size:17px;font-weight:700}.modal-close{cursor:pointer;color:var(--text3);background:0 0;border:none;font-size:18px}.modal-footer{flex-shrink:0;justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{font-size:13px;font-family:var(--font-zh);color:#fff;opacity:1;white-space:nowrap;border-radius:20px;padding:9px 20px;transition:opacity .3s;box-shadow:0 4px 16px #0000002e}.toast.toast-info{background:var(--accent)}.toast.toast-success{background:var(--success)}.toast.toast-error{background:var(--danger)}.toast.toast-hide{opacity:0}:root{--primary:#1a1a2e;--accent:#e94560;--accent2:#0f3460;--surface:#fff;--surface2:#f8f7f4;--surface3:#f1efe8;--border:#00000014;--border2:#00000026;--text:#1a1a2e;--text2:#6b6a66;--text3:#9b9a97;--success:#1d9e75;--warning:#ef9f27;--danger:#e24b4a;--info:#378add;--font-en:"Space Grotesk", sans-serif;--font-zh:"Noto Sans TC", sans-serif;--sidebar-w:240px;--topbar-h:60px;--radius:10px;--radius-lg:16px;--shadow:0 1px 3px #0000000f, 0 4px 16px #0000000a;--shadow-lg:0 4px 24px #0000001a}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-zh);background:var(--surface2);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{min-height:100svh}:root{--line-green:#06c755;--line-green-dark:#05b34c;--line-green-light:#06c75514;--line-blue:#a2b5cd;--line-blue-light:#eef3f8;--line-white:#fff;--line-black:#111;--line-gray:#888;--line-divider:#eee;--line-bg:#f0f4f8;--safe-area-bottom:env(safe-area-inset-bottom)}.register-page{background-color:var(--line-bg);color:var(--line-black);flex-direction:column;min-height:100vh;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,sans-serif;display:flex}.register-page *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}.loader{background:var(--line-white);z-index:1000;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.line-logo-loader{background:var(--line-green);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;animation:1.2s ease-in-out infinite logoPulse;display:flex}.line-logo-loader svg{width:34px;height:34px;fill:var(--line-white)}.loader-dots{gap:7px;display:flex}.loader-dots span{background:var(--line-green);border-radius:50%;width:8px;height:8px;animation:1.1s ease-in-out infinite dotBounce}.loader-dots span:nth-child(2){animation-delay:.18s}.loader-dots span:nth-child(3){animation-delay:.36s}.register-header{background-color:var(--line-green);z-index:100;flex-shrink:0;justify-content:center;align-items:center;gap:10px;height:56px;display:flex;position:sticky;top:0}.register-header .logo-icon{width:28px;height:28px;fill:var(--line-white)}.register-header span{color:var(--line-white);letter-spacing:1.5px;font-size:1.05rem;font-weight:700}.main-content{flex-direction:column;flex:1;gap:14px;padding:20px 16px;display:flex}.welcome-bubble{align-items:flex-end;gap:10px;animation:.5s both slideUp;display:flex}.bot-avatar{background:var(--line-green);width:40px;height:40px;box-shadow:0 0 0 2.5px var(--line-white), 0 0 0 4px var(--line-green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.bot-avatar svg{width:22px;height:22px;fill:var(--line-white)}.bubble{background:var(--line-white);max-width:calc(100% - 60px);color:var(--line-black);border-radius:18px 18px 18px 4px;padding:13px 16px;font-size:14px;line-height:1.6;box-shadow:0 2px 8px #00000012}.bubble strong{color:var(--line-green)}.register-card{background:var(--line-white);border-radius:20px;width:100%;margin:0 auto;padding:24px 20px 20px;animation:.5s .15s both slideUp;box-shadow:0 4px 20px #0000000f}.card-label{color:var(--line-gray);letter-spacing:2px;align-items:center;gap:8px;margin-bottom:18px;font-size:11px;font-weight:700;display:flex}.card-label:after{content:"";background:var(--line-divider);flex:1;height:1px}.form-group{margin-bottom:16px}.field-label{color:var(--line-black);align-items:center;gap:6px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.field-label .dot{background:var(--line-green);border-radius:50%;width:6px;height:6px;display:inline-block}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=email]{border:1.5px solid var(--line-divider);width:100%;color:var(--line-black);background-color:#fafcfe;border-radius:18px;outline:none;padding:13px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s,background .2s}.form-group input[type=text]::placeholder,.form-group input[type=tel]::placeholder,.form-group input[type=email]::placeholder{color:#bbb;font-size:14px}.form-group input:focus{border-color:var(--line-green);background:var(--line-white);box-shadow:0 0 0 4px #06c7551a}.field-error{color:#e24b4a;margin:6px 0 0;font-size:13px;line-height:1.5}.section-divider{background:var(--line-divider);height:1px;margin:20px 0}.checkbox-section{flex-direction:column;gap:13px;display:flex}.check-item{align-items:flex-start;gap:12px;display:flex}.check-item input[type=checkbox]{border:1.5px solid var(--line-divider);cursor:pointer;width:20px;min-width:20px;height:20px;accent-color:var(--line-green);background-color:#fafcfe;border-radius:6px;margin-top:1px;padding:0}.check-item input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px #06c7551f}.check-item label{color:var(--line-gray);cursor:pointer;font-size:13.5px;font-weight:400;line-height:1.55}.check-item label a{color:var(--line-green);border-bottom:1px solid #06c7554d;font-weight:600;text-decoration:none}.check-item label a:hover{border-color:var(--line-green)}.register-footer{background-color:var(--line-white);padding:14px 16px;padding-bottom:calc(14px + var(--safe-area-bottom));border-top:1px solid var(--line-divider)}.submit-btn{background-color:var(--line-green);width:100%;color:var(--line-white);cursor:pointer;letter-spacing:1px;border:none;border-radius:20px;justify-content:center;align-items:center;gap:8px;padding:15px;font-family:inherit;font-size:17px;font-weight:700;transition:transform .12s,background-color .15s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #06c75559}.submit-btn:hover{background-color:var(--line-green-dark);box-shadow:0 6px 20px #06c75573}.submit-btn:active{transform:scale(.97);box-shadow:0 2px 8px #06c75533}.submit-btn:disabled{opacity:.65;cursor:not-allowed}.submit-btn svg{width:18px;height:18px;fill:var(--line-white);flex-shrink:0}.page-error,.page-success{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:40px 20px;display:flex}.page-error p,.page-success p{color:var(--line-black);margin:0;font-size:1rem}.retry-btn{border:1.5px solid var(--line-green);background:var(--line-white);color:var(--line-green);cursor:pointer;border-radius:14px;padding:10px 24px;font-size:15px;font-weight:600}.success-overlay{z-index:999;opacity:0;pointer-events:none;background:#00000059;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.success-overlay.show{opacity:1;pointer-events:all}.success-page{justify-content:center;align-items:center;padding:40px 20px}.success-page .success-card{transform:scale(1)}.success-card{background:var(--line-white);text-align:center;border-radius:24px;width:min(320px,100vw - 40px);padding:36px 32px;transition:transform .3s cubic-bezier(.34,1.56,.64,1);transform:scale(.85)}.success-overlay.show .success-card{transform:scale(1)}.success-icon{background:var(--line-green);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex;box-shadow:0 6px 20px #06c75566}.success-icon svg{fill:none;width:32px;height:32px;stroke:var(--line-white);stroke-linecap:round;stroke-linejoin:round;stroke-width:3px}.success-card h3{color:var(--line-black);margin:0 0 8px;font-size:1.2rem;font-weight:700}.success-card p{color:var(--line-gray);margin:0;font-size:13.5px;line-height:1.6}.close-window-btn{background:var(--line-green);width:100%;color:var(--line-white);cursor:pointer;border:none;border-radius:18px;margin-top:22px;padding:12px 16px;font-family:inherit;font-size:15px;font-weight:700;box-shadow:0 4px 16px #06c75547}.close-window-btn:active{transform:scale(.98)}@keyframes dotBounce{0%,80%,to{opacity:.4;transform:scale(.5)}40%{opacity:1;transform:scale(1.1)}}@keyframes logoPulse{0%,to{transform:scale(1);box-shadow:0 4px 16px #06c7554d}50%{transform:scale(1.06);box-shadow:0 8px 24px #06c75580}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (width>=768px){.register-page{align-items:center}.register-header{width:100%}.main-content{width:460px;padding:28px 0}.register-footer{background:0 0;border-top:none;width:460px;margin-top:4px;padding:0}.register-card{padding:30px 28px}}@media (width<=767px){.register-footer{position:sticky;bottom:0}}.login-page{background:var(--primary);min-height:100vh;display:flex}.login-left{background:linear-gradient(135deg,#1a1a2e 0%,#0f3460 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px;display:flex}@keyframes logoGlow{0%{text-shadow:0 0 #fff0,0 0 #e9456000}40%{text-shadow:0 0 18px #ffffff8c,0 0 40px #e9456066,0 0 80px #e9456026}70%{text-shadow:0 0 28px #ffffffb3,0 0 60px #e945608c,0 0 120px #e9456033}to{text-shadow:0 0 18px #ffffff8c,0 0 40px #e9456066,0 0 80px #e9456026}}@keyframes logoScale{0%,to{letter-spacing:-.5px}50%{letter-spacing:3px}}@keyframes accentPulse{0%,to{color:var(--accent);text-shadow:0 0 12px #e94560b3}50%{color:#ff8fa3;text-shadow:0 0 32px #e94560,0 0 64px #e9456080}}.login-logo-big{font-family:var(--font-en);color:#fff;cursor:default;-webkit-user-select:none;user-select:none;margin-bottom:12px;font-size:52px;font-weight:700;animation:3s ease-in-out infinite logoGlow,3s ease-in-out infinite logoScale}.login-logo-big span{color:var(--accent);animation:3s ease-in-out infinite accentPulse;display:inline-block}.login-tagline{color:#ffffff80;text-align:center;max-width:280px;font-size:15px;line-height:1.6}.login-dots{align-items:center;gap:8px;height:8px;margin-top:32px;display:flex;position:relative}.login-dot{background:#fff3;border-radius:50%;flex-shrink:0;width:8px;height:8px}.login-dot-traveller{background:var(--accent);pointer-events:none;border-radius:50%;width:8px;height:8px;animation:1.8s ease-in-out infinite dotTravel;position:absolute;top:0;left:0;box-shadow:0 0 8px #e94560cc,0 0 16px #e9456066}@keyframes dotTravel{0%{border-radius:50%;width:8px;left:0;box-shadow:0 0 8px #e94560cc}20%{border-radius:4px;width:20px;left:0;box-shadow:0 0 12px #e94560e6}40%{border-radius:50%;width:8px;left:16px;box-shadow:0 0 8px #e94560cc}50%{border-radius:4px;width:20px;left:28px;box-shadow:0 0 12px #e94560e6}70%{border-radius:50%;width:8px;left:28px;box-shadow:0 0 8px #e94560cc}85%{border-radius:4px;width:20px;left:16px;box-shadow:0 0 12px #e94560e6}to{border-radius:50%;width:8px;left:0;box-shadow:0 0 8px #e94560cc}}.login-right{background:var(--surface);flex-direction:column;flex-shrink:0;justify-content:center;width:420px;padding:48px;display:flex}.login-title{color:var(--text);margin-bottom:6px;font-size:24px;font-weight:700}.login-sub{color:var(--text3);margin-bottom:32px;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.server-error{color:var(--danger);border-radius:var(--radius);text-align:center;background:#e24b4a12;padding:10px 12px;font-size:13px}@media (width<=900px){.login-left{display:none}.login-right{width:100%;max-width:420px;margin:auto;padding:32px 24px}.login-page{justify-content:center;align-items:center;padding:20px}}.modal-lg{width:95vw;max-width:680px}.detail-member-header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.detail-coupon-summary{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.detail-coupon-pill{text-align:center;border-radius:10px;flex:1;min-width:90px;padding:10px 14px}.detail-coupon-list{flex-direction:column;gap:10px;max-height:340px;padding-right:2px;display:flex;overflow-y:auto}.coupon-code{font-family:var(--font-en);letter-spacing:1px;background:var(--surface2);border:1px dashed var(--border2);color:var(--text3);border-radius:5px;padding:1px 7px;font-size:10px;font-weight:700}.coupon-filter-tab{cursor:pointer;border:1px solid var(--border2);color:var(--text2);white-space:nowrap;font-size:12px;font-weight:500;font-family:var(--font-zh);background:0 0;border-radius:20px;padding:6px 14px;transition:all .12s}.coupon-filter-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag-pill{cursor:default;white-space:nowrap;border:1px solid #0000;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.member-tag-card{border-radius:12px;flex:1;min-width:160px;padding:12px 14px;position:relative}.points-history-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;display:flex}.points-history-row.no-border{border-bottom:none}.form-row-2col{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-readonly{color:var(--text2);background:var(--surface2);border-radius:var(--radius);border:1px solid var(--border);font-size:13px;font-family:var(--font-en);padding:8px 12px}.form-input.input-error{border-color:#e24b4a;box-shadow:0 0 0 3px #e24b4a14}.field-error{color:#a32d2d;font-size:11px}.submit-error{color:#a32d2d;background:#e24b4a14;border-radius:8px;padding:10px 14px;font-size:13px}.members-search{width:220px;height:auto;padding:7px 12px}.members-tier-select{height:auto;padding:6px 10px;font-size:13px}.mask-toggle-btn{border-radius:var(--radius);border:1px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--text2);white-space:nowrap;font-size:12px;font-weight:500;font-family:var(--font-zh);align-items:center;gap:6px;margin-left:auto;padding:6px 14px;transition:all .15s;display:flex}.mask-toggle-btn:hover,.mask-toggle-btn.revealed{border-color:var(--accent);color:var(--accent)}.mask-revealed{font-weight:600;color:var(--accent)!important}.points-cell{color:var(--warning);align-items:center;gap:4px;font-size:13px;display:inline-flex}.points-icon{font-size:13px}.row-actions{gap:6px;display:flex}.skeleton-row td{padding:14px}.skeleton-cell{background:linear-gradient(90deg, var(--surface3) 25%, var(--surface2) 50%, var(--surface3) 75%);background-size:200% 100%;border-radius:6px;height:14px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-icon{opacity:.4;font-size:36px}.empty-text{color:var(--text3);font-size:14px}.error-msg{color:#a32d2d;background:#e24b4a14;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:13px}.pagination{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:4px;padding-top:16px;display:flex}.pagination-info{color:var(--text3);font-size:12px}.pagination-controls{align-items:center;gap:4px;display:flex}.page-ellipsis{color:var(--text3);padding:0 4px;font-size:12px}:root{--primary:#1a1a2e;--accent:#e94560;--surface:#fff;--surface2:#f8f7f4;--surface3:#f1efe8;--border:#00000014;--text:#1a1a2e;--text2:#6b6a66;--text3:#9b9a97;--font-en:"Space Grotesk", sans-serif;--font-zh:"Noto Sans TC", sans-serif;--sidebar-w:240px;--topbar-h:60px}.admin-shell{font-family:var(--font-zh);background:var(--surface2);color:var(--text);min-height:100vh}.topbar{height:var(--topbar-h);background:var(--primary);z-index:100;align-items:center;gap:16px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-brand{font-family:var(--font-en);color:#fff;letter-spacing:-.5px;flex:1;align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.topbar-brand span{color:var(--accent)}.topbar-logo{background:linear-gradient(135deg, var(--accent) 0%, #f97316 100%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex;box-shadow:0 2px 6px #e9456066}.topbar-logo svg{fill:#fff;width:17px;height:17px}.topbar-actions{align-items:center;gap:12px;display:flex}.topbar-search{color:#fff;width:200px;font-size:13px;font-family:var(--font-zh);background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;outline:none;padding:6px 12px;transition:border-color .15s,background .15s}.topbar-search::placeholder{color:#fff6}.topbar-search:focus{border-color:var(--accent);background:#ffffff26}.topbar-notif{cursor:pointer;color:#ffffffb3;font-size:18px;transition:color .15s;position:relative}.topbar-notif:hover{color:#fff}.notif-badge{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;display:flex;position:absolute;top:-4px;right:-4px}.topbar-avatar{background:var(--accent);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex}.topbar-user-menu-wrap{position:relative}.topbar-menu-btn{cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;width:32px;height:32px;padding:7px 8px;transition:background .12s;display:flex}.topbar-menu-btn:hover{background:#fff3}.topbar-menu-btn span{background:#ffffffd9;border-radius:2px;width:14px;height:1.5px;transition:all .2s;display:block}.topbar-user-dropdown{background:var(--surface);border:1px solid var(--border2,#0000001f);border-radius:var(--radius-lg,16px);z-index:200;width:220px;display:none;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 8px 32px #00000024,0 2px 8px #00000014}.topbar-user-dropdown.open{animation:.15s dropdownIn;display:block}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.dropdown-user-header{background:var(--surface2);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 14px;display:flex}.dropdown-item{color:var(--text);cursor:pointer;text-align:left;width:100%;font-size:13px;font-weight:500;font-family:var(--font-zh);background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;transition:background .1s;display:flex}.dropdown-item:hover{background:var(--surface2)}.dropdown-item .di-icon{text-align:center;flex-shrink:0;width:20px;font-size:15px}.dropdown-item.danger{color:var(--danger,#e24b4a)}.dropdown-item.danger:hover{background:#e24b4a12}.dropdown-divider{background:var(--border);height:1px;margin:4px 0}.lang-toggle{background:var(--surface3);border-radius:6px;flex-shrink:0;align-items:center;gap:2px;margin-left:auto;padding:2px;display:flex}.lang-opt{cursor:pointer;color:var(--text3);-webkit-user-select:none;user-select:none;border-radius:5px;padding:3px 8px;font-size:11px;font-weight:600;transition:all .12s}.lang-opt.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px #0000001a}.sidebar{top:var(--topbar-h);width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:90;flex-direction:column;display:flex;position:fixed;bottom:0;left:0;overflow-y:auto}.sidebar-section{color:var(--text3);letter-spacing:1.5px;text-transform:uppercase;font-size:10px;font-weight:600;font-family:var(--font-en);padding:16px 12px 8px}.nav-item{cursor:pointer;color:var(--text2);border-radius:8px;align-items:center;gap:10px;margin:0 8px 2px;padding:9px 16px;font-size:14px;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface3);color:var(--text)}.nav-item.active{color:var(--accent);background:#e9456014;font-weight:500}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:15px}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:12px 16px 4px}.sidebar-user{border-radius:8px;align-items:center;gap:10px;padding:8px;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sidebar-user-role{color:var(--text3);font-size:11px}.admin-main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);min-height:calc(100vh - var(--topbar-h));padding:28px}
