*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-panel: #ffffff;--bg-card: #f1f5f9;--border: #d1d5db;--border-light: #e5e7eb;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--accent-blue: #2563eb;--accent-red: #dc2626;--accent-amber: #d97706;--accent-cyan: #0891b2;--accent-rose: #e11d48;--accent-violet: #7c3aed;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12)}html,body{height:100%;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary)}#app{display:flex;flex-direction:column;height:100vh}#loading{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;align-items:center;justify-content:center}.loading-content{text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-light);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:14px}#header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);z-index:10;flex-shrink:0}.header-left h1{font-size:20px;font-weight:700;letter-spacing:.3px;color:var(--text-primary)}.header-subtitle{font-size:12px;color:var(--text-muted);margin-left:10px}.header-right{display:flex;align-items:center;gap:16px}.conflict-day{font-size:13px;font-weight:600;color:var(--accent-red);background:#fef2f2;padding:5px 14px;border-radius:6px;border:1px solid #fecaca}.current-date{font-size:13px;color:var(--text-secondary);font-weight:500}.hormuz-banner{text-align:center;font-size:13px;font-weight:600;padding:0;height:0;overflow:hidden;transition:all .3s ease;flex-shrink:0}.hormuz-banner.blocked{padding:8px 20px;height:auto;background:#fef2f2;color:var(--accent-red);border-bottom:1px solid #fecaca}.hormuz-banner.partial{padding:8px 20px;height:auto;background:#fff7ed;color:#c2410c;border-bottom:1px solid #fed7aa}.hormuz-banner.threatened{padding:8px 20px;height:auto;background:#fffbeb;color:var(--accent-amber);border-bottom:1px solid #fde68a}#main-layout{display:flex;flex:1;overflow:hidden}#sidebar{width:340px;min-width:340px;background:var(--bg-secondary);border-right:1px solid var(--border-light);display:flex;flex-direction:column;overflow-y:auto;z-index:5}#sidebar,.legend-panel,.oil-chart-panel,#timeline-bar,#header{-webkit-overflow-scrolling:touch}.sidebar-section{padding:14px;border-bottom:1px solid var(--border-light)}.sidebar-events-list{flex:1;overflow-y:auto}.sidebar-header h2{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.sidebar-stats{display:flex;gap:12px}.stat{font-size:12px;color:var(--text-muted)}.stat.highlight{color:var(--accent-blue);font-weight:600}.event-group-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin:10px 0 6px;font-weight:600}.event-card{padding:10px 12px;margin-bottom:6px;border-radius:8px;background:var(--bg-card);border:1px solid transparent;cursor:pointer;transition:all .15s ease}.event-card:hover{border-color:var(--border);background:#e8edf4;box-shadow:var(--shadow-sm)}.event-card.today{border-left:3px solid var(--accent-blue);background:#eff6ff}.event-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.event-cat-badge{font-size:10px;padding:2px 8px;border-radius:4px;font-weight:600}.event-importance{font-size:10px;color:var(--accent-amber)}.event-card-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3;margin-bottom:4px}.event-card-meta{font-size:11px;color:var(--text-muted);display:flex;gap:4px;align-items:center;flex-wrap:wrap}.event-card-location{margin-left:auto}#map-area{flex:1;position:relative;overflow:hidden}#map-container{width:100%;height:100%}.conflict-map{display:block}.legend-panel{position:absolute;bottom:16px;left:16px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:10px;padding:14px;width:210px;z-index:5;max-height:420px;overflow-y:auto;box-shadow:var(--shadow-md)}.legend-section{margin-bottom:12px}.legend-section:last-child{margin-bottom:0}.legend-section h3{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:6px;font-weight:600}.legend-items{display:flex;flex-direction:column;gap:4px}.legend-item{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.legend-line{width:20px;height:3px;border-radius:2px;display:inline-block;flex-shrink:0}.oil-chart-panel{position:absolute;top:16px;right:16px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:10px;padding:10px;width:320px;z-index:5;box-shadow:var(--shadow-md)}.mobile-panel-controls{display:none}.mobile-toggle-btn{border:1px solid var(--border-light);background:#fffffff2;color:var(--text-secondary);border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mobile-toggle-btn.active{background:#eff6ff;color:var(--accent-blue);border-color:#93c5fd}.sidebar-mini-legend{margin:10px 0 12px;padding:8px 10px;border:1px solid var(--border-light);background:#fff;border-radius:8px}.mini-legend-title{font-size:10px;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-muted);margin-bottom:6px;font-weight:700}.mini-legend-items{display:flex;flex-wrap:wrap;gap:6px 10px}.mini-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;color:var(--text-secondary)}.mini-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.casualty-header{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:10px;font-weight:700}.casualty-list{display:flex;flex-direction:column;gap:5px}.casualty-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:3px 0}.casualty-country{color:var(--text-primary);font-weight:500;font-size:11px}.casualty-numbers{display:flex;gap:10px}.killed{color:var(--accent-red);font-size:11px;font-weight:500}.wounded{color:var(--accent-amber);font-size:11px;font-weight:500}.casualty-total{margin-top:10px;padding-top:8px;border-top:1px solid var(--border-light);font-size:11px;color:var(--text-secondary);font-weight:600}#timeline-bar{display:flex;align-items:center;padding:10px 20px;background:var(--bg-secondary);border-top:1px solid var(--border-light);box-shadow:0 -2px 8px #0000000a;flex-shrink:0;z-index:10}.playback-controls{display:flex;align-items:center;gap:5px;margin-right:14px;flex-shrink:0}.control-btn{width:34px;height:34px;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-card);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.control-btn:hover{background:#e8edf4;border-color:var(--accent-blue);color:var(--text-primary)}.play-btn{width:38px;height:38px;font-size:16px}.speed-select{background:var(--bg-card);border:1px solid var(--border-light);border-radius:6px;color:var(--text-secondary);font-size:12px;padding:5px 8px;font-family:inherit;cursor:pointer}.timeline-scrubber{flex:1;min-width:0}.hidden{display:none!important}.map-tooltip{position:fixed;z-index:100;background:#fffffff7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:10px;padding:14px;max-width:340px;pointer-events:none;box-shadow:var(--shadow-lg)}.tooltip-header{display:flex;justify-content:space-between;align-items:center;padding-left:10px;margin-bottom:8px}.tooltip-category{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tooltip-date{font-size:11px;color:var(--text-muted)}.tooltip-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:6px;line-height:1.3}.tooltip-desc{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}.tooltip-meta{display:flex;gap:10px;font-size:11px;margin-bottom:6px;flex-wrap:wrap}.tooltip-actor{font-weight:600}.tooltip-location{color:var(--text-muted)}.tooltip-casualties{display:flex;gap:10px;font-size:11px;margin-bottom:4px;flex-wrap:wrap}.tooltip-infra,.tooltip-econ{font-size:11px;color:var(--text-secondary);margin-bottom:3px}.tooltip-importance{font-size:11px;color:var(--accent-amber);margin-top:6px}::-webkit-scrollbar{width:7px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.scrubber-svg text{-webkit-user-select:none;user-select:none}.scrubber-svg .domain,.scrubber-svg .tick line{stroke:var(--border-light)}@media(max-width:1024px){#header{padding:10px 14px;gap:10px}.header-left h1{font-size:18px}.header-right{gap:10px}#sidebar{width:300px;min-width:300px}.oil-chart-panel{width:280px;padding:8px}.legend-panel{width:190px}}@media(max-width:768px){html,body{overflow:auto}#app{height:auto;min-height:100vh}#header{flex-direction:column;align-items:flex-start;padding:10px 12px}.header-left{width:100%}.header-left h1{font-size:17px;line-height:1.2}.header-subtitle{display:block;margin:4px 0 0;font-size:11px}.header-right{width:100%;justify-content:space-between;gap:8px;flex-wrap:wrap}.conflict-day,.current-date{font-size:12px}.hormuz-banner.blocked,.hormuz-banner.partial,.hormuz-banner.threatened{padding:8px 12px;font-size:12px;line-height:1.35}#main-layout{flex-direction:column;overflow:visible}#map-area{min-height:54vh;order:1}#sidebar{width:100%;min-width:0;max-height:none;border-right:none;border-top:1px solid var(--border-light);order:2}.sidebar-section{padding:12px}.sidebar-events-list{overflow:visible}.legend-panel{left:10px;right:10px;bottom:10px;width:auto;max-width:none;max-height:170px;padding:10px;font-size:11px}.oil-chart-panel{top:10px;left:10px;right:10px;width:auto;padding:8px}#timeline-bar{flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px 14px}.playback-controls{margin-right:0;justify-content:space-between;flex-wrap:wrap}.control-btn{width:32px;height:32px}.play-btn{width:36px;height:36px}.speed-select{margin-left:auto}.timeline-scrubber{width:100%;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.scrubber-svg{min-width:560px}.map-tooltip{max-width:min(300px,calc(100vw - 20px))}}@media(max-width:480px){#map-area{min-height:50vh}.legend-panel{max-height:140px;font-size:10px}.event-card-title{font-size:12px}.event-card-meta,.tooltip-desc,.tooltip-meta,.tooltip-casualties{font-size:10px}.sidebar-trust-note{padding:8px}.trust-line{font-size:9.5px}.casualty-row,.casualty-country,.killed,.wounded{font-size:10px}}
