:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-main: #f5f7fb;--bg-card: #ffffff;--border-subtle: #e5e7eb;--text-main: #111827;--text-subtle: #6b7280;--accent: #2563eb;--accent-soft: #e0e7ff;--danger: #dc2626;--success: #16a34a;--info: #1d4ed8;--warning: #f97316;--radius-lg: 12px;--shadow-soft: 0 10px 25px rgba(0, 0, 0, .04);--card-padding: 1.1rem}body{margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-main);color:var(--text-main)}.app-root{max-width:1100px;margin:0 auto;padding:24px 16px 40px}.app-header{text-align:center;margin-bottom:24px}.cluster-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:12px;align-items:stretch;margin-bottom:18px}.cluster-grid>.app-section,.cluster-grid>section,.cluster-grid>*{height:100%}.app-header h1{margin:0 0 8px;font-size:1.8rem;font-weight:700}.app-subtitle{margin:0;font-size:.95rem;color:var(--text-subtle)}.app-section{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:16px 16px 20px;margin-bottom:18px;border:1px solid var(--border-subtle)}.section-title{margin:0 0 12px;font-size:1.2rem;border-left:4px solid var(--accent);padding-left:8px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-bottom:12px}.upload-card{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--card-padding);background-color:var(--bg-card);box-shadow:var(--shadow-soft)}.upload-card h3{margin:0 0 6px;font-size:1rem}.upload-desc{margin:0 0 10px;font-size:.85rem;color:var(--text-subtle);line-height:1.4}.file-input{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;font-size:.9rem;border-radius:999px;background-color:var(--accent);color:#fff;cursor:pointer;overflow:hidden;-webkit-user-select:none;user-select:none}.file-input span{pointer-events:none}.file-input input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.alert{margin-top:8px;padding:8px 10px;border-radius:8px;font-size:.85rem;line-height:1.4;display:flex;align-items:flex-start;gap:6px}.alert--info{background-color:#eef2ff;color:#312e81;border:1px solid #c7d2fe}.alert--success{background-color:#ecfdf3;color:var(--success);border:1px solid #bbf7d0}.alert--error{background-color:#fef2f2;color:var(--danger);border:1px solid #fecdd3}.placeholder-text{margin:0;font-size:.9rem;color:var(--text-subtle)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.clear-button{border:1px solid var(--border-subtle);background-color:#fff;color:var(--text-main);padding:6px 12px;border-radius:999px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.clear-button:hover{background-color:#ffecec;border-color:#ffcdd2;color:var(--danger)}.summary-card{padding:12px 14px;border-radius:var(--radius-lg);background-color:var(--bg-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft)}.summary-card--muted{background-color:#f8fafc;border-color:#e5e7eb;box-shadow:0 4px 12px #00000008}.summary-card--muted .summary-value{font-size:1.2rem}.summary-card--muted .summary-label{color:#7a8293}.summary-label{font-size:.9rem;color:var(--text-subtle);margin-bottom:4px}.summary-value{font-size:1.35rem;font-weight:700}.summary-value .unit{font-size:.9rem;margin-left:2px;color:var(--text-subtle)}.export-block{margin-top:14px;padding-top:10px;border-top:1px dashed var(--border-subtle)}.export-title{margin:0 0 6px;font-size:.95rem;font-weight:600}.export-buttons{display:flex;flex-wrap:wrap;gap:8px}.secondary-button{border:1px solid var(--border-subtle);background-color:#fff;color:var(--text-main);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:.88rem;transition:all .2s ease}.secondary-button:hover:not(:disabled){background-color:var(--accent-soft);border-color:#b0d4ff}.secondary-button:disabled{cursor:not-allowed;opacity:.6}.export-hint{margin:6px 0 0;color:var(--text-subtle);font-size:.85rem}.table-wrapper{width:100%;overflow-x:auto}.runs-table--stacked{min-width:720px}.runs-table{width:100%;border-collapse:collapse;font-size:.85rem}.runs-table thead{background-color:#f0f4f8}.runs-table th,.runs-table td{padding:6px 8px;border-bottom:1px solid #e0e0e0;text-align:left;white-space:nowrap}.runs-table--stacked thead th{position:sticky;top:0;background:var(--bg-card);z-index:5}.runs-table th{font-weight:600;font-size:.8rem;color:var(--text-subtle)}.runs-table tbody tr:nth-child(2n){background-color:#fafafa}.runs-table tbody tr:hover{background-color:#e8f4ff}.file-name-cell{max-width:200px;text-overflow:ellipsis;overflow:hidden}.row-selected{background-color:#fff7e6}.runs-table--stacked tbody tr{transition:background-color .2s ease}.stats-section{background:linear-gradient(135deg,#f7fbff,#fff 60%);border:1px solid #d7e4ff}.stats-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;box-shadow:0 6px 18px #1018280f}.stat-period-note{font-size:.85rem;color:#55627a;background:#eef4ff;border:1px dashed #c7d6ff;padding:8px 10px;border-radius:8px;margin:0 0 10px}.runs-table--stats thead{background:#0d47a1;color:#fff}.runs-table--stats th{color:#fff;border-bottom:none;font-weight:700}.runs-table--stats tbody tr:nth-child(2n){background-color:#f8fbff}.runs-table--stats tbody tr:hover{background-color:#f9fafb}.stat-period-label{font-weight:700;color:#0d47a1}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.chart-card{background-color:#fafafa;border:1px solid var(--border-subtle);border-radius:12px;padding:10px;box-shadow:var(--shadow-soft)}.chart-title{font-size:.95rem;font-weight:600;margin:0 0 8px}.simple-chart{position:relative;display:flex;flex-direction:column;gap:6px}.chart-area{position:relative;flex:1;min-height:180px}.chart-responsive{width:100%;height:100%}.chart-area svg{width:100%;height:100%;display:block}.chart-legend{display:flex;flex-wrap:wrap;gap:10px}.chart-legend__item{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-subtle)}.chart-legend__dot,.chart-tooltip__dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.chart-legend__symbol{width:16px;height:8px;border-radius:6px;border:2px solid transparent;display:inline-block}.chart-legend__symbol.is-dashed{border-style:dashed;background-image:linear-gradient(to right,currentColor 60%,transparent 0);background-size:8px 2px;background-repeat:repeat-x}.axis-label{font-size:.72rem;fill:#666}.x-label{text-anchor:middle}.chart-caption{font-size:.78rem;color:var(--text-subtle)}.chart-tooltip{position:absolute;transform:translate(-50%,-110%);pointer-events:none;background:#fff;padding:8px 10px;border-radius:8px;box-shadow:0 6px 18px #0000001f;border:1px solid #e0e0e0;font-size:.85rem}.chart-tooltip__label{font-weight:600;margin-bottom:4px}.chart-tooltip__item{display:flex;gap:6px;align-items:center;line-height:1.4}.chart-tooltip__name{color:var(--text-subtle)}.chart-tooltip__value{font-weight:600}.chart-highlight__label{font-size:.72rem;fill:#c62828;font-weight:600}.chart-badge__text{font-size:.75rem;font-weight:700}.chart-inline-warning{display:flex;gap:8px;align-items:flex-start;background:#fff4e5;border:1px solid #ffcc80;border-radius:10px;padding:8px 10px;margin:6px 0 10px}.chart-inline-warning__dot{width:10px;height:10px;border-radius:50%;background:#f4511e;margin-top:4px;flex-shrink:0}.chart-inline-warning__title{font-weight:700;font-size:.9rem;color:#bf360c;margin:0 0 2px}.chart-inline-warning__text{margin:0;font-size:.85rem;color:#5d4037;line-height:1.4}.table-controls{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin:4px 0 8px;font-size:.82rem;color:var(--text-subtle)}.table-total{color:var(--text-subtle)}.table-page-size select{margin:0 4px;padding:4px 8px;border-radius:8px;border:1px solid var(--border-subtle);font-size:.82rem}.table-pagination{display:inline-flex;align-items:center;gap:6px}.table-pagination .secondary-button{padding:4px 10px;font-size:.82rem}.table-page-info{color:var(--text-main)}.tab-switch{display:flex;gap:8px}.tab-button{border:1px solid var(--border-subtle);background-color:#fff;color:var(--text-main);padding:6px 10px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.tab-button.is-active{background-color:var(--accent-soft);border-color:#b0d4ff;color:var(--accent);font-weight:600}.filters-bar{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-left:auto}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:160px}.filter-label{font-size:.78rem;color:var(--text-subtle)}.filter-group select{border:1px solid var(--border-subtle);border-radius:8px;padding:6px 8px;font-size:.9rem;background-color:#fff}.filter-select{width:100%;position:relative}.select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border-subtle);border-radius:10px;padding:8px 10px;background-color:#fff;font-size:.92rem;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.select-trigger:focus-visible{outline:none;border-color:#90c2ff;box-shadow:0 0 0 3px #e3f2ff}.select-value{color:var(--text-main)}.select-arrow{font-size:.8rem;color:var(--text-subtle)}.select-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 8px 24px #00000014;z-index:20;padding:8px}.select-search{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--border-subtle);margin-bottom:8px;font-size:.9rem}.select-options{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.select-option{text-align:left;width:100%;border:1px solid transparent;background:#f7f9fb;border-radius:8px;padding:8px 10px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.select-option:hover{background:#eef5ff;border-color:#c7ddff}.select-option.is-active{border-color:#90c2ff;background:#e8f2ff;font-weight:600}.select-empty{text-align:center;color:var(--text-subtle);padding:6px;font-size:.9rem}.charts-empty{padding:14px 12px;background-color:#fafafa;border:1px dashed var(--border-subtle);border-radius:10px;color:var(--text-subtle);text-align:center}.app-footer{margin-top:8px;text-align:center;font-size:.8rem;color:var(--text-subtle)}.upload-meta{margin-top:10px;display:flex;flex-direction:column;gap:4px;color:var(--text-subtle);font-size:.92rem}.upload-meta__item{line-height:1.4}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.setting-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:10px;padding:14px;box-shadow:var(--shadow-soft)}.settings-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:10px 14px;background:#f8fafc;cursor:pointer}.settings-toggle__title{font-weight:700;color:var(--text-main)}.settings-toggle__hint,.settings-toggle__chevron{font-size:.9rem;color:var(--text-subtle)}.setting-label{font-weight:600;margin-bottom:8px}.setting-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.setting-field{display:flex;flex-direction:column;gap:4px;font-size:.95rem;color:var(--text-subtle)}.setting-field input{padding:8px;border-radius:8px;border:1px solid var(--border-subtle);font-size:.95rem}.setting-toggle{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.95rem}.setting-hint{margin:8px 0 0;color:var(--text-subtle);font-size:.85rem}.summary-note{margin-top:6px;font-size:.85rem;color:var(--text-subtle)}.link-button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.9rem;padding:0 4px}.link-button:hover{text-decoration:underline}@media(max-width:600px){.app-root{padding:16px 10px 28px}.app-header h1{font-size:1.4rem}.app-section{padding:12px 10px 14px}.summary-card{padding:8px 10px}.runs-table th,.runs-table td{padding:4px 6px;white-space:normal;word-break:break-word;font-size:.8rem}.filter-group{min-width:140px}.runs-table--stacked thead{display:none}.runs-table--stacked tbody tr{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 12px;padding:8px 10px;border:1px solid var(--border-subtle);border-radius:10px;margin-bottom:8px}.runs-table--stacked tbody td{padding:2px 0}.runs-table--stacked tbody td:before{content:attr(data-label);display:block;font-size:.78rem;color:var(--text-subtle);margin-bottom:2px}}
