@import url(https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=DM+Sans:wght@400;500;700;800;900&display=swap);.kpi-modal-backdrop{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.kpi-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000024;min-width:300px;padding:24px}.kpi-modal-title{color:#1a1a1a;font-size:15px;font-weight:500;margin:0 0 16px}.kpi-modal-input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:16px;outline:none;padding:8px 12px;width:100%}.kpi-modal-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.kpi-modal-notice{background:#fefce8;border:1px solid #fde047;border-radius:8px;color:#713f12;font-size:12px;line-height:1.5;margin-top:12px;padding:10px 12px}.kpi-modal-notice code{background:#fef9c3;border-radius:4px;font-family:monospace;font-size:11px;padding:1px 5px}.kpi-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.kpi-modal-cancel{background:none;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;font-size:14px;padding:8px 16px}.kpi-modal-save{background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 20px}.kpi-modal-save:hover{background:#4f46e5}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{height:100%;overflow:hidden}body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app-shell,.sidebar{display:flex;height:100vh;overflow:hidden}.sidebar{align-items:center;background:linear-gradient(180deg,#0a2558,#0f3a7d 50%,#1e5ba8);border-right:1px solid #ffffff14;box-shadow:4px 0 20px #0003;box-sizing:border-box;color:#fff;flex-direction:column;flex-shrink:0;gap:12px;padding:20px 12px;position:relative;transition:width .3s ease;z-index:10}.main-content{flex:1 1;height:100vh;min-width:0;overflow-x:hidden;overflow-y:auto;padding:24px 36px}.header{animation:slideDown .8s cubic-bezier(.16,1,.3,1);margin-bottom:20px;text-align:center}.header-inner{align-items:center;display:inline-flex;flex-direction:column;gap:6px}.header-badge{animation:badgeDrop .5s ease-out .1s forwards;background:linear-gradient(135deg,#0f3a7d,#2563eb);border-radius:20px;color:#fff;display:inline-block;font-size:10px;font-weight:700;letter-spacing:3px;opacity:0;padding:4px 14px;transform:translateY(-8px)}@keyframes badgeDrop{to{opacity:1;transform:translateY(0)}}.header-title{align-items:center;display:flex;font-family:Montserrat,sans-serif;font-size:2.4em;font-weight:500;gap:1px;letter-spacing:-1px;line-height:1;margin:0}.header-letter{-webkit-text-fill-color:#0000;animation:letterPop .5s cubic-bezier(.34,1.56,.64,1) forwards,gradientShift 5s linear 1s infinite;background:linear-gradient(135deg,#0a2558,#1e5ba8 40%,#2563eb 60%,#0f3a7d);-webkit-background-clip:text;background-clip:text;background-size:300% auto;display:inline-block;opacity:0;transform:translateY(20px) scale(.8)}@keyframes letterPop{to{opacity:1;transform:translateY(0) scale(1)}}@keyframes gradientShift{0%{background-position:0}to{background-position:300%}}.header-underline{background:#e5e7eb;border-radius:2px;height:3px;margin-top:2px;overflow:hidden;width:100%}.header-underline-fill{animation:underlineExpand .8s cubic-bezier(.16,1,.3,1) .7s forwards,underlineShimmer 3s linear 1.5s infinite;background:linear-gradient(90deg,#0f3a7d,#2563eb,#38bdf8,#2563eb,#0f3a7d);background-size:200% auto;border-radius:2px;height:100%;width:0}@keyframes underlineExpand{to{width:100%}}@keyframes underlineShimmer{0%{background-position:0}to{background-position:200%}}.header-subtitle{animation:fadeInUp .6s ease-out 1s forwards;color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.3px;margin:0;opacity:0}.header-row{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:16px}.header-row .header{flex-shrink:0;margin-bottom:0}.filter-status-panel{align-self:flex-start;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) .3s both;border-radius:14px;flex-shrink:0;margin-top:4px;max-width:220px;min-width:160px;padding:8px 12px;transition:all .4s ease}.filter-status-panel:not(.is-filtered){background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1.5px solid #bae6fd}.filter-status-panel.is-filtered{animation:panelPulse .5s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fcd34d;box-shadow:0 4px 16px #fbbf2426}@keyframes panelPulse{0%{transform:scale(.97)}60%{transform:scale(1.02)}to{transform:scale(1)}}.filter-status-all{align-items:center;display:flex;gap:10px}.filter-status-all-text{display:flex;flex:1 1;flex-direction:column;gap:1px}.filter-status-all-label{color:#0284c7;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.filter-status-all-value{color:#0f3a7d;font-size:15px;font-weight:700}.filter-status-all-icon{animation:spinSlow 8s linear infinite;font-size:22px}@keyframes spinSlow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.filter-status-active{display:flex;flex-direction:column;gap:10px}.filter-status-header{align-items:center;display:flex;gap:8px}.filter-status-active-label{color:#92400e;flex:1 1;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.filter-status-count{align-items:center;background:#f59e0b;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:700;height:20px;justify-content:center;width:20px}.filter-status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.all-dot{animation:dotPulse 2s ease-in-out infinite;background:#0ea5e9;box-shadow:0 0 0 0 #0ea5e966}.active-dot{animation:dotPulse 1.5s ease-in-out infinite;background:#f59e0b;box-shadow:0 0 0 0 #f59e0b66}@keyframes dotPulse{0%{box-shadow:0 0 0 0 currentColor}70%{box-shadow:0 0 0 6px #0000}to{box-shadow:0 0 0 0 #0000}}.filter-badges{display:flex;flex-direction:column;gap:6px}.filter-badge{align-items:center;animation:badgeSlideIn .35s cubic-bezier(.16,1,.3,1) forwards;background:#fff;border:1px solid #fde68a;border-radius:8px;display:flex;gap:8px;opacity:0;padding:6px 10px;transform:translateX(10px)}@keyframes badgeSlideIn{to{opacity:1;transform:translateX(0)}}.filter-badge-icon{flex-shrink:0;font-size:14px}.filter-badge-text{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.filter-badge-label{color:#92400e;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.filter-badge-value{color:#1f2937;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-badge-remove{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:11px;font-weight:700;line-height:1;padding:2px 4px;transition:all .2s ease}.filter-badge-remove:hover{background:#fee2e2;color:#dc2626}.filter-status-reset{align-self:flex-start;background:none;border:1.5px solid #f59e0b;border-radius:6px;color:#92400e;cursor:pointer;font-size:11px;font-weight:700;padding:5px 10px;transition:all .2s ease}.filter-status-reset:hover{background:#f59e0b;color:#fff}.section-heading{margin-bottom:16px;margin-top:24px;padding-bottom:12px;position:relative}.section-heading:after{animation:expandLine .8s cubic-bezier(.16,1,.3,1) both;background:linear-gradient(90deg,#0f3a7d,#2563eb 50%,#0000);border-radius:2px;bottom:0;content:"";height:3px;left:0;position:absolute;width:100%}@keyframes expandLine{0%{opacity:0;width:0}to{opacity:1;width:100%}}.section-heading h2{align-items:center;animation:slideInLeft .6s cubic-bezier(.16,1,.3,1) both;color:#0f3a7d;display:flex;font-size:1.3em;font-weight:700;gap:8px}.filter-section{animation:fadeInUp .7s cubic-bezier(.16,1,.3,1) both;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;isolation:isolate;margin-bottom:22px;overflow:visible;padding:20px 24px;position:relative;z-index:100}.filter-section:before{animation:sweepShimmer 1.2s ease-out .3s both;background:linear-gradient(90deg,#0000,#fff9,#0000);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:60%}@keyframes sweepShimmer{0%{left:-100%}to{left:200%}}.filter-title{align-items:center;color:#1f2937;display:flex;font-size:1em;font-weight:700;gap:8px;margin-bottom:12px}.filter-grid{grid-gap:12px;align-items:end;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;font-family:inherit;font-size:13px;padding:9px 11px;transition:all .25s ease}.filter-select:hover{border-color:#0f3a7d;box-shadow:0 2px 8px #0f3a7d1a}.filter-select:focus{border-color:#0f3a7d;box-shadow:0 0 0 3px #0f3a7d1a;outline:none}.filter-select:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.filter-button-group{display:flex;gap:8px}.filter-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;overflow:hidden;padding:9px 14px;position:relative;transition:all .25s ease}.filter-btn:after{background:#f8f2f259;border-radius:50%;content:"";height:0;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease,opacity .4s ease;width:0}.filter-btn:active:after{height:200px;opacity:1;width:200px}.filter-btn-apply{background:linear-gradient(135deg,#0f3a7d,#1e5ba8);color:#fff}.filter-btn-apply:hover{box-shadow:0 4px 16px #b3bdcd66;transform:translateY(-2px)}.filter-btn-reset{background:#2d68de;color:#fbfdfe}.filter-btn-reset:hover{background:#052b77}.kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:6px}.kpi-card:first-child{animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .1s both}.kpi-card:nth-child(2){animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .18s both}.kpi-card:nth-child(3){animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .26s both}.kpi-card:nth-child(4){animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .34s both}.kpi-card:nth-child(5){animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .42s both}.kpi-card:nth-child(6){animation:cardPop .6s cubic-bezier(.34,1.56,.64,1) .5s both}@keyframes cardPop{0%{opacity:0;transform:translateY(24px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.kpi-card{background:#fff;border-left:4px solid #0f3a7d;border-radius:12px;box-shadow:0 2px 10px #0000000f;cursor:default;overflow:hidden;padding:20px 22px;position:relative;transition:transform .25s ease,box-shadow .25s ease}.kpi-card:after{background:linear-gradient(120deg,#0000 30%,#ffffff8c 50%,#0000 70%);content:"";inset:0;pointer-events:none;position:absolute;transform:translateX(-100%);transition:transform .55s ease}.kpi-card:hover:after{transform:translateX(100%)}.kpi-card:nth-child(2){border-left-color:#d97706}.kpi-card:nth-child(3){border-left-color:#059669}.kpi-card:nth-child(4){border-left-color:#f59e0b}.kpi-card:nth-child(5){border-left-color:#a855f7}.kpi-card:nth-child(6){border-left-color:#ef4444}.kpi-card:hover{box-shadow:0 10px 28px #0000001f;transform:translateY(-4px) scale(1.01)}.kpi-label{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.kpi-value{font-feature-settings:"tnum";color:#1f2937;font-size:1.3em;font-variant-numeric:tabular-nums;font-weight:700;line-height:1;transition:transform .2s ease}.kpi-card:hover .kpi-value{transform:scale(1.04)}.overall-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(4,1fr);margin-bottom:6px}.overall-card{background:#fff;border-radius:14px;border-top:4px solid #2563eb;box-shadow:0 2px 12px #00000012;cursor:default;overflow:hidden;padding:22px 24px;position:relative;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.overall-card:first-child{animation:cardSlideUp .7s cubic-bezier(.34,1.56,.64,1) .2s both}.overall-card:nth-child(2){animation:cardSlideUp .7s cubic-bezier(.34,1.56,.64,1) .32s both}.overall-card:nth-child(3){animation:cardSlideUp .7s cubic-bezier(.34,1.56,.64,1) .44s both}.overall-card:nth-child(4){animation:cardSlideUp .7s cubic-bezier(.34,1.56,.64,1) .56s both}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.overall-card:before{background:linear-gradient(90deg,#0000,#fffc,#0000);content:"";height:4px;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.overall-card:hover:before{left:100%}.overall-card:after{border-radius:14px;content:"";inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .3s ease}.warehouse:after{background:radial-gradient(ellipse at top left,#2563eb0d 0,#0000 65%)}.distributor:after{background:radial-gradient(ellipse at top left,#f59e0b0d 0,#0000 65%)}.lco:after{background:radial-gradient(ellipse at top left,#10b9810d 0,#0000 65%)}.active:after{background:radial-gradient(ellipse at top left,#ef44440d 0,#0000 65%)}.overall-card:hover:after{opacity:1}.overall-card:hover{box-shadow:0 14px 32px #0000001f;transform:translateY(-5px) scale(1.01)}.warehouse{border-top-color:#2563eb}.distributor{border-top-color:#f59e0b}.lco{border-top-color:#10b981}.active{border-top-color:#ef4444}.card-title{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.card-number{color:#1f2937;font-size:2.1em;font-weight:800;line-height:1;margin-bottom:16px;transition:transform .25s ease}.overall-card:hover .card-number{transform:scale(1.05)}.sub-info{border-top:1px solid #f3f4f6;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding-top:14px}.sub-info div{flex:1 1;min-width:60px}.sub-info span{color:#000;display:block;font-size:12px;font-weight:800;letter-spacing:.4px;margin-bottom:4px;text-transform:uppercase}.sub-label{color:#dc0000!important;display:block!important;font-size:12px!important;font-weight:800!important;letter-spacing:.4px!important;margin-bottom:4px!important;text-transform:uppercase!important}.sub-info strong{color:#1f2937;display:inline-block;font-size:1.35em;font-weight:700;transition:transform .2s ease}.overall-card:hover .sub-info strong{transform:scale(1.06)}.tabs-container{animation:fadeInUp .7s cubic-bezier(.16,1,.3,1) .4s both;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;margin-bottom:10px;overflow:hidden}.tabs-header{background:#f9fafb;border-bottom:2px solid #e5e7eb;display:flex;padding:0 16px}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#9ca3af;cursor:pointer;font-size:.9em;font-weight:600;margin-bottom:-2px;padding:12px 20px;position:relative;transition:all .25s ease}.tab-button:after{background:#0f3a7d;border-radius:2px 2px 0 0;bottom:-2px;content:"";height:3px;left:50%;position:absolute;right:50%;transition:left .3s ease,right .3s ease}.tab-button.active:after{left:0;right:0}.tab-button:hover{background:#0f3a7d0a;color:#0f3a7d}.tab-button.active{color:#0f3a7d}.tab-content{display:none;padding:20px}.tab-content.active{animation:tabSlideIn .35s cubic-bezier(.16,1,.3,1);display:block}@keyframes tabSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:linear-gradient(135deg,#f8f9fa,#f0f4f8);border-left:4px solid #0f3a7d;border-radius:12px;overflow:hidden;padding:20px 22px;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.stat-card:first-child{animation:cardPop .5s cubic-bezier(.34,1.56,.64,1) .05s both;border-left-color:#0f3a7d}.stat-card:nth-child(2){animation:cardPop .5s cubic-bezier(.34,1.56,.64,1) .15s both;border-left-color:#d97706}.stat-card:nth-child(3){animation:cardPop .5s cubic-bezier(.34,1.56,.64,1) .25s both;border-left-color:#059669}.stat-card:nth-child(4){animation:cardPop .5s cubic-bezier(.34,1.56,.64,1) .35s both;border-left-color:#f59e0b}.stat-card:after{background:linear-gradient(120deg,#0000 30%,#ffffff80 50%,#0000 70%);content:"";inset:0;pointer-events:none;position:absolute;transform:translateX(-100%);transition:transform .5s ease}.stat-card:hover:after{transform:translateX(100%)}.stat-card:hover{box-shadow:0 10px 24px #0000001a;transform:translateY(-4px) scale(1.02)}.stat-icon{display:inline-block;font-size:1.6em;margin-bottom:8px;transition:transform .3s ease}.stat-card:hover .stat-icon{transform:scale(1.2) rotate(-8deg)}.stat-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.stat-value{font-feature-settings:"tnum";color:#1f2937;font-size:1.9em;font-variant-numeric:tabular-nums;font-weight:700;transition:transform .2s ease}.stat-card:hover .stat-value{transform:scale(1.05)}.card-number,.kpi-value:has-text,.stat-value{position:relative}@keyframes slideDown{0%{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:1200px){.overall-grid{grid-template-columns:repeat(2,1fr)}.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.overall-grid{grid-template-columns:1fr}.kpi-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.main-content{padding:14px}}.cities-shell{background:linear-gradient(135deg,#e8f0fb,#f0f4f8 50%,#eaf6fb);display:flex;height:100vh;overflow:hidden}.cities-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;padding-bottom:24px}.cities-grid>.city-card:last-child:nth-child(odd){grid-column:1/-1}.cities-grid--solo{grid-template-columns:1fr!important;padding-bottom:32px}@media (max-width:900px){.cities-grid{grid-template-columns:1fr}.cities-grid--solo{grid-template-columns:1fr!important}.cities-grid>.city-card:last-child:nth-child(odd){grid-column:auto}}.city-card{backdrop-filter:blur(18px) saturate(1.6);-webkit-backdrop-filter:blur(18px) saturate(1.6);background:#ffffffb8;border:1px solid #ffffffd9;border-radius:20px;box-shadow:0 4px 24px #00000012,0 1px 2px #0000000a,inset 0 1px 0 #fffffff2;cursor:pointer;display:flex;flex-direction:column;min-height:440px;overflow:hidden;padding:0 0 20px;position:relative;transition:transform .3s cubic-bezier(.34,1.4,.64,1),box-shadow .3s ease}.city-card:hover{box-shadow:0 24px 60px #00000021,0 8px 24px #00000012,inset 0 1px 0 #fffffff2;transform:translateY(-7px) scale(1.005)}.city-card-shine{background:linear-gradient(180deg,#ffffff73,#fff0);border-radius:20px 20px 60% 60%;height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.city-card-top-bar{border-radius:20px 20px 0 0;flex-shrink:0;height:4px;position:relative;z-index:2}.city-card-body{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden;padding:16px 20px 0;position:relative;z-index:2}.city-card-glow{animation:glowPulse 4s ease-in-out infinite;border-radius:50%;height:180px;opacity:.7;pointer-events:none;position:absolute;right:-30px;top:-30px;width:180px;z-index:0}@keyframes glowPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.city-direction-tag{font-size:11px;font-weight:900;letter-spacing:.22em;margin-bottom:3px;position:relative;text-transform:uppercase;z-index:2}.city-card-emoji{display:inline-block;filter:drop-shadow(0 2px 4px rgba(53,52,52,.15));font-size:22px;margin-right:7px;transition:transform .3s ease;vertical-align:middle}.city-card:hover .city-card-emoji{transform:scale(1.2) rotate(8deg)}.city-card-title{align-items:center;color:#0f3a7d;display:flex;font-size:17px;font-weight:800;line-height:1.3}.city-card-divider,.city-card-title{margin-bottom:10px;position:relative;z-index:2}.city-card-divider{border-radius:2px;height:2.5px;transition:width .35s cubic-bezier(.34,1.4,.64,1);width:40px}.city-card:hover .city-card-divider{width:72px}.retry-btn{background:#0000;border:1px solid #dc2626;border-radius:6px;color:#dc2626;cursor:pointer;font-size:12px;margin-top:8px;padding:4px 12px;transition:all .15s ease}.retry-btn:hover{background:#dc2626;color:#fff}.error-row{align-items:center;display:flex;flex-direction:column;padding:16px 0}.error-text{color:#dc2626;font-size:13px}.recharts-wrap{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:visible;position:relative}.recharts-wrap .recharts-surface,.recharts-wrap .recharts-wrapper{overflow:visible!important}.rc-legend{display:flex;flex-shrink:0;gap:16px;justify-content:flex-end;margin-bottom:4px;padding-right:10px}.legend-pill{align-items:center;color:#334155;display:flex;font-family:DM Sans,sans-serif;font-size:13px;font-weight:800;gap:7px;letter-spacing:.08em;text-transform:uppercase}.legend-swatch{border-radius:4px;box-shadow:0 2px 6px #0003;flex-shrink:0;height:14px;width:14px}.swatch-allotted{background:linear-gradient(135deg,#ffb347,#f7941d)}.swatch-active{background:linear-gradient(135deg,#72dada,#47bdbd)}.chart-scroll-outer{box-sizing:border-box;overflow-x:auto;overflow-y:visible;padding-bottom:4px;scrollbar-color:#6382b480 #dce8f566;scrollbar-width:thin;width:100%}.chart-scroll-outer::-webkit-scrollbar{height:6px}.chart-scroll-outer::-webkit-scrollbar-track{background:#dce8f566;border-radius:10px;margin:0 8px}.chart-scroll-outer::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#a0bcd8,#6d99c0);border-radius:10px}.chart-scroll-outer::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#6d99c0,#4a78a8)}.chart-scroll-none{overflow:visible;width:100%}.chart-tooltip{animation:tooltipIn .18s cubic-bezier(.34,1.4,.64,1) both;backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);background:#081228d1;border:1px solid #ffffff21;border-radius:18px;box-shadow:0 28px 72px #00000080,0 8px 24px #0000004d,inset 0 1px 0 #ffffff1f,inset 0 -1px 0 #ffffff0a;min-width:220px;overflow:hidden;padding:18px 22px 16px;pointer-events:none;z-index:9999}@keyframes tooltipIn{0%{opacity:0;transform:scale(.88) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.ctt-shimmer{animation:shimmerSlide 2.4s ease-in-out infinite;background:linear-gradient(105deg,#0000,#ffffff12 50%,#0000);height:100%;left:-60%;pointer-events:none;position:absolute;top:0;width:50%}@keyframes shimmerSlide{0%{left:-60%}to{left:130%}}.ctt-city{color:#f0f6ff;font-family:Sora,sans-serif;font-size:20px;font-weight:800;letter-spacing:.02em;margin-bottom:12px;text-shadow:0 1px 8px #00c8ff33}.ctt-divider{background:linear-gradient(90deg,#0000,#ffffff2e,#0000);height:1px;margin-bottom:13px}.ctt-row{align-items:center;display:flex;gap:11px;line-height:2.1}.ctt-dot{border-radius:4px;box-shadow:0 2px 8px #0006;display:inline-block;flex-shrink:0;height:12px;width:12px}.ctt-label{color:#94a3b8;flex:1 1;font-family:DM Sans,sans-serif;font-size:12.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.ctt-value{color:#f8fafc;font-family:Sora,sans-serif;font-size:17px;font-weight:800;text-shadow:0 0 12px #ffffff26}.chart-empty{align-items:center;color:#9ca3af;display:flex;flex:1 1;font-family:DM Sans,sans-serif;font-size:13px;justify-content:center;min-height:200px}.chart-empty.chart-error{color:#dc2626}@keyframes loadingPulse{0%,to{opacity:.3}50%{opacity:.85}}.skeleton-chart-wrap{display:flex;flex:1 1;flex-direction:column;min-height:240px;padding:4px 8px 0}.skeleton-bars{border-bottom:2px solid #e5e7eb;border-left:2px solid #e5e7eb;gap:12px;padding:0 8px}.skeleton-bar-col,.skeleton-bars{align-items:flex-end;display:flex;flex:1 1}.skeleton-bar-col{gap:3px}.skeleton-bar-item{animation:loadingPulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background-size:200% 100%;border-radius:4px 4px 0 0;flex:1 1}.skeleton-bar-item.sk-active{animation:loadingPulse 1.5s ease-in-out .15s infinite;background:linear-gradient(90deg,#cffafa 25%,#e0fafa 50%,#cffafa 75%);background-size:200% 100%}.skeleton-xlabel-row{display:flex;gap:12px;padding:10px 8px 0}.skeleton-xlabel-item{animation:loadingPulse 1.5s ease-in-out infinite;background:#e5e7eb;border-radius:4px;flex:1 1;height:11px}.summary-cards-row--zones{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(5,1fr);margin-bottom:28px}@media (max-width:1100px){.summary-cards-row--zones{grid-template-columns:repeat(3,1fr)}}@media (max-width:700px){.summary-cards-row--zones{grid-template-columns:1fr 1fr}}@media (max-width:480px){.summary-cards-row--zones{grid-template-columns:1fr}}.summary-card{backdrop-filter:blur(18px) saturate(1.5);-webkit-backdrop-filter:blur(18px) saturate(1.5);background:#ffffffb3;border:1px solid #ffffffe0;border-radius:18px;box-shadow:0 4px 20px #00000012,inset 0 1px 0 #fffffff2;cursor:default;overflow:hidden;padding:0 0 18px;position:relative;transition:transform .28s cubic-bezier(.34,1.4,.64,1),box-shadow .28s ease}.summary-card:hover{box-shadow:0 20px 48px #0000001f,inset 0 1px 0 #fffffff2;transform:translateY(-5px) scale(1.01)}.summary-card-shine{background:linear-gradient(180deg,#ffffff80,#0000);border-radius:18px 18px 80% 80%;height:45%;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.summary-card-top-bar{border-radius:18px 18px 0 0;height:4px;position:relative;z-index:2}.summary-card-glow{animation:glowPulse 4s ease-in-out infinite;border-radius:50%;height:130px;pointer-events:none;position:absolute;right:-30px;top:-30px;width:130px;z-index:0}.summary-card-label{align-items:center;color:#64748b;display:flex;font-family:DM Sans,sans-serif;font-size:13px;font-weight:900;gap:6px;letter-spacing:.14em;padding:14px 18px 0;position:relative;text-transform:uppercase;z-index:2}.summary-card-emoji{filter:drop-shadow(0 1px 3px rgba(0,0,0,.15));font-size:17px}.summary-card-main{font-family:Sora,sans-serif;font-size:36px;font-weight:800;letter-spacing:-.02em;line-height:1.1;padding:8px 18px 0;position:relative;text-shadow:0 2px 8px #00000014;z-index:2}.summary-card-divider{border-radius:2px;height:1.5px;margin:12px 18px;opacity:.3;position:relative;z-index:2}.summary-card-sub-row{display:flex;padding:0 18px;position:relative;z-index:2}.summary-card-sub{display:flex;flex:1 1;flex-direction:column;gap:3px}.summary-sub-label{color:#94a3b8;font-family:DM Sans,sans-serif;font-size:11.5px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.summary-sub-val{color:#1e293b;font-family:DM Sans,sans-serif;font-size:17px;font-weight:800}.summary-skeleton-wrap{display:flex;flex-direction:column;gap:10px;padding:10px 18px 4px}.summary-skeleton{animation:loadingPulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background-size:200% 100%;border-radius:6px}.summary-skeleton-big{height:36px;width:75%}.summary-skeleton-sm{height:16px;width:55%}.city-card-title-row{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:2px;position:relative;z-index:2}.city-card-title-row .city-card-title{flex:1 1;margin-bottom:0;min-width:0}.expand-btn{align-items:center;background:#0000;border:1.5px solid #00d4ff;border:1.5px solid var(--accent,#00d4ff);border-radius:8px;color:#00d4ff;color:var(--accent,#00d4ff);cursor:pointer;display:inline-flex;flex-shrink:0;font-family:DM Sans,sans-serif;font-size:11.5px;font-weight:800;gap:5px;letter-spacing:.06em;padding:5px 11px;transition:background .18s ease,color .18s ease,box-shadow .18s ease,transform .14s cubic-bezier(.34,1.4,.64,1);white-space:nowrap}.expand-btn:hover{background:#00d4ff;background:var(--accent,#00d4ff);box-shadow:0 4px 18px color-mix(in srgb,#00d4ff 45%,#0000);box-shadow:0 4px 18px color-mix(in srgb,var(--accent,#00d4ff) 45%,#0000);color:#fff;transform:translateY(-2px) scale(1.04)}.expand-btn:active{transform:translateY(0) scale(.98)}.expand-btn svg{flex-shrink:0;transition:transform .18s ease}.expand-btn:hover svg{transform:scale(1.15)}.expand-overlay{align-items:center;animation:overlayFadeIn .22s ease both;backdrop-filter:blur(8px) saturate(1.4);-webkit-backdrop-filter:blur(8px) saturate(1.4);background:#081228a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.expand-modal{animation:modalSlideIn .28s cubic-bezier(.34,1.38,.64,1) both;backdrop-filter:blur(24px) saturate(1.7);-webkit-backdrop-filter:blur(24px) saturate(1.7);background:#ffffffc7;border:1px solid #ffffffe6;border-radius:22px;box-shadow:0 40px 100px #00000047,0 12px 32px #00000029,inset 0 1px 0 #fffffff2;display:flex;flex-direction:column;height:calc(100vh - 64px);max-height:920px;max-width:1400px;overflow:hidden;position:relative;width:calc(100vw - 48px)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.92) translateY(28px)}to{opacity:1;transform:scale(1) translateY(0)}}.expand-modal-top-bar{flex-shrink:0;height:5px;width:100%}.expand-modal:before{background:linear-gradient(180deg,#ffffff61,#0000);border-radius:22px 22px 60% 60%;content:"";height:40%;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.expand-modal-header{align-items:flex-start;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 26px 12px;position:relative;z-index:2}.expand-modal-title-group{display:flex;flex-direction:column;gap:2px}.expand-close-btn{align-items:center;background:#1e3a5f0f;border:1.5px solid #1e3a5f2e;border-radius:50%;color:#1e3a5f;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:background .18s ease,color .18s ease,border-color .18s ease,transform .22s cubic-bezier(.34,1.4,.64,1);width:38px}.expand-close-btn:hover{background:#1e3a5f;border-color:#1e3a5f;color:#fff;transform:rotate(90deg) scale(1.1)}.expand-modal-header+.city-card-divider{margin:0 26px 16px;position:relative;z-index:2}.expand-modal-chart{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:0 26px 26px;position:relative;z-index:2}.expand-modal-chart::-webkit-scrollbar{height:7px;width:5px}.expand-modal-chart::-webkit-scrollbar-track{background:#dce8f566;border-radius:10px}.expand-modal-chart::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#a0bcd8,#6d99c0);border-radius:10px}.recharts-wrap-expanded{display:flex;flex:1 1;flex-direction:column;height:100%;min-height:0;width:100%}.recharts-wrap-expanded .rc-legend{flex-shrink:0}.recharts-wrap-expanded .chart-scroll-outer{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-x:auto;overflow-y:hidden}.recharts-wrap-expanded .chart-scroll-outer>div{display:flex;flex-direction:column;height:100%}.recharts-wrap-expanded .recharts-responsive-container{flex:1 1!important;height:100%!important;min-height:0!important}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:#0000}.main-content::-webkit-scrollbar-thumb{background:#0f3a7d33;border-radius:3px}@media (max-width:640px){.cities-main{padding:20px 14px 40px}.expand-modal{border-radius:16px;height:calc(100vh - 24px);width:calc(100vw - 16px)}.expand-modal-header{padding:16px 18px 10px}.expand-modal-chart{padding:0 18px 18px}}
/*# sourceMappingURL=main.dba3ae56.css.map*/