:root{--bg-base:#060a11;--bg-raised:#0c1219;--bg-surface:#121a27;--bg-overlay:#182234;--bg-glass:rgba(12,18,25,0.88);--bg-glass-strong:rgba(12,18,25,0.94);--border-subtle:rgba(255,255,255,0.05);--border-default:rgba(255,255,255,0.08);--border-strong:rgba(255,255,255,0.13);--border-accent:rgba(245,158,11,0.25);--text-primary:#f0f2f5;--text-secondary:#8d99a8;--text-muted:#505c6b;--text-inverse:#060a11;--accent:#f59e0b;--accent-hover:#fbbf24;--accent-muted:rgba(245,158,11,0.12);--accent-strong:rgba(245,158,11,0.25);--red:#ef4444;--orange:#f97316;--yellow:#eab308;--green:#22c55e;--blue:#3b82f6;--cyan:#06b6d4;--critical:#ef4444;--severe:#f97316;--high:#eab308;--moderate:#38bdf8;--low:#22c55e;--font-display:'Space Grotesk','Inter',system-ui,sans-serif;--font:'Inter',system-ui,-apple-system,sans-serif;--mono:'JetBrains Mono','Consolas',monospace;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(0,0,0,0.3);--shadow-md:0 4px 20px rgba(0,0,0,0.4);--shadow-lg:0 8px 40px rgba(0,0,0,0.5);--shadow-glow:0 0 24px rgba(245,158,11,0.1);--shadow-glow-strong:0 0 40px rgba(245,158,11,0.15);--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ease-smooth:cubic-bezier(0.4,0,0.2,1);--duration-fast:150ms;--duration-normal:280ms;--duration-slow:450ms;--duration-dramatic:650ms;--sidebar-w:310px;--header-h:50px;--banner-h:28px;--glass-blur:blur(24px) saturate(1.3)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{height:100%;overflow:hidden;overscroll-behavior:none}body{position:fixed;inset:0;font-family:var(--font);background:var(--bg-base);color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;display:flex;flex-direction:column;overscroll-behavior:none}.hidden{display:none !important}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#loading-screen{position:fixed;inset:0;z-index:10000;background:var(--bg-base);display:flex;align-items:center;justify-content:center;transition:opacity 0.7s var(--ease-out),visibility 0.7s;overflow:hidden}#loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(245,158,11,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(245,158,11,0.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 50% 50% at 50% 50%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 50% 50% at 50% 50%,black 20%,transparent 70%);animation:gridPulse 4s ease-in-out infinite}@keyframes gridPulse{0%,100%{opacity:0.5}50%{opacity:1}}.loading-content{text-align:center;position:relative;z-index:1}.loading-icon-wrap{width:72px;height:72px;margin:0 auto 20px;position:relative;display:flex;align-items:center;justify-content:center}.loading-ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--border-default);border-top-color:var(--accent);animation:spin 1.2s linear infinite}.loading-ring::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid transparent;border-top-color:rgba(245,158,11,0.2);animation:spin 2.4s linear infinite reverse}@keyframes spin{to{transform:rotate(360deg)}}.loading-globe{font-size:1.8rem;filter:drop-shadow(0 0 12px rgba(245,158,11,0.3));animation:globePulse 2s ease-in-out infinite}@keyframes globePulse{0%,100%{transform:scale(1);opacity:0.9}50%{transform:scale(1.08);opacity:1}}.loading-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;letter-spacing:-0.01em;margin-bottom:6px;background:linear-gradient(135deg,var(--text-primary) 40%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-sub{color:var(--text-muted);font-size:0.72rem;margin-bottom:20px}.loading-bar{margin:0 auto;width:220px;height:2px;background:var(--border-default);border-radius:2px;overflow:hidden}.loading-fill{height:100%;width:40%;background:linear-gradient(90deg,var(--accent),var(--orange));border-radius:2px;animation:slide 1.4s ease-in-out infinite}@keyframes slide{0%{transform:translateX(-120%)}100%{transform:translateX(350%)}}.loading-stats{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;font-size:0.58rem;color:var(--text-muted);font-family:var(--mono);letter-spacing:0.03em}.loading-dot-sep{width:3px;height:3px;border-radius:50%;background:var(--border-strong)}#main-header{display:flex;align-items:center;justify-content:space-between;padding-inline:16px;background:var(--bg-raised);border-bottom:1px solid var(--border-subtle);height:var(--header-h);z-index:1100;gap:16px;position:relative;flex-shrink:0}#main-header::after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(245,158,11,0.08) 30%,rgba(245,158,11,0.08) 70%,transparent)}.header-left{display:flex;align-items:center;gap:10px;flex-shrink:0}#sidebar-toggle{width:34px;height:34px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out)}#sidebar-toggle:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-strong)}#sidebar-toggle.toggled{background:var(--accent-muted);color:var(--accent);border-color:var(--border-accent)}.crisis-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.18);padding:4px 12px;border-radius:var(--radius-full);font-size:0.55rem;font-weight:700;color:var(--red);letter-spacing:1.5px;text-transform:uppercase}.pulse-dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 1.8s ease-in-out infinite;box-shadow:0 0 8px rgba(239,68,68,0.5)}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.3;transform:scale(0.5)}}.header-title-text{font-family:var(--font-display);font-size:1rem;font-weight:700;white-space:nowrap;letter-spacing:-0.01em;background:linear-gradient(135deg,var(--text-primary) 50%,var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-center{flex:1;display:flex;justify-content:center;min-width:0}.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.header-icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);color:var(--text-muted);font-size:0.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out)}.header-icon-btn:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent)}.oil-prices-ticker{display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,rgba(12,18,25,0.95),rgba(18,26,39,0.95));backdrop-filter:var(--glass-blur);padding:6px 22px;border-radius:var(--radius-full);border:1px solid var(--border-default);box-shadow:var(--shadow-sm),inset 0 1px 0 rgba(255,255,255,0.03);transition:border-color var(--duration-normal),box-shadow var(--duration-normal)}.ticker-item{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:0;padding:2px 6px;border-radius:var(--radius-sm);transition:background var(--duration-fast)}.ticker-label{font-size:0.48rem;font-weight:700;color:var(--text-muted);letter-spacing:1.8px;text-transform:uppercase}.ticker-value{font-family:var(--mono);font-size:0.9rem;font-weight:700;color:var(--accent);line-height:1.2;text-shadow:0 0 14px rgba(245,158,11,0.25);transition:color var(--duration-fast),text-shadow var(--duration-fast);min-width:5.5ch;text-align:center}.ticker-change{font-family:var(--mono);font-size:0.5rem;font-weight:600;padding:1px 6px;border-radius:var(--radius-xs);line-height:1.3;min-width:4.5ch;text-align:center}.ticker-change.up{color:var(--red);background:rgba(239,68,68,0.1)}.ticker-change.down{color:var(--green);background:rgba(34,197,94,0.1)}.ticker-divider{width:1px;height:30px;background:var(--border-default)}.loading-placeholder{color:var(--text-muted) !important;animation:placeholderPulse 1.2s ease-in-out infinite}@keyframes placeholderPulse{0%,100%{opacity:1}50%{opacity:0.25}}.ticker-value.tick-up{color:var(--red) !important;text-shadow:0 0 14px rgba(239,68,68,0.4) !important}.ticker-value.tick-down{color:var(--green) !important;text-shadow:0 0 14px rgba(34,197,94,0.4) !important}.ticker-value.tick-flash{animation:tickFlash 0.6s ease-out}@keyframes tickFlash{0%{opacity:0.5}100%{opacity:1}}.ticker-item:has(.tick-up.tick-flash){background:rgba(239,68,68,0.06)}.ticker-item:has(.tick-down.tick-flash){background:rgba(34,197,94,0.06)}.oil-prices-ticker.ticker-flash{border-color:rgba(245,158,11,0.35);box-shadow:var(--shadow-sm),var(--shadow-glow)}.oil-prices-ticker.ticker-loading{position:relative;overflow:hidden}.oil-prices-ticker.ticker-loading::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 30%,rgba(245,158,11,0.05) 50%,transparent 70%);animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.oil-prices-ticker.ticker-loading .ticker-value{opacity:0.3}.currency-select{padding:5px 24px 5px 10px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--mono);font-size:0.62rem;outline:none;cursor:pointer;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23505c6b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.currency-select:hover{border-color:var(--border-strong)}.currency-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.header-date{font-size:0.58rem;color:var(--text-muted);white-space:nowrap;font-family:var(--mono)}#realtime-status{display:inline-flex;align-items:center;gap:6px;background:var(--bg-surface);border:1px solid var(--border-default);padding:3px 10px;border-radius:var(--radius-full);font-size:0.52rem}.rt-inner{display:flex;align-items:center;gap:5px}.rt-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.rt-dot.live{background:var(--green);box-shadow:0 0 8px rgba(34,197,94,0.6);animation:rtPulse 2s ease-in-out infinite}.rt-dot.fetching{background:var(--accent);animation:rtPulse 0.4s ease-in-out infinite}.rt-dot.error{background:var(--red)}.rt-dot.connecting{background:var(--blue);animation:rtPulse 1s ease-in-out infinite}.rt-dot.cached{background:var(--cyan);box-shadow:0 0 6px rgba(6,182,212,0.4)}@keyframes rtPulse{0%,100%{opacity:1}50%{opacity:0.15}}.rt-label{font-weight:700;letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase}.rt-time{font-family:var(--mono);font-size:0.5rem;color:var(--text-muted)}.rt-adjustment{font-family:var(--mono);font-size:0.5rem;color:var(--orange);font-weight:600}#manual-refresh-btn{width:28px;height:28px;border-radius:50%;background:transparent;border:1px solid var(--border-default);color:var(--text-muted);font-size:0.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out)}#manual-refresh-btn:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent)}#manual-refresh-btn.spinning{animation:refreshSpin 0.6s var(--ease-out)}@keyframes refreshSpin{to{transform:rotate(360deg)}}#alert-banner{display:flex;align-items:center;height:var(--banner-h);background:linear-gradient(90deg,var(--bg-raised),rgba(18,26,39,0.8),var(--bg-raised));border-bottom:1px solid var(--border-subtle);padding-inline:12px;gap:8px;overflow:hidden;position:relative;z-index:1100;flex-shrink:0}.alert-icon{color:var(--red);font-size:0.75rem;flex-shrink:0;opacity:0.5}.alert-scroll{overflow:hidden;white-space:nowrap;flex:1}.alert-text{display:inline-block;font-size:0.6rem;font-weight:500;color:var(--orange);opacity:0.6;letter-spacing:0.03em;animation:marquee 60s linear infinite}@keyframes marquee{0%{transform:translateX(100%)}100%{transform:translateX(-100%)}}.alert-fade-edge{position:absolute;right:0;top:0;bottom:0;width:40px;background:linear-gradient(90deg,transparent,var(--bg-raised));pointer-events:none}.fetch-progress{height:2px;position:relative;background:var(--border-subtle);overflow:hidden;z-index:200;flex-shrink:0}.fetch-progress.hidden{display:none}.fetch-progress-bar{position:absolute;inset-block:0;left:0;width:35%;background:linear-gradient(90deg,var(--accent),var(--orange));border-radius:2px;animation:fetchSlide 1s ease-in-out infinite}@keyframes fetchSlide{0%{left:-35%}100%{left:100%}}.fetch-progress-label{position:absolute;top:4px;left:50%;transform:translateX(-50%);font-size:0.52rem;color:var(--text-muted);background:var(--bg-raised);padding:1px 10px;border-radius:var(--radius-full);white-space:nowrap;border:1px solid var(--border-default)}.ad-banner{background:var(--bg-raised);border-bottom:1px solid var(--border-subtle);text-align:center;overflow:hidden;display:flex;align-items:center;justify-content:center}.ad-banner:empty,.ad-banner:not(:has(ins[data-ad-status="filled"])){display:none}.ad-sidebar{flex-shrink:0;padding:8px;border-top:1px solid var(--border-subtle);background:var(--bg-base)}.ad-sidebar:not(:has(ins[data-ad-status="filled"])){display:none}.ad-bottom{flex-shrink:0;background:var(--bg-base);border-top:1px solid var(--border-subtle);text-align:center;overflow:hidden}.ad-bottom:not(:has(ins[data-ad-status="filled"])){display:none}#main-content{display:flex;flex:1;min-height:0;overflow:hidden;position:relative;z-index:0;isolation:isolate}#sidebar{width:var(--sidebar-w);background:var(--bg-raised);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--duration-normal) var(--ease-out),opacity var(--duration-fast)}#sidebar.sidebar-collapsed{width:0;overflow:hidden;border-right:none;opacity:0}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-subtle);background:var(--bg-base);flex-shrink:0;position:relative}.stab{flex:1;padding:12px 0 10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font);font-size:0.6rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px;letter-spacing:0.04em;position:relative;z-index:1}.stab-icon{font-size:0.95rem;line-height:1;display:block}.stab-label{display:block}.stab:hover{color:var(--text-secondary)}.stab.active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(245,158,11,0.04)}.stab-indicator{position:absolute;bottom:0;left:0;width:33.333%;height:2px;background:var(--accent);transition:left var(--duration-normal) var(--ease-out);box-shadow:0 0 8px rgba(245,158,11,0.3);border-radius:1px 1px 0 0}.tab-pane{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden}.tab-pane.active{display:flex}#tab-map,#tab-info{overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}#tab-map::-webkit-scrollbar,#tab-info::-webkit-scrollbar{width:4px}#tab-map::-webkit-scrollbar-thumb,#tab-info::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.sb-group{padding:12px 14px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.sb-group:last-child{border-bottom:none}.sb-grow{flex:1;min-height:0;overflow-y:auto;border-bottom:none;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.sb-grow::-webkit-scrollbar{width:4px}.sb-grow::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.sb-label{font-family:var(--font-display);font-size:0.6rem;font-weight:600;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-muted);margin-bottom:10px}.sb-label-toggle{background:none;border:none;cursor:default;padding:0;text-align:left}.sb-label-toggle .toggle-arrow{display:none}.filter-body{display:block}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;font-size:0.72rem;pointer-events:none;color:var(--text-muted);z-index:1}#country-search{width:100%;padding:9px 32px 9px 34px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font);font-size:0.78rem;outline:none;transition:all var(--duration-fast) var(--ease-out)}#country-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}#country-search::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:8px;background:var(--bg-overlay);border:none;color:var(--text-muted);font-size:0.85rem;cursor:pointer;z-index:1;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast)}.search-clear:hover{background:rgba(239,68,68,0.15);color:var(--red)}.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:10;background:var(--bg-surface);backdrop-filter:var(--glass-blur);border:1px solid var(--border-strong);border-radius:var(--radius-md);max-height:240px;overflow-y:auto;box-shadow:var(--shadow-lg)}.search-results.hidden{display:none}.search-result-item{padding:9px 14px;font-size:0.75rem;cursor:pointer;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center;transition:all var(--duration-fast) var(--ease-out)}.search-result-item:hover{background:var(--bg-overlay);color:var(--text-primary);padding-inline-start:18px}.search-result-item:last-child{border-bottom:none}.search-result-price{font-family:var(--mono);font-size:0.68rem;color:var(--accent);font-weight:600}.search-empty{padding:20px;font-size:0.75rem;color:var(--text-muted);text-align:center}.filter-presets{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.filter-chip{padding:6px 13px;border-radius:var(--radius-full);font-size:0.65rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);background:transparent;border:1px solid var(--border-default);color:var(--text-muted)}@media (hover:hover) and (pointer:fine){.filter-chip:hover{border-color:var(--border-strong);color:var(--text-secondary)}}.filter-chip.active{background:var(--accent-muted);border-color:var(--border-accent);color:var(--accent)}.filter-chip[data-filter="cheap"].active{background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.3);color:var(--green)}.filter-chip[data-filter="mid"].active{background:rgba(234,179,8,0.1);border-color:rgba(234,179,8,0.3);color:var(--yellow)}.filter-chip[data-filter="expensive"].active{background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.3);color:var(--red)}.filter-range-row{display:flex;align-items:center;gap:5px;margin-bottom:10px}.filter-input{flex:1;padding:7px 10px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--mono);font-size:0.7rem;outline:none;width:0;min-width:0;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.filter-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.filter-input::placeholder{color:var(--text-muted)}.filter-dash{color:var(--text-muted);font-size:0.7rem;flex-shrink:0}.filter-apply-btn{padding:7px 16px;background:var(--accent);border:none;border-radius:var(--radius-full);color:var(--text-inverse);font-family:var(--font);font-size:0.65rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast) var(--ease-out)}@media (hover:hover) and (pointer:fine){.filter-apply-btn:hover{background:var(--accent-hover);box-shadow:0 4px 14px rgba(245,158,11,0.3)}}.filter-impact-chips{display:flex;flex-wrap:wrap;gap:4px}.filter-impact-chip{padding:5px 9px;border-radius:var(--radius-sm);font-size:0.58rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-transform:uppercase;letter-spacing:0.5px;background:transparent;border:1px solid var(--border-default);color:var(--text-muted)}@media (hover:hover) and (pointer:fine){.filter-impact-chip:hover{border-color:var(--border-strong)}}.filter-impact-chip[data-impact="critical"]{border-color:rgba(239,68,68,0.12);color:rgba(239,68,68,0.45)}.filter-impact-chip[data-impact="critical"]:hover,.filter-impact-chip[data-impact="critical"].active{background:rgba(239,68,68,0.1);border-color:var(--critical);color:var(--critical)}.filter-impact-chip[data-impact="severe"]{border-color:rgba(249,115,22,0.12);color:rgba(249,115,22,0.45)}.filter-impact-chip[data-impact="severe"]:hover,.filter-impact-chip[data-impact="severe"].active{background:rgba(249,115,22,0.1);border-color:var(--severe);color:var(--severe)}.filter-impact-chip[data-impact="high"]{border-color:rgba(234,179,8,0.12);color:rgba(234,179,8,0.45)}.filter-impact-chip[data-impact="high"]:hover,.filter-impact-chip[data-impact="high"].active{background:rgba(234,179,8,0.1);border-color:var(--high);color:var(--high)}.filter-impact-chip[data-impact="moderate"]{border-color:rgba(56,189,248,0.12);color:rgba(56,189,248,0.45)}.filter-impact-chip[data-impact="moderate"]:hover,.filter-impact-chip[data-impact="moderate"].active{background:rgba(56,189,248,0.1);border-color:var(--moderate);color:var(--moderate)}.filter-impact-chip[data-impact="low"]{border-color:rgba(34,197,94,0.12);color:rgba(34,197,94,0.45)}.filter-impact-chip[data-impact="low"]:hover,.filter-impact-chip[data-impact="low"].active{background:rgba(34,197,94,0.1);border-color:var(--low);color:var(--low)}.filter-clear-btn{width:100%;margin-top:8px;padding:6px;background:none;border:1px dashed var(--border-default);border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font);font-size:0.62rem;cursor:pointer;transition:all var(--duration-fast)}.filter-clear-btn:hover{border-color:var(--red);color:var(--red);border-style:solid}.filter-match-count{margin-top:8px;font-size:0.6rem;color:var(--text-muted);text-align:center;font-family:var(--mono)}.ranking-controls{display:flex;gap:5px;margin-bottom:10px}.ranking-select{flex:1;padding:7px 24px 7px 10px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font);font-size:0.68rem;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23505c6b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color var(--duration-fast)}.ranking-select:focus{border-color:var(--accent)}.ranking-select.small{flex:0 0 58px}.ranking-list{max-height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.ranking-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;font-size:0.72rem;transition:all var(--duration-fast) var(--ease-out);border-radius:var(--radius-sm);margin-bottom:2px;border:1px solid transparent}@media (hover:hover) and (pointer:fine){.ranking-item:hover{background:var(--bg-overlay);border-color:var(--border-subtle)}}.ranking-rank{width:22px;text-align:center;font-family:var(--mono);font-size:0.62rem;font-weight:700;color:var(--text-muted);flex-shrink:0}.rank-medal .ranking-rank{color:var(--accent);text-shadow:0 0 8px rgba(245,158,11,0.3);font-size:0.68rem}.ranking-name{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color var(--duration-fast)}.ranking-item:hover .ranking-name{color:var(--text-primary)}.ranking-price{font-family:var(--mono);font-size:0.68rem;font-weight:600;flex-shrink:0}.ranking-price.cheap{color:var(--green)}.ranking-price.mid{color:var(--yellow)}.ranking-price.expensive{color:var(--red)}.view-toggles{display:flex;gap:4px}.view-btn{flex:1;padding:8px 8px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-muted);font-family:var(--font);font-size:0.7rem;font-weight:600;cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-out)}.view-btn:hover{background:var(--bg-overlay);color:var(--text-secondary)}.view-btn.active{background:var(--accent-muted);border-color:var(--border-accent);color:var(--accent);box-shadow:0 0 10px rgba(245,158,11,0.06)}.style-toggles{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}.style-btn{padding:7px 4px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font);font-size:0.64rem;font-weight:500;cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-out)}.style-btn:hover{background:var(--bg-overlay);color:var(--text-secondary)}.style-btn.active{background:var(--accent-muted);border-color:var(--border-accent);color:var(--accent);font-weight:600}.layer-toggle{display:flex;align-items:center;gap:10px;font-size:0.72rem;color:var(--text-secondary);cursor:pointer;padding:6px 0;user-select:none;transition:color var(--duration-fast)}.layer-toggle:hover{color:var(--text-primary)}.layer-toggle input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.layer-swatch{width:10px;height:10px;border-radius:3px;flex-shrink:0}.choropleth-swatch{background:linear-gradient(135deg,var(--green),var(--red))}.crisis-swatch{background:var(--critical)}.station-swatch{background:var(--blue)}.gradient-bar{height:12px;border-radius:6px;background:linear-gradient(to right,#22c55e,#84cc16,#eab308,#f97316,#ef4444,#991b1b);box-shadow:inset 0 1px 2px rgba(0,0,0,0.2)}.gradient-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:0.52rem;color:var(--text-muted);font-family:var(--mono)}.impact-legend-items{display:flex;flex-direction:column;gap:5px}.impact-legend-row{display:flex;align-items:center;gap:8px;font-size:0.7rem;color:var(--text-secondary)}.impact-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.impact-dot.critical{background:var(--critical);box-shadow:0 0 8px rgba(239,68,68,0.3)}.impact-dot.severe{background:var(--severe);box-shadow:0 0 8px rgba(249,115,22,0.3)}.impact-dot.high{background:var(--high);box-shadow:0 0 6px rgba(234,179,8,0.2)}.impact-dot.moderate{background:var(--moderate)}.impact-dot.low{background:var(--low)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:14px 10px;text-align:center;transition:all var(--duration-fast) var(--ease-out);position:relative;overflow:hidden}.stat-card::before{content:"";position:absolute;inset-block-start:0;inset-inline:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--orange));opacity:0.5;transition:opacity var(--duration-fast)}@media (hover:hover) and (pointer:fine){.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md),0 0 20px rgba(245,158,11,0.04)}.stat-card:hover::before{opacity:1}}.stat-value{font-family:var(--mono);font-size:1.15rem;font-weight:700;color:var(--accent);text-shadow:0 0 12px rgba(245,158,11,0.15)}.stat-label{font-size:0.55rem;color:var(--text-muted);margin-top:4px;letter-spacing:0.03em}.timeline-events{overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.timeline-event{display:flex;gap:10px;padding:9px 8px;border-inline-start:2px solid var(--border-default);margin-inline-start:6px;font-size:0.7rem;transition:all var(--duration-fast) var(--ease-out);position:relative}.timeline-event::before{content:"";position:absolute;inset-inline-start:-5px;top:13px;width:8px;height:8px;border-radius:50%;background:var(--bg-raised);border:2px solid var(--border-default)}.timeline-event:hover{background:rgba(255,255,255,0.02)}.event-date{flex-shrink:0;width:44px;font-family:var(--mono);font-weight:700;font-size:0.6rem;padding-top:1px}.event-desc{color:var(--text-secondary);line-height:1.5}.timeline-event.critical{border-inline-start-color:var(--critical)}.timeline-event.critical::before{border-color:var(--critical);background:rgba(239,68,68,0.2)}.timeline-event.critical .event-date{color:var(--critical)}.timeline-event.severe{border-inline-start-color:var(--severe)}.timeline-event.severe::before{border-color:var(--severe);background:rgba(249,115,22,0.2)}.timeline-event.severe .event-date{color:var(--severe)}.timeline-event.high{border-inline-start-color:var(--high)}.timeline-event.high::before{border-color:var(--high);background:rgba(234,179,8,0.2)}.timeline-event.high .event-date{color:var(--high)}#station-live-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.station-status-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.station-status-dot.idle{background:var(--text-muted)}.station-status-dot.loading{background:var(--accent);animation:rtPulse 0.4s ease-in-out infinite}.station-status-dot.live{background:var(--green);box-shadow:0 0 8px rgba(34,197,94,0.5);animation:rtPulse 2s ease-in-out infinite}.station-status-dot.cached{background:var(--cyan);box-shadow:0 0 6px rgba(6,182,212,0.3)}.station-status-dot.error{background:var(--red)}.station-status-label{font-size:0.65rem;color:var(--text-secondary)}.station-status-count{font-family:var(--mono);font-size:0.52rem;color:var(--text-muted)}#map-container{flex:1;position:relative}#map{width:100%;height:100%;background:var(--bg-base)}.leaflet-control-zoom{border:none !important}.leaflet-control-zoom a{background:var(--bg-glass-strong) !important;backdrop-filter:var(--glass-blur) !important;color:var(--text-primary) !important;border:1px solid var(--border-default) !important;width:36px !important;height:36px !important;line-height:36px !important;font-size:16px !important;transition:all var(--duration-fast) !important;border-radius:var(--radius-sm) !important}.leaflet-control-zoom a:hover{background:var(--bg-overlay) !important;border-color:var(--border-strong) !important;color:var(--accent) !important}.leaflet-control-attribution{background:rgba(6,10,17,0.88) !important;color:var(--text-muted) !important;font-size:0.5rem !important;backdrop-filter:var(--glass-blur) !important;border-radius:var(--radius-sm) 0 0 0 !important}.leaflet-control-attribution a{color:var(--text-secondary) !important}.leaflet-popup-content-wrapper{background:var(--bg-glass-strong) !important;backdrop-filter:var(--glass-blur) !important;color:var(--text-primary) !important;border-radius:var(--radius-lg) !important;box-shadow:var(--shadow-lg),0 0 30px rgba(0,0,0,0.3) !important;border:1px solid var(--border-strong) !important}.leaflet-popup-tip{background:var(--bg-glass-strong) !important;border:1px solid var(--border-default) !important}.leaflet-popup-content{margin:14px 18px !important;font-family:var(--font) !important;font-size:0.8rem !important;line-height:1.5 !important}.popup-title{font-family:var(--font-display);font-size:0.95rem;font-weight:700;margin-bottom:8px;letter-spacing:-0.01em}.popup-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border-subtle)}.popup-row:last-child{border-bottom:none}.popup-label{color:var(--text-secondary)}.popup-value{font-family:var(--mono);font-weight:700}.popup-value.cheap{color:var(--green)}.popup-value.mid{color:var(--yellow)}.popup-value.expensive{color:var(--red)}#hover-info{position:absolute;top:12px;left:12px;z-index:800;background:var(--bg-glass-strong);backdrop-filter:var(--glass-blur);border:1px solid var(--border-strong);border-radius:var(--radius-full);padding:8px 20px;display:flex;align-items:center;gap:14px;pointer-events:none;box-shadow:var(--shadow-md);transition:opacity 0.15s var(--ease-out),transform 0.15s var(--ease-out)}#hover-info.hidden{opacity:0;transform:translateY(-4px)}#hover-country-name{font-family:var(--font-display);font-size:0.82rem;font-weight:700}#hover-price{font-family:var(--mono);font-size:0.75rem;color:var(--accent);font-weight:700;text-shadow:0 0 10px rgba(245,158,11,0.2)}.crisis-marker{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-size:14px;border:2px solid;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring)}.crisis-marker:hover{transform:scale(1.15)}.crisis-marker.critical{background:rgba(239,68,68,0.2);border-color:var(--critical);animation:markerPulse 2s ease-in-out infinite}.crisis-marker.severe{background:rgba(249,115,22,0.2);border-color:var(--severe)}.crisis-marker.high{background:rgba(234,179,8,0.2);border-color:var(--high)}@keyframes markerPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,0.35)}50%{box-shadow:0 0 0 14px rgba(239,68,68,0)}}.station-marker{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,0.7);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:white;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,0.4);transition:transform var(--duration-fast) var(--ease-spring)}.station-marker:hover{transform:scale(1.3)}.station-marker.shell{background:#fbcb09;color:#333}.station-marker.caltex{background:#e21836}.station-marker.ptt{background:#1e40af}.station-marker.total{background:#d32f2f}.station-marker.independent{background:#546e7a}.cheapest-badge{position:absolute;top:-6px;right:-6px;background:var(--green);color:white;font-size:7px;padding:1px 4px;border-radius:var(--radius-sm);font-weight:700}.station-cluster{display:flex;align-items:center;justify-content:center;border-radius:50%;color:white;font-family:var(--mono);font-weight:700;border:2px solid rgba(255,255,255,0.35);box-shadow:0 2px 14px rgba(0,0,0,0.35);transition:transform var(--duration-fast) var(--ease-spring)}.station-cluster:hover{transform:scale(1.15)}.station-cluster.cluster-small{width:32px;height:32px;font-size:0.62rem;background:radial-gradient(circle,#3b82f6,#1d4ed8)}.station-cluster.cluster-medium{width:38px;height:38px;font-size:0.7rem;background:radial-gradient(circle,#f59e0b,#d97706)}.station-cluster.cluster-large{width:44px;height:44px;font-size:0.8rem;background:radial-gradient(circle,#ef4444,#b91c1c)}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:none !important}.marker-cluster div{background:none !important}#country-panel{position:absolute;top:12px;right:52px;width:290px;background:var(--bg-glass-strong);backdrop-filter:var(--glass-blur);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 40px rgba(0,0,0,0.2);z-index:1000;padding:18px;animation:panelIn var(--duration-slow) var(--ease-out)}@keyframes panelIn{from{opacity:0;transform:translateY(-12px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}#country-panel.hidden{opacity:0;transform:translateY(-10px) scale(0.96);pointer-events:none;transition:all var(--duration-normal) var(--ease-out)}#close-panel{position:absolute;top:10px;right:12px;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast)}#close-panel:hover{background:rgba(239,68,68,0.1);color:var(--red)}#panel-country-name{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:8px;padding-inline-end:28px;letter-spacing:-0.01em}#panel-impact-badge{margin-bottom:12px}.impact-tag{display:inline-block;padding:3px 12px;border-radius:var(--radius-full);font-size:0.55rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.impact-tag.critical{background:rgba(239,68,68,0.1);color:var(--critical);border:1px solid rgba(239,68,68,0.2)}.impact-tag.severe{background:rgba(249,115,22,0.1);color:var(--severe);border:1px solid rgba(249,115,22,0.2)}.impact-tag.high{background:rgba(234,179,8,0.1);color:var(--high);border:1px solid rgba(234,179,8,0.2)}.impact-tag.moderate{background:rgba(56,189,248,0.1);color:var(--moderate);border:1px solid rgba(56,189,248,0.2)}.impact-tag.low{background:rgba(34,197,94,0.1);color:var(--low);border:1px solid rgba(34,197,94,0.2)}.panel-prices{display:flex;gap:8px;margin-bottom:12px}.panel-price-item{flex:1;background:rgba(0,0,0,0.3);border-radius:var(--radius-md);padding:12px;text-align:center;border:1px solid var(--border-subtle);transition:border-color var(--duration-fast)}.panel-price-item:hover{border-color:var(--border-default)}.price-label{display:block;font-size:0.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.price-value{display:block;font-family:var(--mono);font-size:1.2rem;font-weight:700;margin:4px 0;text-shadow:0 0 10px currentColor}.price-unit{font-size:0.52rem;color:var(--text-muted)}#panel-extra{font-size:0.7rem;color:var(--text-secondary);line-height:1.6}#panel-extra p{margin-bottom:5px}#quick-nav{position:absolute;bottom:16px;left:16px;z-index:1000;display:flex;flex-direction:column;gap:8px}.nav-btn{width:44px;height:44px;border-radius:50%;background:var(--bg-glass-strong);backdrop-filter:var(--glass-blur);border:1px solid var(--border-default);color:var(--text-secondary);font-size:1.1rem;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:var(--shadow-md)}@media (hover:hover) and (pointer:fine){.nav-btn:hover{background:var(--bg-overlay);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-md),0 0 16px rgba(245,158,11,0.1)}}.nav-icon{font-size:1.1rem}.nav-tooltip{position:absolute;left:54px;top:50%;transform:translateY(-50%) translateX(-6px);background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:5px 12px;font-size:0.65rem;font-weight:600;white-space:nowrap;color:var(--text-primary);pointer-events:none;opacity:0;transition:opacity var(--duration-fast),transform var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-md)}.nav-btn:hover .nav-tooltip{opacity:1;transform:translateY(-50%) translateX(0)}#onboarding-toast{position:absolute;bottom:16px;left:50%;transform:translateX(-50%) translateY(12px);z-index:900;background:var(--bg-glass-strong);backdrop-filter:var(--glass-blur);border:1px solid var(--border-strong);border-radius:var(--radius-full);padding:10px 20px;display:flex;align-items:center;gap:14px;max-width:440px;opacity:0;transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out);pointer-events:none;box-shadow:var(--shadow-md)}#onboarding-toast.toast-visible{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}#onboarding-toast.hidden{opacity:0;visibility:hidden;pointer-events:none}.toast-text{font-size:0.7rem;color:var(--text-secondary);line-height:1.4}.toast-close{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;flex-shrink:0;transition:color var(--duration-fast)}.toast-close:hover{color:var(--text-primary)}.modal{position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;transition:opacity var(--duration-normal),visibility var(--duration-normal)}.modal.hidden{opacity:0;visibility:hidden;pointer-events:none}.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.65);backdrop-filter:blur(12px)}.modal-content{position:relative;background:var(--bg-raised);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:90%;max-width:720px;max-height:82vh;overflow-y:auto;box-shadow:var(--shadow-lg);scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;z-index:10;transition:color var(--duration-fast)}.modal-close:hover{color:var(--text-primary)}.modal-header{padding:18px 22px 12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.modal-header h2{font-family:var(--font-display);font-size:1.1rem;font-weight:700;letter-spacing:-0.01em}.badge-critical{font-size:0.52rem;font-weight:700;padding:3px 10px;border-radius:var(--radius-full);letter-spacing:0.8px;background:rgba(239,68,68,0.08);color:var(--critical);border:1px solid rgba(239,68,68,0.2)}.modal-body{padding:8px 22px 22px}.modal-body h3{font-family:var(--font-display);font-size:0.72rem;font-weight:600;color:var(--text-muted);margin:18px 0 10px;text-transform:uppercase;letter-spacing:1px}.hike{color:var(--orange);font-family:var(--mono);font-weight:600}.hike.severe{color:var(--red)}.supply-bars{display:flex;flex-direction:column;gap:6px}.supply-item{display:flex;align-items:center;gap:8px}.supply-label{width:64px;font-size:0.65rem;color:var(--text-secondary);flex-shrink:0}.supply-bar{flex:1;height:20px;background:var(--bg-surface);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--border-default)}.supply-fill{height:100%;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:flex-end;padding-inline-end:8px}.supply-fill span{font-size:0.52rem;font-weight:700;color:white;font-family:var(--mono)}.supply-fill.safe{background:linear-gradient(90deg,var(--green),var(--cyan))}.supply-fill.caution{background:linear-gradient(90deg,var(--yellow),var(--orange))}.supply-fill.danger{background:linear-gradient(90deg,var(--orange),var(--red))}.impact-item{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:10px}.impact-item strong{display:block;color:var(--text-primary);font-size:0.68rem;margin-bottom:3px}.impact-item span{color:var(--text-secondary);font-size:0.62rem}.welcome-overlay{background:radial-gradient(ellipse at 50% 40%,rgba(245,158,11,0.06) 0%,rgba(0,0,0,0.75) 70%) !important}.welcome-content{position:relative;z-index:1;background:var(--bg-raised);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:92%;max-width:460px;padding:36px 32px 28px;text-align:center;box-shadow:var(--shadow-lg),0 0 80px rgba(245,158,11,0.06);animation:welcomeIn var(--duration-dramatic) var(--ease-out);overflow:hidden}@keyframes welcomeIn{from{opacity:0;transform:translateY(24px) scale(0.94)}to{opacity:1;transform:translateY(0) scale(1)}}.welcome-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:300px;height:160px;background:radial-gradient(ellipse,rgba(245,158,11,0.1) 0%,transparent 70%);pointer-events:none}.welcome-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.18);padding:4px 14px;border-radius:var(--radius-full);font-size:0.5rem;font-weight:700;color:var(--red);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:16px}.welcome-icon{font-size:2.8rem;margin-bottom:12px;filter:drop-shadow(0 0 16px rgba(245,158,11,0.2))}.welcome-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:8px;letter-spacing:-0.02em;background:linear-gradient(135deg,var(--text-primary) 30%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-sub{font-size:0.78rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.5;max-width:360px;margin-inline:auto}.welcome-metrics{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:24px;padding:12px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.welcome-metric{display:flex;flex-direction:column;align-items:center;gap:2px}.welcome-metric-value{font-family:var(--mono);font-size:1rem;font-weight:700;color:var(--accent);text-shadow:0 0 10px rgba(245,158,11,0.2)}.welcome-metric-label{font-size:0.52rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.welcome-metric-divider{width:1px;height:28px;background:var(--border-default)}.welcome-search{position:relative;margin-bottom:16px}.welcome-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:0.78rem;pointer-events:none;color:var(--text-muted);z-index:1}.welcome-input{width:100%;padding:13px 18px 13px 42px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font);font-size:0.85rem;outline:none;transition:all var(--duration-fast) var(--ease-out)}.welcome-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted),0 4px 20px rgba(245,158,11,0.06)}.welcome-input::placeholder{color:var(--text-muted)}.welcome-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;box-shadow:var(--shadow-lg);z-index:10}.welcome-suggestions.hidden{display:none}.welcome-suggestion{padding:11px 16px;cursor:pointer;font-size:0.78rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);transition:all var(--duration-fast)}.welcome-suggestion:hover{background:var(--bg-overlay);color:var(--text-primary);padding-inline-start:20px}.welcome-suggestion:last-child{border-bottom:none}.welcome-actions{display:flex;gap:8px;margin-bottom:12px}.welcome-btn{flex:1;padding:12px 16px;border-radius:var(--radius-full);font-family:var(--font);font-size:0.78rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;display:flex;align-items:center;justify-content:center;gap:6px}.welcome-btn.primary{background:var(--accent);color:var(--text-inverse);box-shadow:0 2px 12px rgba(245,158,11,0.2)}.welcome-btn.primary:hover{background:var(--accent-hover);box-shadow:0 4px 20px rgba(245,158,11,0.3)}.welcome-btn.secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-default)}.welcome-btn.secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-icon{font-size:0.85rem}.welcome-skip-link{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:0.68rem;cursor:pointer;padding:4px;transition:color var(--duration-fast)}.welcome-skip-link:hover{color:var(--text-secondary)}@media (max-width:1024px){:root{--sidebar-w:270px}}@media (max-width:768px) and (orientation:portrait){:root{--header-h:46px;--banner-h:0px}#alert-banner{display:none}#main-header{padding-inline:12px;gap:10px}#main-header::after{display:none}.header-left{gap:10px;flex:1;min-width:0}.header-title-text{font-size:0.88rem}.crisis-badge,.header-date{display:none}.header-center{display:none}#realtime-status,#manual-refresh-btn{display:none !important}.header-right{gap:8px}.currency-select{font-size:0.62rem;padding:5px 22px 5px 8px;height:36px}#sidebar-toggle{width:36px;height:36px;font-size:1rem;border-color:var(--border-strong)}.header-icon-btn{width:36px;height:36px;font-size:0.85rem;border-color:var(--border-strong)}#main-content{flex-direction:column;position:relative}#map-container{flex:1}#sidebar{position:absolute;bottom:0;left:0;right:0;width:100%;max-height:60vh;height:auto;border-right:none;border-top:1px solid var(--border-strong);border-radius:var(--radius-xl) var(--radius-xl) 0 0;background:var(--bg-raised);z-index:500;overflow-y:auto;overflow-x:hidden;box-shadow:0 -4px 30px rgba(0,0,0,0.5);transition:transform var(--duration-normal) var(--ease-out),opacity var(--duration-fast);transform:translateY(0)}#sidebar.sidebar-collapsed{transform:translateY(100%);opacity:0;pointer-events:none}#sidebar::before{content:"";display:block;width:36px;height:4px;border-radius:2px;background:var(--border-strong);margin:8px auto 4px;flex-shrink:0}.tab-pane.active{display:flex;flex-direction:column;overflow-y:auto;flex:1;min-height:0}.sb-grow{flex:1;min-height:0;overflow-y:auto}#filter-group{display:none}.sb-group{padding:6px 12px}.sb-label{font-size:0.58rem;margin-bottom:4px;color:var(--text-secondary)}.stab{padding:10px 0 8px}.stab-icon{font-size:0.9rem}.stab-label{font-size:0.56rem}#country-search{padding:8px 30px 8px 32px;font-size:0.78rem}.ranking-controls{margin-bottom:4px}.ranking-item{min-height:42px;padding:8px 10px;font-size:0.72rem}.ranking-rank{width:20px;font-size:0.62rem}.ranking-price{font-size:0.65rem}.ranking-select{font-size:0.68rem;padding:6px 24px 6px 10px}.view-btn,.style-btn{min-height:36px;font-size:0.68rem;display:flex;align-items:center;justify-content:center}.layer-toggle{padding:8px 0;min-height:40px;font-size:0.75rem}.nav-btn{width:44px;height:44px}.station-marker{width:28px !important;height:28px !important;font-size:12px !important}#country-panel{top:auto;right:8px;left:8px;bottom:8px;width:auto;max-height:50vh;border-radius:var(--radius-lg);overflow-y:auto;z-index:600}#quick-nav{flex-direction:row;bottom:14px;left:14px;z-index:400}.nav-tooltip{display:none}#hover-info{left:50%;transform:translateX(-50%);top:8px}#onboarding-toast{bottom:14px;max-width:calc(100% - 28px);border-radius:var(--radius-lg)}.welcome-content{padding:28px 20px 22px;max-width:92%;width:auto;border-radius:var(--radius-xl)}.welcome-glow{width:200px;height:100px;top:-50px}.welcome-title{font-size:1.25rem}.welcome-sub{font-size:0.74rem}.welcome-actions{flex-direction:column}.welcome-btn{padding:13px;min-height:46px;font-size:0.8rem}.welcome-input{padding:13px 16px 13px 40px;font-size:0.85rem}.stat-grid{gap:6px}.stat-card{padding:12px 8px}.modal-content{width:95%;max-height:85vh}}@media (max-width:960px) and (orientation:landscape){:root{--header-h:40px;--banner-h:0px;--sidebar-w:280px}#alert-banner{display:none}#main-header{padding-inline:10px;gap:8px}#main-header::after{display:none}.crisis-badge,.header-date{display:none}.header-center{display:none}.header-title-text{font-size:0.78rem}#sidebar-toggle{width:34px;height:34px}.header-icon-btn{width:34px;height:34px}.currency-select{font-size:0.58rem}#main-content{flex-direction:row;position:relative}#map-container{flex:1}#sidebar{width:var(--sidebar-w);height:100%;max-height:none;border-right:1px solid var(--border-strong);border-bottom:none;background:var(--bg-raised);z-index:500;overflow-y:auto;overflow-x:hidden;flex-shrink:0;transition:width var(--duration-normal) var(--ease-out),opacity var(--duration-fast)}#sidebar.sidebar-collapsed{width:0;overflow:hidden;opacity:0;pointer-events:none}#sidebar::before{display:none}.tab-pane.active{display:flex;flex-direction:column;overflow-y:auto;flex:1;min-height:0}.sb-grow{flex:1;min-height:0;overflow-y:auto}.ranking-list{overflow-y:auto}#filter-group{display:none}.sb-group{padding:6px 10px}.sb-label{font-size:0.55rem;margin-bottom:4px;color:var(--text-secondary)}.stab{padding:8px 0 6px}.stab-icon{font-size:0.8rem}.stab-label{font-size:0.5rem}#country-search{padding:6px 28px 6px 30px;font-size:0.72rem}.ranking-item{min-height:36px;padding:6px 8px;font-size:0.66rem}.ranking-rank{width:18px;font-size:0.58rem}.ranking-price{font-size:0.6rem}.ranking-select{font-size:0.62rem;padding:5px 20px 5px 8px}.ranking-controls{margin-bottom:4px}.view-btn,.style-btn{min-height:32px;font-size:0.62rem;display:flex;align-items:center;justify-content:center}.layer-toggle{padding:5px 0;min-height:32px;font-size:0.68rem}.nav-btn{width:40px;height:40px}#country-panel{top:8px;right:8px;bottom:auto;left:auto;width:250px;max-height:calc(100% - 16px);border-radius:var(--radius-lg);overflow-y:auto}#quick-nav{flex-direction:column;bottom:12px;left:12px}.nav-tooltip{display:none}.welcome-content{padding:16px 20px;max-width:400px}.welcome-title{font-size:1.05rem}.welcome-sub{font-size:0.65rem;margin-bottom:10px}.welcome-metrics{padding:6px 0;margin-bottom:10px}.welcome-actions{flex-direction:row}.welcome-btn{min-height:40px;padding:10px;font-size:0.72rem}.modal-content{width:80%;max-height:90vh}}@media (max-width:380px) and (orientation:portrait){:root{--header-h:44px}.header-title-text{font-size:0.75rem}.currency-select{font-size:0.55rem;padding:4px 18px 4px 6px}#sidebar-toggle,.header-icon-btn{width:34px;height:34px}.welcome-content{padding:22px 16px 18px}.welcome-title{font-size:1.1rem}.welcome-icon{font-size:2rem;margin-bottom:8px}.sb-group{padding:5px 10px}.ranking-item{min-height:38px;padding:6px 8px;font-size:0.66rem}}@media (min-width:769px) and (max-width:1024px) and (orientation:portrait){:root{--sidebar-w:260px}.oil-prices-ticker{gap:14px}.welcome-content{max-width:480px}}@supports (padding:env(safe-area-inset-top)){@media (max-width:768px){#main-header{padding-top:env(safe-area-inset-top);height:calc(var(--header-h) + env(safe-area-inset-top))}#sidebar{padding-bottom:env(safe-area-inset-bottom)}#quick-nav{bottom:calc(14px + env(safe-area-inset-bottom))}#country-panel{bottom:calc(8px + env(safe-area-inset-bottom))}}}@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.stat-card{animation:fadeIn 0.3s var(--ease-out) both}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}}