*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0f;--bg-secondary:#0f1016;--bg-panel:#12131c;--bg-card:#181a28;--border:#252840;--text-primary:#d8dae5;--text-secondary:#7b7f9e;--text-muted:#4a4d6a;--accent:#6ea8d7;--risk-calm:#1a6b4a;--risk-low:#3d8b37;--risk-medium:#b8a02e;--risk-high:#d4822a;--risk-danger:#c93d3d;--risk-extreme:#8b1a1a;--success:#1a6b4a;--font-mono:ui-monospace, "Cascadia Code", "SF Mono", "Fira Code", "DejaVu Sans Mono", Menlo, Consolas, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;overscroll-behavior-x:none;-ms-scroll-chaining:none;font-size:13px;line-height:1.5}.header-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:101;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f1016f2;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0}.header-brand{font-family:var(--font-mono);letter-spacing:2px;color:var(--text-primary);font-size:12px;font-weight:700}.header-lang{gap:3px;display:flex}.tab-nav{background:var(--bg-panel);border-bottom:1px solid var(--border);scrollbar-width:none;z-index:100;display:flex;position:sticky;top:42px;overflow-x:auto}.tab-nav::-webkit-scrollbar{display:none}.top-tab{cursor:pointer;white-space:nowrap;min-height:44px;font-family:var(--font-mono);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;padding:12px 14px;transition:all .15s;display:flex}.top-tab-icon{opacity:.4;font-size:14px}.top-tab-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.top-tab.active{border-bottom-color:var(--accent);background:#6aa8d70a}.top-tab.active .top-tab-icon{opacity:1}.top-tab.active .top-tab-label{color:var(--accent);font-weight:600}.top-tab:hover .top-tab-label{color:var(--text-secondary)}.lang-btn{font-family:var(--font-mono);border:1px solid var(--border);min-width:36px;min-height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:3px;padding:8px 12px;font-size:10px;font-weight:600;transition:all .15s}.lang-btn:hover{color:var(--text-primary)}.lang-btn.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.hm-stats-bar{border-top:1px solid var(--border);gap:8px;margin-top:20px;padding-top:16px;display:flex}.hm-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex:1;align-items:center;padding:10px 8px;display:flex}.hm-stat-value{color:var(--accent);font-size:16px;font-weight:700}.hm-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:center;font-size:8px}.dashboard-main{max-width:1400px;min-height:calc(100vh - 120px);margin:0 auto;padding:12px 16px}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:20px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.panel h2{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:600}.panel-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:10px}.heatmap-container{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x pan-y;scrollbar-width:thin;scrollbar-color:var(--border) transparent;padding-bottom:4px;overflow-x:auto}.heatmap-grid{grid-template-columns:44px repeat(24,1fr);gap:2px;min-width:650px;display:grid}.heatmap-hour-label{color:var(--text-muted);text-align:center;padding:2px 0;font-size:8px}.heatmap-hour-label.night{color:var(--text-muted);opacity:.5}.heatmap-cell.night{opacity:.7}.top-worst{margin-top:20px}.top-worst h3{letter-spacing:.5px;color:var(--risk-danger);margin-bottom:8px;font-size:11px;font-weight:600}.top-worst-list{flex-direction:column;gap:6px;display:flex}.top5-group{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;margin-bottom:8px;padding:8px}.top5-group-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.top5-rank{color:var(--text-muted);font-size:10px;font-weight:700}.top5-count{font-size:11px;font-weight:700}.top5-count.worst{color:var(--risk-danger)}.top5-count.best{color:var(--success)}.top5-group-items{flex-wrap:wrap;gap:4px;display:flex}.top5-tag{background:var(--bg-panel);border:1px solid var(--border);min-height:36px;color:var(--text-secondary);cursor:pointer;border-radius:4px;align-items:center;padding:8px 12px;font-size:9px;transition:all .15s;display:inline-flex}.top5-tag:hover{border-color:var(--accent);color:var(--accent)}.top5-toggle{font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:4px 0;font-size:9px;transition:color .15s}.top5-toggle:hover{color:var(--accent)}.heatmap-day-label{color:var(--text-secondary);z-index:5;background:var(--bg-panel);align-items:center;padding-right:4px;font-size:10px;font-weight:600;display:flex;position:sticky;left:0}.heatmap-corner{z-index:6;background:var(--bg-panel);position:sticky;left:0}.heatmap-cell{aspect-ratio:1;cursor:pointer;border-radius:3px;justify-content:center;align-items:center;min-height:26px;transition:transform .15s,box-shadow .15s;display:flex;position:relative}.heatmap-cell:hover{z-index:10;transform:scale(1.2);box-shadow:0 0 12px #6aa8d740}.heatmap-cell.selected{outline:2px solid var(--accent);outline-offset:1px;transform:scale(1.1)}.heatmap-count{color:#ffffffd9;text-shadow:0 1px 2px #00000080;font-size:8px;font-weight:700}.heatmap-legend{color:var(--text-muted);justify-content:center;align-items:center;gap:6px;margin-top:12px;font-size:9px;display:flex}.legend-bar{border-radius:3px;gap:1px;display:flex;overflow:hidden}.legend-swatch{width:24px;height:10px}.heatmap-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-top:16px;padding:14px;animation:.2s fadeIn}.heatmap-detail h3{color:var(--accent);margin-bottom:10px;font-size:11px;font-weight:600}.detail-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;gap:3px;max-height:280px;display:flex;overflow-y:auto}.detail-item{background:var(--bg-panel);border-radius:4px;align-items:center;gap:10px;padding:5px 8px;font-size:10px;display:flex}.detail-time{color:var(--text-muted);min-width:42px}.detail-cities{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.v-timeline{flex-direction:column;gap:3px;display:flex}.v-timeline-row{cursor:pointer;border-radius:4px;align-items:center;gap:6px;height:24px;padding:0 4px;transition:background .15s;display:flex}.v-timeline-row:hover{background:#ffffff08}.v-timeline-row.selected{outline:1px solid var(--accent);background:#6aa8d714}.v-tl-date{color:var(--text-muted);text-align:right;min-width:36px;font-size:9px}.v-tl-day{color:var(--text-secondary);min-width:24px;font-size:9px;font-weight:600}.v-tl-bar-track{background:#ffffff08;border-radius:3px;flex:1;height:16px;overflow:hidden}.v-tl-bar-fill{border-radius:3px;height:100%;transition:width .4s}.v-tl-count{color:var(--text-primary);text-align:right;min-width:18px;font-size:10px;font-weight:700}.timeline-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-top:16px;padding:14px;animation:.2s fadeIn}.timeline-detail h3{color:var(--accent);text-transform:capitalize;margin-bottom:10px;font-size:11px;font-weight:600}.detail-breakdown{gap:8px;margin-bottom:14px;display:flex}.missiles-badge,.aircraft-badge{border-radius:4px;padding:3px 10px;font-size:10px;font-weight:600}.missiles-badge{color:var(--risk-danger);background:#c93d3d26;border:1px solid #c93d3d4d}.aircraft-badge{color:var(--risk-high);background:#d4822a26;border:1px solid #d4822a4d}.hourly-breakdown{flex-direction:column;gap:2px;display:flex}.hourly-row{align-items:center;gap:8px;display:flex}.hourly-time{color:var(--text-muted);min-width:36px;font-size:9px}.hourly-bar-container{background:#ffffff08;border-radius:3px;flex:1;height:12px;overflow:hidden}.hourly-bar{border-radius:3px;height:100%;transition:width .4s}.hourly-count{color:var(--text-secondary);text-align:right;min-width:18px;font-size:9px;font-weight:600}.histogram-panel{overflow:hidden}.h-histogram{flex-direction:column;gap:3px;display:flex}.h-bar-row{align-items:center;gap:6px;height:20px;display:flex}.h-bar-row.night{opacity:.6}.h-bar-row.routine .h-bar-hour{color:var(--accent);font-weight:700}.h-bar-hour{color:var(--text-muted);text-align:right;min-width:36px;font-size:9px}.h-bar-track{background:#ffffff08;border-radius:3px;flex:1;height:16px;position:relative;overflow:hidden}.h-bar-fill{border-radius:3px;height:100%;transition:width .4s}.h-bar-routine-dot{background:var(--accent);width:5px;height:5px;box-shadow:0 0 4px var(--accent);border-radius:50%;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.h-bar-pct{color:var(--text-secondary);text-align:right;min-width:34px;font-size:9px;font-weight:600}.h-bar-count{color:var(--text-muted);min-width:24px;font-size:8px}.histogram-legend{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:16px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:4px;font-size:9px;display:flex}.legend-dot{border-radius:2px;width:8px;height:8px;display:inline-block}.routine-dot{box-shadow:0 0 4px var(--accent);background:var(--accent)!important}.routine-section{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.routine-section h3{color:var(--text-primary);letter-spacing:.5px;margin-bottom:10px;font-size:11px;font-weight:600}.routine-windows{flex-wrap:wrap;gap:10px;margin-bottom:10px;display:flex}.routine-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;min-width:170px;padding:12px 14px;transition:border-color .2s;position:relative}.routine-card:hover{border-color:var(--accent)}.routine-label{color:var(--accent);letter-spacing:.5px;font-size:10px;font-weight:600}.routine-time{margin:3px 0;font-size:14px;font-weight:700}.routine-risk{color:var(--text-secondary);font-size:9px}.routine-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:14px;line-height:1;transition:color .15s;position:absolute;top:6px;right:8px}.routine-remove:hover{color:var(--risk-danger)}.routine-form{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.routine-form input,.routine-form select{font-family:var(--font-mono);background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:5px;min-height:44px;padding:8px 10px;font-size:16px}.routine-form input:focus,.routine-form select:focus{border-color:var(--accent);outline:none}.routine-form span{color:var(--text-muted);font-size:10px}.btn-add,.btn-cancel,.btn-add-routine{font-family:var(--font-mono);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;border-radius:5px;padding:6px 14px;font-size:10px;transition:all .15s}.btn-add:hover,.btn-add-routine:hover{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.btn-cancel:hover{background:var(--risk-danger);color:#fff;border-color:var(--risk-danger)}.trend-chart-container{scrollbar-width:thin;scrollbar-color:var(--border) transparent;overflow-x:auto}.trend-svg{width:100%;min-width:400px;height:auto}.trend-legend{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:12px;display:flex}.legend-line{vertical-align:middle;width:18px;height:2px;margin-right:4px;display:inline-block}.legend-line.total{background:var(--accent)}.legend-line.ma{background:#fff;border-top:2px dashed #fff;height:0}.legend-line.missiles{background:var(--risk-danger)}.legend-line.aircraft{background:var(--risk-high)}.rec-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.rec-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;gap:12px;padding:14px;transition:border-color .2s;display:flex}.rec-card:hover{border-color:var(--text-muted)}.rec-icon{justify-content:center;align-items:center;min-width:32px;font-size:22px;display:flex}.rec-card.best{border-left:3px solid var(--success)}.rec-card.best .rec-icon{color:var(--success)}.rec-card.worst{border-left:3px solid var(--risk-danger)}.rec-card.worst .rec-icon{color:var(--risk-danger)}.rec-card.trend{border-left:3px solid var(--risk-medium)}.rec-card.trend .rec-icon{font-size:26px;font-weight:700}.rec-card.avg{border-left:3px solid var(--accent)}.rec-card.avg .rec-icon{color:var(--accent);font-size:18px}.rec-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:9px}.rec-value{margin:2px 0;font-size:15px;font-weight:700}.rec-detail{color:var(--text-secondary);font-size:9px}.rec-hourly-summary{border-top:1px solid var(--border);padding-top:16px}.rec-hourly-summary h3{letter-spacing:.5px;margin-bottom:10px;font-size:11px;font-weight:600}.rec-franja-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.franja-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:8px;padding:10px 8px;transition:border-color .2s}.franja-card:hover{border-color:var(--text-muted)}.franja-label{color:var(--text-primary);font-size:10px;font-weight:600}.franja-hours{color:var(--text-muted);margin:2px 0;font-size:8px}.franja-risk{margin:3px 0;font-size:13px;font-weight:700}.franja-pct{color:var(--text-secondary);font-size:9px}.life-tips{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.life-tips h3{letter-spacing:.5px;color:var(--text-primary);margin-bottom:10px;font-size:11px;font-weight:600}.life-tips-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.life-tip{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--success);cursor:pointer;-webkit-tap-highlight-color:#6aa8d726;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:8px;min-height:48px;padding:14px;transition:background .15s;display:flex;position:relative}.life-tip:active{background:var(--bg-secondary)}.life-tip.danger{border-left-color:var(--risk-danger);background:#c93d3d0f}.tip-badge{border-radius:50%;justify-content:center;align-items:center;min-width:24px;height:24px;font-size:14px;font-weight:700;display:flex}.tip-badge.ok{color:var(--success);background:#1a6b4a26}.tip-badge.danger{color:#fff;background:var(--risk-danger);font-size:15px;font-weight:800;box-shadow:0 0 6px #c93d3d80}.tip-emoji{font-size:18px}.tip-text{color:var(--text-secondary);flex:1;font-size:9px;line-height:1.3}.tip-value{color:var(--text-primary);white-space:nowrap;font-size:14px;font-weight:700}.life-tip.expanded{background:var(--bg-secondary);border-color:var(--accent);flex-wrap:wrap}.life-tip.expanded.danger{border-color:var(--risk-danger)}.tip-fact{border-top:1px solid var(--border);width:100%;color:var(--text-secondary);margin-top:8px;padding-top:8px;font-size:9px;line-height:1.6}.patterns-section{border-top:1px solid var(--border);margin-top:16px;padding-top:14px}.patterns-section h3{letter-spacing:.5px;color:var(--text-primary);margin-bottom:10px;font-size:11px;font-weight:600}.patterns-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.pattern-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--text-muted);cursor:pointer;border-radius:8px;flex-direction:column;gap:4px;padding:10px 12px;transition:background .15s;display:flex}.pattern-card:hover{background:var(--bg-secondary)}.pattern-card.safe{border-left-color:var(--success)}.pattern-card.danger{border-left-color:var(--risk-danger)}.pattern-card.neutral{border-left-color:var(--accent)}.pattern-icon{font-size:16px}.pattern-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:8px}.pattern-value{color:var(--text-primary);font-size:14px;font-weight:700}.pattern-detail{color:var(--text-secondary);font-size:9px}.pattern-card .tip-fact{margin-top:6px}@media (width<=768px){.life-tips-grid{grid-template-columns:1fr}.patterns-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.patterns-grid{grid-template-columns:1fr}}.now-hero{text-align:center;border-radius:12px;margin-bottom:20px;padding:24px 20px}.now-time{color:#ffffffb3;letter-spacing:1px;text-transform:uppercase;font-size:12px}.now-risk-label{color:#fff;letter-spacing:3px;margin:8px 0 4px;font-size:28px;font-weight:700}.now-advice{color:#ffffffe6;margin-bottom:8px;font-size:13px}.now-stat{color:#ffffff80;font-size:10px}.now-section{margin-bottom:20px}.now-section h3{letter-spacing:.5px;color:var(--text-primary);text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:600}.now-forecast{-webkit-overflow-scrolling:touch;gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.forecast-cell{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;min-width:36px;display:flex}.forecast-cell.current{outline:1px solid var(--accent);background:#6aa8d71a;border-radius:6px;padding:4px 2px}.forecast-hour{color:var(--text-muted);font-size:8px}.forecast-bar{border-radius:3px;width:20px;min-height:4px}.forecast-count{color:var(--text-secondary);font-size:9px;font-weight:600}.now-today{flex-direction:column;gap:2px;display:flex}.today-row{border-radius:3px;align-items:center;gap:6px;height:20px;padding:0 4px;display:flex}.today-row.current{background:#6aa8d714;outline:1px solid #6aa8d74d}.today-hour{color:var(--text-muted);text-align:right;min-width:36px;font-size:9px}.today-bar-track{background:#ffffff08;border-radius:3px;flex:1;height:12px;overflow:hidden}.today-bar-fill{border-radius:3px;height:100%;transition:width .3s}.today-count{color:var(--text-secondary);min-width:14px;font-size:9px;font-weight:600}.today-now-badge{color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-size:7px;font-weight:700}.trend-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.trend-header h2{margin-bottom:4px}.trend-range-toggle{gap:2px;display:flex}.range-btn{font-family:var(--font-mono);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:3px;padding:4px 10px;font-size:9px;transition:all .15s}.range-btn.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.loading-skeleton{flex-direction:column;gap:12px;padding:16px;display:flex}.skel-block{background:var(--bg-card);border-radius:8px;animation:1.2s ease-in-out infinite pulse}.skel-hero{height:120px}.skel-row{height:24px}.skel-row.short{width:60%}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}[dir=rtl] .heatmap-grid{direction:ltr}[dir=rtl] .h-bar-row,[dir=rtl] .v-timeline-row,[dir=rtl] .today-row,[dir=rtl] .hourly-row{flex-direction:row-reverse}[dir=rtl] .tab-nav{direction:rtl}.dashboard-footer{border-top:1px solid var(--border);color:var(--text-muted);background:var(--bg-secondary);flex-wrap:wrap;justify-content:space-between;gap:8px;padding:16px 20px;font-size:9px;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=768px){.header-brand{letter-spacing:1px;font-size:10px}.header-bar{padding:8px 12px}.tab-nav{top:38px}.top-tab{padding:10px}.top-tab-icon{font-size:12px}.top-tab-label{font-size:8px}.dashboard-main{padding:8px 10px}.panel{border-radius:8px;padding:14px}.panel h2{font-size:12px}.hm-stats-bar{gap:6px}.hm-stat-value{font-size:14px}.heatmap-grid{grid-template-columns:36px repeat(24,1fr);gap:1.5px;min-width:520px}.heatmap-cell{border-radius:2px;min-height:20px}.heatmap-count{font-size:7px}.heatmap-day-label{font-size:9px}.heatmap-hour-label{font-size:7px}.trend-svg{min-width:340px}.trend-panel .panel-subtitle{margin-bottom:8px}.rec-grid{grid-template-columns:1fr}.rec-franja-grid{grid-template-columns:repeat(3,1fr)}.heatmap-legend{flex-wrap:wrap;gap:4px}.routine-windows{flex-direction:column}.routine-form{flex-direction:column;align-items:stretch}.routine-form input,.routine-form select{width:100%}.dashboard-footer{text-align:center;flex-direction:column}}@media (width<=420px){html{font-size:12px}.heatmap-grid{min-width:460px}.rec-franja-grid{grid-template-columns:repeat(2,1fr)}.rec-card{padding:10px}.rec-value{font-size:13px}}@supports (padding:env(safe-area-inset-bottom)){.dashboard-footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.header-bar{padding-top:calc(10px + env(safe-area-inset-top))}}
