.pwa-update-prompt{position:fixed;right:1rem;bottom:1rem;z-index:9999;display:flex;align-items:center;gap:.75rem;width:min(26rem,calc(100vw - 2rem));padding:.9rem 1rem;border-radius:18px;background:radial-gradient(circle at top right,rgba(59,130,246,.18),transparent 32%),var(--bg-primary, #0f172a);border:1px solid rgba(148,163,184,.18);color:var(--text-primary, #f8fafc);box-shadow:0 18px 44px #0f172a57;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.pwa-update-copy{display:flex;flex:1;min-width:0;flex-direction:column}.pwa-update-eyebrow{color:#60a5fa;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.pwa-update-text{margin-top:.2rem;font-size:.88rem;line-height:1.35;color:var(--text-primary, #f8fafc)}.pwa-update-primary{min-height:40px;padding:0 .95rem;border:none;border-radius:12px;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;font-weight:700;cursor:pointer}.pwa-update-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px #2563eb3d}.pwa-update-close{border:none;background:transparent;color:var(--text-tertiary, #94a3b8);cursor:pointer;font-size:1.1rem;padding:0 .2rem}@media(max-width:640px){.pwa-update-prompt{right:.75rem;left:.75rem;width:auto;bottom:calc(64px + env(safe-area-inset-bottom,0px) + .75rem);align-items:flex-start;flex-wrap:wrap}.pwa-update-primary{width:100%;min-height:44px}}.pwa-install-backdrop{position:fixed;inset:0;background:#0f172a6b;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:400}.pwa-install-sheet{position:fixed;bottom:0;left:0;right:0;max-width:44rem;margin:0 auto;z-index:401;background:radial-gradient(circle at top left,rgba(59,130,246,.14),transparent 35%),radial-gradient(circle at top right,rgba(16,185,129,.12),transparent 30%),var(--bg-primary, #0f172a);border-top:1px solid rgba(148,163,184,.2);border-radius:24px 24px 0 0;padding:0 24px calc(env(safe-area-inset-bottom,0px) + 28px);box-shadow:0 -18px 48px #0f172a59}body.pwa-install-open{overflow:hidden}.pwa-install-handle-wrap{display:flex;justify-content:center;padding-top:12px;padding-bottom:10px}.pwa-install-handle{width:42px;height:4px;border-radius:999px;background:#94a3b866}.pwa-install-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin:4px 0 20px}.pwa-install-brand{display:flex;align-items:center;gap:14px}.pwa-install-logo{width:52px;height:52px;border-radius:14px;flex-shrink:0;box-shadow:0 8px 20px #6366f138}.pwa-install-title{margin:0;font-weight:700;font-size:1rem;color:var(--text-primary, #e2e8f0)}.pwa-install-subtitle{margin:4px 0 0;font-size:.86rem;color:var(--text-secondary, #94a3b8);line-height:1.45;max-width:34rem}.pwa-install-close{background:#ffffff0f;border:1px solid rgba(148,163,184,.16);border-radius:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary, #94a3b8);flex-shrink:0}.pwa-install-steps{display:flex;flex-direction:column;gap:14px}.pwa-install-step{display:flex;align-items:center;gap:14px}.pwa-install-step-icon{width:40px;height:40px;border-radius:12px;background:#3b82f61f;border:1px solid rgba(59,130,246,.22);display:flex;align-items:center;justify-content:center;color:#60a5fa;flex-shrink:0}.pwa-install-step-label{margin:0;font-size:.69rem;color:var(--text-tertiary, #64748b);font-weight:700;text-transform:uppercase;letter-spacing:.08em}.pwa-install-step-text{margin:2px 0 0;font-size:.92rem;color:var(--text-primary, #e2e8f0);line-height:1.45}.pwa-install-soft-note{opacity:.6}.pwa-install-benefits{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.pwa-install-benefit{display:inline-flex;align-items:center;gap:.55rem;padding:.65rem .85rem;border-radius:999px;background:#ffffff0f;border:1px solid rgba(148,163,184,.15);color:var(--text-primary, #e2e8f0);font-size:.84rem;font-weight:600}.pwa-install-benefit-icon{color:#60a5fa;display:inline-flex}.pwa-install-actions{display:flex;gap:.75rem}.pwa-install-primary,.pwa-install-secondary{min-height:44px;border-radius:14px;font-weight:700;font-size:.92rem;cursor:pointer;border:none;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.pwa-install-primary{flex:1;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;box-shadow:0 14px 28px #3b82f63d}.pwa-install-secondary{padding:0 1rem;background:#ffffff0f;color:var(--text-primary, #e2e8f0);border:1px solid rgba(148,163,184,.15)}.pwa-install-primary:hover,.pwa-install-secondary:hover{transform:translateY(-1px)}.pwa-install-footnote{margin-top:14px;color:var(--text-tertiary, #64748b);font-size:.78rem;line-height:1.45}@media(max-width:640px){.pwa-install-sheet{padding-left:18px;padding-right:18px;max-width:none}.pwa-install-brand{align-items:flex-start}.pwa-install-actions{flex-direction:column}.pwa-install-primary,.pwa-install-secondary{width:100%}}.offline-indicator{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 16px);left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:10px;background:radial-gradient(circle at top left,rgba(245,158,11,.22),transparent 34%),#0f172aeb;color:#f9fafb;font-size:.875rem;font-weight:600;line-height:1.4;white-space:nowrap;padding:12px 18px;border-radius:18px;border:1px solid rgba(251,191,36,.18);box-shadow:0 14px 34px #0f172a3d,0 6px 12px -6px #00000052;animation:offline-slide-up .25s cubic-bezier(.34,1.56,.64,1) both}.offline-indicator--syncing{background:radial-gradient(circle at top left,rgba(59,130,246,.22),transparent 34%),#0f172aeb;border-color:#60a5fa33}.offline-indicator--recovered{background:radial-gradient(circle at top left,rgba(16,185,129,.2),transparent 34%),#0f172aeb;border-color:#34d39933}.offline-indicator--conflict{background:radial-gradient(circle at top left,rgba(249,115,22,.22),transparent 34%),#0f172aeb;border-color:#fb923c3d}@keyframes offline-slide-up{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-indicator__icon{flex-shrink:0;width:16px;height:16px;color:#fbbf24}.offline-indicator--syncing .offline-indicator__icon{color:#60a5fa}.offline-indicator--recovered .offline-indicator__icon{color:#34d399}.offline-indicator--conflict .offline-indicator__icon{color:#fb923c}.offline-indicator__message{flex:1}.offline-indicator__badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:9999px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.75rem;font-weight:700;line-height:1;flex-shrink:0}.offline-indicator__action{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 12px;border-radius:999px;border:1px solid rgb(255 255 255 / .16);background:#ffffff14;color:inherit;font-size:.75rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .15s ease,transform .15s ease}.offline-indicator__action:hover{background:#ffffff24;transform:translateY(-1px)}.offline-indicator__action:focus-visible{outline:2px solid rgb(255 255 255 / .45);outline-offset:2px}@media(max-width:640px){.offline-indicator{left:.75rem;right:.75rem;transform:none;justify-content:center;white-space:normal;text-align:center;flex-wrap:wrap}.offline-indicator__message{flex:initial}}@media(prefers-reduced-motion:reduce){.offline-indicator{animation:none}}.splash-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);z-index:99999;animation:splashFadeIn .3s ease-out}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}.splash-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.splash-logo-container{display:flex;align-items:center;gap:1rem;animation:splashLogoEnter .6s cubic-bezier(.16,1,.3,1) .2s both}@keyframes splashLogoEnter{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.splash-logo{width:64px;height:64px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(99,102,241,.4))}.splash-name{font-size:2.5rem;font-weight:700;color:#a78bfa;letter-spacing:-.02em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;text-shadow:0 2px 12px rgba(167,139,250,.3)}.splash-loader{width:180px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;animation:splashLoaderEnter .4s ease-out .5s both}@keyframes splashLoaderEnter{0%{opacity:0;width:0}to{opacity:1;width:180px}}.splash-loader-bar{width:40%;height:100%;background:linear-gradient(90deg,#6366f1,#a78bfa,#6366f1);background-size:200% 100%;border-radius:2px;animation:splashLoaderMove 1.2s ease-in-out infinite}@keyframes splashLoaderMove{0%{transform:translate(-100%)}50%{transform:translate(150%)}to{transform:translate(-100%)}}.splash-footer{position:absolute;bottom:calc(env(safe-area-inset-bottom,20px) + 2rem);animation:splashFooterEnter .4s ease-out .8s both}@keyframes splashFooterEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.splash-credit{font-size:.8125rem;color:#fff6;font-weight:500;letter-spacing:.05em}.splash-screen.hiding{animation:splashFadeOut .4s ease-out forwards}@keyframes splashFadeOut{0%{opacity:1}to{opacity:0;visibility:hidden}}@media(max-width:480px){.splash-logo{width:56px;height:56px}.splash-name{font-size:2rem}.splash-loader{width:140px}.splash-credit{font-size:.75rem}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;overscroll-behavior:none;background-color:var(--bg-secondary);overflow-x:hidden;width:100%;max-width:100vw}body{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;background-color:var(--bg-secondary);overflow-x:hidden;overscroll-behavior-y:none;width:100%;max-width:100vw}#root{width:100%;max-width:100vw;overflow-x:hidden}img,video,iframe,embed,object{max-width:100%;height:auto}p,h1,h2,h3,h4,h5,h6,span,a,li,td,th{word-wrap:break-word;overflow-wrap:break-word}[data-theme=dark] html,[data-theme=dark] body,.dark-mode html,.dark-mode body{background-color:#0f172a}html:before,html:after{content:"";position:fixed;left:0;right:0;height:env(safe-area-inset-top,0);background-color:inherit;z-index:-1}html:after{top:auto;bottom:0;height:env(safe-area-inset-bottom,0)}@supports (-webkit-touch-callout: none){input,select,textarea{font-size:16px!important}input[type=date],input[type=time],input[type=datetime-local]{-webkit-appearance:none;appearance:none;min-height:44px;padding:12px 16px}*{color-scheme:light dark}}:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-dark: #4f46e5;--primary-light: #818cf8;--primary-50: #eef2ff;--primary-100: #e0e7ff;--primary-200: #c7d2fe;--primary-900: #312e81;--primary-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--primary-gradient-hover: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #9333ea 100%);--secondary: #8b5cf6;--secondary-dark: #7c3aed;--secondary-light: #a78bfa;--accent-cyan: #06b6d4;--accent-pink: #ec4899;--accent-orange: #f97316;--accent-emerald: #10b981;--accent-amber: #f59e0b;--accent-rose: #f43f5e;--success: #10b981;--success-light: #34d399;--success-gradient: linear-gradient(135deg, #10b981 0%, #34d399 100%);--danger: #ef4444;--danger-light: #f87171;--danger-gradient: linear-gradient(135deg, #ef4444 0%, #f87171 100%);--warning: #f59e0b;--warning-light: #fbbf24;--warning-gradient: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);--info: #3b82f6;--info-light: #60a5fa;--info-gradient: linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%);--color-primary: var(--primary);--color-secondary: var(--secondary);--color-success: var(--success);--color-error: var(--danger);--color-warning: var(--warning);--color-info: var(--info);--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-dark: #0f172a;--bg-elevated: #ffffff;--bg-glass: rgba(255, 255, 255, .8);--bg-hover: rgba(99, 102, 241, .06);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-light: #f1f5f9;--border-focus: var(--primary);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .04);--shadow-primary: 0 4px 14px rgba(99, 102, 241, .25);--shadow-primary-lg: 0 10px 30px rgba(99, 102, 241, .3);--radius-xs: .25rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--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;--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--font-xs: .75rem;--font-sm: .8125rem;--font-base: .875rem;--font-md: .9375rem;--font-lg: 1rem;--font-xl: 1.125rem;--font-2xl: 1.25rem;--font-3xl: 1.5rem;--font-4xl: 1.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625}.dark-mode{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-dark: #020617;--bg-elevated: #1e293b;--bg-glass: rgba(30, 41, 59, .8);--bg-hover: rgba(99, 102, 241, .12);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--border-color: #334155;--border-light: #1e293b;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 10px 10px -5px rgba(0, 0, 0, .5);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .7);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .3);--shadow-primary: 0 4px 14px rgba(99, 102, 241, .4);--shadow-primary-lg: 0 8px 25px rgba(99, 102, 241, .5)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:var(--leading-normal);font-size:var(--font-base);font-weight:var(--font-normal);letter-spacing:-.01em}code{font-family:JetBrains Mono,Fira Code,Menlo,Monaco,monospace;font-size:var(--font-sm)}#root{min-height:100vh}h1,.text-4xl{font-size:var(--font-4xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);letter-spacing:-.025em}h2,.text-3xl{font-size:var(--font-3xl);font-weight:var(--font-bold);line-height:var(--leading-tight);letter-spacing:-.02em}h3,.text-2xl{font-size:var(--font-2xl);font-weight:var(--font-bold);line-height:var(--leading-snug);letter-spacing:-.015em}h4,.text-xl{font-size:var(--font-xl);font-weight:var(--font-semibold);line-height:var(--leading-snug)}h5,.text-lg{font-size:var(--font-lg);font-weight:var(--font-semibold);line-height:var(--leading-normal)}h6,.text-md{font-size:var(--font-md);font-weight:var(--font-medium);line-height:var(--leading-normal)}.text-base{font-size:var(--font-base)}.text-sm{font-size:var(--font-sm)}.text-xs{font-size:var(--font-xs)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}p{font-size:var(--font-base);line-height:var(--leading-relaxed);color:var(--text-secondary)}small,.small{font-size:var(--font-xs);color:var(--text-tertiary)}label{font-size:var(--font-sm);font-weight:var(--font-medium);color:var(--text-secondary)}@media(max-width:768px){:root{--font-4xl: 1.5rem;--font-3xl: 1.25rem;--font-2xl: 1.125rem;--font-xl: 1rem;--font-lg: .9375rem;--font-md: .875rem;--font-base: .875rem;--font-sm: .8125rem;--font-xs: .75rem}}@media(max-width:480px){:root{--font-4xl: 1.375rem;--font-3xl: 1.125rem;--font-2xl: 1rem;--font-xl: .9375rem;--font-lg: .875rem;--font-md: .875rem;--font-base: .8125rem;--font-sm: .75rem;--font-xs: .6875rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes glow{0%,to{box-shadow:0 0 20px #6366f14d}50%{box-shadow:0 0 40px #6366f180}}.animate-slide-in-right{animation:slideInRight .4s ease-out}.animate-slide-in-left{animation:slideInLeft .4s ease-out}.animate-bounce{animation:bounce 2s infinite}.animate-pulse{animation:pulse 2s infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full);transition:background var(--transition-base)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}a,button{transition:all var(--transition-base)}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:transparent;-webkit-appearance:none;appearance:none;transition:all var(--transition-base)}button:disabled{cursor:not-allowed;opacity:.5}input,textarea,select{font-family:inherit;outline:none;transition:all var(--transition-base)}a{color:inherit;text-decoration:none;transition:all var(--transition-base)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.625rem 1.25rem;border-radius:var(--radius-lg);font-weight:600;font-size:.9375rem;line-height:1;transition:all var(--transition-base);cursor:pointer;border:none;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-primary-lg)}.btn-primary:active{transform:translateY(0) scale(.97);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--text-tertiary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,#dc2626 100%);color:#fff;box-shadow:0 4px 14px #ef444440}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ef444459}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}.btn-sm{padding:.5rem .875rem;font-size:.8125rem;border-radius:var(--radius-md)}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-lg)}.btn-icon.sm{width:32px;height:32px;border-radius:var(--radius-md)}.btn:active:not(:disabled){transform:scale(.97);transition:transform 80ms ease}.btn-primary:active:not(:disabled){transform:translateY(0) scale(.97)}.btn-danger:active:not(:disabled){transform:translateY(0) scale(.97)}.card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-elevated{box-shadow:var(--shadow-lg);border:none}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.card-glass{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2)}.input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:.9375rem;color:var(--text-primary);transition:all var(--transition-base)}.input:hover{border-color:var(--text-tertiary)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-100);background:var(--bg-primary)}.input::placeholder{color:var(--text-tertiary)}.input-error{border-color:var(--danger)}.input-error:focus{box-shadow:0 0 0 4px #ef44441a}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-badge,.status-pending,.status-todo{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-in_progress{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.status-completed{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.status-active{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.priority-low{background:var(--bg-tertiary);color:var(--text-secondary)}.priority-medium{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.priority-high{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#c2410c}.priority-urgent{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.dark-mode .status-pending,.dark-mode .status-todo{background:#fef3c726;color:#fbbf24}.dark-mode .status-in_progress{background:#dbeafe26;color:#60a5fa}.dark-mode .status-completed{background:#d1fae526;color:#34d399}.dark-mode .status-cancelled{background:#fee2e226;color:#f87171}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner-lg{width:32px;height:32px;border-width:3px}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);color:var(--text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12);color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state p{color:var(--text-tertiary);margin-bottom:var(--space-6)}.container{max-width:1280px;margin:0 auto;padding:0 1rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-accent{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-6) 0;letter-spacing:-.02em}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-4)}.section-subtitle{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--space-3)}.rbc-calendar{font-family:inherit;background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-sm)}.rbc-toolbar{margin-bottom:var(--space-4)}.rbc-toolbar button{color:var(--text-primary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-base)}.rbc-toolbar button:hover{background-color:var(--bg-tertiary)}.rbc-toolbar button.rbc-active{background:var(--primary);color:#fff;border-color:var(--primary)}.rbc-event{background-color:var(--primary);border-radius:var(--radius-sm);padding:.25rem .5rem;border:none!important;font-size:.8125rem}.rbc-today{background-color:var(--primary-50)}.rbc-header{font-weight:600;color:var(--text-secondary);padding:var(--space-3)}.react-calendar{width:100%;border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-4);background:var(--bg-primary);font-family:inherit}.react-calendar__tile--active{background:var(--primary)!important;color:#fff!important;border-radius:var(--radius-md)}.react-calendar__tile--now{background:var(--primary-light);color:#fff;border-radius:var(--radius-md)}.Toastify__toast-container{padding:0!important;width:auto!important;max-width:calc(100vw - 2rem)!important}.Toastify__toast-container--top-center{top:max(60px,calc(env(safe-area-inset-top,0px) + 16px))!important;left:50%!important;transform:translate(-50%)!important;width:calc(100% - 2rem)!important;max-width:400px!important}.Toastify__toast{min-height:48px!important;padding:.875rem 1rem!important;border-radius:var(--radius-xl)!important;font-size:.9375rem!important;font-weight:500!important;box-shadow:var(--shadow-xl)!important;backdrop-filter:blur(12px)}.Toastify__toast-body{padding:0!important;margin:0!important}.Toastify__toast--success{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important}.Toastify__toast--error{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important}.Toastify__toast--info{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;color:#fff!important}.Toastify__toast--warning{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important}.Toastify__close-button{color:#fff!important;opacity:.8!important}.Toastify__progress-bar{height:3px!important;background:#fff6!important}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.template-option{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-base);text-align:center}.template-option:hover{border-color:var(--primary);background:var(--primary-50);transform:translateY(-2px)}.template-option.selected{border-color:var(--primary);background:var(--primary-100);box-shadow:var(--shadow-primary)}.template-name{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.template-columns{font-size:.75rem;color:var(--text-secondary);margin-top:var(--space-1)}.hide-on-mobile{display:block}.hide-on-desktop{display:none}@media(max-width:768px){.hide-on-mobile{display:none!important}.hide-on-desktop{display:block!important}.container{padding:0 var(--space-3)}.page-title{font-size:1.5rem;margin-bottom:var(--space-4)}.page-header{flex-direction:column;align-items:stretch;gap:var(--space-3)}.grid-responsive{grid-template-columns:1fr!important}.btn-group-responsive{flex-direction:column;width:100%}.btn-group-responsive button{width:100%;justify-content:center}.Toastify__toast-container--top-center{top:max(60px,calc(env(safe-area-inset-top,0px) + 12px))!important;width:calc(100% - 1.5rem)!important;max-width:none!important}.Toastify__toast{min-height:44px!important;padding:.625rem .875rem!important;border-radius:var(--radius-lg)!important;font-size:.875rem!important}}@media(min-width:769px)and (max-width:1024px){.container{padding:0 var(--space-6)}.grid-responsive-tablet{grid-template-columns:repeat(2,1fr)!important}}@media(min-width:1280px){.container{max-width:1440px}}@media(hover:none)and (pointer:coarse){button,.btn{min-height:44px;min-width:44px}.hover-lift:hover{transform:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(prefers-contrast:high){:root{--border-color: #000}.btn{border:2px solid currentColor}.card{border:2px solid var(--text-primary)}}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:var(--space-4) var(--space-8);border-radius:var(--radius-lg);z-index:9999;transition:top var(--transition-base)}.skip-link:focus{top:var(--space-4)}@supports (padding: env(safe-area-inset-bottom)){.fixed-bottom{padding-bottom:env(safe-area-inset-bottom)}}::selection{background:var(--primary);color:#fff}::placeholder{color:var(--text-tertiary);opacity:1}.smooth-scroll{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}@media print{.sidebar,.header,.notification-center,.btn,button{display:none!important}.main-content{margin-left:0!important;width:100%!important}body{background:#fff;color:#000}.card{box-shadow:none;border:1px solid #ccc}}.app-loading-fallback{display:flex;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}.loading-logo{width:48px;height:48px;animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;transition:background .15s ease,color .15s ease;border-radius:8px;color:var(--text-secondary);padding:0}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn-sm{width:28px;height:28px}.icon-btn-md{width:36px;height:36px}.icon-btn-lg{width:44px;height:44px}.icon-btn-default{color:var(--text-secondary)}.icon-btn-default:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.icon-btn-primary{color:var(--primary)}.icon-btn-primary:hover:not(:disabled){background:#6366f11a}.icon-btn-danger{color:var(--danger)}.icon-btn-danger:hover:not(:disabled){background:#ef44441a}.icon-btn-ghost{color:var(--text-tertiary)}.icon-btn-ghost:hover:not(:disabled){color:var(--text-primary)}.icon-btn.danger{color:var(--danger)}.icon-btn.danger:hover:not(:disabled){background:#ef44441f}@media(max-width:768px){html{height:-webkit-fill-available}html,body{width:100%;max-width:100%;overflow-x:hidden}body{min-height:-webkit-fill-available}#root{width:100%;max-width:100%;min-height:100dvh;min-height:-webkit-fill-available}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideInDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes bounce{0%,20%,53%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateY(0)}40%,43%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translateY(-15px)}70%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translateY(-7px)}80%{transform:translateY(0)}90%{transform:translateY(-3px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ripple{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--primary),0 0 10px var(--primary)}50%{box-shadow:0 0 20px var(--primary),0 0 30px var(--primary)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-fade-in-up{animation:fadeInUp .4s ease-out}.animate-fade-in-down{animation:fadeInDown .4s ease-out}.animate-fade-in-left{animation:fadeInLeft .4s ease-out}.animate-fade-in-right{animation:fadeInRight .4s ease-out}.animate-scale-in{animation:scaleIn .3s ease-out}.animate-bounce{animation:bounce 1s ease}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-float{animation:float 3s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-text:last-child{width:80%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-card{height:150px;border-radius:var(--radius-lg)}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s,transform .3s}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .2s}.hover-lift{transition:transform .2s ease,box-shadow .2s ease}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform .2s ease}.hover-scale:hover{transform:scale(1.02)}.hover-glow:hover{box-shadow:0 0 20px #6366f14d}.ripple-effect{position:relative;overflow:hidden}.ripple-effect:after{content:"";position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;background-image:radial-gradient(circle,#fff 10%,transparent 10.01%);background-repeat:no-repeat;background-position:50%;transform:scale(10);opacity:0;transition:transform .5s,opacity 1s}.ripple-effect:active:after{transform:scale(0);opacity:.3;transition:0s}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-dots{display:flex;gap:4px}.loading-dots span{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0s}.progress-animated .progress-fill{animation:progressGrow 1s ease-out forwards}@keyframes progressGrow{0%{width:0}}.success-checkmark{width:56px;height:56px;border-radius:50%;display:block;stroke-width:2;stroke:var(--success);stroke-miterlimit:10;animation:scaleIn .3s ease-in-out}.success-checkmark__circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:var(--success);fill:none;animation:stroke .6s cubic-bezier(.65,0,.45,1) forwards}.success-checkmark__check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;animation:stroke .3s cubic-bezier(.65,0,.45,1) .8s forwards}@keyframes stroke{to{stroke-dashoffset:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
