*{box-sizing:border-box;margin:0;padding:0}body,html{overflow-x:hidden}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#a5b4fc;--secondary:#f1f5f9;--accent:#10b981;--warning:#f59e0b;--danger:#ef4444;--success:#22c55e;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--color-background:var(--gray-50);--color-surface:#fff;--color-surface-muted:var(--gray-100);--color-surface-subtle:var(--gray-50);--color-surface-hover:#0f172a0f;--color-surface-pressed:#0f172a1a;--color-border:var(--gray-200);--color-border-strong:var(--gray-300);--color-text-primary:var(--gray-900);--color-text-secondary:var(--gray-600);--color-text-muted:var(--gray-500);--color-header-background:#fff;--color-sidebar-background:#fff;--color-popover-background:#fff;--color-popover-border:#0f172a14;--color-popover-shadow:0 18px 40px -24px #0f172a66;--color-accent-soft:#6366f11f}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;background:#f8fafc;background:var(--color-background);color:#0f172a;color:var(--color-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;touch-action:manipulation}:root[data-theme=dark]{--primary:#818cf8;--primary-dark:#6366f1;--primary-light:#a5b4fc;--secondary:#15213b;--accent:#38d9a9;--warning:#fbbf24;--danger:#f87171;--success:#34d399;--gray-50:#050a18;--gray-100:#0b1529;--gray-200:#13203b;--gray-300:#1e2f4f;--gray-400:#2b3e65;--gray-500:#94a3b8;--gray-600:#cbd5f5;--gray-700:#e2e8f0;--gray-800:#f1f5f9;--gray-900:#f8fafc;--color-background:#050a18;--color-surface:#101d33;--color-surface-muted:#15263f;--color-surface-subtle:#071124;--color-surface-hover:#94a3b829;--color-surface-pressed:#94a3b847;--color-border:#94a3b82e;--color-border-strong:#94a3b859;--color-text-primary:#f8fafc;--color-text-secondary:#cbd5f5;--color-text-muted:#9ba8c5;--color-header-background:#0b1529;--color-sidebar-background:#070f1f;--color-popover-background:#101d33;--color-popover-border:#56648d99;--color-popover-shadow:0 28px 45px -25px #000000a6;--color-accent-soft:#818cf859;--shadow-sm:0 1px 2px 0 #0206178c;--shadow-md:0 10px 20px -12px #020617b3,0 6px 12px -8px #0206178c;--shadow-lg:0 24px 35px -20px #020617bf,0 14px 28px -18px #02061799;--shadow-xl:0 32px 55px -28px #020617d9,0 24px 45px -26px #020617b3}.app-layout{display:flex;min-height:100vh;overflow-x:hidden}.sidebar{background:#fff;background:var(--color-sidebar-background);border-right:1px solid #e2e8f0;border-right:1px solid var(--color-border);display:flex;flex-direction:column;height:100vh;position:fixed;transition:transform .3s ease;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);height:80px;padding:0 2rem;padding:0 var(--spacing-xl)}.logo,.sidebar-header{align-items:center;display:flex}.logo{color:#0f172a;color:var(--color-text-primary);font-size:1.25rem;font-weight:700;gap:1rem;gap:var(--spacing-md)}.logo-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-radius:.5rem;border-radius:var(--radius-md);color:#fff;display:flex;font-size:1.2rem;height:32px;justify-content:center;width:32px}.sidebar-nav{flex:1 1;padding:1.5rem;padding:var(--spacing-lg)}.nav-section{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.nav-section-title{color:#64748b;color:var(--color-text-muted);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;margin-bottom:var(--spacing-md);text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#475569;color:var(--color-text-secondary);cursor:pointer;display:flex;font-weight:500;gap:1rem;gap:var(--spacing-md);justify-content:flex-start;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.nav-item:hover{background:#0f172a0f;background:var(--color-surface-hover);color:#0f172a;color:var(--color-text-primary)}.nav-item.active{background:#6366f1;background:var(--primary);color:#fff}.nav-item-icon{flex-shrink:0;height:20px;width:20px}.sidebar-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);padding:1.5rem;padding:var(--spacing-lg)}.user-profile{background:#f8fafc;background:var(--color-surface-subtle);border-radius:.5rem;border-radius:var(--radius-md);gap:1rem;gap:var(--spacing-md);padding:1rem;padding:var(--spacing-md)}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#6366f1,#4f46e5);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-radius:50%;color:#fff;font-weight:600;height:40px;justify-content:center;width:40px}.user-info{flex:1 1}.user-name{color:#0f172a;color:var(--color-text-primary);font-size:.875rem;font-weight:600}.user-role{color:#64748b;color:var(--color-text-muted);font-size:.75rem}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:280px;min-width:0;overflow-x:hidden}.main-header{align-items:center;background:#fff;background:var(--color-header-background);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);display:flex;height:80px;justify-content:space-between;padding:0 2rem;padding:0 var(--spacing-xl);position:-webkit-sticky;position:sticky;top:0;z-index:50}.page-title{color:#0f172a;color:var(--color-text-primary);font-size:1.5rem;font-weight:700}.page-subtitle{color:#64748b;color:var(--color-text-muted);font-size:.875rem;margin-top:.25rem;margin-top:var(--spacing-xs)}.header-actions{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md)}.mobile-time-display .time-short{display:none}.mobile-time-display .time-text{display:inline}.theme-switcher{position:relative}.theme-button{align-items:center;background:#f1f5f9;background:var(--color-surface-muted);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);color:#0f172a;color:var(--color-text-primary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;gap:var(--spacing-xs);padding:.25rem 1rem;padding:var(--spacing-xs) var(--spacing-md);transition:all .2s ease}.theme-button:hover{background:#0f172a0f;background:var(--color-surface-hover)}.theme-button svg{height:16px;width:16px}.theme-dropdown{background:#fff;background:var(--color-popover-background);border:1px solid #0f172a14;border:1px solid var(--color-popover-border);box-shadow:0 18px 40px -24px #0f172a66;box-shadow:var(--color-popover-shadow);flex-direction:column;gap:.25rem;gap:var(--spacing-xs);min-width:200px;padding:.25rem;padding:var(--spacing-xs);position:absolute;right:0;top:calc(100% + .25rem);top:calc(100% + var(--spacing-xs));z-index:2000}.theme-dropdown,.theme-dropdown-item{border-radius:.5rem;border-radius:var(--radius-md);display:flex}.theme-dropdown-item{align-items:center;background:#0000;border:none;color:#0f172a;color:var(--color-text-primary);cursor:pointer;gap:.5rem;gap:var(--spacing-sm);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:background .2s ease,color .2s ease;width:100%}.theme-dropdown-item svg{height:16px;width:16px}.theme-dropdown-item:hover{background:#0f172a0f;background:var(--color-surface-hover)}.theme-dropdown-item.active{background:#6366f11f;background:var(--color-accent-soft)}.theme-dropdown-label{flex:1 1}.theme-dropdown-hint{color:#64748b;color:var(--color-text-muted);font-size:.75rem;margin-left:auto}.mobile-menu-button{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#475569;color:var(--color-text-secondary);cursor:pointer;display:none;justify-content:center;min-height:44px;min-width:44px;padding:.5rem;padding:var(--spacing-sm);transition:all .2s ease}.mobile-menu-button:hover{background:#0f172a0f;background:var(--color-surface-hover);color:#0f172a;color:var(--color-text-primary)}.mobile-menu-button:active{background:#0f172a1a;background:var(--color-surface-pressed)}@media (max-width:1024px){.mobile-menu-button{display:flex}}.main-body{box-sizing:border-box;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem;padding:var(--spacing-xl);width:100%}.card{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transition:all .2s ease}.card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.card-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);padding:1.5rem 2rem;padding:var(--spacing-lg) var(--spacing-xl)}.card-title{align-items:center;color:#0f172a;color:var(--color-text-primary);display:flex;font-size:1.125rem;font-weight:600;gap:1rem;gap:var(--spacing-md)}.card-description{color:#64748b;color:var(--color-text-muted);font-size:.875rem;margin-top:.25rem;margin-top:var(--spacing-xs)}.card-content{padding:2rem;padding:var(--spacing-xl)}.card-footer{background:#f8fafc;background:var(--color-surface-subtle);border-radius:0 0 .75rem .75rem;border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);padding:1.5rem 2rem;padding:var(--spacing-lg) var(--spacing-xl)}.stats-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);box-sizing:border-box;display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem;margin-bottom:var(--spacing-xl);width:100%}.stat-card{background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:2rem;padding:var(--spacing-xl);transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.stat-title{color:#475569;color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.stat-icon{color:#94a3b8;color:var(--gray-400);height:24px;width:24px}.stat-value{color:#0f172a;color:var(--color-text-primary);font-size:2rem;font-weight:700;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.stat-change{align-items:center;display:flex;font-size:.875rem;gap:.25rem;gap:var(--spacing-xs)}.stat-change.positive{color:#22c55e;color:var(--success)}.stat-change.negative{color:#ef4444;color:var(--danger)}.stat-change.neutral{color:#64748b;color:var(--color-text-muted)}.btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);text-decoration:none;transition:all .2s ease;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary:hover:not(:disabled){background:#4f46e5;background:var(--primary-dark)}.btn-secondary:hover:not(:disabled){background:#0f172a1a;background:var(--color-surface-pressed)}.btn-outline{background:#0000;border:1px solid #cbd5e1;border:1px solid var(--color-border-strong);color:#334155;color:var(--gray-700)}.btn-outline:hover:not(:disabled){background:#f8fafc;background:var(--color-surface-subtle);border-color:#cbd5e1;border-color:var(--color-border-strong)}.btn-danger{background:#ef4444;background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{font-size:.75rem;padding:.25rem 1rem;padding:var(--spacing-xs) var(--spacing-md)}.btn-lg{font-size:1rem;padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl)}.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem;padding:var(--spacing-2xl);text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-top:3px solid #6366f1;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);height:32px;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);width:32px}.loading-text{color:#475569;color:var(--color-text-secondary);font-weight:500}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem;padding:var(--spacing-2xl);text-align:center}.empty-icon{color:#cbd5e1;color:var(--gray-300);height:64px;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);width:64px}.empty-title{color:#0f172a;color:var(--color-text-primary);font-size:1.125rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.empty-description{color:#64748b;color:var(--color-text-muted);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{animation:slideUp .2s ease;background:#fff;background:var(--color-surface);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{gap:1rem;gap:var(--spacing-md)}.modal-title{font-size:1.25rem}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--color-border);display:flex;gap:1rem;gap:var(--spacing-md);justify-content:flex-end;padding:2rem;padding:var(--spacing-xl)}.form-group{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.form-label{color:#334155;color:var(--gray-700);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.form-input{border:1px solid #cbd5e1;border:1px solid var(--color-border-strong);border-radius:.5rem;border-radius:var(--radius-md);font-size:.875rem;padding:1rem;padding:var(--spacing-md);transition:all .2s ease;width:100%}.form-input:focus{border-color:#6366f1;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.form-input.error{border-color:#ef4444;border-color:var(--danger)}.form-error{color:#ef4444;color:var(--danger);font-size:.75rem;margin-top:.25rem;margin-top:var(--spacing-xs)}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0;width:100%}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.main-header{align-items:flex-start;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);height:auto;min-height:64px;padding:1rem;padding:var(--spacing-md)}.main-header>div:first-child{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md);width:100%}.header-actions{flex-wrap:wrap;justify-content:flex-end;width:100%}.header-actions .flex{font-size:.75rem;gap:.25rem;gap:var(--spacing-xs)}.mobile-time-display .time-text{display:none}.mobile-time-display .time-short{display:inline}.main-body{box-sizing:border-box;padding:1rem;padding:var(--spacing-md)}.stats-grid{gap:1rem;gap:var(--spacing-md);grid-template-columns:1fr;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.card{box-sizing:border-box;margin:0;width:100%}.card-content,.card-header{padding:1rem;padding:var(--spacing-md)}.stat-card{box-sizing:border-box;padding:1.5rem;padding:var(--spacing-lg);width:100%}.page-title{font-size:1.25rem}.page-subtitle{font-size:.8rem}.nav-item{font-size:1rem;justify-content:flex-start;min-height:48px;padding:1.5rem;padding:var(--spacing-lg)}.btn,.button,button{font-size:1rem;min-height:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}.card{margin-bottom:1rem;margin-bottom:var(--spacing-md)}.card-title{font-size:1rem}.card-description{line-height:1.5}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem;line-height:1.5}.text-xs{font-size:.75rem;line-height:1.4}.text-lg{font-size:1.125rem;line-height:1.6}.text-xl{font-size:1.25rem;line-height:1.6}.text-gray-500{color:#64748b;color:var(--color-text-muted)}.text-gray-600{color:#475569;color:var(--gray-600)}.text-gray-700{color:#334155;color:var(--gray-700)}.text-gray-900{color:#0f172a;color:var(--color-text-primary)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.mb-4{margin-bottom:1rem;margin-bottom:var(--spacing-md)}.mb-6{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.mb-8{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.mt-2{margin-top:.5rem;margin-top:var(--spacing-sm)}.mt-4{margin-top:1rem;margin-top:var(--spacing-md)}.mt-6{margin-top:1.5rem;margin-top:var(--spacing-lg)}.mt-8{margin-top:2rem;margin-top:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:.5rem;gap:var(--spacing-sm)}.gap-4{gap:1rem;gap:var(--spacing-md)}.gap-6{gap:1.5rem;gap:var(--spacing-lg)}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:.5rem;border-radius:var(--radius-md)}.rounded-lg{border-radius:.75rem;border-radius:var(--radius-lg)}.shadow{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg)}.btn,.button,button{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:inherit;font-weight:500;gap:.5rem;gap:var(--spacing-sm);justify-content:center;min-height:40px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);touch-action:manipulation;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn-primary{background:#6366f1;background:var(--primary);color:#fff}.btn-primary:hover{background:#4f46e5;background:var(--primary-dark)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{background:#f1f5f9;background:var(--color-surface-muted);color:#0f172a;color:var(--color-text-primary)}.btn-secondary:hover{background:#0f172a1a;background:var(--color-surface-pressed)}.btn-secondary:active{transform:translateY(1px)}input,select,textarea{background:#fff;background:var(--color-surface);border:1px solid #cbd5e1;border:1px solid var(--color-border-strong);border-radius:.5rem;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;line-height:1.5;min-height:44px;padding:1rem;padding:var(--spacing-md);touch-action:manipulation;transition:all .2s ease}input:focus,select:focus,textarea:focus{border-color:#6366f1;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.md\:hidden{display:none}@media (max-width:768px){.md\:hidden{display:block}}.hourly-chart{align-items:end;box-sizing:border-box;display:flex;gap:.5rem;gap:var(--spacing-sm);height:250px;overflow-x:auto;overflow-y:hidden;padding:1rem;padding:var(--spacing-md);width:100%}.hourly-bar{align-items:center;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);height:100%;justify-content:flex-end;min-width:32px;transition:all .2s ease}.hourly-bar:hover{transform:translateY(-3px)}.hourly-fill{border-radius:.375rem;border-radius:var(--radius-sm);display:block;min-height:2px;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.hourly-bar:hover .hourly-fill{box-shadow:0 4px 12px #6366f166;filter:brightness(1.1)}.hourly-label{color:#64748b;color:var(--color-text-muted);font-size:.75rem;font-weight:500;text-align:center;transition:all .2s ease;white-space:nowrap;writing-mode:horizontal-tb}.hourly-bar:hover .hourly-label{color:#6366f1;color:var(--primary);font-size:.85rem;font-weight:700}.weekly-chart{flex-direction:column}.weekly-chart,.weekly-item{display:flex;gap:1rem;gap:var(--spacing-md)}.weekly-item{align-items:center}.weekly-day{color:#334155;color:var(--gray-700);font-size:.875rem;font-weight:500;min-width:80px}.weekly-bar{background:#0f172a1a;background:var(--color-surface-pressed);flex:1 1;height:8px;overflow:hidden}.weekly-bar,.weekly-fill{border-radius:.375rem;border-radius:var(--radius-sm)}.weekly-fill{height:100%;transition:width .3s ease}.weekly-count{color:#0f172a;color:var(--color-text-primary);font-weight:600;min-width:60px;text-align:right}.direction-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.direction-card{background:#f8fafc;background:var(--color-surface-subtle);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease}.direction-card:hover{background:#fff;background:var(--color-surface);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.direction-name{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.direction-count{color:#6366f1;color:var(--primary);font-size:1.5rem;font-weight:700;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.direction-bar{background:#0f172a1a;background:var(--color-surface-pressed);height:6px;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);overflow:hidden}.direction-bar,.direction-fill{border-radius:.375rem;border-radius:var(--radius-sm)}.direction-fill{height:100%;transition:width .3s ease}.direction-percentage{color:#475569;color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.trend-summary{padding:2rem;padding:var(--spacing-xl);text-align:center}.trend-value{color:#6366f1;color:var(--primary);font-size:3rem;font-weight:700;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.trend-description{color:#475569;color:var(--color-text-secondary);font-size:1.125rem}.heatmap-container{overflow-x:auto}.heatmap-row{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.heatmap-day-label{color:#334155;color:var(--gray-700);font-size:.875rem;font-weight:500;min-width:80px}.heatmap-hours{display:flex;gap:2px}.heatmap-cell{align-items:center;border-radius:.375rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:.625rem;font-weight:500;height:24px;justify-content:center;transition:all .2s ease;width:24px}.heatmap-cell:hover{transform:scale(1.1);z-index:10}.export-options{display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md)}.summary-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{background:#f8fafc;background:var(--color-surface-subtle);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);padding:1.5rem;padding:var(--spacing-lg)}.summary-label{color:#475569;color:var(--color-text-secondary);font-size:.875rem;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.summary-value{color:#0f172a;color:var(--color-text-primary);font-size:1.25rem;font-weight:600}.animate-spin{animation:spin 1s linear infinite}.space-y-6>*+*{margin-top:2rem;margin-top:var(--spacing-xl)}.space-y-4>*+*{margin-top:1.5rem;margin-top:var(--spacing-lg)}.space-y-2>*+*{margin-top:.5rem;margin-top:var(--spacing-sm)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.day-type-controls{display:flex;gap:.25rem;gap:var(--spacing-xs);margin-top:.5rem;margin-top:var(--spacing-sm)}.day-type-btn{background:#fff;background:var(--color-surface);border:1px solid #cbd5e1;border:1px solid var(--color-border-strong);border-radius:.375rem;border-radius:var(--radius-sm);color:#334155;color:var(--gray-700);cursor:pointer;font-size:.875rem;font-weight:500;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.day-type-btn:hover{background:#f8fafc;background:var(--color-surface-subtle);border-color:#cbd5e1;border-color:var(--color-border-strong)}.day-type-btn.active{background:#6366f1;background:var(--primary);border-color:#6366f1;border-color:var(--primary);color:#fff}.day-type-btn.active:hover{background:#4f46e5;background:var(--primary-dark)}.hourly-chart{position:relative}.chart-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fffc;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #cbd5e1;border-top:3px solid #6366f1;border:3px solid var(--gray-300);border-radius:50%;border-top-color:var(--primary);height:24px;width:24px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.hourly-chart.loading .hourly-fill{transition:all .6s cubic-bezier(.4,0,.2,1)}@media (min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:100%;z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar-header{height:64px;padding:0 1.5rem;padding:0 var(--spacing-lg)}.logo{font-size:1.125rem}.nav-item{font-size:1rem;justify-content:flex-start;min-height:48px;padding:1.5rem;padding:var(--spacing-lg)}.nav-item-icon{height:24px;width:24px}.user-profile{padding:1.5rem;padding:var(--spacing-lg)}.hourly-chart{gap:2px;height:150px;overflow-x:auto;overflow-y:hidden;padding:.5rem;padding:var(--spacing-sm);scrollbar-color:#cbd5e1 #f1f5f9;scrollbar-color:var(--gray-300) var(--gray-100);scrollbar-width:thin}.hourly-bar{flex-shrink:0;min-width:20px}.hourly-label{font-size:.55rem;line-height:1.2;text-align:center;transform:none;writing-mode:horizontal-tb}.direction-grid{grid-template-columns:1fr}.heatmap-cell{font-size:.5rem;height:18px;width:18px}.export-options{flex-direction:column;gap:1rem;gap:var(--spacing-md)}.summary-grid{grid-template-columns:1fr}.stat-card{padding:1.5rem;padding:var(--spacing-lg)}.stat-value{font-size:1.75rem}.stat-label{font-size:.875rem}.sidebar-overlay{background:#00000080;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:all .3s ease;visibility:hidden;z-index:999}.sidebar-overlay.show{opacity:1;visibility:visible}}@media (max-width:480px){.main-header{align-items:flex-start;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);min-height:56px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md)}.main-header>div:first-child{width:100%}.header-actions{justify-content:space-between;width:100%}.header-actions .flex{font-size:.7rem;gap:.25rem;gap:var(--spacing-xs)}.mobile-time-display .time-text{display:none}.mobile-time-display .time-short{display:inline}.mobile-time-display{justify-content:center}.main-body{box-sizing:border-box;padding:.5rem;padding:var(--spacing-sm)}.page-title{font-size:1.125rem}.card-content,.card-header{padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md)}.card-title{font-size:.95rem}.stat-card{box-sizing:border-box;padding:1rem;padding:var(--spacing-md);width:100%}.stat-value{font-size:1.5rem}.stat-label{font-size:.8rem}.stats-grid{gap:.5rem;gap:var(--spacing-sm);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.sidebar-header{height:56px;padding:0 1rem;padding:0 var(--spacing-md)}.logo{font-size:1rem}.nav-item{font-size:.95rem;justify-content:flex-start;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}.heatmap-cell{font-size:.4rem;height:15px;width:15px}.export-section{gap:.5rem;gap:var(--spacing-sm)}*{box-sizing:border-box;max-width:100%}.card,.stat-card{max-width:100%;min-width:0}.hourly-chart{gap:1px;height:120px;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.hourly-bar{min-width:18px}.hourly-label{font-size:.5rem;line-height:1.1}}.heatmap-container::-webkit-scrollbar,.hourly-chart::-webkit-scrollbar{height:6px}.heatmap-container::-webkit-scrollbar-track,.hourly-chart::-webkit-scrollbar-track{background:#f1f5f9;background:var(--color-surface-muted);border-radius:.375rem;border-radius:var(--radius-sm)}.heatmap-container::-webkit-scrollbar-thumb,.hourly-chart::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--gray-300);border-radius:.375rem;border-radius:var(--radius-sm)}.heatmap-container::-webkit-scrollbar-thumb:hover,.hourly-chart::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--gray-400)}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--color-surface);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:2rem;padding:var(--spacing-xl)}.modal-title{color:#0f172a;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin:0}.modal-subtitle{color:#475569;color:var(--color-text-secondary);font-size:.875rem;margin-top:.25rem;margin-top:var(--spacing-xs)}.modal-close{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#64748b;color:var(--color-text-muted);cursor:pointer;display:flex;justify-content:center;padding:.25rem;padding:var(--spacing-xs);transition:all .2s ease}.modal-close:hover{background:#0f172a0f;background:var(--color-surface-hover);color:#0f172a;color:var(--color-text-primary)}.modal-body{padding:2rem;padding:var(--spacing-xl)}.loading-spinner{align-items:center;justify-content:center;padding:3rem;padding:var(--spacing-2xl)}.half-hour-breakdown,.loading-spinner{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.half-hour-breakdown{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.half-hour-list{background:#f8fafc;background:var(--color-surface-subtle);border-radius:.5rem;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);padding:1rem;padding:var(--spacing-md)}.half-hour-item{align-items:center;background:#fff;background:var(--color-surface);border-radius:.375rem;border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.half-hour-item:hover{background:#0f172a0f;background:var(--color-surface-hover);transform:translateX(2px)}.half-hour-time{color:#0f172a;color:var(--color-text-primary);font-size:.9375rem;font-weight:600}.half-hour-count{color:#475569;color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.direction-breakdown{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}.breakdown-title{align-items:center;color:#0f172a;color:var(--color-text-primary);display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);margin:0}.direction-bars{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}.direction-bar-item{display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}.direction-bar-label{align-items:center;display:flex;justify-content:space-between}.direction-name{color:#0f172a;color:var(--color-text-primary);font-size:.9375rem;font-weight:600}.direction-stats{color:#475569;color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.direction-bar-container{background:#f1f5f9;background:var(--color-surface-muted);height:40px;overflow:hidden;position:relative}.direction-bar-container,.direction-bar-fill{border-radius:.5rem;border-radius:var(--radius-md)}.direction-bar-fill{align-items:center;color:#fff;display:flex;font-weight:600;height:100%;justify-content:center;transition:width .6s cubic-bezier(.4,0,.2,1)}.error-message{color:#475569;color:var(--color-text-secondary);padding:2rem;padding:var(--spacing-xl);text-align:center}@media (max-width:768px){.modal-content{max-height:85vh;width:95%}.modal-body,.modal-header{padding:1.5rem;padding:var(--spacing-lg)}.modal-title{font-size:1.25rem}.direction-bar-container{height:35px}}.upload-dropzone{background:#f8fafc;background:var(--color-surface-subtle);border:2px dashed #cbd5e1;border:2px dashed var(--color-border-strong);border-radius:.75rem;border-radius:var(--radius-lg);cursor:pointer;padding:3rem;padding:var(--spacing-2xl);text-align:center;transition:all .3s ease}.upload-dropzone.drag-over,.upload-dropzone:hover{background:#6366f11f;background:var(--color-accent-soft);border-color:#6366f1;border-color:var(--primary)}.dropzone-content{align-items:center;display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}.dropzone-icon{color:#94a3b8;color:var(--gray-400)}.dropzone-text{text-align:center}.file-input{display:none}.selected-files{background:#f8fafc;background:var(--color-surface-subtle);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);margin-top:1.5rem;margin-top:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.file-list{flex-direction:column}.file-item,.file-list{display:flex;gap:1rem;gap:var(--spacing-md)}.file-item{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-md)}.file-icon{color:#6366f1;color:var(--primary);flex-shrink:0}.file-name{color:#0f172a;color:var(--color-text-primary);flex:1 1;font-weight:500}.file-size{color:#64748b;color:var(--color-text-muted);font-size:.875rem}.upload-actions{display:flex;justify-content:center;margin-top:1.5rem;margin-top:var(--spacing-lg)}.result-item{align-items:flex-start;border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);display:flex;gap:1rem;gap:var(--spacing-md);padding:1.5rem;padding:var(--spacing-lg)}.result-success{background:#22c55e0d;border-color:#22c55e33}.result-error{background:#ef44440d;border-color:#ef444433}.result-content{flex:1 1}.result-message{margin-top:.25rem;margin-top:var(--spacing-xs)}.history-item{align-items:center;background:#f8fafc;background:var(--color-surface-subtle);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-md);display:flex;gap:1.5rem;gap:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease}.history-item:hover{background:#fff;background:var(--color-surface);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.history-icon{flex-shrink:0}.history-content{flex:1 1}.history-filename{color:#0f172a;color:var(--color-text-primary);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.history-details{color:#475569;color:var(--color-text-secondary)}.history-status{flex-shrink:0}.status-badge{align-items:center;border-radius:.5rem;border-radius:var(--radius-md);display:inline-flex;font-size:.75rem;font-weight:500;gap:.25rem;gap:var(--spacing-xs);padding:.25rem 1rem;padding:var(--spacing-xs) var(--spacing-md)}.status-badge.success{background:#22c55e1a;color:#15803d}.filter-info ul{list-style:none;padding:0}.filter-info code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem}.database-stats{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.database-info{margin-top:1.5rem;margin-top:var(--spacing-lg)}.danger-zone{margin-top:2rem;margin-top:var(--spacing-xl)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.confirmation-modal{max-width:600px}.confirmation-input{border:2px solid #cbd5e1;border:2px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;padding:1rem;padding:var(--spacing-md);text-align:center;transition:border-color .3s ease;width:100%}.confirmation-input:focus{border-color:#ef4444;border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a;outline:none}.warning-stats{background:#ef44440d;border:1px solid #ef444433;border-radius:.5rem;border-radius:var(--radius-md);margin:1.5rem 0;margin:var(--spacing-lg) 0;padding:1.5rem;padding:var(--spacing-lg)}.warning-stats p{color:#ef4444;color:var(--danger);font-weight:600;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.warning-stats ul{color:#334155;color:var(--gray-700);margin-left:1.5rem;margin-left:var(--spacing-lg)}.warning-stats li{margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}@media (max-width:768px){.upload-dropzone{min-height:120px;padding:1.5rem;padding:var(--spacing-lg)}.dropzone-content{gap:1rem;gap:var(--spacing-md)}.file-item{gap:.5rem;gap:var(--spacing-sm)}.file-item,.history-item{align-items:flex-start;flex-direction:column;padding:1rem;padding:var(--spacing-md)}.history-item{gap:1rem;gap:var(--spacing-md)}.result-item{align-items:flex-start;flex-direction:column}.admin-login-modal,.result-item{padding:1rem;padding:var(--spacing-md)}.admin-login-modal{margin:1rem;margin:var(--spacing-md);max-width:calc(100vw - 2rem)}.admin-login-form input{font-size:16px}.form-group{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.form-label{color:#334155;color:var(--gray-700);display:block;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}}@media (max-width:480px){.upload-dropzone{min-height:100px;padding:1rem;padding:var(--spacing-md)}.admin-login-modal,.file-item,.history-item,.result-item{padding:.5rem;padding:var(--spacing-sm)}.admin-login-modal{margin:.5rem;margin:var(--spacing-sm)}}.weekly-bar-chart{align-items:end;background:linear-gradient(0deg,#f8fafc,#0000);background:linear-gradient(to top,var(--color-surface-subtle),#0000);border-radius:.5rem;border-radius:var(--radius-md);display:flex;gap:.5rem;gap:var(--spacing-sm);height:250px;padding:1rem;padding:var(--spacing-md)}.weekly-bar-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.bar-container{align-items:end;display:flex;height:180px;justify-content:center;width:100%}.bar-fill{border-radius:.375rem .375rem 0 0;border-radius:var(--radius-sm) var(--radius-sm) 0 0;box-shadow:0 2px 4px #0000001a;min-height:4px;transition:all .3s ease;width:80%}.bar-label{color:#475569;color:var(--color-text-secondary);font-size:.75rem;font-weight:500;text-align:center;word-break:break-word}.bar-value{color:#0f172a;color:var(--color-text-primary);font-size:.875rem;font-weight:600;text-align:center}.hourly-histogram{align-items:end;display:flex;gap:2px;height:200px;overflow-x:auto;padding:1rem;padding:var(--spacing-md)}.histogram-bar{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.25rem;gap:var(--spacing-xs);min-width:20px}.histogram-fill{border-radius:.375rem .375rem 0 0;border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;min-height:2px;transition:all .3s ease;width:100%}.histogram-fill:hover{opacity:.8;transform:scaleY(1.05)}.histogram-label{color:#64748b;color:var(--color-text-muted);font-size:.6rem;font-weight:500;margin-top:.25rem;margin-top:var(--spacing-xs);transform:rotate(-45deg);white-space:nowrap}.weekday-stat{padding:2rem;padding:var(--spacing-xl);text-align:center}.weekday-stat .stat-value{color:#6366f1;color:var(--primary);font-size:2.5rem;font-weight:700;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.weekday-stat .stat-description{color:#475569;color:var(--color-text-secondary);font-size:.875rem;font-weight:500}@media (max-width:768px){.modal{margin:1rem;margin:var(--spacing-md);max-height:95vh;max-width:95%;width:95%}.modal-header{flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);padding:1.5rem;padding:var(--spacing-lg)}.modal-header .flex{flex:1 1;min-width:0}.modal-header .btn{flex-shrink:0}.modal-title{font-size:1.125rem;line-height:1.4}.modal-body,.modal-footer{padding:1.5rem;padding:var(--spacing-lg)}.modal-footer{flex-direction:column-reverse;gap:.5rem;gap:var(--spacing-sm)}.modal-footer .btn{justify-content:center;width:100%}.form-input{font-size:1rem;padding:1.5rem 1rem;padding:var(--spacing-lg) var(--spacing-md)}.form-input.pl-10{padding-left:2.5rem}.form-input.pr-10{padding-right:2.5rem}.absolute.left-3{left:.75rem}.absolute.right-3{right:.75rem}}@media (max-width:480px){.modal{border-radius:0;margin:0;max-height:100vh;max-width:100%;width:100%}.modal-overlay{align-items:flex-start;padding:0}}.date-filter-container{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #e2e8f0;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:.75rem;padding:.75rem 1rem}.date-filter-group{align-items:center;display:flex;gap:.5rem}.date-filter-label{color:#334155;color:var(--gray-700);font-size:.875rem;font-weight:500;min-width:-webkit-fit-content;min-width:fit-content;white-space:nowrap}.date-filter-input{background:#fff;background:var(--color-surface);border:1px solid #cbd5e1;border:1px solid var(--color-border-strong);border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:.875rem;padding:.5rem .75rem;transition:all .2s ease;width:150px}.date-filter-input:hover{border-color:#cbd5e1;border-color:var(--color-border-strong)}.date-filter-input:focus{border-color:#6366f1;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.date-filter-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;-webkit-transition:opacity .2s ease;transition:opacity .2s ease}.date-filter-input::-webkit-calendar-picker-indicator:hover{opacity:1}.btn-today{background:#0f172a1a;background:var(--color-surface-pressed);border:none;border-radius:.5rem;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#475569;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-today:hover{background:#0f172a0f;background:var(--color-surface-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-today:active{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(0)}.btn-today.active{background:linear-gradient(135deg,#6366f1,#4f46e5);background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.btn-today.active:hover{background:linear-gradient(135deg,#4f46e5,#3730a3);background:linear-gradient(135deg,var(--primary-dark),#3730a3)}.date-filter-clear{background:none;border:none;color:#475569;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;text-decoration:underline;text-underline-offset:2px;transition:color .2s ease;white-space:nowrap}.date-filter-clear:hover{color:#ef4444;color:var(--danger)}@media (max-width:768px){.date-filter-container{align-items:stretch;flex-direction:column;gap:.5rem}.date-filter-group{justify-content:space-between}.date-filter-input{min-width:0;width:100%}.btn-today{justify-content:center;width:100%}}
/*# sourceMappingURL=main.1fd9e95a.css.map*/