:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--accent-primary: #3b82f6;--accent-hover: #2563eb;--accent-secondary: #10b981;--border-color: #334155;--error: #ef4444;--warning: #f59e0b;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #e2e8f0;--text-primary: #0f172a;--text-secondary: #64748b;--border-color: #cbd5e1;--accent-primary: #2563eb;--accent-hover: #1d4ed8}body{margin:0;font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#475569}.container{max-width:1400px;margin:0 auto;padding:2rem}.card{background-color:var(--bg-secondary);border-radius:.75rem;border:1px solid var(--border-color);box-shadow:var(--shadow-md);padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;gap:.5rem}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:#475569}.input{background-color:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem .75rem;border-radius:.5rem;width:100%;outline:none;transition:border-color .2s}.input:focus{border-color:var(--accent-primary)}.label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.upload-container{width:100%;max-width:600px;margin:4rem auto;text-align:center}.upload-area{background-color:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:1rem;padding:3rem 2rem;transition:all .3s ease;position:relative;cursor:pointer}.upload-area:hover{border-color:var(--accent-primary);background-color:#3b82f60d}.upload-area.active{border-color:var(--accent-primary);background-color:#3b82f61a;transform:scale(1.02)}.upload-input{display:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.icon-wrapper{background-color:var(--bg-tertiary);padding:1rem;border-radius:50%;margin-bottom:.5rem;color:var(--accent-primary)}.upload-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.upload-subtitle{margin:0;color:var(--text-secondary);margin-bottom:1rem}.error-message{margin-top:1.5rem;padding:1rem;background-color:#ef44441a;border:1px solid var(--error);border-radius:.5rem;color:var(--error);display:flex;align-items:center;justify-content:center;gap:.5rem}.log-table-container{overflow:hidden}.table-wrapper{overflow-x:auto}.log-table{width:100%;border-collapse:collapse;font-size:.875rem;text-align:left}.log-table th,.log-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.log-table thead{font-weight:700!important}.log-table th{background-color:var(--bg-tertiary);color:var(--text-secondary);font-weight:600;position:sticky;top:0;-webkit-user-select:none;user-select:none}.sortable-header{cursor:pointer}.sortable-header:hover{color:var(--text-primary);background-color:#475569}.th-content{display:flex;align-items:center;gap:.5rem}.log-table tr:hover td{background-color:#ffffff05}.toggle-cell{cursor:pointer;width:40px;text-align:center;color:var(--text-secondary)}.toggle-cell:hover{color:var(--accent-primary)}.detail-row td{background-color:#0003;padding:1rem;white-space:pre-wrap}.json-detail{margin:0;font-family:Fira Code,monospace;font-size:.75rem;color:var(--text-secondary);max-height:400px;overflow-y:auto}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-top:1px solid var(--border-color)}.page-info{color:var(--text-secondary);font-size:.875rem}.groups-list{display:flex;flex-direction:column;gap:1rem}.group-item{padding:0;overflow:hidden}.group-header{display:flex;align-items:center;gap:1rem;padding:1rem;cursor:pointer;background-color:var(--bg-secondary);transition:background-color .2s}.group-header:hover{background-color:var(--bg-tertiary)}.group-title{display:flex;gap:.5rem;font-weight:500}.group-key{color:var(--text-secondary)}.group-value{color:var(--accent-primary)}.badge{background-color:var(--bg-primary);padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;color:var(--text-secondary);margin-left:auto;border:1px solid var(--border-color)}.group-content{border-top:1px solid var(--border-color)}.no-results{text-align:center;padding:4rem 2rem}.no-results-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.no-results-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.no-results-message{color:var(--text-secondary);max-width:500px;margin:0 auto;line-height:1.6}.action-pill{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.action-allow{background-color:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.action-block{background-color:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.action-other{background-color:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.controls-container{margin-bottom:1.5rem}.controls-header{display:flex;justify-content:space-between;align-items:center}.controls-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;width:100%;justify-content:space-between}.left-controls{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.group-by-control{display:flex;align-items:center;gap:.5rem}.label-inline{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.select-inline{width:auto;min-width:200px}.filters-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.filter-row{display:grid;grid-template-columns:2fr 1fr 2fr auto;gap:1rem;margin-bottom:.5rem;align-items:center}.btn-icon{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:.25rem}.btn-icon:hover{background-color:var(--bg-tertiary);color:var(--error)}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.columns-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);max-height:300px;overflow-y:auto}.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:.25rem}.checkbox-label:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.custom-header-control{display:flex;align-items:center;gap:.5rem}.custom-headers-list{margin:16px 0}.custom-headers-tags{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.custom-header-tag{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);transition:all .2s ease}.custom-header-tag:hover{border-color:var(--accent-primary);background-color:var(--bg-secondary)}.remove-header-btn{cursor:pointer;color:var(--text-secondary);width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;border:none;background-color:#ffffff1a;transition:all .2s}.remove-header-btn:hover{background-color:var(--error);color:#fff}.input{width:216px}.clear-all-btn{margin-left:1rem}.time-range-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.time-range-inputs{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.time-input-group{display:flex;flex-direction:column;gap:.25rem}.time-input-group .label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.time-range-inputs .btn{width:38px;height:38px;padding:0;border-radius:50%;flex-shrink:0}.shortcuts-container{margin-bottom:1.5rem}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:.75rem;border-radius:.5rem;transition:background-color .2s}.shortcuts-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.shortcuts-icon{color:var(--accent-primary)}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1rem;margin-top:.5rem}.shortcut-btn{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;text-align:left;cursor:pointer;transition:all .2s}.shortcut-btn:hover{background-color:var(--bg-tertiary);border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.shortcut-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.shortcut-desc{font-size:.75rem;color:var(--text-secondary)}.app-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-content{display:flex;justify-content:space-between;align-items:center;padding:0 2rem}.logo{display:flex;align-items:center;gap:.75rem;color:var(--accent-primary)}.logo h1{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.file-info{display:flex;align-items:center;gap:.5rem;font-weight:500}.main-content{padding-top:2rem;padding-bottom:4rem}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.header-actions{display:flex;align-items:center;gap:1rem}.btn-icon-only{padding:.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;aspect-ratio:1}
