:root{--background:#0a0a0a;--foreground:#ededed;--card-bg:#1a1a1a;--border:#333;--accent:#3b82f6;--accent-hover:#2563eb;--success:#22c55e;--warning:#f59e0b;--error:#ef4444}*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}body{color:var(--foreground);background:var(--background)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:1rem}.login-card{background:var(--card-bg);padding:2rem;border-radius:12px;border:1px solid var(--border);width:100%;max-width:400px}.login-title{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-size:.875rem;color:#888}.form-input{width:100%;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:8px;color:var(--foreground);font-size:1rem}.form-input:focus{outline:none;border-color:var(--accent)}.submit-btn{width:100%;padding:.75rem 1rem;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.submit-btn:hover{background:var(--accent-hover)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.error-message{color:var(--error);font-size:.875rem;margin-top:1rem;text-align:center}.dashboard-container{min-height:100vh;padding:1.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.dashboard-title{font-size:1.75rem;font-weight:600}.header-controls{display:flex;gap:1rem;align-items:center}.toggle-btn{background:var(--card-bg);color:var(--foreground)}.logout-btn,.toggle-btn{padding:.5rem 1rem;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.875rem}.logout-btn{background:transparent;color:#888}.logout-btn:hover{border-color:var(--error);color:var(--error)}.refresh-btn{padding:.5rem .75rem;background:var(--card-bg);border:1px solid var(--border);border-radius:6px;color:var(--foreground);cursor:pointer;font-size:1rem;transition:transform .2s}.refresh-btn:hover{background:var(--accent);border-color:var(--accent)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn:not(:disabled):active{transform:rotate(180deg)}.toggle-btn.active{background:var(--accent);border-color:var(--accent);animation:none}.live-btn.active{background:#22c55e;border-color:#22c55e;animation:pulse 2s infinite}.live-btn:disabled{opacity:.4;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border)}.stat-label{font-size:.875rem;color:#888;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:600}.section{background:var(--card-bg);border-radius:12px;border:1px solid var(--border);margin-bottom:2rem;overflow:hidden}.section-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.section-title{font-size:1.125rem;font-weight:600}.section-content{padding:1rem 1.5rem}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.data-table th{font-size:.75rem;text-transform:uppercase;color:#888;font-weight:500}.data-table tbody tr:hover{background:hsla(0,0%,100%,.02)}.data-table tbody tr:last-child td{border-bottom:none}.event-pill{display:inline-block;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:500;background:rgba(59,130,246,.2);color:var(--accent)}.clickable{cursor:pointer;transition:opacity .15s ease,background-color .15s ease}.clickable:hover{opacity:.8}.event-pill.clickable:hover{background:rgba(59,130,246,.35)}td.clickable:hover{background:rgba(59,130,246,.1)}.feedback-positive{background:rgba(34,197,94,.2);color:var(--success)}.feedback-negative{background:rgba(239,68,68,.2);color:var(--error)}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#888}.tabs{display:flex;gap:.5rem;margin-bottom:1rem}.tab{padding:.5rem 1rem;background:transparent;border:1px solid var(--border);border-radius:6px;color:#888;cursor:pointer;font-size:.875rem}.tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.chart-container{height:300px;display:flex;align-items:flex-end;gap:4px;padding:1rem 0}.chart-bar{flex:1 1;background:var(--accent);border-radius:4px 4px 0 0;min-height:4px;position:relative}.chart-bar:hover{background:var(--accent-hover)}.chart-bar-label{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-size:.625rem;color:#666;white-space:nowrap}.last-update{font-size:.75rem;color:#888;display:flex;align-items:center;gap:.25rem}.last-update:has(+.logout-btn){margin-right:.5rem}.error-banner{background:rgba(239,68,68,.15);border:1px solid var(--error);color:var(--error);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.error-banner,.status-indicator{font-size:.875rem}.status-indicator.connected{color:var(--success)}.status-indicator.connecting{color:var(--warning);animation:pulse 1.5s infinite}.status-indicator.error{color:var(--error)}.days-select{padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:6px;color:var(--foreground);font-size:.875rem;cursor:pointer}.days-select:focus{outline:none;border-color:var(--accent)}.toggle-btn.small{padding:.375rem .75rem;font-size:.75rem}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.live-events-container{max-height:300px;overflow-y:auto;padding:.5rem 0}.live-event{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;border-bottom:1px solid var(--border);animation:slideIn .3s ease-out}.live-event:last-child{border-bottom:none}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.live-event-time{font-size:.75rem;color:#666;min-width:60px}.live-event-device{font-family:monospace;font-size:.75rem;color:#888}.live-event-platform{font-size:.75rem;color:#888;margin-left:auto}.live-dot{display:inline-block;margin-left:.5rem;color:#666}.live-dot.active{color:var(--success);animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.filters-bar{display:flex;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-select{padding:.5rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:6px;color:var(--foreground);font-size:.875rem;min-width:150px}.filter-select:focus{outline:none;border-color:var(--accent)}.filter-input{padding:.5rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:6px;color:var(--foreground);font-size:.875rem;min-width:150px}.filter-input:focus{outline:none;border-color:var(--accent)}.filter-input::placeholder{color:#666}.time-cell{font-size:.75rem;color:#888;white-space:nowrap}.mono{font-family:monospace;font-size:.75rem}.metadata-cell{font-size:.75rem;color:#888;max-width:200px;overflow:hidden;text-overflow:ellipsis}.metadata-cell code{background:hsla(0,0%,100%,.05);padding:.125rem .375rem;border-radius:4px;font-size:.625rem}.no-data{text-align:center;color:#666;padding:2rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem;border-top:1px solid var(--border)}.pagination-info{font-size:.875rem;color:#888}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.breakdown-bars{gap:.75rem}.breakdown-bars,.breakdown-item{display:flex;flex-direction:column}.breakdown-item{gap:.25rem}.breakdown-label{display:flex;justify-content:space-between;font-size:.875rem}.breakdown-label span:last-child{color:#888;font-size:.75rem}.breakdown-bar-bg{height:8px;background:hsla(0,0%,100%,.1);border-radius:4px;overflow:hidden}.breakdown-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease-out}.clickable-row{cursor:pointer}.clickable-row:hover{background:rgba(59,130,246,.1)!important}.config-form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.config-form .filter-input,.config-form .filter-select{flex:1 1;min-width:150px}.chain-breadcrumb{display:flex;align-items:center;gap:.5rem;padding:1rem;background:rgba(59,130,246,.1);border-radius:8px;margin-bottom:1rem;flex-wrap:wrap;min-height:48px}.chain-hint{color:#888;font-size:.875rem}.chain-reset{background:rgba(239,68,68,.2);color:var(--error);border:none;border-radius:4px;padding:.25rem .5rem;cursor:pointer;font-size:.75rem;transition:background .15s ease}.chain-reset:hover{background:rgba(239,68,68,.4)}.chain-step{display:flex;align-items:center;gap:.5rem}.chain-event{background:rgba(59,130,246,.2);color:var(--accent);border:1px solid rgba(59,130,246,.3);border-radius:99px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease}.chain-event:hover{background:rgba(59,130,246,.35);border-color:rgba(59,130,246,.5)}.chain-arrow{color:#666;font-size:.875rem}.chain-stats{padding:.75rem 1rem;margin-bottom:1rem}.chain-total{font-size:.875rem;color:#888}.chain-start-grid{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem}.chain-start-btn{background:transparent;border:1px solid var(--border);border-radius:8px;padding:.5rem;cursor:pointer;transition:all .15s ease}.chain-start-btn:hover{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.3)}.chain-percentage{position:relative;height:24px;min-width:100px;background:hsla(0,0%,100%,.1);border-radius:4px;overflow:hidden}.chain-percentage-bar{position:absolute;top:0;left:0;height:100%;background:rgba(59,130,246,.3);transition:width .3s ease}.chain-percentage-text{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;height:100%;padding-right:.5rem;font-size:.75rem;font-weight:500}.chain-end-row{opacity:.6}.event-pill.chain-end{background:hsla(220,9%,46%,.2);color:#888}.flag-value{font-family:var(--font-mono);padding:.25rem .5rem;background:rgba(59,130,246,.1);border-radius:4px;font-size:.875rem}.flag-value.clickable:hover{background:rgba(59,130,246,.2)}.flag-edit-row{display:flex;gap:.25rem;align-items:center}.flag-value-input{width:80px;padding:.25rem .5rem;background:var(--card-bg);border:1px solid var(--accent);border-radius:4px;color:var(--text);font-family:var(--font-mono);font-size:.875rem}.flag-value-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,130,246,.2)}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;align-items:stretch}.header-controls{flex-wrap:wrap;justify-content:center}.tabs{flex-wrap:wrap}.filters-bar{flex-direction:column}.filter-input,.filter-select{width:100%}.breakdown-grid{grid-template-columns:1fr}}