.dashboard{--gruvbox-bg: #282828;--gruvbox-bg0-h: #1d2021;--gruvbox-bg1: #3c3836;--gruvbox-bg2: #504945;--gruvbox-bg3: #665c54;--gruvbox-fg: #ebdbb2;--gruvbox-fg0: #fbf1c7;--gruvbox-fg2: #d5c4a1;--gruvbox-fg3: #bdae93;--gruvbox-fg4: #a89984;--gruvbox-red: #fb4934;--gruvbox-green: #b8bb26;--gruvbox-yellow: #fabd2f;--gruvbox-blue: #83a598;--gruvbox-purple: #d3869b;--gruvbox-aqua: #8ec07c;--gruvbox-orange: #fe8019;--gruvbox-gray: #928374}.dashboard{font-family:JetBrains Mono,Consolas,Monaco,monospace;font-size:12px;line-height:1.4;letter-spacing:.02em;background:var(--gruvbox-bg0-h);color:var(--gruvbox-fg);min-height:100vh;border:1px solid var(--gruvbox-bg3)}.dashboard *{border-radius:0!important;box-shadow:none!important}.stats-bar{background:var(--gruvbox-bg);border-bottom:1px solid var(--gruvbox-bg2);padding:8px 16px;display:flex;flex-wrap:wrap;gap:4px 20px}.stats-bar .stat{display:inline-flex;gap:6px}.stats-bar .stat-label{color:var(--gruvbox-fg4);text-transform:uppercase;font-size:10px}.stats-bar .stat-value{color:var(--gruvbox-fg0);font-weight:600}.stats-bar .stat-value.highlight{color:var(--gruvbox-green)}.stats-bar .stat-value.warning{color:var(--gruvbox-red)}.stats-bar .stat-value.live{color:var(--gruvbox-yellow);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.insights-panel{border-bottom:1px solid var(--gruvbox-bg2)}.insights-tabs{display:flex;background:var(--gruvbox-bg1);border-bottom:1px solid var(--gruvbox-bg2)}.insights-tabs .tab{padding:6px 12px;background:transparent;border:none;border-right:1px solid var(--gruvbox-bg2);color:var(--gruvbox-fg4);cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;transition:all .15s}.insights-tabs .tab:hover{color:var(--gruvbox-fg);background:var(--gruvbox-bg2)}.insights-tabs .tab.active{color:var(--gruvbox-aqua);background:var(--gruvbox-bg0-h);border-bottom:2px solid var(--gruvbox-aqua);margin-bottom:-1px}.insights-content{padding:10px 14px;background:var(--gruvbox-bg0-h);display:none}.insights-content.active{display:block}.insights-list{display:flex;flex-direction:column;gap:6px}.insights-row{display:grid;grid-template-columns:1fr 60px 100px;gap:10px;padding:6px 0;border-bottom:1px solid var(--gruvbox-bg1);font-size:11px}.insights-row:last-child{border-bottom:none}.insights-row .label{color:var(--gruvbox-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.insights-row .value{color:var(--gruvbox-aqua);text-align:right}.insights-row .bar{background:var(--gruvbox-bg2);height:14px;position:relative}.insights-row .bar-fill{position:absolute;left:0;top:0;height:100%;background:var(--gruvbox-blue)}.traffic-stats{display:flex;flex-wrap:wrap;gap:20px 40px}.traffic-stat{display:flex;flex-direction:column;gap:4px}.traffic-stat .label{font-size:10px;color:var(--gruvbox-fg4);text-transform:uppercase}.traffic-stat .value{font-size:20px;font-weight:600;color:var(--gruvbox-fg0)}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;padding:10px 16px;background:var(--gruvbox-bg1);border-bottom:1px solid var(--gruvbox-bg2)}.filter-input{padding:8px 12px;background:var(--gruvbox-bg0-h);border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg);font-family:inherit;font-size:11px;min-width:140px}.filter-input::placeholder{color:var(--gruvbox-fg4);text-transform:uppercase}.filter-input:focus{outline:none;border-color:var(--gruvbox-blue)}.dropdown{position:relative;min-width:130px}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 12px;background:var(--gruvbox-bg0-h);border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg);font-family:inherit;font-size:11px;cursor:pointer;text-align:left}.dropdown-trigger:hover,.dropdown-trigger.open{border-color:var(--gruvbox-blue)}.dropdown-trigger .placeholder{color:var(--gruvbox-fg4);text-transform:uppercase}.dropdown-arrow{width:10px;height:10px;color:var(--gruvbox-fg4)}.dropdown-trigger.open .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background:var(--gruvbox-bg);border:1px solid var(--gruvbox-bg3);z-index:50}.dropdown-option{display:block;width:100%;padding:8px 12px;background:transparent;border:none;color:var(--gruvbox-fg2);font-family:inherit;font-size:11px;text-align:left;cursor:pointer}.dropdown-option:hover{background:var(--gruvbox-bg1);color:var(--gruvbox-fg)}.dropdown-option.selected{color:var(--gruvbox-aqua)}.dashboard-content{display:grid;grid-template-columns:1fr;min-height:calc(100vh - 200px)}@media(min-width:1024px){.dashboard-content.with-panel{grid-template-columns:1fr 450px}}.visitor-table-wrap{overflow-x:auto}.visitor-table{width:100%;border-collapse:collapse;font-size:11px}.visitor-table th,.visitor-table td{padding:8px 10px;border-bottom:1px solid var(--gruvbox-bg1);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.visitor-table th{background:var(--gruvbox-bg1);color:var(--gruvbox-fg4);font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--gruvbox-bg3);position:sticky;top:0;z-index:1}.visitor-table tbody tr{cursor:pointer;transition:background .15s}.visitor-table tbody tr:nth-child(2n){background:var(--gruvbox-bg)}.visitor-table tbody tr:hover{background:var(--gruvbox-bg1)}.visitor-table tbody tr.selected{background:var(--gruvbox-bg2);outline:1px solid var(--gruvbox-blue);outline-offset:-1px}.visitor-table .col-num{width:30px;text-align:right;color:var(--gruvbox-fg4)}.visitor-table .col-hash{color:var(--gruvbox-blue);font-size:10px}.visitor-table .col-name{color:var(--gruvbox-fg0);max-width:120px}.visitor-table .col-loc{color:var(--gruvbox-yellow)}.visitor-table .col-ref{color:var(--gruvbox-fg3);max-width:100px}.visitor-table .col-num-data{text-align:right;color:var(--gruvbox-aqua)}.visitor-table .col-time{color:var(--gruvbox-fg3)}.journey-panel{border-left:1px solid var(--gruvbox-bg3);background:var(--gruvbox-bg0-h);overflow-y:auto;max-height:calc(100vh - 150px)}.journey-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--gruvbox-bg1);border-bottom:1px solid var(--gruvbox-bg3);position:sticky;top:0;z-index:1}.journey-header .visitor-id{display:flex;flex-direction:column;gap:3px}.journey-header .name{color:var(--gruvbox-fg0);font-weight:600;font-size:13px;text-transform:capitalize}.journey-header .hash{font-size:9px;color:var(--gruvbox-blue)}.journey-header .close-btn{background:none;border:none;padding:4px 8px;color:var(--gruvbox-fg4);cursor:pointer;font-family:inherit;font-size:18px;line-height:1;opacity:.5;transition:opacity .15s,color .15s}.journey-header .close-btn:hover{opacity:1;color:var(--gruvbox-red)}.journey-stats{padding:14px;border-bottom:1px solid var(--gruvbox-bg1);display:grid;grid-template-columns:repeat(2,1fr);gap:6px 20px;font-size:11px}.journey-stats .stat-row{display:flex;justify-content:space-between}.journey-stats .label{color:var(--gruvbox-fg4);text-transform:uppercase}.journey-stats .value{color:var(--gruvbox-fg0)}.journey-section{padding:14px;border-bottom:1px solid var(--gruvbox-bg1)}.journey-section:last-child{border-bottom:none}.journey-section-title{font-size:10px;font-weight:600;color:var(--gruvbox-aqua);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.page-table{font-size:10px}.page-row{display:grid;grid-template-columns:1fr 40px 50px 80px;gap:10px;padding:6px 0;border-bottom:1px solid var(--gruvbox-bg1)}.page-row:last-child{border-bottom:none}.page-row .path{color:var(--gruvbox-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-row .visits{color:var(--gruvbox-aqua);text-align:right}.page-row .time{color:var(--gruvbox-fg3);text-align:right}.page-row .scroll-bar{background:var(--gruvbox-bg2);height:14px;position:relative}.page-row .scroll-fill{position:absolute;left:0;top:0;height:100%;background:var(--gruvbox-blue)}.page-row .scroll-value{position:absolute;right:3px;top:0;font-size:9px;line-height:14px;color:var(--gruvbox-fg0)}.event-log{font-size:10px;background:var(--gruvbox-bg0-h);max-height:400px;overflow-y:auto}.event-log .session-block{margin-bottom:14px}.event-log .session-header{color:var(--gruvbox-fg4);margin-bottom:6px;padding-bottom:6px;border-bottom:1px dashed var(--gruvbox-bg2)}.event-log .event-row{display:grid;grid-template-columns:50px 70px 1fr;gap:10px;padding:3px 0}.event-log .timestamp{color:var(--gruvbox-fg4)}.event-log .type{font-weight:600;text-transform:uppercase}.event-log .event-row.pageview .type{color:var(--gruvbox-green)}.event-log .event-row.click .type{color:var(--gruvbox-blue)}.event-log .event-row.scroll .type{color:var(--gruvbox-yellow)}.event-log .event-row.exit .type{color:var(--gruvbox-red)}.event-log .details{color:var(--gruvbox-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.password-gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--gruvbox-bg0-h);z-index:100}.password-form{display:flex;border:1px solid var(--gruvbox-bg3)}.password-input{padding:14px 18px;background:var(--gruvbox-bg);border:none;color:var(--gruvbox-fg);font-family:inherit;font-size:14px;width:300px}.password-input::placeholder{color:var(--gruvbox-fg4);text-transform:uppercase}.password-input:focus{outline:none}.password-input:disabled{opacity:.5;cursor:not-allowed}.password-submit{padding:14px 24px;background:var(--gruvbox-bg1);border:none;border-left:1px solid var(--gruvbox-bg3);color:var(--gruvbox-aqua);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer}.password-submit:hover:not(:disabled){background:var(--gruvbox-aqua);color:var(--gruvbox-bg0-h)}.password-submit:disabled{opacity:.5;cursor:not-allowed}.password-error{position:absolute;margin-top:60px;color:var(--gruvbox-red);font-size:11px}.loading{display:flex;align-items:center;justify-content:center;padding:32px;color:var(--gruvbox-fg4)}.spinner{width:18px;height:18px;border:2px solid var(--gruvbox-bg2);border-top-color:var(--gruvbox-aqua);animation:spin .8s linear infinite}.empty-state{text-align:center;padding:32px;color:var(--gruvbox-fg4);font-size:11px;text-transform:uppercase}.pagination{display:flex;justify-content:center;padding:14px;border-top:1px solid var(--gruvbox-bg1)}.pagination-btn{padding:8px 20px;background:transparent;border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg3);font-family:inherit;font-size:11px;text-transform:uppercase;cursor:pointer}.pagination-btn:hover:not(:disabled){border-color:var(--gruvbox-aqua);color:var(--gruvbox-aqua)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.advanced-analytics-panel{border-bottom:1px solid var(--gruvbox-bg2)}.analytics-tabs{display:flex;background:var(--gruvbox-bg1);border-bottom:1px solid var(--gruvbox-bg2)}.analytics-tabs .tab{padding:6px 12px;background:transparent;border:none;border-right:1px solid var(--gruvbox-bg2);color:var(--gruvbox-fg4);cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;transition:all .15s}.analytics-tabs .tab:hover{color:var(--gruvbox-fg);background:var(--gruvbox-bg2)}.analytics-tabs .tab.active{color:var(--gruvbox-green);background:var(--gruvbox-bg0-h);border-bottom:2px solid var(--gruvbox-green);margin-bottom:-1px}.analytics-content{padding:12px;background:var(--gruvbox-bg0-h);display:none}.analytics-content.active{display:block}.analytics-controls{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.date-range-picker{display:flex;align-items:center;gap:8px}.date-input{padding:6px 10px;background:var(--gruvbox-bg1);border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg);font-family:inherit;font-size:11px}.date-input:focus{outline:none;border-color:var(--gruvbox-aqua)}.date-separator{color:var(--gruvbox-fg4)}.interval-selector{display:flex;gap:4px}.interval-btn{padding:6px 12px;background:var(--gruvbox-bg1);border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg3);font-family:inherit;font-size:10px;cursor:pointer;transition:all .15s}.interval-btn:hover{border-color:var(--gruvbox-aqua);color:var(--gruvbox-aqua)}.interval-btn.active{background:var(--gruvbox-aqua);color:var(--gruvbox-bg0-h);border-color:var(--gruvbox-aqua)}.time-series-chart{background:var(--gruvbox-bg1);padding:16px}.chart-legend{display:flex;gap:20px;margin-bottom:12px;font-size:10px}.legend-item{display:flex;align-items:center;gap:6px;color:var(--gruvbox-fg)}.legend-item .legend-dot{width:10px;height:10px;display:inline-block}.legend-item.visitors .legend-dot{background:var(--gruvbox-aqua)}.legend-item.pageviews .legend-dot{background:var(--gruvbox-yellow)}.chart-svg{width:100%;height:auto;max-height:250px}.chart-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:9px;color:var(--gruvbox-fg4)}.chart-label{text-align:center}.chart-empty{text-align:center;padding:40px;color:var(--gruvbox-fg4);font-size:11px}.cohort-analysis{background:var(--gruvbox-bg1);padding:16px}.cohort-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.cohort-card{background:var(--gruvbox-bg0-h);border:1px solid var(--gruvbox-bg3);padding:14px}.cohort-title{color:var(--gruvbox-green);font-size:11px;font-weight:600;margin-bottom:12px;letter-spacing:.05em}.cohort-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.cohort-stat{display:flex;flex-direction:column;gap:4px}.cohort-stat .label{font-size:9px;color:var(--gruvbox-fg4);text-transform:uppercase}.cohort-stat .value{font-size:16px;font-weight:600;color:var(--gruvbox-fg0)}.cohort-empty{text-align:center;padding:40px;color:var(--gruvbox-fg4);font-size:11px}.heatmap{background:var(--gruvbox-bg1);padding:16px;overflow-x:auto}.heatmap-table{display:flex;flex-direction:column;min-width:400px}.heatmap-header,.heatmap-row{display:grid;grid-template-columns:200px repeat(auto-fill,80px);gap:2px}.heatmap-header{font-weight:600;border-bottom:2px solid var(--gruvbox-bg3);margin-bottom:4px}.heatmap-cell{padding:8px;font-size:10px;text-align:center;background:var(--gruvbox-bg0-h)}.heatmap-header .heatmap-cell{color:var(--gruvbox-aqua);font-weight:600}.heatmap-row .path-cell{text-align:left;color:var(--gruvbox-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.heatmap-row .value-cell{color:var(--gruvbox-fg0);font-weight:600}.heatmap-empty{text-align:center;padding:40px;color:var(--gruvbox-fg4);font-size:11px}.bounce-rate-table{background:var(--gruvbox-bg1);padding:16px;overflow-x:auto}.bounce-table{width:100%;border-collapse:collapse;font-size:11px}.bounce-table th,.bounce-table td{padding:8px 10px;border-bottom:1px solid var(--gruvbox-bg2);text-align:left}.bounce-table th{background:var(--gruvbox-bg0-h);color:var(--gruvbox-aqua);font-weight:600;text-transform:uppercase;font-size:10px}.bounce-table tbody tr:hover{background:var(--gruvbox-bg2)}.bounce-table .path-col{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--gruvbox-fg)}.bounce-table .num-col{text-align:right;color:var(--gruvbox-fg0)}.bounce-table .time-col{text-align:right;color:var(--gruvbox-fg3)}.bounce-table .high-bounce{color:var(--gruvbox-red);font-weight:600}.bounce-empty{text-align:center;padding:40px;color:var(--gruvbox-fg4);font-size:11px}.table-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:8px 16px;background:var(--gruvbox-bg);border-bottom:1px solid var(--gruvbox-bg2);flex-wrap:wrap}.toolbar-filters{display:flex;gap:10px;flex:1;min-width:300px}.toolbar-actions{display:flex;gap:16px;align-items:center}.export-section{display:flex;align-items:center;gap:8px}.export-label{font-size:10px;color:var(--gruvbox-fg4);text-transform:uppercase}.export-btn{padding:6px 14px;background:var(--gruvbox-bg0-h);border:1px solid var(--gruvbox-bg3);color:var(--gruvbox-fg);font-family:inherit;font-size:10px;cursor:pointer;transition:all .15s}.export-btn:hover:not(:disabled){border-color:var(--gruvbox-green);color:var(--gruvbox-green)}.export-btn:disabled{opacity:.5;cursor:not-allowed}.export-status{font-size:10px;color:var(--gruvbox-yellow);animation:pulse 1.5s ease-in-out infinite}@media(max-width:768px){.dashboard{font-size:11px}.stats-bar{flex-direction:column;gap:6px}.insights-tabs,.analytics-tabs{flex-wrap:wrap}.table-toolbar{flex-direction:column;align-items:stretch}.toolbar-filters{flex-direction:column;min-width:auto}.toolbar-actions{flex-direction:column;gap:8px}.filter-input,.dropdown{width:100%}.export-section{width:100%;justify-content:space-between}.visitor-table{font-size:10px}.visitor-table th,.visitor-table td{padding:6px 8px}.journey-panel{border-left:none;border-top:1px solid var(--gruvbox-bg3)}.cohort-grid{grid-template-columns:1fr}.analytics-controls{flex-direction:column;align-items:stretch}}
