@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;600;700;900&family=Noto+Serif+TC:wght@500;600;700;900&family=JetBrains+Mono:wght@400;500&display=swap";.offline-banner[data-v-83357b22]{position:fixed;top:0;left:0;right:0;z-index:1000;padding:var(--space-3) var(--space-4);text-align:center;font-size:var(--text-sm);font-weight:600;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding-top:calc(var(--space-3) + env(safe-area-inset-top));padding-left:calc(var(--space-4) + env(safe-area-inset-left));padding-right:calc(var(--space-4) + env(safe-area-inset-right))}.offline-banner.offline[data-v-83357b22]{background:var(--color-error-bg);color:var(--color-error);border-bottom:1px solid var(--color-error)}.offline-banner.online[data-v-83357b22]{background:var(--color-success-bg);color:var(--color-success);border-bottom:1px solid var(--color-success)}.banner-content[data-v-83357b22]{display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.status-indicator[data-v-83357b22]{width:8px;height:8px;border-radius:50%;animation:pulse-83357b22 2s infinite}.status-indicator.disconnected[data-v-83357b22]{background:var(--color-error)}.status-indicator.connected[data-v-83357b22]{background:var(--color-success)}@keyframes pulse-83357b22{0%,to{opacity:1}50%{opacity:.5}}.slide-down-enter-active[data-v-83357b22],.slide-down-leave-active[data-v-83357b22]{transition:all var(--transition-base)}.slide-down-enter-from[data-v-83357b22],.slide-down-leave-to[data-v-83357b22]{transform:translateY(-100%);opacity:0}.bottom-nav[data-v-8cdefdc9]{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:space-around;align-items:stretch;padding-bottom:env(safe-area-inset-bottom);background:#fbf7f0f0;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-top:1px solid var(--rule);box-shadow:0 -1px 0 var(--rule),0 -8px 24px #46321e0f}[data-theme=dark] .bottom-nav[data-v-8cdefdc9]{background:#14161eeb;border-top-color:var(--rule);box-shadow:0 -1px 0 var(--rule),0 -8px 24px #0000004d}.nav-item[data-v-8cdefdc9]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 0 12px;color:var(--fg-muted);text-decoration:none;position:relative;min-height:56px;min-width:44px;transition:color var(--d-fast) var(--ease-brand);-webkit-tap-highlight-color:transparent}.nav-item[data-v-8cdefdc9]:active{transform:scale(.95);transition:transform 80ms var(--ease-brand),color var(--d-fast) var(--ease-brand)}.nav-item.active[data-v-8cdefdc9]{color:var(--mojo-red)}.nav-item.active[data-v-8cdefdc9]:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--mojo-red);border-radius:0 0 var(--r-pill) var(--r-pill)}.nav-icon[data-v-8cdefdc9]{width:22px;height:22px;flex-shrink:0;transition:transform var(--d-fast) var(--ease-brand)}.nav-item.active .nav-icon[data-v-8cdefdc9]{transform:translateY(-1px)}.nav-label[data-v-8cdefdc9]{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:inherit;line-height:1}@media(prefers-reduced-motion:reduce){.nav-item[data-v-8cdefdc9],.nav-icon[data-v-8cdefdc9]{transition:none!important}}.toast[data-v-1a4aa702]{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);min-width:300px;max-width:400px;animation:slideIn-1a4aa702 .3s var(--ease-out-expo);position:relative;overflow:hidden}.toast-success[data-v-1a4aa702]{border-left:3px solid var(--color-success)}.toast-error[data-v-1a4aa702]{border-left:3px solid var(--color-error)}.toast-warning[data-v-1a4aa702]{border-left:3px solid var(--color-warning)}.toast-info[data-v-1a4aa702]{border-left:3px solid var(--color-info)}.toast-icon[data-v-1a4aa702]{width:20px;height:20px;flex-shrink:0}.toast-message[data-v-1a4aa702]{flex:1;font-size:var(--text-sm);color:var(--color-text-primary);margin:0}.toast-close[data-v-1a4aa702]{width:24px;height:24px;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-muted);font-size:var(--text-xl);line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0;padding:0}.toast-close[data-v-1a4aa702]:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.toast-close[data-v-1a4aa702]:active{transform:scale(.9)}@keyframes slideIn-1a4aa702{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media(prefers-reduced-motion:reduce){.toast[data-v-1a4aa702]{animation:none!important}@keyframes slideIn-1a4aa702{0%{opacity:0}to{opacity:1}}}.update-prompt[data-v-553188c0]{position:fixed;left:var(--space-4);right:var(--space-4);bottom:calc(var(--space-4) + 72px);z-index:9000;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--color-text-primary)}.update-text[data-v-553188c0]{display:flex;flex-direction:column;gap:2px}.update-text strong[data-v-553188c0]{font-size:var(--text-sm);font-weight:600}.update-text small[data-v-553188c0]{font-size:var(--text-xs);color:var(--color-text-muted)}.update-actions[data-v-553188c0]{display:flex;gap:var(--space-2);align-items:center}.btn-refresh[data-v-553188c0]{padding:var(--space-2) var(--space-4);background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer}.btn-dismiss[data-v-553188c0]{width:32px;height:32px;background:transparent;border:none;color:var(--color-text-muted);font-size:var(--text-base);cursor:pointer;border-radius:50%}.btn-dismiss[data-v-553188c0]:hover{background:var(--color-bg-elevated)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast-list-move,.toast-list-enter-active,.toast-list-leave-active{transition:all .3s var(--ease-out-expo)}.toast-list-enter-from,.toast-list-leave-to{opacity:0;transform:translate(100%)}.toast-list-leave-active{position:absolute}@media(max-width:640px){.toast-container{left:var(--space-4);right:var(--space-4)}}.slide-right-enter-active,.slide-right-leave-active,.slide-left-enter-active,.slide-left-leave-active,.fade-enter-active,.fade-leave-active{transition:all .25s var(--ease-out-expo)}.slide-right-enter-from{opacity:0;transform:translate(100%)}.slide-right-leave-to,.slide-left-enter-from{opacity:0;transform:translate(-30%)}.slide-left-leave-to{opacity:0;transform:translate(100%)}.fade-enter-from,.fade-leave-to{opacity:0}@media(prefers-reduced-motion:reduce){.slide-right-enter-active,.slide-right-leave-active,.slide-left-enter-active,.slide-left-leave-active,.fade-enter-active,.fade-leave-active{transition:none!important}.slide-right-enter-from,.slide-right-leave-to,.slide-left-enter-from,.slide-left-leave-to{transform:none}}:root{--mojo-red: #C93E2E;--mojo-red-deep: #A8311F;--mojo-red-soft: #E8A199;--mojo-red-wash: #FAEAE6;--mojo-blue: #1C3F73;--mojo-blue-deep: #122A4E;--mojo-blue-soft: #6B83A6;--mojo-ink: #2A201F;--mojo-ink-soft: #6B5853;--mojo-ink-mute: #A39086;--mojo-paper: #FBF7F0;--mojo-paper-deep: #F2EBDD;--mojo-rule: #D9CFBC;--mojo-white: #FFFFFF;--mojo-bronze: #8A6A3F;--mojo-bronze-soft:#E8DCC4;--status-on: #2F7D4A;--status-on-soft: #DCEFE0;--status-warn: #B8761A;--status-warn-soft:#F5E6CC;--status-off: var(--mojo-red);--status-off-soft: var(--mojo-red-wash);--bg-canvas: var(--mojo-paper);--bg-card: var(--mojo-white);--bg-card-deep: var(--mojo-paper-deep);--bg-inset: #F4ECDC;--fg-primary: var(--mojo-ink);--fg-secondary: var(--mojo-ink-soft);--fg-muted: var(--mojo-ink-mute);--fg-on-red: var(--mojo-paper);--rule: var(--mojo-rule);--rule-strong: #B5A78A;--font-sans: "Noto Sans TC", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif: "Noto Serif TC", "Source Han Serif TC", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;--tracking-en: .22em;--tracking-label: .12em;--leading-tc: 1.6;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 32px;--text-3xl: 44px;--text-hero: 64px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--s-16: 64px;--r-0: 0px;--r-1: 2px;--r-2: 4px;--r-3: 8px;--r-pill: 999px;--sh-1: 0 1px 0 rgba(70, 50, 30, .06);--sh-2: 0 1px 2px rgba(70, 50, 30, .08), 0 0 0 1px rgba(70, 50, 30, .04);--sh-3: 0 6px 16px rgba(70, 50, 30, .12), 0 0 0 1px rgba(70, 50, 30, .05);--sh-stamp: 0 2px 0 rgba(168, 49, 31, .18);--sh-inset-hair: inset 0 0 0 1px var(--rule);--ease-brand: cubic-bezier(.2, .7, .2, 1);--d-fast: .14s;--d-base: .22s;--d-slow: .38s;--pattern-url: url(assets/pattern-qinghai-wave.png)}[data-theme=dark]{--bg-canvas: #14161E;--bg-card: #1C1F2A;--bg-card-deep: #232633;--bg-inset: #181A24;--fg-primary: #F2ECDF;--fg-secondary: #B7AFA2;--fg-muted: #756E62;--fg-on-red: #F8F1E1;--rule: #2C2F3D;--rule-strong: #3E4153;--mojo-red: #E15748;--mojo-red-deep: #C93E2E;--mojo-red-wash: #2A1E1E;--mojo-blue: #6B83A6;--mojo-blue-soft: #4A5C7A;--mojo-paper: #F2ECDF;--mojo-paper-deep: #1C1F2A;--status-on: #4FAE6C;--status-on-soft: #1E2C24;--status-warn: #D49340;--status-warn-soft:#2C2418;--sh-1: 0 1px 0 rgba(0, 0, 0, .4);--sh-2: 0 1px 2px rgba(0, 0, 0, .4), 0 0 0 1px rgba(0, 0, 0, .3);--sh-3: 0 6px 16px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 220, 180, .04)}.mojo-app{font-family:var(--font-sans);color:var(--fg-primary);background:var(--bg-canvas);-webkit-font-smoothing:antialiased;font-feature-settings:"palt";line-height:var(--leading-tc)}.mojo-app *,.mojo-app *:before,.mojo-app *:after{box-sizing:border-box}.mojo-app button{font-family:inherit}.t-display{font-family:var(--font-serif);font-weight:600;letter-spacing:.01em;line-height:1.2}.t-en-caps{font-family:var(--font-sans);font-weight:500;letter-spacing:var(--tracking-en);text-transform:uppercase;font-size:var(--text-xs)}.t-label{font-family:var(--font-sans);font-weight:500;letter-spacing:var(--tracking-label);text-transform:uppercase;font-size:var(--text-xs);color:var(--fg-secondary)}.t-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.mojo-pattern-bg{position:relative;isolation:isolate}.mojo-pattern-bg:before{content:"";position:absolute;inset:0;background-image:var(--pattern-url);background-size:180px;background-repeat:repeat;opacity:.06;pointer-events:none;z-index:-1}[data-theme=dark] .mojo-pattern-bg:before{opacity:.04}.mojo-stamp{display:inline-flex;align-items:center;justify-content:center;background:var(--mojo-red);color:var(--mojo-paper);font-family:var(--font-serif);font-weight:700;border-radius:var(--r-1);letter-spacing:.05em;box-shadow:var(--sh-stamp);flex-shrink:0}.mojo-stamp--sm{width:28px;height:28px;font-size:14px}.mojo-stamp--md{width:40px;height:40px;font-size:20px}.mojo-stamp--lg{width:56px;height:56px;font-size:28px}.mojo-stamp--bronze{background:var(--mojo-bronze)}.mojo-vertical{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--font-serif);font-weight:600;letter-spacing:.15em;color:var(--mojo-blue);line-height:1.3}.mojo-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);font-family:var(--font-sans);font-weight:600;font-size:var(--text-base);border:none;border-radius:var(--r-2);padding:14px var(--s-5);min-height:48px;cursor:pointer;transition:background var(--d-fast) var(--ease-brand),color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand);letter-spacing:.05em}.mojo-btn--primary{background:var(--mojo-red);color:var(--mojo-paper)}.mojo-btn--primary:hover{background:var(--mojo-red-deep)}.mojo-btn--primary:active{background:var(--mojo-red-deep);transform:translateY(.5px)}.mojo-btn--secondary{background:transparent;color:var(--fg-primary);box-shadow:inset 0 0 0 1px var(--rule-strong)}.mojo-btn--secondary:hover{box-shadow:inset 0 0 0 1px var(--mojo-ink);background:var(--bg-card-deep)}.mojo-btn--ghost{background:transparent;color:var(--fg-secondary);padding:8px var(--s-3);min-height:36px}.mojo-btn--ghost:hover{color:var(--mojo-red);background:var(--mojo-red-wash)}.mojo-btn--block{width:100%}.mojo-btn--sm{min-height:36px;padding:8px var(--s-3);font-size:var(--text-sm)}.mojo-card{background:var(--bg-card);border-radius:var(--r-3);box-shadow:var(--sh-inset-hair);position:relative}.mojo-card--paper{background:var(--bg-card-deep)}.mojo-card--inset{background:var(--bg-inset)}.mojo-input{font-family:var(--font-sans);font-size:var(--text-md);background:var(--bg-card);color:var(--fg-primary);border:1px solid var(--rule);border-radius:var(--r-2);padding:12px var(--s-4);width:100%;outline:none;transition:border-color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand)}.mojo-input:focus{border-color:var(--mojo-blue);box-shadow:0 0 0 2px var(--mojo-blue),0 0 0 4px var(--bg-canvas)}.mojo-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;border-radius:var(--r-pill);white-space:nowrap}.mojo-badge--on{background:var(--status-on-soft);color:var(--status-on)}.mojo-badge--warn{background:var(--status-warn-soft);color:var(--status-warn)}.mojo-badge--off{background:var(--status-off-soft);color:var(--status-off)}.mojo-badge--neutral{background:var(--bg-card-deep);color:var(--fg-secondary)}.mojo-badge--blue{background:#1c3f731a;color:var(--mojo-blue)}.mojo-badge .dot{width:6px;height:6px;border-radius:50%;display:inline-block}.mojo-badge--on .dot{background:var(--status-on);box-shadow:0 0 0 3px var(--status-on-soft)}.mojo-badge--warn .dot{background:var(--status-warn)}.mojo-badge--off .dot{background:var(--status-off)}.mojo-rule{height:1px;background:var(--rule);border:none;margin:0}.mojo-rule--strong{background:var(--rule-strong)}.mojo-rule--red{background:var(--mojo-red);height:2px}@keyframes stampDrop{0%{transform:translateY(-12px) rotate(-8deg) scale(1.4);opacity:0}60%{transform:translateY(2px) rotate(2deg) scale(.96);opacity:1}to{transform:translateY(0) rotate(0) scale(1);opacity:1}}.mojo-anim-stamp{animation:stampDrop .48s var(--ease-brand) both}@keyframes verticalReveal{0%{clip-path:inset(0 0 100% 0);opacity:0}to{clip-path:inset(0 0 0 0);opacity:1}}.mojo-anim-vertical{animation:verticalReveal .7s var(--ease-brand) both}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mojo-anim-fade{animation:fadeUp .32s var(--ease-brand) both}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-tc);color:var(--fg-primary);background:var(--bg-canvas);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"palt";padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#app{min-height:100vh;min-height:calc(100vh - env(safe-area-inset-top))}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:700;line-height:1.2;color:var(--fg-primary)}p{color:var(--fg-secondary);line-height:var(--leading-tc)}a{color:var(--mojo-red);text-decoration:none;transition:color var(--d-fast) var(--ease-brand)}a:hover{color:var(--mojo-red-deep)}button{font-family:var(--font-sans);cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:var(--font-sans);font-size:var(--text-base);color:var(--fg-primary);background:var(--bg-card);border:1px solid var(--rule);border-radius:var(--r-2);padding:12px var(--s-4);width:100%;outline:none;transition:border-color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand)}input::placeholder,textarea::placeholder{color:var(--fg-muted)}input:focus,select:focus,textarea:focus{border-color:var(--mojo-blue);box-shadow:0 0 0 2px #1c3f7326}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A39086' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.mojo-input{font-family:var(--font-sans);font-size:var(--text-md);color:var(--fg-primary);background:var(--bg-card);border:1px solid var(--rule);border-radius:var(--r-2);padding:12px var(--s-4);width:100%;outline:none;transition:border-color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand);min-height:48px}.mojo-input:focus{border-color:var(--mojo-blue);box-shadow:0 0 0 2px #1c3f7326}.mojo-input::placeholder{color:var(--fg-muted)}.mojo-input:disabled{opacity:.55;cursor:not-allowed}[data-theme=dark] .mojo-input,[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg-card-deep);color:var(--fg-primary)}:root{--color-accent: var(--mojo-red);--color-accent-light: var(--mojo-red-soft);--color-accent-dark: var(--mojo-red-deep);--color-accent-glow: rgba(201, 62, 46, .15);--color-success: var(--status-on);--color-success-bg: var(--status-on-soft);--color-warning: var(--status-warn);--color-warning-bg: var(--status-warn-soft);--color-error: var(--mojo-red);--color-error-bg: var(--mojo-red-wash);--color-info: var(--mojo-blue);--color-info-bg: rgba(28, 63, 115, .1);--color-text-primary: var(--fg-primary);--color-text-secondary:var(--fg-secondary);--color-text-muted: var(--fg-muted);--color-bg-primary: var(--bg-canvas);--color-bg-secondary: var(--bg-card-deep);--color-bg-card: var(--bg-card);--color-bg-elevated: var(--bg-card-deep);--color-border: var(--rule);--color-border-light: var(--rule-strong);--space-1: var(--s-1);--space-2: var(--s-2);--space-3: var(--s-3);--space-4: var(--s-4);--space-5: var(--s-5);--space-6: var(--s-6);--space-8: var(--s-8);--space-10: var(--s-10);--space-12: var(--s-12);--radius-sm: var(--r-1);--radius-md: var(--r-2);--radius-lg: var(--r-3);--radius-xl: var(--r-3);--radius-full: var(--r-pill);--shadow-sm: var(--sh-1);--shadow-md: var(--sh-2);--shadow-lg: var(--sh-3);--shadow-glow: 0 0 16px rgba(201, 62, 46, .2);--font-body: var(--font-sans);--font-heading: var(--font-serif);--font-display: var(--font-serif);--text-xs: var(--text-xs);--text-sm: var(--text-sm);--text-base: var(--text-base);--text-lg: var(--text-lg);--text-xl: var(--text-xl);--text-2xl: var(--text-2xl);--text-3xl: var(--text-3xl);--transition-fast: var(--d-fast) var(--ease-brand);--transition-base: var(--d-base) var(--ease-brand);--transition-slow: var(--d-slow) var(--ease-brand);--glass-hero-bg: rgba(251, 247, 240, .92);--glass-hero-border: rgba(217, 207, 188, .6);--shadow-hero: var(--sh-3);--spring-easing: var(--ease-brand)}[data-theme=dark]{--glass-hero-bg: rgba(20, 22, 30, .88);--glass-hero-border: rgba(44, 47, 61, .8)}.page{max-width:500px;margin:0 auto;padding:var(--s-4);padding-bottom:calc(80px + env(safe-area-inset-bottom))}.page-header{display:flex;align-items:center;gap:var(--s-4);margin-bottom:var(--s-6)}.loading-spinner{width:24px;height:24px;border:2px solid var(--rule);border-top-color:var(--mojo-red);border-radius:50%;animation:globalSpin .8s linear infinite}@keyframes globalSpin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-4);padding:var(--s-10)}.modal-overlay{position:fixed;inset:0;background:#2a201f8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--s-4)}.divider{height:1px;background:var(--rule);border:none;margin:var(--s-6) 0}.empty-state{text-align:center;padding:var(--s-10);color:var(--fg-muted)}.empty-state-icon{width:48px;height:48px;margin:0 auto var(--s-4);opacity:.4;color:var(--fg-muted)}.toast-container{position:fixed;top:var(--s-4);right:var(--s-4);z-index:9999;display:flex;flex-direction:column;gap:var(--s-3);pointer-events:none}.toast-container>*{pointer-events:auto}@media(max-width:640px){.toast-container{left:var(--s-4);right:var(--s-4)}}html{transition:background-color var(--d-slow) var(--ease-brand),color var(--d-slow) var(--ease-brand)}*:focus-visible{outline:2px solid var(--mojo-blue);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.theme-toggle{width:36px;height:36px;border-radius:var(--r-pill);border:1px solid var(--rule);background:transparent;color:var(--fg-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:border-color var(--d-fast) var(--ease-brand),color var(--d-fast) var(--ease-brand),background var(--d-fast) var(--ease-brand);padding:0;flex-shrink:0}.theme-toggle:hover{border-color:var(--mojo-red);color:var(--mojo-red);background:var(--mojo-red-wash)}.theme-toggle:active{transform:scale(.95)}:root{--color-primary: var(--mojo-red);--color-secondary: var(--mojo-red-soft);--color-text: var(--fg-primary);--color-background: var(--bg-canvas);--color-white: #FFFFFF;--color-surface: var(--bg-card-deep);--color-surface-elevated: var(--bg-card);--color-gray-50: var(--mojo-paper-deep);--color-gray-100: #e8e4dd;--color-gray-200: var(--rule);--color-gray-300: #c4beb5;--color-gray-400: var(--mojo-ink-mute);--color-gray-500: var(--mojo-ink-soft);--color-gray-600: var(--mojo-ink-soft);--color-gray-700: var(--mojo-ink);--color-gray-800: #2a211f;--color-gray-900: #1a1614;--glass-layer-1-bg: rgba(255,255,255,.55);--glass-layer-1-border: rgba(201,62,46,.12);--glass-layer-1-blur: 12px;--glass-layer-2-bg: rgba(255,255,255,.75);--glass-layer-2-border: rgba(201,62,46,.18);--glass-layer-2-blur: 16px;--glass-layer-3-bg: rgba(255,255,255,.9);--glass-layer-3-border: rgba(201,62,46,.25);--glass-layer-3-blur: 20px;--shadow-layer-3: 0 8px 24px rgba(63,46,45,.14),0 4px 8px rgba(63,46,45,.07), 0 0 0 1px rgba(201,62,46,.12),inset 0 1px 1px rgba(255,255,255,.8);--spring-duration: .6s;--ease-out-expo: cubic-bezier(.16,1,.3,1)}[data-theme=dark]{--color-text: var(--fg-primary);--color-background: var(--bg-canvas);--glass-layer-3-bg: rgba(255,255,255,.16);--glass-layer-3-border: rgba(255,255,255,.25);--shadow-layer-3: 0 8px 24px rgba(0,0,0,.5),0 4px 8px rgba(0,0,0,.3), 0 0 0 1px rgba(201,62,46,.2),inset 0 1px 1px rgba(255,255,255,.15)}.glass-layer-3{background:var(--glass-layer-3-bg);backdrop-filter:blur(var(--glass-layer-3-blur)) saturate(180%);-webkit-backdrop-filter:blur(var(--glass-layer-3-blur)) saturate(180%);border:1px solid var(--glass-layer-3-border);box-shadow:var(--shadow-layer-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);font-family:var(--font-sans);font-weight:600;font-size:var(--text-base);border:none;border-radius:var(--r-2);padding:14px var(--s-5);min-height:48px;cursor:pointer;letter-spacing:.05em;transition:background var(--d-fast) var(--ease-brand),color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--mojo-red);color:var(--mojo-paper)}.btn-primary:hover:not(:disabled){background:var(--mojo-red-deep)}.btn-secondary{background:transparent;color:var(--fg-primary);box-shadow:inset 0 0 0 1px var(--rule-strong)}.btn-secondary:hover:not(:disabled){box-shadow:inset 0 0 0 1px var(--mojo-ink);background:var(--bg-card-deep)}.btn-danger{background:var(--mojo-red);color:var(--mojo-paper)}.btn-danger:hover:not(:disabled){background:var(--mojo-red-deep)}.btn-sm{min-height:36px;padding:8px var(--s-3);font-size:var(--text-sm)}.btn-lg{min-height:56px;padding:16px var(--s-6);font-size:var(--text-lg)}.modal-title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:700;color:var(--fg-primary);margin:0 0 var(--s-1);line-height:1.2}.modal-header{display:flex;flex-direction:column;gap:var(--s-1);margin-bottom:var(--s-4)}.modal-description,.modal-desc{color:var(--fg-secondary);font-size:var(--text-sm);margin:0;line-height:var(--leading-tc)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--s-2);margin-top:var(--s-5);padding-top:var(--s-4);border-top:1px solid var(--rule)}.card-title{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:700;color:var(--fg-primary);margin:0 0 var(--s-2);line-height:1.2}.input-inset{background:var(--bg-inset);border:1px solid var(--rule);box-shadow:inset 0 1px 2px #46321e0f;transition:border-color var(--d-fast) var(--ease-brand),box-shadow var(--d-fast) var(--ease-brand)}.input-inset:focus{border-color:var(--mojo-blue);box-shadow:inset 0 1px 2px #46321e0a,0 0 0 2px #1c3f7326;outline:none}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--fg-muted)}.text-accent{color:var(--mojo-red)}.text-success{color:var(--status-on)}.text-warning{color:var(--status-warn)}.text-error{color:var(--mojo-red)}.font-display{font-family:var(--font-serif)}.font-mono{font-family:var(--font-mono)}.mt-4{margin-top:var(--s-4)}.mb-4{margin-bottom:var(--s-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--s-2)}.gap-4{gap:var(--s-4)}.cursor-pointer{cursor:pointer}
