*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0c29;--bg2:#1a1540;--surface:#ffffff12;--border:#ffffff1f;--text:#e8e3f8;--muted:#ffffff73;--accent:#a855f7;--accent2:#f472b6;--success:#4ade80;--danger:#f87171;color:var(--text);-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,Helvetica Neue,Arial,Noto Sans TC,sans-serif;font-size:16px}body{background:linear-gradient(135deg,#0f0c29 0%,#302b63 50%,#24243e 100%) fixed;min-height:100svh;margin:0}#root{flex-direction:column;min-height:100svh;display:flex}.app-shell{flex-direction:column;width:100%;max-width:480px;min-height:100svh;margin:0 auto;display:flex}.app-header{text-align:center;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#0f0c2999;padding:16px 20px 12px;position:sticky;top:0}.app-title{background:linear-gradient(90deg,#c084fc,#f472b6);-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700}.app-main{flex:1;padding-bottom:72px;overflow-y:auto}.bottom-nav{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:20;background:#0f0c29d9;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:var(--muted);flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 0 12px;text-decoration:none;transition:color .2s;display:flex}.nav-item.active{color:#c084fc}.nav-icon{font-size:22px;line-height:1}.nav-label{letter-spacing:.3px;font-size:11px;font-weight:600}.page-center{flex-direction:column;justify-content:center;align-items:center;gap:12px;height:60vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:#c084fc;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;opacity:.8;padding:40px 20px}.empty-icon{margin-bottom:12px;font-size:56px}.empty-state h2,.empty-state h3{color:var(--text);margin-bottom:6px;font-size:20px}.empty-state p{color:var(--muted);font-size:14px}.muted-text{color:var(--muted);padding:8px 0;font-size:13px}.spin-page{flex-direction:column;align-items:center;gap:12px;padding:16px 12px;display:flex}.category-tabs{width:100%;overflow:hidden}.tabs-scroll{scrollbar-width:none;gap:8px;padding:4px 2px 8px;display:flex;overflow-x:auto}.tabs-scroll::-webkit-scrollbar{display:none}.tab-pill{border:1.5px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;flex-shrink:0;padding:8px 18px;font-size:14px;font-weight:600;transition:all .2s}.tab-pill.active{color:#fff;box-shadow:0 0 12px #a855f766}.wheel-wrapper{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.wheel-canvas-wrap{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;transition:transform .15s,box-shadow .15s;display:inline-block}.wheel-canvas-wrap:active{transform:scale(.97)}.wheel-canvas-wrap.state-spinning,.wheel-canvas-wrap.state-decelerating{box-shadow:0 0 32px #a855f759}canvas{max-width:100%;height:auto;display:block}.wheel-hint{color:var(--muted);letter-spacing:.2px;height:20px;font-size:14px}.result-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;align-items:center;gap:12px;padding:16px 28px;animation:.4s cubic-bezier(.34,1.56,.64,1) both popIn;display:flex;box-shadow:0 0 30px #a855f740}.result-emoji{font-size:32px}.result-text{background:linear-gradient(90deg,#c084fc,#f472b6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700}@keyframes popIn{0%{opacity:0;transform:scale(.7)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.admin-page{flex-direction:column;gap:12px;padding:16px 14px;display:flex}.admin-header{justify-content:space-between;align-items:center;padding:4px 2px;display:flex}.admin-title{color:var(--text);font-size:18px;font-weight:700}.categories-list{flex-direction:column;gap:10px;display:flex}.category-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;transition:border-color .2s;overflow:hidden}.category-card:focus-within{border-color:#a855f780}.card-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:14px 16px;display:flex}.cat-color-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.cat-name{flex:1;font-size:15px;font-weight:600}.opt-count{color:var(--muted);font-size:12px}.card-actions{gap:4px;display:flex}.chevron{color:var(--muted);font-size:11px}.card-body{border-top:1px solid var(--border);flex-direction:column;gap:4px;padding:10px 16px 14px;display:flex}.card-edit-wrap{padding:16px}.option-row{border-radius:8px;align-items:center;gap:8px;padding:6px 4px;transition:background .15s;display:flex}.option-row:hover{background:#ffffff0a}.option-row.editing{background:#ffffff0f;padding:6px 8px}.option-dot{background:var(--muted);border-radius:50%;flex-shrink:0;width:6px;height:6px}.option-name{flex:1;font-size:14px}.inline-form{flex-direction:column;gap:12px;display:flex}.form-input{border:1px solid var(--border);width:100%;color:var(--text);background:#ffffff14;border-radius:10px;outline:none;padding:10px 14px;font-size:15px;transition:border-color .2s}.form-input:focus{border-color:#c084fc}.form-input.compact{border-radius:8px;padding:6px 10px;font-size:14px}.form-input::placeholder{color:var(--muted)}.color-swatches{flex-wrap:wrap;gap:8px;display:flex}.swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .15s,border-color .15s}.swatch:hover{transform:scale(1.15)}.swatch.selected{border-color:#fff;transform:scale(1.1);box-shadow:0 0 0 2px #fff6}.form-actions{gap:8px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.btn:disabled{opacity:.5;cursor:default}.btn-primary{color:#fff;background:linear-gradient(135deg,#a855f7,#f472b6)}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--surface);color:var(--text)}.btn-outline{border:1px dashed var(--border);color:var(--muted);text-align:center;background:0 0;width:100%;margin-top:4px}.btn-outline:hover{color:#c084fc;border-color:#c084fc}.btn.sm{border-radius:6px;padding:5px 10px;font-size:13px}.icon-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:14px;line-height:1;transition:opacity .15s,background .15s}.icon-btn:hover{opacity:1;background:#ffffff14}.add-opt-btn{border-radius:8px}
