.error-boundary[data-v-c1dda7b6]{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);background-color:var(--color-background)}.error-content[data-v-c1dda7b6]{text-align:center;max-width:500px}.error-icon[data-v-c1dda7b6]{color:var(--color-danger);margin-bottom:var(--spacing-lg)}.error-title[data-v-c1dda7b6]{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-md)}.error-message[data-v-c1dda7b6]{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.error-actions[data-v-c1dda7b6]{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-xl)}.btn[data-v-c1dda7b6]{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-primary[data-v-c1dda7b6]{background-color:var(--color-primary);color:#fff}.btn-primary[data-v-c1dda7b6]:hover{background-color:var(--color-primary-dark)}.btn-secondary[data-v-c1dda7b6]{background-color:var(--color-background-secondary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary[data-v-c1dda7b6]:hover{background-color:var(--color-background-tertiary)}.error-details[data-v-c1dda7b6]{text-align:left;background-color:var(--color-background-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.error-details summary[data-v-c1dda7b6]{cursor:pointer;color:var(--color-text-secondary)}.error-details pre[data-v-c1dda7b6]{margin-top:var(--spacing-sm);white-space:pre-wrap;word-break:break-word;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.toast-container[data-v-65028b72]{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:400px}.toast[data-v-65028b72]{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);background-color:var(--color-surface);box-shadow:var(--shadow-lg);cursor:pointer;transition:transform .2s ease,opacity .2s ease}.toast[data-v-65028b72]:hover{transform:translate(-4px)}.toast-icon[data-v-65028b72]{display:flex;align-items:center;flex-shrink:0}.toast-message[data-v-65028b72]{flex:1;font-size:var(--font-size-sm);color:var(--color-text)}.toast-close[data-v-65028b72]{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs);background:none;border:none;cursor:pointer;color:var(--color-text-secondary);opacity:.6;transition:opacity .2s ease}.toast-close[data-v-65028b72]:hover{opacity:1}.toast-success[data-v-65028b72]{border-left:4px solid var(--color-success)}.toast-success .toast-icon[data-v-65028b72]{color:var(--color-success)}.toast-error[data-v-65028b72]{border-left:4px solid var(--color-danger)}.toast-error .toast-icon[data-v-65028b72]{color:var(--color-danger)}.toast-warning[data-v-65028b72]{border-left:4px solid var(--color-warning)}.toast-warning .toast-icon[data-v-65028b72]{color:var(--color-warning)}.toast-info[data-v-65028b72]{border-left:4px solid var(--color-primary)}.toast-info .toast-icon[data-v-65028b72]{color:var(--color-primary)}.toast-enter-active[data-v-65028b72],.toast-leave-active[data-v-65028b72]{transition:all .3s ease}.toast-enter-from[data-v-65028b72],.toast-leave-to[data-v-65028b72]{opacity:0;transform:translate(100%)}.offline-banner[data-v-62e9af57]{position:fixed;bottom:0;left:0;right:0;background-color:var(--color-warning);color:#fff;padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;z-index:9998;box-shadow:var(--shadow-lg)}.offline-content[data-v-62e9af57]{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.offline-dismiss[data-v-62e9af57]{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs);background:none;border:none;cursor:pointer;color:#fff;opacity:.8;transition:opacity .2s ease}.offline-dismiss[data-v-62e9af57]:hover{opacity:1}.offline-banner-enter-active[data-v-62e9af57],.offline-banner-leave-active[data-v-62e9af57]{transition:transform .3s ease}.offline-banner-enter-from[data-v-62e9af57],.offline-banner-leave-to[data-v-62e9af57]{transform:translateY(100%)}.bottom-nav[data-v-cc8579bd]{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:flex-end;background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--spacing-2) 0;padding-bottom:calc(var(--spacing-2) + env(safe-area-inset-bottom));z-index:var(--z-index-fixed)}.nav-item[data-v-cc8579bd]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-1);padding:var(--spacing-2);background:transparent;border:none;cursor:pointer;transition:color var(--transition-fast);color:var(--color-text-tertiary);min-width:64px;position:relative}.nav-item[data-v-cc8579bd]:hover:not(.fab-item){color:var(--color-text-secondary)}.nav-item.active[data-v-cc8579bd]{color:var(--color-primary)}.nav-item.active[data-v-cc8579bd]:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--color-primary);border-radius:var(--radius-full)}.nav-icon[data-v-cc8579bd]{transition:opacity var(--transition-fast)}.nav-label[data-v-cc8579bd]{font-size:var(--text-xs);font-weight:500;transition:color var(--transition-fast)}.fab-item[data-v-cc8579bd]{position:relative;top:0;width:56px;height:56px;background:var(--color-primary);border-radius:var(--radius-full);color:var(--color-text-inverse);transition:background-color var(--transition-fast);border:1px solid var(--color-primary)}.fab-item[data-v-cc8579bd]:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.fab-icon[data-v-cc8579bd]{margin:0}@media(max-width:360px){.nav-label[data-v-cc8579bd]{font-size:10px}.nav-item[data-v-cc8579bd]{min-width:56px}}:root{--color-primary: #1C1A19;--color-primary-hover: #363330;--color-primary-light: #F4F2EE;--color-accent: #D97A62;--color-accent-hover: #C5664E;--color-accent-light: #FDF4F1;--color-bg: #FAF9F6;--color-bg-secondary: #F2F0EA;--color-surface: #FFFFFF;--color-surface-hover: #F8F7F4;--color-border: #E6E4DF;--color-border-light: #F0EFEB;--color-border-dark: #D1CFCA;--color-text-primary: #1C1A19;--color-text-secondary: #63605D;--color-text-tertiary: #9E9A95;--color-text-placeholder: #C4C2BC;--color-text-inverse: #FFFFFF;--color-success: #437A55;--color-success-bg: #F0F5F1;--color-warning: #B37D26;--color-warning-bg: #FDF8ED;--color-danger: #C04A4A;--color-danger-bg: #FDF1F1;--color-info: #546C8C;--color-info-bg: #F2F5F8;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", sans-serif;--font-serif: "Georgia", "Times New Roman", "Songti SC", 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;--text-4xl: 2.5rem;--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 24px;--spacing-6: 32px;--spacing-8: 48px;--spacing-10: 64px;--spacing-12: 80px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-none: none;--shadow-sm: 0 1px 2px rgba(28, 26, 25, .03);--shadow-md: 0 4px 12px rgba(28, 26, 25, .04);--shadow-lg: 0 12px 24px rgba(28, 26, 25, .05);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--z-index-dropdown: 100;--z-index-sticky: 200;--z-index-fixed: 300;--z-index-modal-backdrop: 400;--z-index-modal: 500;--z-index-popover: 600;--z-index-tooltip: 700;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);letter-spacing:-.01em;line-height:1.6;color:var(--color-text-primary);background-color:var(--color-bg)}a{color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;outline:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-4)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);transition:background-color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-text-inverse);border:1px solid var(--color-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border-dark)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-text-primary)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.btn-danger{background-color:var(--color-danger);color:var(--color-text-inverse);border:1px solid var(--color-danger)}.btn-danger:hover:not(:disabled){background-color:#a33d3d;border-color:#a33d3d}.btn-accent{background-color:var(--color-accent);color:var(--color-text-inverse);border:1px solid var(--color-accent)}.btn-accent:hover:not(:disabled){background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--text-xs)}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-base)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.btn-icon-sm{width:32px;height:32px}.btn-icon-lg{width:48px;height:48px}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-5);box-shadow:var(--shadow-none);transition:border-color var(--transition-base)}.card-interactive:hover{border-color:var(--color-border-dark)}.input{width:100%;padding:10px 14px;background-color:transparent;border:1px solid var(--color-border-dark);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-primary);transition:border-color var(--transition-fast)}.input::placeholder{color:var(--color-text-placeholder)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:none}.input:disabled{background-color:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-tertiary)}.tag{font-size:var(--text-xs);color:var(--color-text-secondary);background-color:var(--color-bg-secondary);padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-weight:500}.tag-success{background-color:var(--color-success-bg);color:var(--color-success);border-color:#d6e5da}.tag-warning{background-color:var(--color-warning-bg);color:var(--color-warning);border-color:#e8d9b8}.tag-danger{background-color:var(--color-danger-bg);color:var(--color-danger);border-color:#e8caca}.tag-info{background-color:var(--color-info-bg);color:var(--color-info);border-color:#c5d0dc}.font-serif{font-family:var(--font-serif);letter-spacing:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-5{gap:var(--spacing-5)}.gap-6{gap:var(--spacing-6)}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.w-full{width:100%}.h-full{height:100%}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-5{padding:var(--spacing-5)}.px-4{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.py-4{padding-top:var(--spacing-4);padding-bottom:var(--spacing-4)}.m-0{margin:0}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.border{border:1px solid var(--color-border)}.border-dark{border:1px solid var(--color-border-dark)}.bg-surface{background-color:var(--color-surface)}.bg-bg{background-color:var(--color-bg)}.bg-bg-secondary{background-color:var(--color-bg-secondary)}@media(max-width:640px){.sm\:hidden{display:none}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:flex-col{flex-direction:column}}@media(max-width:768px){.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}.md\:flex-col{flex-direction:column}}@media(max-width:1024px){.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:flex-col{flex-direction:column}}@media(min-width:641px){.sm\:up-hidden{display:none}}@media(min-width:769px){.md\:up-hidden{display:none}}@media(min-width:1025px){.lg\:up-hidden{display:none}}
