:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--success-50:#f0fdf4;--success-100:#dcfce7;--success-200:#bbf7d0;--success-400:#4ade80;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-200:#fde68a;--warning-400:#fbbf24;--warning-500:#f59e0b;--warning-600:#d97706;--warning-700:#b45309;--error-50:#fef2f2;--error-100:#fee2e2;--error-200:#fecaca;--error-400:#f87171;--error-500:#ef4444;--error-600:#dc2626;--error-700:#b91c1c;--primary-color:var(--primary-600);--success-color:var(--success-500);--warning-color:var(--warning-500);--error-color:var(--error-500);--bg-color:#f9fafb;--card-bg:#fff;--text-primary:#1f2937;--text-secondary:#6b7280;--text-muted:#9ca3af;--border-color:#e5e7eb;--border-hover:#d1d5db;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-hover:0 8px 16px #0000001a;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--transition-fast:150ms ease;--transition-normal:200ms ease;--transition-slow:300ms ease}html.dark{--bg-color:#0f1219;--card-bg:#1a1f2e;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#94a3b81a;--border-hover:#94a3b833;--shadow-sm:0 0 0 1px #94a3b80d,0 1px 2px #0006;--shadow-md:0 0 0 1px #94a3b80d,0 4px 12px #00000080;--shadow-lg:0 0 0 1px #94a3b80d,0 8px 24px #0009;--shadow-hover:0 0 0 1px #94a3b81a,0 12px 32px #00000080;--primary-50:#3b82f61f;--primary-100:#3b82f62e;--success-50:#22c55e1f;--success-100:#22c55e2e;--warning-50:#f59e0b1f;--warning-100:#f59e0b2e;--error-50:#ef44441f;--error-100:#ef44442e;--primary-500:#60a5fa;--primary-600:#3b82f6;--success-500:#4ade80;--success-600:#22c55e;--warning-500:#fbbf24;--error-500:#f87171}html.dark .card{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-top:3px solid var(--border-color)}html.dark .chart-container,html.dark .chart-container-full,html.dark .insights,html.dark .weekly-summary{border:1px solid #e5e7eb;border:1px solid var(--border-color)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--bg-color);color:#1f2937;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;transition:background-color .3s ease,color .3s ease}.app-header,.card,.chart-container,.chart-container-full,.csv-upload,.dropzone,.insight,.insights,.manual-entry,.message,.weekly-summary,button,input,select,textarea{transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease,color .2s ease}.container{margin:0 auto;max-width:1200px;padding:0 20px;padding:0 var(--space-5)}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--primary-500);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:0 0 0 4px #dbeafe;box-shadow:0 0 0 4px var(--primary-100);outline:2px solid #3b82f6;outline:2px solid var(--primary-500);outline-offset:2px}.app-header{background-color:#fff;background-color:var(--card-bg);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:20px 0;padding:var(--space-5) 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header h1{color:#3b82f6;color:var(--primary-500);font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:12px;margin-bottom:var(--space-3)}html.dark .app-header h1{text-shadow:0 0 30px #60a5fa4d}.nav{display:flex;gap:8px;gap:var(--space-2)}.nav button{background-color:initial;border:none;border-radius:8px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;padding:var(--space-3) var(--space-5);position:relative;transition:all .15s ease;transition:all var(--transition-fast)}.nav button:after{background-color:#2563eb;background-color:var(--primary-600);border-radius:1px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .2s ease;transition:width var(--transition-normal);width:0}.nav button:hover{background-color:#eff6ff;background-color:var(--primary-50);color:#1f2937;color:var(--text-primary)}.nav button:hover:after{width:60%}.nav button.active{background-color:#eff6ff;background-color:var(--primary-50);color:#2563eb;color:var(--primary-600);font-weight:600}.nav button.active:after{width:80%}.nav button.theme-toggle{align-items:center;border-radius:50%;display:flex;font-size:18px;height:40px;justify-content:center;margin-left:auto;padding:8px 12px;padding:var(--space-2) var(--space-3);width:40px}.nav button.theme-toggle:hover{background-color:#eff6ff;background-color:var(--primary-50);transform:rotate(15deg)}.nav button.theme-toggle:after{display:none}html.dark .nav button.theme-toggle:hover{background-color:#fbbf2426;box-shadow:0 0 20px #fbbf2433}.app-main{min-height:calc(100vh - 200px);padding:32px 0;padding:var(--space-8) 0}.dashboard-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;gap:var(--space-4);justify-content:space-between;margin-bottom:24px;margin-bottom:var(--space-6)}.dashboard h2{font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0}.time-range-selector{align-items:center;display:flex;gap:12px;gap:var(--space-3)}.time-range-selector label{color:#6b7280;color:var(--text-secondary);font-size:14px;font-weight:500}.time-range-selector select{background-color:#fff;background-color:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-primary);cursor:pointer;font-size:14px;padding:8px 12px;padding:var(--space-2) var(--space-3);transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.time-range-selector select:hover{border-color:#d1d5db;border-color:var(--border-hover)}.time-range-selector select:focus{border-color:#3b82f6;border-color:var(--primary-500);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--primary-100)}.time-range-selector .refresh-btn{align-items:center;background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:50%;color:#6b7280;color:var(--text-secondary);display:flex;font-size:18px;height:36px;justify-content:center;padding:0;width:36px}.time-range-selector .refresh-btn:hover{background:#eff6ff;background:var(--primary-50);border-color:#3b82f6;border-color:var(--primary-500);color:#3b82f6;color:var(--primary-500);transform:rotate(180deg)}.time-range-selector .refresh-btn:active{transform:rotate(1turn)}.summary-cards{grid-gap:20px;grid-gap:var(--space-5);display:grid;gap:20px;gap:var(--space-5);grid-template-columns:repeat(3,1fr);margin-bottom:32px;margin-bottom:var(--space-8)}@media (max-width:900px){.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.summary-cards{grid-template-columns:1fr}}.card{background-color:#fff;background-color:var(--card-bg);border-radius:12px;border-radius:var(--radius-lg);border-top:3px solid #e5e7eb;border-top:3px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);padding:24px;padding:var(--space-6);transition:transform .2s ease,box-shadow .2s ease;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{box-shadow:0 8px 16px #0000001a;box-shadow:var(--shadow-hover);transform:translateY(-2px)}.card.card-primary,.card.card-weight{border-top-color:#3b82f6;border-top-color:var(--primary-500)}.card.card-deficit,.card.card-success{border-top-color:#22c55e;border-top-color:var(--success-500)}.card.card-data,.card.card-warning{border-top-color:#f59e0b;border-top-color:var(--warning-500)}.card.card-accuracy,.card.card-info{border-top-color:#60a5fa;border-top-color:var(--primary-400)}.card.card-error{border-top-color:#ef4444;border-top-color:var(--error-500)}.card h3{color:#9ca3af;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.08em;margin-bottom:12px;margin-bottom:var(--space-3);text-transform:uppercase}.card .value{color:#1f2937;color:var(--text-primary);font-size:36px;font-weight:700;letter-spacing:-.02em;line-height:1.1;margin-bottom:4px;margin-bottom:var(--space-1)}.card .change{color:#6b7280;color:var(--text-secondary);font-size:14px;font-weight:500}.card .change.positive{color:#16a34a;color:var(--success-600)}.card .change.negative{color:#dc2626;color:var(--error-600)}.card .sub{color:#6b7280;color:var(--text-secondary);font-size:13px;margin-top:8px;margin-top:var(--space-2)}.card .sync{color:#9ca3af;color:var(--text-muted);font-size:12px;margin:4px 0;margin:var(--space-1) 0}.card .detail{font-size:12px;line-height:1.4;margin-top:8px;margin-top:var(--space-2)}.card .accuracy-select{background-color:#fff;background-color:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);color:#1f2937;color:var(--text-primary);cursor:pointer;font-size:13px;margin-bottom:8px;margin-bottom:var(--space-2);padding:4px 8px;padding:var(--space-1) var(--space-2);width:100%}.charts-grid{grid-gap:20px;grid-gap:var(--space-5);display:grid;gap:20px;gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:32px;margin-bottom:var(--space-8)}.chart-container,.chart-container-full{background-color:#fff;background-color:var(--card-bg);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);padding:24px;padding:var(--space-6);transition:box-shadow .2s ease;transition:box-shadow var(--transition-normal)}.chart-container-full:hover,.chart-container:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}.chart-container-full{margin-bottom:32px;margin-bottom:var(--space-8)}.chart-container h3,.chart-container-full h3{color:#1f2937;color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:16px;margin-bottom:var(--space-4)}.insights{background-color:#fff;background-color:var(--card-bg);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-bottom:32px;margin-bottom:var(--space-8);padding:24px;padding:var(--space-6)}.insights h3{font-size:18px;font-weight:600;margin-bottom:16px;margin-bottom:var(--space-4)}.insights-list{display:flex;flex-direction:column;gap:12px;gap:var(--space-3)}.insight{border-left:4px solid;border-radius:8px;border-radius:var(--radius-md);padding:16px;padding:var(--space-4);transition:transform .15s ease;transition:transform var(--transition-fast)}.insight:hover{transform:translateX(4px)}.insight.success{background-color:#f0fdf4;background-color:var(--success-50);border-color:#22c55e;border-color:var(--success-500)}.insight.warning{background-color:#fffbeb;background-color:var(--warning-50);border-color:#f59e0b;border-color:var(--warning-500)}.insight.info{background-color:#eff6ff;background-color:var(--primary-50);border-color:#3b82f6;border-color:var(--primary-500)}.insight.error{background-color:#fef2f2;background-color:var(--error-50);border-color:#ef4444;border-color:var(--error-500)}.insight-header{align-items:center;display:flex;gap:8px;gap:var(--space-2);margin-bottom:4px;margin-bottom:var(--space-1)}.insight-icon{font-size:18px;font-weight:700}.insight p{color:#6b7280;color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}.weekly-summary{background-color:#fff;background-color:var(--card-bg);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-bottom:32px;margin-bottom:var(--space-8);padding:24px;padding:var(--space-6)}.weekly-summary h3{font-size:18px;font-weight:600;margin-bottom:16px;margin-bottom:var(--space-4)}.trends-table{overflow-x:auto}.trends-table table{border-collapse:collapse;width:100%}.trends-table td,.trends-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:12px 16px;padding:var(--space-3) var(--space-4);text-align:left}.trends-table th{color:#9ca3af;color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.trends-table th,.trends-table tr:hover{background-color:#f9fafb;background-color:var(--bg-color)}.trends-table td.positive{color:#16a34a;color:var(--success-600);font-weight:600}.trends-table td.negative{color:#ef4444;color:var(--error-500)}.csv-upload,.manual-entry{background-color:#fff;background-color:var(--card-bg);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);padding:32px;padding:var(--space-8)}.header{align-items:center;display:flex;gap:16px;gap:var(--space-4);margin-bottom:24px;margin-bottom:var(--space-6)}.back-button{background-color:#f9fafb;background-color:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;padding:8px 12px;padding:var(--space-2) var(--space-3);transition:all .15s ease;transition:all var(--transition-fast)}.back-button:hover{background-color:#e5e7eb;background-color:var(--border-color);border-color:#d1d5db;border-color:var(--border-hover)}.form-section{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);margin-bottom:24px;margin-bottom:var(--space-6);padding-bottom:20px;padding-bottom:var(--space-5)}.form-section:last-of-type{border-bottom:none}.form-section h3{color:#2563eb;color:var(--primary-600);font-size:18px;font-weight:600;margin-bottom:16px;margin-bottom:var(--space-4)}.form-section label{color:#1f2937;color:var(--text-primary);display:block;font-size:14px;font-weight:500;margin-bottom:12px;margin-bottom:var(--space-3)}.form-section input[type=date],.form-section input[type=number],.form-section input[type=text],.form-section select,.form-section textarea{background-color:#fff;background-color:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-primary);font-size:14px;margin-top:4px;margin-top:var(--space-1);padding:12px;padding:var(--space-3);transition:border-color .15s ease,box-shadow .15s ease;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-section input:hover,.form-section select:hover,.form-section textarea:hover{border-color:#d1d5db;border-color:var(--border-hover)}.form-section input:focus,.form-section select:focus,.form-section textarea:focus{border-color:#3b82f6;border-color:var(--primary-500);box-shadow:0 0 0 3px #dbeafe;box-shadow:0 0 0 3px var(--primary-100);outline:none}.form-section textarea{font-family:inherit;min-height:100px;resize:vertical}.form-section label.checkbox{align-items:center;cursor:pointer;display:flex;gap:8px;gap:var(--space-2)}.form-section input[type=checkbox]{cursor:pointer;margin-top:0;width:auto}.form-actions{display:flex;gap:12px;gap:var(--space-3);margin-top:24px;margin-top:var(--space-6)}button{background-color:#fff;background-color:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500;overflow:hidden;padding:12px 20px;padding:var(--space-3) var(--space-5);position:relative;transition:all .15s ease;transition:all var(--transition-fast)}button:hover{background-color:#f9fafb;background-color:var(--bg-color);border-color:#d1d5db;border-color:var(--border-hover)}button:active{transform:scale(.98)}button.primary,button[type=submit]{background-color:#2563eb;background-color:var(--primary-600);border-color:#2563eb;border-color:var(--primary-600);color:#fff}button.primary:hover,button[type=submit]:hover{background-color:#1d4ed8;background-color:var(--primary-700);border-color:#1d4ed8;border-color:var(--primary-700)}button.success{background-color:#22c55e;background-color:var(--success-500);border-color:#22c55e;border-color:var(--success-500);color:#fff}button.success:hover{background-color:#16a34a;background-color:var(--success-600);border-color:#16a34a;border-color:var(--success-600)}button.danger{background-color:#ef4444;background-color:var(--error-500);border-color:#ef4444;border-color:var(--error-500);color:#fff}button.danger:hover{background-color:#dc2626;background-color:var(--error-600);border-color:#dc2626;border-color:var(--error-600)}button:disabled{cursor:not-allowed;opacity:.5;transform:none}.message{border:1px solid;border-radius:8px;border-radius:var(--radius-md);margin-bottom:20px;margin-bottom:var(--space-5);padding:16px;padding:var(--space-4)}.message.success{background-color:#f0fdf4;background-color:var(--success-50);border-color:#bbf7d0;border-color:var(--success-200);color:#15803d;color:var(--success-700)}.message.error{background-color:#fef2f2;background-color:var(--error-50);border-color:#fecaca;border-color:var(--error-200);color:#b91c1c;color:var(--error-700)}.message.warning{background-color:#fffbeb;background-color:var(--warning-50);border-color:#fde68a;border-color:var(--warning-200);color:#b45309;color:var(--warning-700)}.message.info{background-color:#eff6ff;background-color:var(--primary-50);border-color:#bfdbfe;border-color:var(--primary-200);color:#1d4ed8;color:var(--primary-700)}.message h3{font-weight:600;margin-bottom:8px;margin-bottom:var(--space-2)}.message ul{margin-left:20px;margin-left:var(--space-5);margin-top:8px;margin-top:var(--space-2)}.upload-info{background-color:#f9fafb;background-color:var(--bg-color);border-radius:8px;border-radius:var(--radius-md);margin-bottom:20px;margin-bottom:var(--space-5);padding:16px;padding:var(--space-4)}.upload-info h3{font-size:16px;font-weight:600;margin-bottom:12px;margin-bottom:var(--space-3)}.upload-info pre{background-color:#fff;background-color:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);font-size:12px;margin:12px 0;margin:var(--space-3) 0;overflow-x:auto;padding:12px;padding:var(--space-3)}.dropzone{border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;margin:20px 0;margin:var(--space-5) 0;padding:40px;padding:var(--space-10);text-align:center;transition:all .2s ease;transition:all var(--transition-normal)}.dropzone.active,.dropzone:hover{background-color:#eff6ff;background-color:var(--primary-50);border-color:#3b82f6;border-color:var(--primary-500)}.dropzone p{color:#6b7280;color:var(--text-secondary);margin-bottom:16px;margin-bottom:var(--space-4)}.file-label{background-color:#2563eb;background-color:var(--primary-600);border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-block;font-weight:500;padding:12px 20px;padding:var(--space-3) var(--space-5);transition:all .15s ease;transition:all var(--transition-fast)}.file-label:hover{background-color:#1d4ed8;background-color:var(--primary-700)}.file-info{background-color:#f9fafb;background-color:var(--bg-color);border-radius:8px;border-radius:var(--radius-md);margin:16px 0;margin:var(--space-4) 0;padding:16px;padding:var(--space-4)}.app-footer{background-color:#fff;background-color:var(--card-bg);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#6b7280;color:var(--text-secondary);font-size:14px;margin-top:40px;margin-top:var(--space-10);padding:20px 0;padding:var(--space-5) 0;text-align:center}.error,.loading{padding:40px;padding:var(--space-10);text-align:center}.skeleton{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#f9fafb 25%,#e5e7eb 50%,#f9fafb 75%);background:linear-gradient(90deg,var(--bg-color) 25%,var(--border-color) 50%,var(--bg-color) 75%);background-size:200% 100%;border-radius:8px;border-radius:var(--radius-md)}.skeleton-text{height:16px;margin-bottom:8px;margin-bottom:var(--space-2)}.skeleton-title{height:24px;margin-bottom:12px;margin-bottom:var(--space-3);width:60%}.skeleton-value{height:40px;width:80%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-top-color:#3b82f6;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-500);height:40px;margin:0 auto 16px;margin:0 auto var(--space-4);width:40px}html.dark .spinner{border-color:#3b82f6 #94a3b833 #94a3b833;border-top-color:var(--primary-500);box-shadow:0 0 20px #60a5fa33}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.charts-grid,.summary-cards{grid-template-columns:1fr}.trends-table{font-size:12px}.trends-table td,.trends-table th{padding:8px;padding:var(--space-2) var(--space-2)}.dashboard-header{align-items:flex-start;flex-direction:column}.card .value{font-size:28px}.csv-upload,.manual-entry{padding:20px;padding:var(--space-5)}}@media (max-width:480px){.nav{justify-content:flex-start}.container{padding-left:12px;padding-left:var(--space-3);padding-right:12px;padding-right:var(--space-3)}.card .value{font-size:24px}.csv-upload,.manual-entry{padding:16px;padding:var(--space-4)}}.text-success{color:#16a34a;color:var(--success-600)}.text-warning{color:#d97706;color:var(--warning-600)}.text-error{color:#dc2626;color:var(--error-600)}.text-muted{color:#9ca3af;color:var(--text-muted)}.bg-success{background-color:#f0fdf4;background-color:var(--success-50)}.bg-warning{background-color:#fffbeb;background-color:var(--warning-50)}.bg-error{background-color:#fef2f2;background-color:var(--error-50)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}html.dark .insight.success{box-shadow:0 0 20px #22c55e1a}html.dark .insight.warning{box-shadow:0 0 20px #f59e0b1a}html.dark .insight.info{box-shadow:0 0 20px #3b82f61a}html.dark .insight.error{box-shadow:0 0 20px #ef44441a}html.dark .card.card-primary,html.dark .card.card-weight{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 -2px 20px #3b82f626;box-shadow:var(--shadow-md),0 -2px 20px #3b82f626}html.dark .card.card-deficit,html.dark .card.card-success{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 -2px 20px #22c55e26;box-shadow:var(--shadow-md),0 -2px 20px #22c55e26}html.dark .card.card-data,html.dark .card.card-warning{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 -2px 20px #f59e0b26;box-shadow:var(--shadow-md),0 -2px 20px #f59e0b26}html.dark .card.card-accuracy,html.dark .card.card-info{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 -2px 20px #60a5fa26;box-shadow:var(--shadow-md),0 -2px 20px #60a5fa26}html.dark input:focus,html.dark select:focus,html.dark textarea:focus{box-shadow:0 0 0 3px #60a5fa40}html.dark .dropzone.active,html.dark .dropzone:hover{box-shadow:0 0 30px #3b82f626}html.dark button.primary,html.dark button[type=submit]{box-shadow:0 0 20px #3b82f640}html.dark button.primary:hover,html.dark button[type=submit]:hover{box-shadow:0 0 30px #3b82f659}html.dark button.success{box-shadow:0 0 20px #22c55e40}html.dark button.danger{box-shadow:0 0 20px #ef444440}html.dark .card .change.positive,html.dark .text-success,html.dark .trends-table td.positive{color:#22c55e;color:var(--success-500)}html.dark .card .change.negative,html.dark .text-error,html.dark .trends-table td.negative{color:#ef4444;color:var(--error-500)}.collapsible-section{margin-bottom:8px;margin-bottom:var(--space-2)}.collapsible-header{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-primary);cursor:pointer;display:flex;font-size:18px;font-weight:600;justify-content:space-between;padding:12px 16px;padding:var(--space-3) var(--space-4);transition:background-color .15s ease;transition:background-color var(--transition-fast);user-select:none;-webkit-user-select:none;width:100%}.collapsible-header:hover{background-color:#eff6ff;background-color:var(--primary-50)}.collapsible-title{flex:1 1;text-align:left}.chevron{align-items:center;color:#9ca3af;color:var(--text-muted);display:flex;flex-shrink:0;font-size:12px;height:36px;justify-content:center;transition:transform .3s ease;width:36px}.chevron.collapsed{transform:rotate(-90deg)}.collapsible-body{overflow:hidden;transition:max-height .3s ease-out}.bottom-nav{align-items:stretch;background:#fff;background:var(--card-bg);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -2px 10px #0000001a;display:none;height:64px;justify-content:space-around;left:0;padding:0;position:fixed;right:0;z-index:200}html.dark .bottom-nav{box-shadow:0 -2px 10px #0006}.bottom-nav-item{align-items:center;background:#0000;border:none;border-radius:0;color:#9ca3af;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:10px;font-weight:500;justify-content:center;min-height:44px;min-width:0;padding:4px 0;padding:var(--space-1) 0;position:relative;transition:color .15s ease;transition:color var(--transition-fast)}.bottom-nav-item:before{background:#0000;border-radius:0 0 2px 2px;content:"";height:3px;left:25%;position:absolute;right:25%;top:0;transition:background-color .15s ease;transition:background-color var(--transition-fast)}.bottom-nav-item.active{color:#2563eb;color:var(--primary-600)}.bottom-nav-item.active:before{background:#2563eb;background:var(--primary-600)}html.dark .bottom-nav-item.active{color:#3b82f6;color:var(--primary-500)}html.dark .bottom-nav-item.active:before{background:#3b82f6;background:var(--primary-500)}.bottom-nav-icon{font-size:20px;line-height:1;margin-bottom:2px}.bottom-nav-label{font-size:10px;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ptr-indicator{display:none;left:50%;pointer-events:none;position:fixed;top:-50px;transform:translateX(-50%);z-index:150}.ptr-spinner{align-items:center;background:#fff;background:var(--card-bg);border-radius:50%;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#3b82f6;color:var(--primary-500);display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.ptr-arrow{display:inline-block;transition:transform .2s ease}.ptr-loading{animation:spin .8s linear infinite;display:inline-block}.ptr-spinner.spinning{animation:none}.view-container{touch-action:pan-y;will-change:transform}@media (max-width:768px){body{overscroll-behavior-y:contain}button{min-height:44px;min-width:44px}input,select{font-size:16px;min-height:44px}input[type=checkbox]{height:22px;min-height:22px;min-width:22px;width:22px}.chevron{height:44px;width:44px}.nav button,.nav button.theme-toggle{display:none}.app-header{padding:8px 0;padding:var(--space-2) 0}.app-header .container{align-items:center;display:flex;gap:12px;gap:var(--space-3);justify-content:center}.app-header h1{font-size:18px;margin-bottom:0;white-space:nowrap}.app-main{padding-bottom:80px}.app-footer{display:none}.bottom-nav{display:flex}body:has(input:focus) .bottom-nav,body:has(select:focus) .bottom-nav,body:has(textarea:focus) .bottom-nav{display:none}.ptr-indicator{display:block}.view-animating{transition:transform .25s ease-out}}
/*# sourceMappingURL=main.067e74fd.css.map*/