:root,[data-theme=light]{--color-bg: #f9fafb;--color-surface: #ffffff;--color-surface-hover: #f3f4f6;--color-border: #e5e7eb;--color-text: #111827;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #eef2ff;--color-accent: #10b981;--color-accent-light: #d1fae5;--color-danger: #ef4444;--color-chart-bar: #6366f1;--color-chart-bar-hover: #4f46e5;--color-breakdown-fill: #6366f1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace}[data-theme=dark]{--color-bg: #0f1117;--color-surface: #1a1d2e;--color-surface-hover: #252940;--color-border: #2d3148;--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-primary: #818cf8;--color-primary-hover: #a5b4fc;--color-primary-light: #1e1b4b;--color-accent: #34d399;--color-accent-light: #064e3b;--color-danger: #f87171;--color-chart-bar: #818cf8;--color-chart-bar-hover: #a5b4fc;--color-breakdown-fill: #818cf8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}#app{min-height:100vh}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:var(--color-bg)}.login-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem;border:1px solid var(--color-border)}.login-card__header{text-align:center;margin-bottom:2rem}.login-card__header h1{font-size:1.75rem;font-weight:700;color:var(--color-primary);margin-bottom:.25rem}.login-card__header p{color:var(--color-text-secondary);font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.4rem}.form-group input{width:100%;padding:.7rem .9rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.login-error{background:#fef2f2;border:1px solid #fecaca;color:var(--color-danger);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem}[data-theme=dark] .login-error{background:#1c1017;border-color:#7f1d1d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-decoration:none}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover)}.btn--primary:disabled{opacity:.6;cursor:not-allowed}.btn--full{width:100%;padding:.75rem}.btn--ghost{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn--ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn--icon{background:transparent;color:var(--color-text-secondary);padding:.5rem;font-size:1.2rem;border-radius:var(--radius-sm)}.btn--icon:hover{background:var(--color-surface-hover)}.dashboard{min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header__left{display:flex;align-items:center;gap:1.25rem}.header__title{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.header__right{display:flex;align-items:center;gap:.5rem}.select{padding:.45rem 2rem .45rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:.85rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;cursor:pointer}.select:focus{outline:none;border-color:var(--color-primary)}.main{padding:1.5rem;max-width:1400px;margin:0 auto}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card--realtime{border-color:var(--color-accent);background:var(--color-accent-light)}.kpi-card__icon{font-size:1.5rem;flex-shrink:0}.kpi-card__content{display:flex;flex-direction:column}.kpi-card__value{font-size:1.5rem;font-weight:700;line-height:1.2;color:var(--color-text)}.kpi-card__label{font-size:.78rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.section h2{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--color-text)}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section__header h2{margin-bottom:0}.section__sub{font-size:.8rem;color:var(--color-text-muted)}.chart{overflow-x:auto;padding-bottom:.5rem}.chart__bars{display:flex;align-items:flex-end;gap:3px;height:180px;min-width:600px}.chart__bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.chart__bar{width:100%;background:var(--color-chart-bar);border-radius:3px 3px 0 0;position:relative;min-height:3px;transition:background .15s;cursor:pointer}.chart__bar:hover{background:var(--color-chart-bar-hover)}.chart__bar--empty{background:var(--color-border);opacity:.3}.chart__bar-val{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.65rem;color:var(--color-text-muted);white-space:nowrap;display:none}.chart__bar:hover .chart__bar-val{display:block}.chart__bar-label{font-size:.6rem;color:var(--color-text-muted);margin-top:4px;white-space:nowrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 768px){.grid-2{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{text-align:left;padding:.6rem .75rem;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.data-table td{padding:.55rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-surface-hover)}.cell-truncate{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-num{text-align:right;font-variant-numeric:tabular-nums;font-weight:500;color:var(--color-text)}.breakdown__row{display:flex;align-items:center;gap:.75rem;padding:.4rem 0}.breakdown__label{min-width:80px;font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.breakdown__bar-track{flex:1;height:8px;background:var(--color-surface-hover);border-radius:4px;overflow:hidden}.breakdown__bar-fill{height:100%;background:var(--color-breakdown-fill);border-radius:4px;transition:width .4s ease}.breakdown__pct{min-width:40px;text-align:right;font-size:.8rem;color:var(--color-text-muted);font-weight:500;font-variant-numeric:tabular-nums}.realtime-dot{display:inline-block;width:8px;height:8px;background:var(--color-accent);border-radius:50%;margin-left:.4rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.realtime-feed{display:flex;flex-direction:column;gap:.25rem}.realtime-item{display:grid;grid-template-columns:24px 1fr auto auto;gap:.75rem;align-items:center;padding:.5rem .6rem;border-radius:var(--radius-sm);font-size:.83rem;transition:background .1s}.realtime-item:hover{background:var(--color-surface-hover)}.realtime-item__icon{font-size:1rem;text-align:center}.realtime-item__url{color:var(--color-text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.realtime-item__meta{color:var(--color-text-muted);font-size:.78rem}.realtime-item__time{color:var(--color-text-muted);font-size:.75rem;font-variant-numeric:tabular-nums}.realtime-users{margin-top:1rem}.realtime-users__header{display:grid;grid-template-columns:60px 2fr 1fr 1fr 80px;gap:.5rem;padding:.5rem .75rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.realtime-users__row{display:grid;grid-template-columns:60px 2fr 1fr 1fr 80px;gap:.5rem;padding:.6rem .75rem;font-size:.83rem;border-bottom:1px solid var(--color-border)}.realtime-users__row:last-child{border-bottom:none}.realtime-users__visitor{font-family:monospace;font-size:.72rem;color:var(--color-text-muted);background:var(--color-surface-hover);padding:.15rem .35rem;border-radius:3px}.realtime-users__page{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.realtime-pages{margin-bottom:1.25rem}.realtime-pages h3{font-size:.85rem;font-weight:600;margin-bottom:.5rem}.realtime-pages__row{display:flex;justify-content:space-between;align-items:center;padding:.45rem .75rem;font-size:.83rem;border-bottom:1px solid var(--color-border)}.realtime-pages__row:last-child{border-bottom:none}.realtime-pages__path{font-weight:500}.realtime-pages__count{color:var(--color-text-muted);font-size:.78rem}.loading{text-align:center;padding:3rem;color:var(--color-text-muted);font-size:.95rem}.error-msg{text-align:center;padding:2rem;color:var(--color-danger);background:#fef2f2;border-radius:var(--radius-md);border:1px solid #fecaca}[data-theme=dark] .error-msg{background:#1c1017;border-color:#7f1d1d}.empty{color:var(--color-text-muted);font-size:.85rem;padding:1rem 0}.skeleton{background:linear-gradient(90deg,var(--color-surface-hover) 25%,var(--color-surface) 50%,var(--color-surface-hover) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;min-height:80px;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 640px){.header{padding:.75rem 1rem;flex-wrap:wrap;gap:.5rem}.header__title{font-size:1.1rem}.main{padding:1rem}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.kpi-card{padding:1rem}.kpi-card__value{font-size:1.25rem}.chart__bars{height:140px}.realtime-item{grid-template-columns:24px 1fr auto}.realtime-item__meta{display:none}.login-card{padding:1.5rem}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}}.kpi-card__trend{font-size:.72rem;font-weight:600;margin-left:.4rem}.kpi-card__trend--up{color:#10b981}.kpi-card__trend--down{color:#ef4444}.chart__container{display:flex;gap:.5rem}.chart__yaxis{display:flex;flex-direction:column;justify-content:space-between;font-size:.7rem;color:var(--color-text-muted);padding-bottom:20px;min-width:30px;text-align:right}.visitors-page{max-width:1100px;margin:0 auto;padding:1.5rem}.visitors-list__header{display:grid;grid-template-columns:80px 1.5fr 1.5fr 60px 100px;gap:.75rem;padding:.6rem .85rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.visitors-list__row{display:grid;grid-template-columns:80px 1.5fr 1.5fr 60px 100px;gap:.75rem;padding:.7rem .85rem;font-size:.83rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s}.visitors-list__row:hover{background:var(--color-surface-hover)}.visitors-list__id{font-family:monospace;font-size:.75rem;color:var(--color-primary);font-weight:600}.timeline-panel{margin-top:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.timeline-panel__header{margin-bottom:1.25rem}.timeline-panel__header h2{font-size:1rem;font-weight:600;margin-bottom:.35rem}.timeline-panel__meta{display:flex;gap:1rem;font-size:.78rem;color:var(--color-text-muted)}.timeline-day{margin-bottom:1.25rem}.timeline-day__date{font-size:.78rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid var(--color-border)}.timeline-entry{display:flex;align-items:flex-start;gap:.75rem;padding:.35rem 0 .35rem .5rem}.timeline-entry__dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary);margin-top:.35rem;flex-shrink:0}.timeline-entry__content{display:flex;gap:.75rem;align-items:baseline;flex-wrap:wrap}.timeline-entry__path{font-weight:500;font-size:.85rem}.timeline-entry__time{font-size:.72rem;color:var(--color-text-muted)}.timeline-entry__duration{font-size:.7rem;font-weight:600;color:var(--color-primary);background:var(--color-surface-hover);padding:.1rem .4rem;border-radius:3px}.timeline-entry__duration--active{color:#10b981;background:#10b98118}.timeline-entry__ref{font-size:.72rem;color:var(--color-text-muted);font-style:italic}@media (max-width: 640px){.visitors-list__header,.visitors-list__row{grid-template-columns:60px 1fr 80px}.visitors-list__header span:nth-child(3),.visitors-list__header span:nth-child(5),.visitors-list__row span:nth-child(3),.visitors-list__row span:nth-child(5){display:none}}.btn:focus-visible,.select:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}[data-theme=dark] .select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}
