@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Libre+Baskerville:wght@400;700&family=DM+Sans:wght@400;500;600;700&family=Noto+Sans+TC:wght@400;500;600;700&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-59dcaa8e]{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:space-around;align-items:center;padding:var(--space-2) var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom));background:var(--glass-hero-bg);border-top:1px solid var(--glass-hero-border);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);box-shadow:var(--shadow-hero)}[data-theme=dark] .bottom-nav[data-v-59dcaa8e]{background:#ffffff26;border-top:1px solid rgba(255,255,255,.3)}[data-theme=light] .bottom-nav[data-v-59dcaa8e]{background:#fffdf8d9;border-top:1px solid rgba(201,62,46,.3)}.nav-item[data-v-59dcaa8e]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-muted);text-decoration:none;transition:all var(--transition-base);min-width:60px;position:relative}.nav-item[data-v-59dcaa8e]:active{transform:scale(.95)}.nav-item.active[data-v-59dcaa8e]{color:var(--color-accent)}.nav-item.active[data-v-59dcaa8e]:before{content:"";position:absolute;inset:0;border-radius:var(--radius-md);background:radial-gradient(circle at 50% 50%,rgba(212,165,70,.15) 0%,rgba(212,165,70,.08) 50%,transparent 100%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:-1;animation:tab-activate-59dcaa8e .4s var(--spring-easing)}.nav-item.active[data-v-59dcaa8e]:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-accent-light) 100%);border-radius:0 0 var(--radius-full) var(--radius-full);box-shadow:0 0 12px var(--color-accent-glow)}@keyframes tab-activate-59dcaa8e{0%{transform:scale(.95);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.nav-icon[data-v-59dcaa8e]{width:24px;height:24px;transition:transform var(--transition-base)}.nav-item.active .nav-icon[data-v-59dcaa8e]{transform:scale(1.1)}.nav-label[data-v-59dcaa8e]{font-size:var(--text-xs);font-weight:600;transition:font-weight var(--transition-fast)}.nav-item.active .nav-label[data-v-59dcaa8e]{font-weight:700}@media(prefers-reduced-motion:reduce){.nav-item[data-v-59dcaa8e],.nav-icon[data-v-59dcaa8e],.nav-label[data-v-59dcaa8e]{transition:none!important}.nav-item.active[data-v-59dcaa8e]:before{animation:none}@keyframes tab-activate-59dcaa8e{0%,to{transform:scale(1);opacity:1}}}.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}}}.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-container>*{pointer-events:auto}.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{--color-primary: #c93e2e;--color-secondary: #e85545;--color-cta: #bc955b;--color-background: #fffdf8;--color-text: #3f2e2d;--color-brand-hover: #ff6b5a;--color-brand-glow: rgba(201, 62, 46, .3);--color-gold-dark: #7f5430;--color-ochre: #d4a574;--color-success: #10B981;--color-warning: #d4a574;--color-error: #c93e2e;--color-info: #e85545;--color-white: #FFFFFF;--color-surface: #f5f1ea;--color-surface-elevated: #ffffff;--color-gray-50: #f5f1ea;--color-gray-100: #e8e4dd;--color-gray-200: #d8d4cc;--color-gray-300: #c4beb5;--color-gray-400: #9a8f83;--color-gray-500: #746a5e;--color-gray-600: #746a5e;--color-gray-700: #3f2e2d;--color-gray-800: #2a211f;--color-gray-900: #1a1614;--glass-white: rgba(255, 253, 248, .85);--glass-light: rgba(255, 253, 248, .65);--glass-dark: rgba(63, 46, 45, .1);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--shadow-sm: 0 2px 8px rgba(60, 46, 45, .08);--shadow-md: 0 4px 16px rgba(201, 62, 46, .12), 0 2px 8px rgba(60, 46, 45, .08);--shadow-lg: 0 8px 32px rgba(201, 62, 46, .16), 0 4px 16px rgba(60, 46, 45, .12);--shadow-xl: 0 12px 48px rgba(201, 62, 46, .2), 0 8px 32px rgba(60, 46, 45, .16);--shadow-glow: 0 0 24px var(--color-brand-glow);--shadow-glow-strong: 0 0 36px var(--color-brand-glow), 0 4px 16px rgba(201, 62, 46, .25);--font-heading: "Noto Sans TC", sans-serif;--font-body: "Noto Sans TC", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--glass-layer-1-bg: rgba(255, 255, 255, .45);--glass-layer-1-border: rgba(255, 255, 255, .25);--glass-layer-1-blur: 12px;--glass-layer-2-bg: rgba(255, 255, 255, .65);--glass-layer-2-border: rgba(255, 255, 255, .4);--glass-layer-2-blur: 16px;--glass-layer-3-bg: rgba(255, 255, 255, .85);--glass-layer-3-border: rgba(255, 255, 255, .6);--glass-layer-3-blur: 20px;--glass-hero-bg: rgba(255, 255, 255, .95);--glass-hero-border: rgba(255, 255, 255, .8);--glass-hero-blur: 24px;--shadow-layer-1: 0 2px 8px rgba(63, 46, 45, .04), 0 1px 2px rgba(63, 46, 45, .02), inset 0 1px 1px rgba(255, 255, 255, .5);--shadow-layer-2: 0 4px 16px rgba(63, 46, 45, .08), 0 2px 4px rgba(63, 46, 45, .04), inset 0 1px 1px rgba(255, 255, 255, .6);--shadow-layer-3: 0 8px 24px rgba(63, 46, 45, .12), 0 4px 8px rgba(63, 46, 45, .06), 0 0 0 1px rgba(201, 62, 46, .08), inset 0 1px 1px rgba(255, 255, 255, .7);--shadow-hero: 0 12px 32px rgba(63, 46, 45, .16), 0 6px 12px rgba(63, 46, 45, .08), 0 0 0 1px rgba(201, 62, 46, .12), inset 0 2px 2px rgba(255, 255, 255, .8);--spring-duration: .6s;--spring-easing: cubic-bezier(.34, 1.56, .64, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}[data-theme=light]{--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;--glass-hero-bg: rgba(255, 255, 255, .98);--glass-hero-border: rgba(201, 62, 46, .3);--glass-hero-blur: 24px;--shadow-layer-1: 0 2px 8px rgba(63, 46, 45, .06), 0 1px 2px rgba(63, 46, 45, .03), inset 0 1px 1px rgba(255, 255, 255, .6);--shadow-layer-2: 0 4px 16px rgba(63, 46, 45, .1), 0 2px 4px rgba(63, 46, 45, .05), inset 0 1px 1px rgba(255, 255, 255, .7);--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);--shadow-hero: 0 12px 32px rgba(63, 46, 45, .18), 0 6px 12px rgba(63, 46, 45, .09), 0 0 0 1px rgba(201, 62, 46, .15), inset 0 2px 2px rgba(255, 255, 255, .9);--color-text-primary: #3f2e2d;--color-text-secondary: #746a5e;--color-bg-elevated: rgba(255, 255, 255, .95);--color-border: rgba(201, 62, 46, .2)}[data-theme=light] body{background:radial-gradient(circle at 20% 80%,rgba(188,149,91,.03) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(201,62,46,.03) 0%,transparent 50%),var(--color-background)}[data-theme=dark]{--glass-layer-1-bg: rgba(255, 255, 255, .08);--glass-layer-1-border: rgba(255, 255, 255, .12);--glass-layer-1-blur: 12px;--glass-layer-2-bg: rgba(255, 255, 255, .12);--glass-layer-2-border: rgba(255, 255, 255, .18);--glass-layer-2-blur: 16px;--glass-layer-3-bg: rgba(255, 255, 255, .16);--glass-layer-3-border: rgba(255, 255, 255, .25);--glass-layer-3-blur: 20px;--glass-hero-bg: rgba(255, 255, 255, .2);--glass-hero-border: rgba(255, 255, 255, .3);--glass-hero-blur: 24px;--shadow-layer-1: 0 2px 8px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2), inset 0 1px 1px rgba(255, 255, 255, .1);--shadow-layer-2: 0 4px 16px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .25), inset 0 1px 1px rgba(255, 255, 255, .12);--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);--shadow-hero: 0 12px 32px rgba(0, 0, 0, .6), 0 6px 12px rgba(0, 0, 0, .35), 0 0 0 1px rgba(201, 62, 46, .25), inset 0 2px 2px rgba(255, 255, 255, .18);--color-text: #f5f1ea;--color-text-primary: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-bg-elevated: rgba(255, 255, 255, .12);--color-border: rgba(255, 255, 255, .2);--spring-duration: .6s;--spring-easing: cubic-bezier(.34, 1.56, .64, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-background);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark] body{background:radial-gradient(circle at 20% 80%,rgba(188,149,91,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(201,62,46,.08) 0%,transparent 50%),#0f0d0b}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;margin-bottom:var(--space-md)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--space-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 24px;border:none;border-radius:var(--radius-xl);font-family:var(--font-body);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width var(--transition-slow),height var(--transition-slow)}.btn:active:before{width:300px;height:300px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-cta) 0%,#FB923C 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #f9731666}.btn-secondary{background:var(--glass-white);color:var(--color-primary);border:2px solid var(--color-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover:not(:disabled){background:var(--color-primary);color:var(--color-white);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-danger{background:linear-gradient(135deg,var(--color-error) 0%,#DC2626 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #ef444466}.btn-sm{padding:8px 16px;font-size:var(--text-sm)}.btn-lg{padding:16px 32px;font-size:var(--text-lg)}.card{background:var(--glass-white);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-2xl);padding:var(--space-lg);box-shadow:var(--shadow-lg);transition:all var(--transition-base);position:relative}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%);opacity:.5}.card-hover{cursor:pointer}.card-hover:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-xl),var(--shadow-glow);border-color:#7c3aed4d}.card-header{margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid rgba(124,58,237,.1)}.card-title{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-xs);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-subtitle{font-size:var(--text-sm);color:var(--color-gray-600)}.input{width:100%;padding:14px 18px;border:2px solid rgba(124,58,237,.2);border-radius:var(--radius-xl);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--glass-white);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base);color-scheme:light dark}[data-theme=dark] .input{color:#fff}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #7c3aed1a,var(--shadow-glow);transform:translateY(-1px)}.input:disabled{background:var(--color-gray-100);cursor:not-allowed;opacity:.6}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 4px #ef44441a}.label{display:block;margin-bottom:var(--space-xs);font-size:var(--text-sm);font-weight:600;color:var(--color-text)}[data-theme=dark] .label{color:var(--color-text-primary)}.input-helper{margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--color-gray-600)}.input-error-text{margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--color-error);font-weight:500}.modal-overlay{position:fixed;inset:0;background:#4c1d9566;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-md)}.modal{background:var(--color-bg-elevated);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-xl);box-shadow:var(--shadow-xl);max-width:min(500px,calc(100vw - 2rem));width:100%;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;z-index:var(--z-modal)}.modal *{box-sizing:border-box;max-width:100%}.modal-header{margin-bottom:var(--space-lg)}.modal-title{font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2);word-wrap:break-word;overflow-wrap:break-word}.modal-desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.modal-footer{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid rgba(124,58,237,.1);display:flex;gap:var(--space-md);justify-content:flex-end}.badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge-primary{background:#7c3aed26;color:var(--color-primary);border:1px solid rgba(124,58,237,.3)}.badge-success{background:#10b98126;color:var(--color-success);border:1px solid rgba(16,185,129,.3)}.badge-warning{background:#f9731626;color:var(--color-cta);border:1px solid rgba(249,115,22,.3)}.badge-error{background:#ef444426;color:var(--color-error);border:1px solid rgba(239,68,68,.3)}.text-left{text-align:left}.justify-center{justify-content:center}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.cursor-not-allowed{cursor:not-allowed}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:768px){.btn{min-height:44px;min-width:44px}.card{padding:var(--space-md)}.modal{padding:var(--space-lg)}}.glass-layer-1{background:var(--glass-layer-1-bg);backdrop-filter:blur(var(--glass-layer-1-blur)) saturate(150%);-webkit-backdrop-filter:blur(var(--glass-layer-1-blur)) saturate(150%);border:1px solid var(--glass-layer-1-border);box-shadow:var(--shadow-layer-1)}.glass-layer-2{background:var(--glass-layer-2-bg);backdrop-filter:blur(var(--glass-layer-2-blur)) saturate(150%);-webkit-backdrop-filter:blur(var(--glass-layer-2-blur)) saturate(150%);border:1px solid var(--glass-layer-2-border);box-shadow:var(--shadow-layer-2)}.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)}.glass-hero{background:var(--glass-hero-bg);backdrop-filter:blur(var(--glass-hero-blur)) saturate(200%);-webkit-backdrop-filter:blur(var(--glass-hero-blur)) saturate(200%);border:1px solid var(--glass-hero-border);box-shadow:var(--shadow-hero)}.glass-subtle{background:var(--glass-layer-1-bg);backdrop-filter:blur(var(--glass-layer-1-blur)) saturate(150%);-webkit-backdrop-filter:blur(var(--glass-layer-1-blur)) saturate(150%);border:1px solid var(--glass-layer-1-border);box-shadow:var(--shadow-layer-1)}.glass-medium{background:var(--glass-layer-2-bg);backdrop-filter:blur(var(--glass-layer-2-blur)) saturate(150%);-webkit-backdrop-filter:blur(var(--glass-layer-2-blur)) saturate(150%);border:1px solid var(--glass-layer-2-border);box-shadow:var(--shadow-layer-2)}.glass-strong{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)}.spring-press{transition:transform var(--spring-duration) var(--spring-easing)}.spring-press:active{transform:scale(.95)}.spring-press-strong{transition:transform var(--spring-duration) var(--spring-easing)}.spring-press-strong:active{transform:scale(.93)}.spring-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.spring-lift:hover{transform:translateY(-2px)}.spring-lift:active{transform:translateY(0)}.input-inset{background:#0003;border:1px solid var(--color-gray-300);box-shadow:inset 0 2px 4px #0003;transition:all var(--transition-base)}.input-inset:focus{border-color:var(--color-primary);box-shadow:inset 0 1px 2px #0000001a,0 0 0 3px var(--color-brand-glow);background:#00000026;outline:none}[data-theme=light] .input-inset{background:#0000000a;box-shadow:inset 0 1px 3px #00000014}[data-theme=light] .input-inset:focus{background:#00000005;box-shadow:inset 0 1px 2px #0000000d,0 0 0 3px var(--color-brand-glow)}@media(prefers-reduced-motion:reduce){.spring-press,.spring-press-strong,.spring-lift{transition:none!important}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--color-bg-primary: #0f0f0f;--color-bg-secondary: #1a1a1a;--color-bg-card: #222222;--color-bg-elevated: #2a2a2a;--color-accent: #d4a546;--color-accent-light: #e8c476;--color-accent-dark: #b8912e;--color-accent-glow: rgba(212, 165, 70, .2);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .15);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .15);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .15);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .15);--color-text-primary: #f5f5f5;--color-text-secondary: #999999;--color-text-muted: #666666;--color-border: #333333;--color-border-light: #444444;--font-display: "Libre Baskerville", Georgia, serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}[data-theme=light]{--color-bg-primary: #fffdf8;--color-bg-secondary: #f5f1ea;--color-bg-card: #ffffff;--color-bg-elevated: #f8f6f2;--color-accent: #c93e2e;--color-accent-light: #e85545;--color-accent-dark: #a83222;--color-accent-glow: rgba(201, 62, 46, .15);--color-success: #16a34a;--color-success-bg: rgba(22, 163, 74, .12);--color-warning: #d97706;--color-warning-bg: rgba(217, 119, 6, .12);--color-error: #dc2626;--color-error-bg: rgba(220, 38, 38, .12);--color-info: #2563eb;--color-info-bg: rgba(37, 99, 235, .12);--color-text-primary: #3f2e2d;--color-text-secondary: #746a5e;--color-text-muted: #9a8f83;--color-border: #d8d4cc;--color-border-light: #e8e4dc;--shadow-sm: 0 1px 3px rgba(63, 46, 45, .08);--shadow-md: 0 4px 12px rgba(63, 46, 45, .12);--shadow-lg: 0 8px 24px rgba(63, 46, 45, .16);--shadow-glow: 0 0 20px var(--color-accent-glow)}[data-theme=dark]{--color-bg-primary: #0f0f0f;--color-bg-secondary: #1a1a1a;--color-bg-card: #222222;--color-bg-elevated: #2a2a2a;--color-accent: #d4a546;--color-accent-light: #e8c476;--color-accent-dark: #b8912e;--color-accent-glow: rgba(212, 165, 70, .2);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .15);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .15);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .15);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .15);--color-text-primary: #f5f5f5;--color-text-secondary: #999999;--color-text-muted: #666666;--color-border: #333333;--color-border-light: #444444;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px var(--color-accent-glow)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;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{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--text-3xl);letter-spacing:.02em}h2{font-size:var(--text-xl);color:var(--color-text-secondary);font-family:var(--font-body);font-weight:600;text-transform:uppercase;letter-spacing:.08em}p{color:var(--color-text-secondary)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-light)}button{font-family:var(--font-body);font-size:var(--text-base);font-weight:600;cursor:pointer;border:none;border-radius:var(--radius-md);padding:var(--space-3) var(--space-5);transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:#0f0f0f;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-light),var(--color-accent));transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border-light)}.btn-secondary:hover:not(:disabled){background:var(--color-border-light);border-color:var(--color-text-muted)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:#1ea84e}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-elevated)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-lg);border-radius:var(--radius-lg)}.btn-block{width:100%}input,select,textarea{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}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='%23999' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.card-elevated{background:var(--color-bg-elevated);box-shadow:var(--shadow-lg)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{background:var(--color-bg-elevated);color:var(--color-text-muted)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgba(34,197,94,.3)}.alert-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid rgba(245,158,11,.3)}.alert-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid rgba(239,68,68,.3)}.alert-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid rgba(59,130,246,.3)}.loading-text{color:var(--color-text-muted);text-align:center;padding:var(--space-8)}.loading-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-10)}.page{max-width:500px;margin:0 auto;padding:var(--space-4);padding-bottom:calc(80px + env(safe-area-inset-bottom))}.page-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-text-primary)}.section{margin-bottom:var(--space-8)}.section-title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-4)}.back-btn{background:none;border:none;padding:var(--space-2);margin:calc(var(--space-2) * -1);color:var(--color-text-secondary);font-size:var(--text-lg);display:flex;align-items:center;gap:var(--space-2)}.back-btn:hover{color:var(--color-accent)}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4)}.modal{background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:400px;border:1px solid var(--color-border);box-shadow:var(--shadow-lg);animation:modal-in .2s ease-out}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2)}.modal-desc{color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-5)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}.empty-state{text-align:center;padding:var(--space-10);color:var(--color-text-muted)}.empty-state-icon{width:48px;height:48px;margin:0 auto var(--space-4);opacity:.5;color:var(--color-text-muted)}.divider{height:1px;background:var(--color-border);margin:var(--space-6) 0}@supports (padding-bottom: env(safe-area-inset-bottom)){.page{padding-bottom:calc(var(--space-12) + env(safe-area-inset-bottom))}}.glass-strong{background:#ffffff14;backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff1a inset,0 0 40px #d4a5461a}.glass-medium{background:#ffffff0f;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 16px #0003,0 0 0 1px #ffffff14 inset}.glass-subtle{background:#ffffff0a;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);border:1px solid rgba(255,255,255,.08);box-shadow:0 2px 8px #00000026}[data-theme=light] .glass-strong{background:#ffffffd9;backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(201,62,46,.15);box-shadow:0 8px 32px #3f2e2d26,0 0 0 1px #fffc inset,0 0 40px #c93e2e14}[data-theme=light] .glass-medium{background:#ffffffb3;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border:1px solid rgba(201,62,46,.1);box-shadow:0 4px 16px #3f2e2d1a,0 0 0 1px #fff9 inset}[data-theme=light] .glass-subtle{background:#ffffff80;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);border:1px solid rgba(201,62,46,.08);box-shadow:0 2px 8px #3f2e2d14}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.font-display{font-family:var(--font-display)}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.cursor-pointer{cursor:pointer}.theme-toggle{width:36px;height:36px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.125rem;transition:all var(--transition-base);padding:0;flex-shrink:0}.theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-bg-card)}.theme-toggle:active{transform:scale(.95)}html{transition:background-color var(--transition-slow),color var(--transition-slow)}body,.card,.login-form,.action-card,input,select,textarea,button{transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-base)}
