.spinner{display:inline-block;width:32px;height:32px;border:3px solid rgba(0,0,0,.1);border-top-color:#4f46e5;border-radius:50%;animation:spin .9s linear infinite}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@keyframes spin{to{transform:rotate(360deg)}}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:1000;background:#dc2626;color:#fff;padding:8px 16px;box-shadow:0 2px 8px #00000026;animation:slideDown .3s ease-out;font-size:.875rem}.offline-indicator-content{display:flex;align-items:center;gap:8px;max-width:1200px;margin:0 auto}.offline-indicator svg{flex-shrink:0;width:16px;height:16px}.offline-indicator strong{font-weight:600}.offline-indicator span{line-height:1.4}@media (min-width: 768px){.offline-indicator{padding:12px 24px;font-size:1rem}.offline-indicator-content{gap:12px}.offline-indicator svg{width:20px;height:20px}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);color:var(--text-primary)}.skip-to-content{position:absolute;left:-9999px;z-index:var(--z-modal);padding:var(--space-3) var(--space-4);background:var(--gray-900);color:var(--text-inverse);text-decoration:none;border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold)}.skip-to-content:focus{left:var(--space-3);top:var(--space-3)}.app-header{position:sticky;top:0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--gray-900);color:#fff;box-shadow:var(--shadow-sm)}.app-header .brand{font-weight:var(--font-weight-bold);letter-spacing:.5px;font-size:var(--font-size-lg);color:#fff;display:flex;align-items:center;gap:var(--space-2)}.brand-icon{color:var(--primary-400);flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));width:36px;height:36px}.brand-text{font-size:var(--font-size-lg)}.header-profile-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:#ffffff1a;color:#fff;text-decoration:none;transition:all var(--transition-fast);flex-shrink:0}.header-profile-button:hover{background:#fff3}.profile-icon{display:block}.app-main{flex:1;padding:var(--space-4);padding-bottom:calc(var(--space-4) + 96px);overflow-x:hidden;width:100%}.app-footer-nav{position:fixed;bottom:-1px;left:0;right:0;display:flex;align-items:center;justify-content:space-around;background:var(--surface-primary);border-top:1px solid var(--border-light);padding:var(--space-2) var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom));box-shadow:0 -2px 10px #0000001a;z-index:var(--z-sticky)}.footer-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);min-width:64px;text-decoration:none;color:var(--text-secondary);transition:all var(--transition-fast);border-radius:var(--radius-md)}.footer-nav-item:hover{color:var(--text-primary);background:var(--surface-hover)}.footer-nav-item.active{color:var(--primary-600)}.footer-nav-icon{flex-shrink:0}.footer-nav-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1}.fab-button{position:fixed;bottom:calc(80px + var(--space-4));right:var(--space-4);width:56px;height:56px;border-radius:var(--radius-full);background:var(--primary-600);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-2xl);transition:all var(--transition-base);z-index:var(--z-sticky);text-decoration:none}.fab-button:hover{background:var(--primary-700);transform:scale(1.1) translateY(-4px);box-shadow:var(--shadow-2xl)}.fab-button:active{transform:scale(.95)}.fab-button .fab-icon{color:#fff}@media (min-width: 768px){.app-header{padding:var(--space-4) var(--space-6)}.app-header .brand{font-size:var(--font-size-xl)}.brand-icon{width:40px;height:40px}.brand-text{font-size:var(--font-size-xl)}.app-main{padding:var(--space-6);padding-bottom:calc(var(--space-6) + 96px)}.footer-nav-item{min-width:80px}.footer-nav-label{font-size:var(--font-size-sm)}.fab-button{bottom:calc(88px + var(--space-6));right:var(--space-6)}}@media (min-width: 1024px){.app-main{padding:var(--space-8);padding-bottom:calc(var(--space-8) + 96px);max-width:1400px;margin:0 auto}.fab-button{bottom:calc(88px + var(--space-8));right:var(--space-8)}}:root{--primary-50: #ecfdf5;--primary-100: #d1fae5;--primary-200: #a7f3d0;--primary-300: #6ee7b7;--primary-400: #34d399;--primary-500: #10b981;--primary-600: #059669;--primary-700: #047857;--primary-800: #065f46;--primary-900: #064e3b;--secondary-50: #eff6ff;--secondary-100: #dbeafe;--secondary-200: #bfdbfe;--secondary-300: #93c5fd;--secondary-400: #60a5fa;--secondary-500: #3b82f6;--secondary-600: #2563eb;--secondary-700: #1d4ed8;--secondary-800: #1e40af;--secondary-900: #1e3a8a;--accent-50: #fffbeb;--accent-100: #fef3c7;--accent-200: #fde68a;--accent-300: #fcd34d;--accent-400: #fbbf24;--accent-500: #f59e0b;--accent-600: #d97706;--accent-700: #b45309;--accent-800: #92400e;--accent-900: #78350f;--success: var(--primary-500);--warning: var(--accent-500);--error: #ef4444;--info: var(--secondary-500);--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg-primary: #ffffff;--bg-secondary: var(--gray-50);--bg-tertiary: var(--gray-100);--bg-elevated: #ffffff;--surface-primary: #ffffff;--surface-secondary: var(--gray-50);--surface-hover: var(--gray-100);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-tertiary: var(--gray-500);--text-inverse: #ffffff;--text-link: var(--secondary-600);--text-link-hover: var(--secondary-700);--border-light: var(--gray-200);--border-medium: var(--gray-300);--border-heavy: var(--gray-400);--border-focus: var(--primary-500);--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--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;--space-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .1s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-base: 0;--z-dropdown: 1000;--z-sticky: 1100;--z-fixed: 1200;--z-modal-backdrop: 1300;--z-modal: 1400;--z-popover: 1500;--z-tooltip: 1600}@media (prefers-color-scheme: dark){:root{--success: var(--primary-400);--warning: var(--accent-400);--error: #f87171;--info: var(--secondary-400);--bg-primary: var(--gray-900);--bg-secondary: var(--gray-800);--bg-tertiary: var(--gray-700);--bg-elevated: var(--gray-800);--surface-primary: var(--gray-800);--surface-secondary: var(--gray-700);--surface-hover: var(--gray-600);--text-primary: var(--gray-50);--text-secondary: var(--gray-300);--text-tertiary: var(--gray-400);--text-inverse: var(--gray-900);--text-link: var(--secondary-400);--text-link-hover: var(--secondary-300);--border-light: var(--gray-700);--border-medium: var(--gray-600);--border-heavy: var(--gray-500);--border-focus: var(--primary-400);--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .4), 0 1px 2px -1px rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .5), 0 2px 4px -2px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .6), 0 4px 6px -4px rgb(0 0 0 / .5);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .7), 0 8px 10px -6px rgb(0 0 0 / .6);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .8)}}@media (prefers-contrast: high){:root{--border-light: var(--gray-400);--border-medium: var(--gray-500);--border-heavy: var(--gray-600)}@media (prefers-color-scheme: dark){:root{--border-light: var(--gray-500);--border-medium: var(--gray-400);--border-heavy: var(--gray-300)}}}.card{background:var(--surface-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card--interactive{cursor:pointer}.card--interactive:hover{border-color:var(--border-medium);box-shadow:var(--shadow-lg)}.card--flat{box-shadow:none;border:1px solid var(--border-light)}.card--elevated{box-shadow:var(--shadow-lg);border:none}.card__header{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light)}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}.card__subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.card__content{color:var(--text-secondary)}.card__footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-light);display:flex;gap:var(--space-3);align-items:center;justify-content:flex-end}.stat-card{background:var(--surface-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;transition:all var(--transition-base)}.stat-card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-card__value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight)}.stat-card__trend{font-size:var(--font-size-sm);margin-top:var(--space-2);display:flex;align-items:center;justify-content:center;gap:var(--space-1)}.stat-card__trend--positive{color:var(--success)}.stat-card__trend--negative{color:var(--error)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;min-height:44px}.button:disabled{opacity:.5;cursor:not-allowed}.button--primary{background:var(--primary-600);color:var(--text-inverse)}.button--primary:hover:not(:disabled){background:var(--primary-700);box-shadow:var(--shadow-md)}.button--primary:active:not(:disabled){background:var(--primary-800);transform:translateY(1px)}.button--secondary{background:var(--secondary-600);color:var(--text-inverse)}.button--secondary:hover:not(:disabled){background:var(--secondary-700);box-shadow:var(--shadow-md)}.button--outline{background:transparent;color:var(--text-primary);border:2px solid var(--border-medium)}.button--outline:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-heavy)}.button--ghost{background:transparent;color:var(--text-secondary)}.button--ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text-primary)}.button--danger{background:var(--error);color:var(--text-inverse)}.button--danger:hover:not(:disabled){background:#dc2626;box-shadow:var(--shadow-md)}.button--success{background:var(--success);color:var(--text-inverse)}.button--success:hover:not(:disabled){background:var(--primary-700);box-shadow:var(--shadow-md)}.button--sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);min-height:36px}.button--lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);min-height:52px}.button--block{width:100%}.button--icon{padding:var(--space-3);width:44px;height:44px}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.form-label--required:after{content:" *";color:var(--error)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--space-3) var(--space-4);font-size:16px;font-family:var(--font-sans);color:var(--text-primary);background:var(--surface-primary);border:2px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--border-medium)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #10b9811a}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-textarea{min-height:100px;resize:vertical}.form-help{display:block;font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--space-2)}.form-error{display:block;font-size:var(--font-size-sm);color:var(--error);margin-top:var(--space-2)}.form-input--error,.form-textarea--error,.form-select--error{border-color:var(--error)}.form-input--error:focus,.form-textarea--error:focus,.form-select--error:focus{box-shadow:0 0 0 3px #ef44441a}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge--primary{background:var(--primary-100);color:var(--primary-700)}.badge--secondary{background:var(--secondary-100);color:var(--secondary-700)}.badge--success{background:var(--primary-100);color:var(--primary-700)}.badge--warning{background:var(--accent-100);color:var(--accent-700)}.badge--error{background:#fee2e2;color:#991b1b}.badge--neutral{background:var(--gray-100);color:var(--gray-700)}@media (prefers-color-scheme: dark){.badge--primary{background:var(--primary-900);color:var(--primary-300)}.badge--secondary{background:var(--secondary-900);color:var(--secondary-300)}.badge--success{background:var(--primary-900);color:var(--primary-300)}.badge--warning{background:var(--accent-900);color:var(--accent-300)}.badge--error{background:#7f1d1d;color:#fca5a5}.badge--neutral{background:var(--gray-700);color:var(--gray-300)}}.stack{display:flex;flex-direction:column}.stack--sm>*+*{margin-top:var(--space-2)}.stack--md>*+*{margin-top:var(--space-4)}.stack--lg>*+*{margin-top:var(--space-6)}.grid{display:grid;gap:var(--space-4)}.grid--2{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid--3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid--4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}@media (min-width: 768px){.grid{gap:var(--space-6)}}.divider{height:1px;background:var(--border-light);border:none;margin:var(--space-6) 0}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-warning{color:var(--warning)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);line-height:var(--line-height-normal);color:var(--text-primary);background:var(--bg-primary);-webkit-overflow-scrolling:touch}*:focus{outline:2px solid var(--border-focus);outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;box-shadow:0 0 0 3px #10b9811a}button,a,[role=button],[tabindex]:not([tabindex="-1"]){cursor:pointer}button:disabled,[aria-disabled=true]{cursor:not-allowed;opacity:.6}button,a[role=button],input[type=checkbox],input[type=radio]{min-height:44px;min-width:44px}a:not([role=button]){min-height:auto;min-width:auto}h1{font-size:1.75rem;line-height:1.2;margin-bottom:1rem}h2{font-size:1.5rem;line-height:1.3;margin-bottom:.875rem}h3{font-size:1.25rem;line-height:1.4;margin-bottom:.75rem}p{margin-bottom:1rem}@media (min-width: 768px){html{font-size:18px}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}}a{color:var(--primary-600);text-decoration:underline;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}a:active{color:var(--primary-800)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}input,textarea,select,button{font-size:16px;border-radius:var(--radius-md)}input,textarea,select{padding:12px 16px;border:2px solid var(--border-light);width:100%;transition:border-color var(--transition-fast);background:var(--surface-primary);color:var(--text-primary)}input:focus,textarea:focus,select:focus{border-color:var(--border-focus)}button{padding:12px 20px;font-weight:var(--font-weight-medium);border:none;transition:all var(--transition-fast)}.button,button[type=submit]{background:var(--primary-600);color:var(--text-inverse)}.button:hover:not(:disabled),button[type=submit]:hover:not(:disabled){background:var(--primary-700)}.button:active:not(:disabled),button[type=submit]:active:not(:disabled){background:var(--primary-800)}.button--secondary{background:var(--surface-secondary);color:var(--text-primary)}.button--secondary:hover:not(:disabled){background:var(--surface-hover)}@media (min-width: 768px){input,textarea,select,button{font-size:inherit}input,textarea,select{padding:10px 14px}button{padding:10px 18px}}@media (prefers-contrast: high){*:focus-visible{outline-width:3px;outline-offset:3px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.container{width:100%;margin:0 auto;padding:0 16px}@media (min-width: 768px){.container{max-width:768px;padding:0 24px}}@media (min-width: 1024px){.container{max-width:1024px;padding:0 32px}}@media (min-width: 1280px){.container{max-width:1280px}}.stack-sm>*+*{margin-top:.5rem}.stack>*+*{margin-top:1rem}.stack-lg>*+*{margin-top:1.5rem}img{max-width:100%;height:auto;display:block}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
