.app-header[data-v-beb0b098]{display:flex;align-items:center;height:var(--header-height);background:var(--gradient-header);padding:0 var(--space-sm);padding-top:0;padding-top:calc(0px + env(safe-area-inset-top))}.app-header__menu[data-v-beb0b098]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.app-header__menu[data-v-beb0b098]:hover{background:#ffffff26}.app-header__logo[data-v-beb0b098]{font-size:20px;color:#ffffffe6;margin-left:var(--space-xs)}.app-header__title[data-v-beb0b098]{font-size:17px;font-weight:700;color:#fff;margin-left:var(--space-xs)}.app-header__spacer[data-v-beb0b098]{flex:1}.sidebar-overlay[data-v-937f2412]{position:fixed;inset:0;background:var(--color-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:199}.sidebar[data-v-937f2412]{display:flex;flex-direction:column;width:var(--sidebar-width);height:100vh;background:var(--color-sidebar-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-right:1px solid rgba(255,255,255,.5);transition:width .25s var(--ease-default);overflow:hidden;flex-shrink:0;position:sticky;top:0;z-index:2}.sidebar--collapsed[data-v-937f2412]{width:var(--sidebar-width-collapsed)}.sidebar--collapsed .sidebar__nav[data-v-937f2412]{padding:0 6px}.sidebar--collapsed .sidebar__link[data-v-937f2412]{justify-content:center;padding:12px 0;gap:0}.sidebar--collapsed .sidebar__link--active[data-v-937f2412]{box-shadow:none;border-style:solid;background:var(--color-primary-light)}.sidebar--mobile[data-v-937f2412]{position:fixed;left:0;top:0;z-index:200;transform:translate(-100%);transition:transform .3s var(--ease-default);box-shadow:none;width:260px;border-radius:0 var(--radius-2xl) var(--radius-2xl) 0}.sidebar--open[data-v-937f2412]{transform:translate(0);box-shadow:var(--shadow-xl)}.sidebar__logo[data-v-937f2412]{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-md);height:72px;flex-shrink:0;margin-bottom:var(--space-sm)}.sidebar__logo-badge[data-v-937f2412]{width:44px;height:44px;background:var(--color-accent);border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #fbbf2459;transform:rotate(12deg);transition:transform .3s var(--ease-bounce);flex-shrink:0}.sidebar__logo:hover .sidebar__logo-badge[data-v-937f2412]{transform:rotate(0) scale(1.05)}.sidebar__logo-icon[data-v-937f2412]{font-size:24px;color:#fff}.sidebar__logo-text[data-v-937f2412]{font-size:20px;font-weight:900;color:var(--color-text);white-space:nowrap;letter-spacing:-.02em}.sidebar__class[data-v-937f2412]{padding:0 var(--space-md);margin-bottom:var(--space-md)}.sidebar__class-label[data-v-937f2412]{font-size:12px;font-weight:700;color:var(--color-text-muted)}.sidebar__class-name[data-v-937f2412]{font-size:12px;font-weight:900;color:var(--color-primary)}.sidebar__nav[data-v-937f2412]{display:flex;flex-direction:column;gap:6px;padding:0 var(--space-sm)}.sidebar__link[data-v-937f2412]{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-xl);color:var(--color-text-secondary);text-decoration:none;font-size:16px;font-weight:900;cursor:pointer;transition:all .2s var(--ease-bounce);background:none;border:2px solid transparent;width:100%;text-align:left;position:relative}.sidebar__link[data-v-937f2412]:hover:not(.sidebar__link--active){transform:translate(4px);background:#fff9;color:var(--color-primary)}.sidebar__link--active[data-v-937f2412]{background:#ffffffe6;color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light),0 4px 12px #6366f133;border:2px dashed var(--color-primary)}.sidebar__link-icon[data-v-937f2412]{font-size:22px;flex-shrink:0;width:28px;text-align:center;line-height:1;transition:transform .2s var(--ease-default);opacity:.9}.sidebar__link--active .sidebar__link-icon[data-v-937f2412]{opacity:1;transform:scale(1.1)}.sidebar__link-text[data-v-937f2412]{white-space:nowrap;letter-spacing:.02em}.sidebar__footer[data-v-937f2412]{margin-top:auto;padding:var(--space-sm);border-top:1px solid rgba(0,0,0,.05)}.sidebar__toggle[data-v-937f2412]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0 auto var(--space-xs);background:var(--color-bg);border:2px solid var(--color-border);cursor:pointer;color:var(--color-text-muted);font-size:18px;border-radius:var(--radius-full);transition:all .2s;box-shadow:0 2px 0 var(--color-border)}.sidebar__toggle[data-v-937f2412]:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.sidebar__toggle[data-v-937f2412]:active{box-shadow:none;transform:translateY(2px)}.sidebar__toggle-icon[data-v-937f2412]{font-size:18px}.sidebar__user[data-v-937f2412]{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm)}.sidebar__user-icon[data-v-937f2412]{font-size:22px;color:var(--color-text-muted);flex-shrink:0;width:32px;text-align:center}.sidebar__user-name[data-v-937f2412]{flex:1;font-size:13px;color:var(--color-text-secondary);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-logout[data-v-937f2412]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--color-text-muted);border-radius:var(--radius-sm);flex-shrink:0;transition:all .2s}.sidebar__user-logout[data-v-937f2412]:hover{color:var(--color-danger);background:var(--color-danger-light)}.app-toast[data-v-23d3497b]{position:fixed;top:60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:16px 24px;border-radius:var(--radius-lg);background:#1f2937;color:#fff;font-size:15px;font-weight:900;z-index:9999;pointer-events:none;border-left:4px solid;min-width:240px;animation:card-in .3s ease-out both}.app-toast__icon[data-v-23d3497b]{font-size:22px}.app-toast--success[data-v-23d3497b]{border-left-color:#10b981}.app-toast--error[data-v-23d3497b]{border-left-color:#ef4444}.app-toast--warning[data-v-23d3497b]{border-left-color:#f59e0b}.float-timer[data-v-0fa3cc08]{position:fixed;bottom:var(--space-xl);right:var(--space-xl);z-index:500;display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--color-bg-card, #fff);border:3px solid var(--color-primary);border-radius:var(--radius-full);box-shadow:0 8px 32px #00000026;cursor:pointer;transition:all .2s var(--ease-bounce);-webkit-user-select:none;user-select:none}.float-timer[data-v-0fa3cc08]:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0003}.float-timer[data-v-0fa3cc08]:active{transform:scale(.96)}.float-timer__dot[data-v-0fa3cc08]{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);flex-shrink:0}.float-timer__dot--running[data-v-0fa3cc08]{background:var(--color-success, #10B981);animation:float-pulse-0fa3cc08 1.2s ease-in-out infinite}.float-timer__icon[data-v-0fa3cc08]{font-size:18px;color:var(--color-primary);flex-shrink:0}.float-timer__time[data-v-0fa3cc08]{font-size:18px;font-weight:900;color:var(--color-text);font-variant-numeric:tabular-nums;letter-spacing:1px;min-width:56px}.float-timer__close[data-v-0fa3cc08]{width:24px;height:24px;border-radius:50%;border:none;background:none;color:var(--color-text-muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-left:4px}.float-timer__close[data-v-0fa3cc08]:hover{background:var(--color-danger-light);color:var(--color-danger)}@keyframes float-pulse-0fa3cc08{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.float-timer-enter-active[data-v-0fa3cc08]{animation:float-timer-in-0fa3cc08 .3s var(--ease-bounce)}.float-timer-leave-active[data-v-0fa3cc08]{animation:float-timer-in-0fa3cc08 .2s ease-in reverse}@keyframes float-timer-in-0fa3cc08{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.float-timer[data-v-0fa3cc08]{bottom:var(--space-md);right:var(--space-md);padding:8px 12px}.float-timer__time[data-v-0fa3cc08]{font-size:15px}}.icon-badge[data-v-eb24aca1],.icon-food[data-v-186175ac]{display:inline-block;vertical-align:-.15em;flex-shrink:0}.dev-fab[data-v-d32b5b9b]{position:fixed;left:16px;bottom:16px;z-index:999;width:44px;height:44px;border-radius:var(--radius-full);background:#334155;color:#fff;border:2px solid #475569;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0003;transition:all .2s var(--ease-bounce);opacity:.6}.dev-fab[data-v-d32b5b9b]:hover{opacity:1;transform:scale(1.1) rotate(-15deg);box-shadow:0 8px 24px #0000004d}.dev-overlay[data-v-d32b5b9b]{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--color-overlay)}.dev-panel[data-v-d32b5b9b]{width:90%;max-width:520px;max-height:80vh;background:var(--color-bg-card);border-radius:var(--radius-3xl);border:4px solid #ffffff;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;overflow:hidden;animation:card-in .4s var(--ease-bounce) backwards}.dev-panel__header[data-v-d32b5b9b]{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:2px solid #f1f5f9;flex-shrink:0}.dev-panel__title[data-v-d32b5b9b]{display:flex;align-items:center;gap:var(--space-sm);font-size:18px;font-weight:900;color:var(--color-text)}.dev-panel__title-icon[data-v-d32b5b9b]{font-size:22px;color:#64748b}.dev-panel__close[data-v-d32b5b9b]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);font-size:18px;color:var(--color-text-muted);cursor:pointer;background:#f1f5f9;border:2px solid #e2e8f0;transition:all .25s var(--ease-bounce);box-shadow:0 2px #e2e8f0}.dev-panel__close[data-v-d32b5b9b]:hover{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger);transform:rotate(90deg) scale(1.1);box-shadow:none}.dev-panel__body[data-v-d32b5b9b]{flex:1;overflow-y:auto;padding:var(--space-lg) var(--space-xl)}.dev-section[data-v-d32b5b9b]{margin-bottom:var(--space-xl)}.dev-section[data-v-d32b5b9b]:last-child{margin-bottom:0}.dev-section__title[data-v-d32b5b9b]{display:flex;align-items:center;gap:var(--space-sm);font-size:14px;font-weight:900;color:var(--color-text);margin-bottom:var(--space-md)}.dev-section__icon[data-v-d32b5b9b]{font-size:18px;color:var(--color-primary)}.dev-section__icon--danger[data-v-d32b5b9b]{color:var(--color-danger)}.dev-section__row[data-v-d32b5b9b]{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.dev-section__hint[data-v-d32b5b9b]{margin-top:var(--space-sm);font-size:12px;font-weight:700;color:var(--color-text-muted)}.dev-label[data-v-d32b5b9b]{font-size:13px;font-weight:800;color:var(--color-text-secondary);flex-shrink:0}.dev-input[data-v-d32b5b9b]{width:80px;height:36px;padding:0 12px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-weight:800;color:var(--color-text);background:var(--color-input-bg);outline:none;transition:border-color .2s}.dev-input[data-v-d32b5b9b]:focus{border-color:var(--color-primary)}.dev-btn[data-v-d32b5b9b]{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border-radius:var(--radius-lg);font-size:13px;font-weight:900;cursor:pointer;border:2px solid transparent;transition:all .15s var(--ease-bounce);box-shadow:0 2px #0000001a;position:relative;top:0;white-space:nowrap}.dev-btn[data-v-d32b5b9b]:active{top:2px;box-shadow:none}.dev-btn--primary[data-v-d32b5b9b]{background:var(--color-primary);color:#fff;box-shadow:0 2px #4338ca}.dev-btn--primary[data-v-d32b5b9b]:hover{filter:brightness(1.1);transform:translateY(-1px)}.dev-btn--accent[data-v-d32b5b9b]{background:#f8fafc;color:var(--color-text-secondary);border-color:#e2e8f0;box-shadow:0 2px #e2e8f0}.dev-btn--accent[data-v-d32b5b9b]:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.dev-btn--danger[data-v-d32b5b9b]{background:#fef2f2;color:var(--color-danger);border-color:#fecaca;box-shadow:0 2px #fecaca}.dev-btn--danger[data-v-d32b5b9b]:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.dev-overlay-enter-active[data-v-d32b5b9b]{transition:opacity .15s ease-out}.dev-overlay-enter-active .dev-panel[data-v-d32b5b9b]{transition:transform .25s ease-out,opacity .15s ease-out}.dev-overlay-leave-active[data-v-d32b5b9b],.dev-overlay-leave-active .dev-panel[data-v-d32b5b9b]{transition:opacity .1s ease-out}.dev-overlay-enter-from[data-v-d32b5b9b]{opacity:0}.dev-overlay-enter-from .dev-panel[data-v-d32b5b9b]{transform:translateY(-20px) scale(.9);opacity:0}.dev-overlay-leave-to[data-v-d32b5b9b]{opacity:0}.app-login[data-v-3c05a8cf]{height:100vh;overflow-y:auto;overscroll-behavior:contain;background:var(--bg-gradient)}.app-layout[data-v-3c05a8cf]{display:flex;height:100vh;background:var(--bg-gradient);position:relative;overflow:hidden}.app-layout__orb[data-v-3c05a8cf]{position:fixed;border-radius:999px;pointer-events:none;z-index:0;animation:wb-float 8s ease-in-out infinite}.app-layout__orb--1[data-v-3c05a8cf]{width:340px;height:340px;top:-80px;right:-60px;background:radial-gradient(circle,var(--orb-1),transparent 70%);animation-delay:0s}.app-layout__orb--2[data-v-3c05a8cf]{width:280px;height:280px;bottom:-60px;left:-40px;background:radial-gradient(circle,var(--orb-2),transparent 70%);animation-delay:2s}.app-layout__orb--3[data-v-3c05a8cf]{width:200px;height:200px;top:30%;left:220px;background:radial-gradient(circle,var(--orb-3),transparent 70%);animation-delay:4s}.app-layout__right[data-v-3c05a8cf]{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;position:relative;z-index:1}.app-layout__content[data-v-3c05a8cf]{flex:1;display:flex;flex-direction:column;overflow-y:auto;overscroll-behavior:contain;padding:var(--space-lg)}@media(max-width:767px){.app-layout__content[data-v-3c05a8cf]{padding:var(--space-sm)}}:root{--color-success: #22C55E;--color-success-light: #DCFCE7;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-danger: #EF4444;--color-danger-light: #FEE2E2;--color-food: #F97316;--color-trophy-gold: #F59E0B;--color-trophy-silver: #94A3B8;--color-trophy-bronze: #D97706;--color-overlay: rgba(15, 23, 42, .85);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-2xl: 28px;--radius-3xl: 40px;--radius-full: 9999px;--sidebar-width: 180px;--sidebar-width-collapsed: 64px;--header-height: 52px;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.175, .885, .32, 1.275)}:root,[data-theme=forest]{--color-primary: #10B981;--color-primary-light: #D1FAE5;--color-primary-dark: #047857;--color-accent: #FBBF24;--color-accent-light: #FEF3C7;--color-highlight: #FBBF24;--color-bg: #ECFDF5;--color-bg-card: #FFFFFF;--color-bg-nav: #FFFFFF;--color-sidebar-bg: rgba(209, 250, 229, .65);--color-sidebar-active: #D1FAE5;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #E2E8F0;--color-border-active: #10B981;--color-input-bg: #F5FDF9;--gradient-button: linear-gradient(135deg, #10B981, #059669);--gradient-progress: linear-gradient(90deg, #10B981, #34D399);--gradient-header: linear-gradient(135deg, #059669, #10B981);--bg-gradient: linear-gradient(160deg, #d1fae5 0%, #dbeafe 30%, #fef3c7 60%, #fce7f3 100%);--orb-1: rgba(52, 211, 153, .25);--orb-2: rgba(147, 197, 253, .25);--orb-3: rgba(251, 191, 36, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 15px 40px rgba(0, 0, 0, .15);--shadow-card: 0 15px 40px rgba(0, 0, 0, .05);--shadow-card-hover: 0 25px 60px rgba(0, 0, 0, .1);--shadow-btn: 0 8px 0 #047857, 0 12px 40px rgba(16, 185, 129, .3);--shadow-btn-hover: 0 10px 0 #047857, 0 14px 50px rgba(16, 185, 129, .35);--color-card-border: rgba(16, 185, 129, .08);--color-card-border-hover: rgba(16, 185, 129, .2);--color-track-bg: rgba(16, 185, 129, .08);--color-primary-shadow-25: rgba(16, 185, 129, .25);--color-primary-shadow-18: rgba(16, 185, 129, .18)}[data-theme=starry]{--color-primary: #6366F1;--color-primary-light: #E0E7FF;--color-primary-dark: #4338CA;--color-accent: #F59E0B;--color-accent-light: #FEF3C7;--color-highlight: #FBBF24;--color-bg: #EEF2FF;--color-bg-card: #FFFFFF;--color-bg-nav: #FFFFFF;--color-sidebar-bg: rgba(224, 231, 255, .65);--color-sidebar-active: #E0E7FF;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #E0E4F0;--color-border-active: #6366F1;--color-input-bg: #F8F9FF;--gradient-button: linear-gradient(135deg, #6366F1, #4F46E5);--gradient-progress: linear-gradient(90deg, #6366F1, #818CF8);--gradient-header: linear-gradient(135deg, #4F46E5, #6366F1);--bg-gradient: linear-gradient(160deg, #e0e7ff 0%, #ede9fe 30%, #dbeafe 60%, #fef3c7 100%);--orb-1: rgba(129, 140, 248, .25);--orb-2: rgba(196, 181, 253, .25);--orb-3: rgba(251, 191, 36, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 15px 40px rgba(0, 0, 0, .15);--shadow-card: 0 15px 40px rgba(0, 0, 0, .05);--shadow-card-hover: 0 25px 60px rgba(0, 0, 0, .1);--shadow-btn: 0 8px 0 #4338CA, 0 12px 40px rgba(99, 102, 241, .3);--shadow-btn-hover: 0 10px 0 #4338CA, 0 14px 50px rgba(99, 102, 241, .35);--color-card-border: rgba(99, 102, 241, .08);--color-card-border-hover: rgba(99, 102, 241, .2);--color-track-bg: rgba(99, 102, 241, .08);--color-primary-shadow-25: rgba(99, 102, 241, .25);--color-primary-shadow-18: rgba(99, 102, 241, .18)}[data-theme=milk-tea]{--color-primary: #D4A574;--color-primary-light: #FFF5EB;--color-primary-dark: #A67B5B;--color-accent: #8B5CF6;--color-accent-light: #EDE9FE;--color-highlight: #F59E0B;--color-bg: #FFF8F0;--color-bg-card: #FFFFFF;--color-bg-nav: #FFFFFF;--color-sidebar-bg: rgba(255, 245, 235, .75);--color-sidebar-active: #FFF5EB;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #F0E6D8;--color-border-active: #D4A574;--color-input-bg: #FFFCF7;--gradient-button: linear-gradient(135deg, #D4A574, #C08B5C);--gradient-progress: linear-gradient(90deg, #D4A574, #E2BD96);--gradient-header: linear-gradient(135deg, #C08B5C, #D4A574);--bg-gradient: linear-gradient(160deg, #fff5eb 0%, #fef3c7 30%, #fce7f3 60%, #ede9fe 100%);--orb-1: rgba(212, 165, 116, .25);--orb-2: rgba(251, 191, 36, .2);--orb-3: rgba(196, 181, 253, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 15px 40px rgba(0, 0, 0, .15);--shadow-card: 0 15px 40px rgba(0, 0, 0, .05);--shadow-card-hover: 0 25px 60px rgba(0, 0, 0, .1);--shadow-btn: 0 8px 0 #A67B5B, 0 12px 40px rgba(212, 165, 116, .3);--shadow-btn-hover: 0 10px 0 #A67B5B, 0 14px 50px rgba(212, 165, 116, .35);--color-card-border: rgba(212, 165, 116, .08);--color-card-border-hover: rgba(212, 165, 116, .2);--color-track-bg: rgba(212, 165, 116, .08);--color-primary-shadow-25: rgba(212, 165, 116, .25);--color-primary-shadow-18: rgba(212, 165, 116, .18)}[data-theme=candy]{--color-primary: #F97316;--color-primary-light: #FFF7ED;--color-primary-dark: #C2410C;--color-accent: #3B82F6;--color-accent-light: #DBEAFE;--color-highlight: #FBBF24;--color-bg: #FFF7ED;--color-bg-card: #FFFFFF;--color-bg-nav: #FFFFFF;--color-sidebar-bg: rgba(255, 237, 213, .65);--color-sidebar-active: #FFEDD5;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #F3E8D8;--color-border-active: #F97316;--color-input-bg: #FFFCF7;--gradient-button: linear-gradient(135deg, #F97316, #EA580C);--gradient-progress: linear-gradient(90deg, #F97316, #FB923C);--gradient-header: linear-gradient(135deg, #EA580C, #F97316);--bg-gradient: linear-gradient(160deg, #fef3c7 0%, #ffedd5 30%, #fce7f3 60%, #dbeafe 100%);--orb-1: rgba(251, 146, 60, .25);--orb-2: rgba(251, 191, 36, .25);--orb-3: rgba(147, 197, 253, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 15px 40px rgba(0, 0, 0, .15);--shadow-card: 0 15px 40px rgba(0, 0, 0, .05);--shadow-card-hover: 0 25px 60px rgba(0, 0, 0, .1);--shadow-btn: 0 8px 0 #C2410C, 0 12px 40px rgba(249, 115, 22, .3);--shadow-btn-hover: 0 10px 0 #C2410C, 0 14px 50px rgba(249, 115, 22, .35);--color-card-border: rgba(249, 115, 22, .08);--color-card-border-hover: rgba(249, 115, 22, .2);--color-track-bg: rgba(249, 115, 22, .08);--color-primary-shadow-25: rgba(249, 115, 22, .25);--color-primary-shadow-18: rgba(249, 115, 22, .18)}[data-theme=sakura]{--color-primary: #EC4899;--color-primary-light: #FCE7F3;--color-primary-dark: #BE185D;--color-accent: #8B5CF6;--color-accent-light: #F5F3FF;--color-highlight: #F59E0B;--color-bg: #FDF2F8;--color-bg-card: #FFFFFF;--color-bg-nav: #FFFFFF;--color-sidebar-bg: rgba(252, 231, 243, .65);--color-sidebar-active: #FCE7F3;--color-text: #1E293B;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #F4EAF0;--color-border-active: #EC4899;--color-input-bg: #FFF8FC;--gradient-button: linear-gradient(135deg, #EC4899, #DB2777);--gradient-progress: linear-gradient(90deg, #EC4899, #F472B6);--gradient-header: linear-gradient(135deg, #DB2777, #EC4899);--bg-gradient: linear-gradient(160deg, #fce7f3 0%, #ede9fe 30%, #dbeafe 60%, #fef3c7 100%);--orb-1: rgba(244, 114, 182, .25);--orb-2: rgba(196, 181, 253, .25);--orb-3: rgba(251, 191, 36, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 15px 40px rgba(0, 0, 0, .15);--shadow-card: 0 15px 40px rgba(0, 0, 0, .05);--shadow-card-hover: 0 25px 60px rgba(0, 0, 0, .1);--shadow-btn: 0 8px 0 #BE185D, 0 12px 40px rgba(236, 72, 153, .3);--shadow-btn-hover: 0 10px 0 #BE185D, 0 14px 50px rgba(236, 72, 153, .35);--color-card-border: rgba(236, 72, 153, .08);--color-card-border-hover: rgba(236, 72, 153, .2);--color-track-bg: rgba(236, 72, 153, .08);--color-primary-shadow-25: rgba(236, 72, 153, .25);--color-primary-shadow-18: rgba(236, 72, 153, .18)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}html{font-family:var(--font-family);font-size:16px;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}body{line-height:1.5}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,textarea{font:inherit;color:inherit;border:none;outline:none;background:none}ul,ol{list-style:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:#00000014;border-radius:4px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:#0000002e}::-webkit-scrollbar-track{background:transparent}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}::selection{background:var(--color-primary-light);color:var(--color-text)}#nprogress .bar{background:var(--color-primary)}#nprogress .peg{box-shadow:0 0 10px var(--color-primary),0 0 5px var(--color-primary)}button:focus,button:focus-visible,[role=button]:focus,[role=button]:focus-visible{outline:none}.icon-xs{font-size:14px;width:14px;height:14px}.icon-sm{font-size:16px;width:16px;height:16px}.icon-md{font-size:20px;width:20px;height:20px}.icon-lg{font-size:24px;width:24px;height:24px}.icon-xl{font-size:32px;width:32px;height:32px}.floating-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-card);border:3px solid #ffffff;transition:transform .3s var(--ease-bounce)}.floating-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 18px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:900;cursor:pointer;white-space:nowrap;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--gradient-button);color:#fff}.btn--primary:not(:disabled):hover{filter:brightness(1.08)}.btn--primary:not(:disabled):active{transform:scale(.96)}.btn--danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn--danger:not(:disabled):hover{filter:brightness(1.08)}.btn--danger:not(:disabled):active{transform:scale(.96)}.btn--secondary{background:#f1f5f9;color:#64748b}.btn--secondary:not(:disabled):hover{background:#e2e8f0;color:#475569}.btn--secondary:not(:disabled):active{transform:scale(.96)}.btn--ghost{background:var(--color-bg-card);color:var(--color-text-secondary);border:2px solid var(--color-border)}.btn--ghost:not(:disabled):hover{border-color:var(--color-primary);color:var(--color-primary)}.btn--ghost:not(:disabled):active{transform:scale(.96)}.btn--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.btn--sm{height:36px;padding:0 12px;font-size:13px;gap:4px}.btn--lg{height:48px;padding:0 32px;font-size:16px;border-radius:16px;gap:8px}.cgs-checkbox{appearance:none;-webkit-appearance:none;width:22px;height:22px;border:2.5px solid #e2e8f0;border-radius:8px;background:#f8fafc;cursor:pointer;transition:all .2s var(--ease-bounce);position:relative;flex-shrink:0}.cgs-checkbox:hover{border-color:#fb923c;background:#fff7ed;transform:scale(1.1)}.cgs-checkbox:checked{background:linear-gradient(135deg,#f97316,#fb923c);border-color:#f97316;box-shadow:0 2px 8px #f973164d}.cgs-checkbox:checked:after{content:"";position:absolute;left:6px;top:2.5px;width:6px;height:10px;border:solid white;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}.cgs-checkbox:active{transform:scale(.9)}.privacy-mode .student-score{filter:blur(4px)}.scroll-gpu{-webkit-overflow-scrolling:touch;transform:translateZ(0)}.fade-enter-active,.fade-leave-active{transition:opacity .25s var(--ease-default)}.fade-enter-from,.fade-leave-to{opacity:0}.modal-enter-active{transition:all .35s var(--ease-bounce)}.modal-leave-active{transition:all .2s var(--ease-default)}.modal-enter-from{opacity:0;transform:translateY(-20px) scale(.9)}.modal-leave-to{opacity:0;transform:scale(.95)}.slide-left-enter-active,.slide-left-leave-active,.slide-right-enter-active,.slide-right-leave-active{transition:transform .3s var(--ease-default)}.slide-left-enter-from{transform:translate(100%)}.slide-left-leave-to,.slide-right-enter-from{transform:translate(-30%)}.slide-right-leave-to{transform:translate(100%)}.list-enter-active,.list-leave-active{transition:all .3s var(--ease-default)}.list-enter-from{opacity:0;transform:translateY(8px)}.list-leave-to{opacity:0;transform:translateY(-8px)}.list-move{transition:transform .3s var(--ease-default)}.scale-enter-active{transition:all .5s var(--ease-bounce)}.scale-leave-active{transition:all .2s var(--ease-default)}.scale-enter-from{opacity:0;transform:scale(.3)}.scale-leave-to{opacity:0;transform:scale(.85)}@keyframes card-in{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.card-in{animation:card-in .6s var(--ease-bounce) backwards}@keyframes bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05);opacity:1}70%{transform:scale(.9)}to{transform:scale(1)}}.animate-bounce-in{animation:bounce-in .5s var(--ease-bounce) both}@keyframes pop-in{0%{transform:scale(0);opacity:0}70%{transform:scale(1.1);opacity:1}to{transform:scale(1)}}.animate-pop-in{animation:pop-in .4s var(--ease-bounce) both}@keyframes floating{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-floating{animation:floating 3s ease-in-out infinite}@keyframes wb-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}@keyframes score-float-up{0%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-40px) scale(1.1)}}.score-float{position:fixed;z-index:9999;font-size:32px;font-weight:900;pointer-events:none;animation:score-float-up .8s ease-out forwards;text-shadow:0 3px 12px rgba(0,0,0,.15)}.score-float--bonus{color:var(--color-success)}.score-float--penalty{color:var(--color-danger)}@keyframes sticker-wiggle{0%,to{transform:rotate(-1deg)}50%{transform:rotate(1deg)}}.animate-sticker{animation:sticker-wiggle 2s ease-in-out infinite}@keyframes slide-out-right{to{transform:translate(100%);opacity:0}}@keyframes slide-out-left{to{transform:translate(-100%);opacity:0}}.animate-slide-right{animation:slide-out-right .3s ease-in forwards}.animate-slide-left{animation:slide-out-left .3s ease-in forwards}@keyframes gift-unwrap{0%{transform:scale(.5) rotate(-10deg);opacity:0}50%{transform:scale(1.1) rotate(5deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.animate-gift-unwrap{animation:gift-unwrap .6s var(--ease-bounce) both}@keyframes badge-earned{0%{transform:scale(0) rotate(-180deg)}60%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.animate-badge-earned{animation:badge-earned .8s var(--ease-bounce) both}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}.animate-wiggle{animation:wiggle .4s ease-in-out}@keyframes winner-reveal{0%{transform:scale(.3) rotate(-10deg);opacity:0}50%{transform:scale(1.15) rotate(3deg);opacity:1}70%{transform:scale(.95) rotate(-1deg)}to{transform:scale(1) rotate(0)}}.animate-winner{animation:winner-reveal .6s var(--ease-bounce) both}@keyframes shine-sweep{0%{transform:translate(-100%,-100%) rotate(0)}20%,to{transform:translate(100%,100%) rotate(0)}}@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:.8;transform:scale(1.2)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #fbbf244d}50%{box-shadow:0 0 40px #fbbf2499,0 0 60px #fbbf2433}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float-badge{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(3deg)}}@keyframes wb-shimmer{0%{left:-100%}to{left:200%}}@keyframes crown-wiggle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(15deg)}}
