*{box-sizing:border-box;margin:0;padding:0}:root{--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 2px 4px rgba(15, 23, 42, .15);--shadow-md: 0 10px 30px rgba(15, 23, 42, .25);--shadow-lg: 0 20px 40px rgba(15, 23, 42, .3);--transition-fast: .2s ease;--transition-normal: .3s ease}:root[data-theme=dark]{--bg-body: #0f172a;--bg-surface: #1e293b;--bg-panel: #334155;--border-subtle: rgba(148, 163, 184, .2);--accent: #60a5fa;--accent-soft: rgba(96, 165, 250, .2);--accent-strong: #3b82f6;--success: #34d399;--success-soft: rgba(52, 211, 153, .2);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .2);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .2);--text-main: #f8fafc;--text-muted: #cbd5e1;--text-subtle: #94a3b8}:root[data-theme=light]{--bg-body: #f8fafc;--bg-surface: #ffffff;--bg-panel: #f1f5f9;--border-subtle: rgba(148, 163, 184, .3);--accent: #3b82f6;--accent-soft: rgba(59, 130, 246, .1);--accent-strong: #2563eb;--success: #10b981;--success-soft: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .1);--text-main: #1e293b;--text-muted: #475569;--text-subtle: #64748b}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top left,rgba(59,130,246,.15) 0,transparent 55%),radial-gradient(circle at bottom right,rgba(34,197,94,.12) 0,transparent 55%),var(--bg-body);color:var(--text-main);line-height:1.5}.layout-root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.layout-shell{width:100%;max-width:1200px;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);overflow:hidden}.layout-main{padding:20px}.layout-content{display:flex;gap:16px;min-height:300px}.layout-sidebar{flex:0 0 280px;display:flex;flex-direction:column;gap:16px}.layout-body{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}.panel{background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:14px 16px;box-shadow:var(--shadow-sm)}.panel-header-title{font-size:16px;font-weight:600;margin-bottom:10px;color:var(--text-main)}.btn{border-radius:999px;padding:8px 12px;font-size:12px;font-weight:500;border:1px solid var(--border-subtle);background:var(--bg-panel);color:var(--text-main);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform .1s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--success),var(--success));border-color:var(--success-soft);color:#0f172a}.btn-primary:hover{background:linear-gradient(135deg,var(--success-soft),var(--success));border-color:var(--success)}.btn-ghost{background:transparent}.btn-chip{border-radius:999px;padding:4px 8px;font-size:11px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-muted)}.btn-chip:hover{border-color:var(--accent);color:var(--accent)}.btn-chip--active{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:transparent;color:#0b1120}.table-shell{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-panel);overflow:hidden}@media (min-width: 1366px) and (max-width: 1920px){.layout-shell{max-width:1400px}.layout-sidebar{flex:0 0 320px}.panel{padding:18px 20px}.chart-container{height:450px;min-height:450px}}@media (max-width: 1024px){.layout-shell{border-radius:var(--radius-xl)}.layout-main{padding:12px}.layout-content{flex-direction:column}.layout-sidebar{flex:none;width:100%}}@media (max-width: 640px){.layout-root{padding:8px}.layout-shell{border-radius:var(--radius-lg)}.layout-content{min-height:100px;gap:8px}.layout-sidebar,.layout-body{gap:8px}}.loading-overlay[data-v-ae0a1363]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f172acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.loading-spinner[data-v-ae0a1363]{border:4px solid var(--accent-soft);border-radius:50%;border-top:4px solid var(--accent);width:40px;height:40px;animation:spin-ae0a1363 1s linear infinite;margin-bottom:15px}.loading-text[data-v-ae0a1363]{color:var(--accent);font-size:16px;font-weight:700}@keyframes spin-ae0a1363{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast-container[data-v-6d3be1e3]{position:fixed;top:20px;right:20px;z-index:1001;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast[data-v-6d3be1e3]{padding:15px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:14px;font-weight:500;max-width:350px;word-wrap:break-word;pointer-events:auto}.toast.success[data-v-6d3be1e3]{background:linear-gradient(135deg,#27ae60,#2ecc71)}.toast.error[data-v-6d3be1e3]{background-color:#e74c3c}.toast.warning[data-v-6d3be1e3]{background-color:#f39c12}.toast.info[data-v-6d3be1e3]{background-color:#3498db}.toast-message[data-v-6d3be1e3]{white-space:pre-line}.toast-enter-active[data-v-6d3be1e3]{transition:all .3s ease-out}.toast-leave-active[data-v-6d3be1e3]{transition:all .2s ease-in}.toast-enter-from[data-v-6d3be1e3],.toast-leave-to[data-v-6d3be1e3]{opacity:0;transform:translate(100%)}@media (max-width: 480px){.toast-container[data-v-6d3be1e3]{top:8px;right:8px;left:8px;gap:6px}.toast[data-v-6d3be1e3]{padding:10px 14px;font-size:12px}}svg[data-v-564bf3de]{flex-shrink:0;transition:transform .2s ease;vertical-align:middle}:host-context(.upload-button:hover) svg[data-v-564bf3de]{transform:scale(1.1)}:host-context(.upload-button.primary:hover) svg[data-v-564bf3de]{transform:scale(1.15)}:host-context(.hole-button:hover) svg[data-v-564bf3de]{transform:scale(1.1)}:host-context(.hole-button.active:hover) svg[data-v-564bf3de]{transform:scale(1.15)}.file-upload-section[data-v-a2efbf6d]{width:100%;height:auto;min-height:0}.section-header[data-v-a2efbf6d]{margin-bottom:12px;display:flex;align-items:flex-end;gap:8px}.section-title[data-v-a2efbf6d]{font-size:18px;font-weight:600;color:var(--text-main);line-height:1.3;margin:0}.section-description[data-v-a2efbf6d]{font-size:12px;color:var(--text-muted);line-height:1.4;margin:0;align-self:flex-end}.upload-buttons[data-v-a2efbf6d]{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-height:0}.upload-button[data-v-a2efbf6d]{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-panel);color:var(--text-main);font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:36px}.upload-button[data-v-a2efbf6d]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.upload-button[data-v-a2efbf6d]:hover:before{left:100%}.upload-button[data-v-a2efbf6d]:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.upload-button.primary[data-v-a2efbf6d]{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:var(--accent-soft);color:#fff;box-shadow:0 4px 12px #3b82f64d}.upload-button.primary[data-v-a2efbf6d]:hover{background:linear-gradient(135deg,var(--accent-strong),var(--accent-strong));border-color:var(--accent);box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}.upload-button.secondary[data-v-a2efbf6d]:hover{background:var(--accent-soft);border-color:var(--accent)}.upload-button svg[data-v-a2efbf6d]{flex-shrink:0}@media (max-width: 480px){.upload-buttons[data-v-a2efbf6d]{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.upload-button[data-v-a2efbf6d]{padding:8px 6px;gap:4px;font-size:10px;min-height:40px}.upload-button span[data-v-a2efbf6d]{font-size:10px}.upload-button svg[data-v-a2efbf6d]{width:12px;height:12px}}.section-header[data-v-edbfa9fd]{display:flex;align-items:flex-end;gap:12px;margin-bottom:16px}.section-title[data-v-edbfa9fd]{font-size:18px;font-weight:700;color:var(--text-main);line-height:1.2;margin:0}.section-description[data-v-edbfa9fd]{font-size:12px;color:var(--text-muted);line-height:1.4;margin:0;padding-bottom:2px}@media (max-width: 480px){.section-header[data-v-edbfa9fd]{margin-bottom:16px}.section-title[data-v-edbfa9fd]{font-size:16px}.section-description[data-v-edbfa9fd]{font-size:12px}}.hole-selector-section[data-v-4a9c0cf7]{width:100%}.hole-buttons[data-v-4a9c0cf7]{display:flex;flex-wrap:wrap;gap:8px;max-height:180px;overflow-y:auto;padding-right:4px;justify-content:center;-webkit-overflow-scrolling:touch;touch-action:pan-y}.hole-buttons[data-v-4a9c0cf7]::-webkit-scrollbar{width:4px}.hole-buttons[data-v-4a9c0cf7]::-webkit-scrollbar-track{background:var(--bg-panel);border-radius:999px}.hole-buttons[data-v-4a9c0cf7]::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:999px}.hole-buttons[data-v-4a9c0cf7]::-webkit-scrollbar-thumb:hover{background:var(--accent-soft)}.hole-button[data-v-4a9c0cf7]{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;background:var(--bg-panel);color:var(--text-muted);border-radius:50%;border:1px solid var(--border-subtle);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:36px;height:36px;text-align:center;min-width:36px;min-height:36px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.hole-button[data-v-4a9c0cf7]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.hole-button[data-v-4a9c0cf7]:hover:before{left:100%}.hole-button[data-v-4a9c0cf7]:hover{border-color:var(--accent);color:var(--text-main);background:var(--accent-soft);box-shadow:0 4px 12px #3b82f64d}.hole-button.active[data-v-4a9c0cf7]{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;border-color:var(--accent-soft);box-shadow:0 4px 12px #3b82f64d}.hole-button.active[data-v-4a9c0cf7]:hover{background:linear-gradient(135deg,var(--accent-strong),var(--accent-strong));border-color:var(--accent);box-shadow:0 6px 16px #3b82f666}.hole-button svg[data-v-4a9c0cf7]{opacity:.8;transition:opacity .2s ease,transform .2s ease}.hole-button:hover svg[data-v-4a9c0cf7]{opacity:1}.hole-button.active svg[data-v-4a9c0cf7]{opacity:1}@media (max-width: 480px){.hole-buttons[data-v-4a9c0cf7]{gap:6px;max-height:160px}.hole-button[data-v-4a9c0cf7]{padding:8px;font-size:11px;width:38px;height:38px;min-width:38px;min-height:38px}}.statistics-section[data-v-dda57473]{width:100%;padding:16px;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);overflow:hidden}.statistics-content[data-v-dda57473]{height:auto;overflow:visible;padding-right:0}.statistic-cards[data-v-dda57473]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;width:100%}.hole-statistic-card[data-v-dda57473]{width:100%;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;cursor:pointer;transition:all var(--transition-normal);animation:slideInUp-dda57473 .4s ease forwards}.hole-statistic-card[data-v-dda57473]:hover{transform:translateY(-3px);box-shadow:0 8px 16px #0000001a;border-color:var(--accent)}@keyframes slideInUp-dda57473{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.hole-statistic-card[data-v-dda57473]:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.card-header[data-v-dda57473]{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-subtle)}.hole-info[data-v-dda57473]{display:flex;align-items:center;gap:10px}.hole-label[data-v-dda57473]{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.hole-number[data-v-dda57473]{font-size:14px;font-weight:700;color:#fff;background:var(--accent);padding:4px 10px;border-radius:var(--radius-sm);box-shadow:0 2px 4px #3b82f64d}.hole-status[data-v-dda57473]{display:flex;align-items:center;gap:6px}.status-indicator[data-v-dda57473]{width:6px;height:6px;border-radius:50%;background:var(--text-muted);transition:all var(--transition-normal)}.status-indicator.active[data-v-dda57473]{background:var(--success);box-shadow:0 0 0 3px #10b9811a}.status-text[data-v-dda57473]{font-size:10px;font-weight:600;color:var(--text-main)}.card-content[data-v-dda57473]{padding:20px}.stat-grid[data-v-dda57473]{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.stat-item[data-v-dda57473]{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;position:relative;overflow:hidden;transition:all var(--transition-normal)}.stat-item[data-v-dda57473]:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}.stat-item[data-v-dda57473]:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);border-radius:var(--radius-md) 0 0 var(--radius-md)}.stat-label[data-v-dda57473]{display:block;font-size:10px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.stat-value[data-v-dda57473]{display:block;font-size:16px;font-weight:700;color:var(--text-main);line-height:1.2}.stat-icon[data-v-dda57473]{position:absolute;top:8px;right:8px;font-size:16px;opacity:.1}.significant-hammers[data-v-dda57473]{padding-top:16px;border-top:1px solid var(--border-subtle)}.hammers-title[data-v-dda57473]{font-size:12px;font-weight:600;color:var(--text-main);margin:0 0 12px;display:flex;align-items:center;gap:6px}.hammers-title[data-v-dda57473]:before{content:"🔨";font-size:14px}.hammer-list[data-v-dda57473]{display:flex;flex-direction:column;gap:8px}.hammer-item[data-v-dda57473]{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden;transition:all var(--transition-normal)}.hammer-item[data-v-dda57473]:hover{border-color:var(--success);background:var(--success-soft);transform:translate(4px)}.hammer-item[data-v-dda57473]:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--success);border-radius:var(--radius-md) 0 0 var(--radius-md)}.hammer-info[data-v-dda57473]{flex:1;display:flex;flex-direction:column;gap:3px}.hammer-count-row[data-v-dda57473]{display:flex;align-items:center}.hammer-depth-row[data-v-dda57473]{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hammer-count[data-v-dda57473]{font-size:12px;font-weight:600;color:var(--text-main)}.hammer-depth[data-v-dda57473],.hammer-total-depth[data-v-dda57473]{font-size:11px;font-weight:500;color:var(--text-muted)}.hammer-marker[data-v-dda57473]{width:10px;height:10px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px #10b9811a}@media (max-width: 768px){.statistics-section[data-v-dda57473]{padding:12px}.statistic-cards[data-v-dda57473]{grid-template-columns:1fr;gap:16px}.section-title[data-v-dda57473]{font-size:18px}.card-header[data-v-dda57473]{padding:12px 16px}.card-content[data-v-dda57473]{padding:16px}.stat-grid[data-v-dda57473]{grid-template-columns:1fr;gap:12px}.stat-value[data-v-dda57473]{font-size:20px}}@media (max-width: 480px){.section-header[data-v-dda57473]{margin-bottom:16px}.section-title[data-v-dda57473]{font-size:16px}.section-description[data-v-dda57473]{font-size:12px}.hole-info[data-v-dda57473]{gap:8px}.hole-number[data-v-dda57473]{font-size:14px;padding:4px 8px}.status-text[data-v-dda57473]{font-size:10px}.card-content[data-v-dda57473],.stat-item[data-v-dda57473]{padding:12px}.stat-value[data-v-dda57473]{font-size:18px}.hammers-title[data-v-dda57473]{font-size:12px}.hammer-item[data-v-dda57473]{padding:10px}.hammer-count[data-v-dda57473]{font-size:12px}.hammer-depth[data-v-dda57473],.hammer-total-depth[data-v-dda57473]{font-size:10px}}.chart-content[data-v-8b27945f]{width:100%;height:100%;display:flex;flex-direction:column}.chart-wrapper[data-v-8b27945f]{position:relative;flex:1;width:100%;min-height:400px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-panel);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);transition:all .3s ease}.chart-wrapper[data-v-8b27945f]:hover{border-color:var(--accent);box-shadow:0 8px 24px #3b82f64d;transform:translateY(-2px)}.chart-wrapper canvas[data-v-8b27945f]{display:block;width:100%!important;height:100%!important}@media (max-width: 480px){.chart-wrapper[data-v-8b27945f]{min-height:260px;touch-action:pan-x pan-y}}.data-table-section[data-v-4f9b468b]{flex:1;display:flex;flex-direction:column;width:100%;height:100%}.table-container[data-v-4f9b468b]{flex:1;overflow-y:auto;overflow-x:hidden;min-height:260px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-panel);position:relative}table[data-v-4f9b468b]{width:100%;border-collapse:collapse;position:relative;table-layout:auto}th[data-v-4f9b468b],td[data-v-4f9b468b]{padding:6px 8px;text-align:center;border-bottom:1px solid var(--border-subtle);min-width:80px;font-size:12px;color:var(--text-main);word-wrap:break-word;white-space:normal;overflow:hidden;text-overflow:ellipsis}tr[data-v-4f9b468b]{transition:background-color var(--transition-fast)}tr[data-v-4f9b468b]:hover{background-color:var(--accent-soft)}th[data-v-4f9b468b]{background:var(--bg-surface);border-bottom:2px solid var(--accent);font-weight:600;position:sticky;top:0;z-index:10;color:var(--text-main);box-shadow:0 2px 8px #00000026}.zebra-row[data-v-4f9b468b]{background-color:var(--bg-surface)}.depth-cell[data-v-4f9b468b]{position:relative;display:block;padding-right:80px}.depth-value[data-v-4f9b468b]{position:relative;z-index:2}.depth-bar[data-v-4f9b468b]{position:absolute;left:0;top:0;height:100%;z-index:1;border-radius:var(--radius-sm)}.no-data[data-v-4f9b468b]{text-align:center;padding:32px;color:var(--text-muted);font-size:13px}@media (max-width: 480px){.table-container[data-v-4f9b468b]{min-height:250px;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;touch-action:pan-x pan-y}.table-container[data-v-4f9b468b]::-webkit-scrollbar{width:6px;height:6px}table[data-v-4f9b468b]{table-layout:auto;width:auto;min-width:100%}th[data-v-4f9b468b],td[data-v-4f9b468b]{min-width:55px;font-size:10px;padding:6px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}th[data-v-4f9b468b]{font-size:10px;padding:8px 4px}.depth-cell[data-v-4f9b468b]{padding-right:50px}}.header{background:linear-gradient(135deg,var(--bg-panel),var(--bg-surface));border-bottom:1px solid var(--border-subtle);padding:8px 20px}.header-content{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:nowrap}.header-brand{display:flex;align-items:center;gap:12px;flex:1;flex-wrap:nowrap}.brand-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;box-shadow:0 4px 16px #3b82f666;transition:all var(--transition-normal)}.brand-icon:hover{transform:scale(1.05);box-shadow:0 6px 20px #3b82f680}.brand-text{display:flex;align-items:flex-end;gap:12px;flex:1}.header-title{font-size:16px;font-weight:700;color:var(--text-main);line-height:1.2;margin:0}.header-subtitle{font-size:11px;color:var(--text-muted);line-height:1.3;margin:0;align-self:flex-end}.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;white-space:nowrap}.header-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;padding:4px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--bg-panel);color:var(--text-main);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.header-button:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.help-button{background:var(--success-soft);border-color:var(--success-soft);color:var(--success)}.help-button:hover{border-color:var(--success);background:var(--success-soft);box-shadow:0 4px 12px #10b9814d}.theme-toggle{position:relative;overflow:hidden}.theme-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.theme-toggle:hover:before{left:100%}.theme-toggle:hover{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 4px 12px #3b82f64d}.empty-state{display:flex;align-items:center;justify-content:center;min-height:500px;text-align:center}.empty-state-content{max-width:500px;padding:48px 32px;background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md)}.empty-state-icon{width:120px;height:120px;margin:0 auto 24px;background:var(--accent-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent)}.empty-state-title{font-size:24px;font-weight:700;color:var(--text-main);margin-bottom:16px;line-height:1.3}.empty-state-description{font-size:16px;color:var(--text-muted);margin-bottom:32px;line-height:1.5}.empty-state-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px;padding:12px 20px;border-radius:var(--radius-md);border:none;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 16px #3b82f666;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.empty-state-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f680;background:linear-gradient(135deg,var(--accent-strong),var(--accent-strong))}.empty-state-button:active{transform:translateY(0);box-shadow:0 4px 16px #3b82f666}.section-header{margin-bottom:16px}.section-header .header-content{display:flex;align-items:center;justify-content:space-between;gap:20px}.section-header .header-content>div:first-child{flex:1;display:flex;align-items:flex-end;gap:12px}.section-header .header-content>div:first-child h3{margin:0}.section-header .header-content>div:first-child p{margin:0;align-self:flex-end}.section-title{font-size:18px;font-weight:600;color:var(--text-main);line-height:1.3}.section-description{font-size:14px;color:var(--text-muted);line-height:1.4}.chart-controls{display:flex;gap:8px}.chart-type-button{min-height:32px;padding:6px 12px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-panel);color:var(--text-main);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.chart-type-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.chart-type-button:hover:before{left:100%}.chart-type-button:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.chart-type-button.active{border-color:var(--accent);background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;box-shadow:0 4px 12px #3b82f64d}.chart-type-button.active:hover{background:linear-gradient(135deg,var(--accent-strong),var(--accent-strong));border-color:var(--accent);box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}.chart-container{height:400px;min-height:400px}.help-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-normal)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.help-modal{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);width:90%;max-width:600px;max-height:80vh;overflow-y:auto;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-subtle)}.modal-header h2{font-size:16px;font-weight:600;color:var(--text-main);margin:0}.modal-close{width:24px;height:24px;border-radius:50%;border:1px solid var(--border-subtle);background:var(--bg-panel);color:var(--text-main);font-size:16px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal-close:hover{background:var(--danger-soft);border-color:var(--danger);color:var(--danger);transform:rotate(90deg)}.modal-content{padding:24px;line-height:1.4;font-size:13px}.modal-content h3{font-size:14px;font-weight:600;color:var(--text-main);margin:16px 0 8px}.modal-content h3:first-child{margin-top:0}.modal-content ol,.modal-content ul{margin:12px 0;padding-left:20px}.modal-content li{margin:6px 0;color:var(--text-muted);font-size:13px}.modal-content p{margin:12px 0;color:var(--text-muted);font-size:13px}.usage-note{margin:16px 0;padding:12px;background:var(--accent-soft);border-radius:var(--radius-md);border-left:4px solid var(--accent)}.usage-note p{margin:0;color:var(--text-main);line-height:1.4;font-size:13px}.usage-note a{color:var(--accent);text-decoration:none;font-weight:600}.usage-note a:hover{text-decoration:underline}@media (min-width: 1025px) and (max-width: 1366px){.layout-sidebar{flex:0 0 260px}.chart-container{height:380px;min-height:380px}.panel{padding:14px 16px}}@media (min-width: 769px) and (max-width: 1200px){.header-content{align-items:center;gap:16px}.header-actions{align-self:center;justify-content:flex-end}.layout-content{flex-direction:column}.layout-sidebar{flex:none;width:100%;flex-direction:row;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.layout-sidebar::-webkit-scrollbar{height:6px}.layout-sidebar::-webkit-scrollbar-track{background:var(--bg-panel);border-radius:3px}.layout-sidebar::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}.panel{flex:0 0 280px}.chart-container{min-height:280px}}@media (max-width: 480px){.layout-root{padding:6px}.header{padding:10px 14px}.header-content{flex-direction:column;align-items:flex-start;gap:8px}.header-title{font-size:18px}.header-subtitle{font-size:11px}.header-actions{align-self:flex-end}.brand-text{flex-direction:column;align-items:flex-start;gap:4px}.layout-main{padding:4px}.layout-content{flex-direction:column;gap:8px}.layout-sidebar{flex-direction:column;gap:8px;width:100%;overflow-x:hidden;padding-bottom:0}.layout-body{gap:8px}.panel{width:100%;padding:10px 12px;min-height:0;height:auto}.empty-state-content{padding:20px 14px}.empty-state-icon{width:72px;height:72px}.empty-state-title{font-size:16px}.empty-state-button{padding:12px 20px;min-height:44px;font-size:14px}.chart-container{min-height:280px}.help-modal{width:calc(100% - 12px);max-width:calc(100% - 12px);max-height:94vh;margin:6px}.modal-header{padding:14px 18px}.modal-content{padding:18px}}
