*{margin:0;padding:0;box-sizing:border-box}
:root{--y:#FFCC00;--yl:rgba(255,204,0,0.1);--yd:#e6b800;--bg:#f5f5f5;--white:#fff;--dark:#222;--text:#333;--sub:#777;--bor:#e5e5e5;--card:#fff;--rad:14px;--shadow:0 2px 12px rgba(0,0,0,0.06)}
@media(prefers-color-scheme:dark){:root:not(.light-mode){--bg:#0d0d14;--white:#161625;--dark:#f0f0f0;--text:#e0e0e0;--sub:#999;--bor:#2a2a3a;--card:#161625;--shadow:0 2px 12px rgba(0,0,0,0.4);--yl:rgba(255,204,0,0.12)}}
.dark-mode{--bg:#0d0d14;--white:#161625;--dark:#f0f0f0;--text:#e0e0e0;--sub:#999;--bor:#2a2a3a;--card:#161625;--shadow:0 2px 12px rgba(0,0,0,0.4);--yl:rgba(255,204,0,0.12)}
.dark-mode .hdr{background:var(--y)}.dark-mode nav{background:var(--card);border-color:var(--bor)}.dark-mode .drawer{background:var(--card)}.dark-mode .drawer-item{color:var(--text)}.dark-mode .litem{background:var(--card);border-color:var(--bor)}.dark-mode input{background:var(--card);color:var(--text);border-color:var(--bor)}
.dark-mode .hero-greeting{background:linear-gradient(135deg,rgba(255,204,0,0.15),rgba(255,204,0,0.05))!important}.dark-mode .hero-greeting .greeting-text{color:var(--y)}.dark-mode .hero-greeting .city-label{color:var(--sub)}.dark-mode .hero-weather .hw-temp{color:var(--y)}
.dark-mode .info-banner{background:linear-gradient(135deg,rgba(255,204,0,0.15),rgba(255,204,0,0.08))!important;box-shadow:0 4px 16px rgba(255,204,0,0.08)}.dark-mode .info-banner .ib-title,.dark-mode .info-banner .ib-desc{color:var(--text)}
.dark-mode .stat-card.sc-gray{background:var(--card);border-color:var(--bor)}.dark-mode .occ-bar{background:var(--card)}.dark-mode .pk-item{background:var(--card)}.dark-mode .tile-v2{background:var(--card)}.dark-mode .qa-btn{background:var(--card);box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.dark-mode .ncard-v2{background:var(--card)}.dark-mode .form-group input,.dark-mode .form-group textarea,.dark-mode .form-group select{background:var(--card);color:var(--text);border-color:var(--bor)}
.dark-mode .skel{background:linear-gradient(90deg,var(--bor) 25%,#2a2a3a 50%,var(--bor) 75%);background-size:200px 100%}
.dark-mode .city-chip{background:var(--card);border-color:var(--bor)}.dark-mode .city-chip .cc-name{color:var(--text)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.skip-link{position:absolute;top:-100px;left:0;background:var(--y);color:#000;padding:12px 24px;z-index:10001;font-weight:800;font-size:14px;border-radius:0 0 8px 0;transition:top .2s}.skip-link:focus{top:0}
@keyframes skeleton{0%{background-position:-200px 0}100%{background-position:calc(200px + 100%) 0}}
.skel{background:linear-gradient(90deg,var(--bor) 25%,#e8e8e8 50%,var(--bor) 75%);background-size:200px 100%;animation:skeleton 1.5s infinite;border-radius:8px}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:none}}
@keyframes slideOut{from{transform:none}to{transform:translateX(-100%)}}
.fi{animation:fadeIn .3s ease both}

/* SVG ICON SYSTEM — replaces emoji in key areas */
.svg-ico{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;vertical-align:-0.125em}
.svg-ico svg{width:100%;height:100%;fill:currentColor;stroke:currentColor;stroke-width:0}
/* Stroke-based icons */
.svg-ico.str svg{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* HEADER */
.hdr{position:sticky;top:0;z-index:100;background:var(--y);padding:0 14px;height:52px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.hdr-left{display:flex;align-items:center;gap:10px}
.hdr .ham{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--hdr-ham-bg,rgba(0,0,0,0.08));border-radius:8px;cursor:pointer;font-size:18px;color:var(--hdr-text,#000)}
.hdr h1{font-size:16px;font-weight:800;color:var(--hdr-text,#000);letter-spacing:-.02em}
.back-btn{display:flex;align-items:center;justify-content:center;gap:4px;border:none;background:var(--hdr-ham-bg,rgba(0,0,0,0.08));border-radius:8px;cursor:pointer;font-size:13px;color:var(--hdr-text,#000);font-weight:700;-webkit-tap-highlight-color:transparent;padding:0 10px;height:36px;white-space:nowrap}.back-btn:active{background:rgba(0,0,0,0.15)}.back-btn .ba{font-size:18px}
.hdr-right{display:flex;gap:6px;align-items:center}
.lang-btn{padding:5px 10px;border-radius:8px;border:2px solid var(--hdr-ham-bg,rgba(0,0,0,0.15));background:var(--hdr-ham-bg,rgba(0,0,0,0.05));font-size:12px;font-weight:700;color:var(--hdr-text,#000);cursor:pointer}

/* SIDE DRAWER */
.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.4);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s}
.overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;left:0;bottom:0;width:280px;background:#fff;z-index:201;transform:translateX(-100%);transition:transform .3s ease;overflow-y:auto;box-shadow:4px 0 24px rgba(0,0,0,0.15)}
.drawer.open{transform:none}
.drawer-head{background:var(--y);padding:24px 16px 16px;display:flex;align-items:center;gap:12px}
.drawer-logo{width:48px;height:48px;border-radius:14px;background:var(--y);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:20px;color:var(--hdr-text,#000);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.drawer-head .info h2{font-size:15px;font-weight:800;color:#000}
.drawer-head .info p{font-size:11px;color:rgba(0,0,0,0.6)}
.drawer-sep{height:1px;background:#eee;margin:8px 16px}
.drawer-item{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;transition:background .15s;font-size:14px;color:#333;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.drawer-item:hover,.drawer-item.act{background:var(--yl)}
.drawer-item.act{color:#000;font-weight:700}
.drawer-item .dic{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--yl);font-size:16px}
.svg-drawer svg{width:18px;height:18px;stroke:var(--y);stroke-width:2}
.drawer-foot{padding:16px;border-top:1px solid #eee;margin-top:8px}
.drawer-foot a{display:block;padding:8px 0;font-size:12px;color:#999;text-decoration:none}

/* BOTTOM NAV */
nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#fff;border-top:1px solid var(--bor);padding:6px 0 max(6px,env(safe-area-inset-bottom));box-shadow:0 -2px 12px rgba(0,0,0,0.05)}
.ni{display:flex;max-width:500px;margin:0 auto;justify-content:space-around}
.ni button{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 12px;border:none;background:none;cursor:pointer;font-size:9px;color:#999;font-family:inherit;-webkit-tap-highlight-color:transparent;transition:color .15s}
.ni .on{color:var(--yd)}
.ni .on .nic{color:var(--y)}
.ni .nic{font-size:20px;line-height:1.2}

/* MAIN */
main{max-width:800px;margin:0 auto;padding:0 0 80px}

/* CARDS */
.card{background:var(--card);border-radius:var(--rad);box-shadow:var(--shadow);overflow:hidden;transition:transform .2s,box-shadow .2s}
.card:active{transform:scale(0.98)}
.card-pad{padding:14px 16px}
.card-img{width:100%;height:160px;object-fit:cover;background:#eee}

/* SECTION HEADER */
.sec-hdr{padding:18px 16px 10px;display:flex;align-items:center;justify-content:space-between}
.sec-hdr h2{font-size:20px;font-weight:800;color:var(--y);letter-spacing:-.01em}
.sec-hdr .more{padding:6px 14px;border-radius:20px;border:2px solid var(--y);background:none;color:var(--y);font-size:11px;font-weight:700;cursor:pointer}

/* WEATHER */
.weather-box{padding:16px;display:flex;align-items:center;justify-content:space-between}
.weather-box .wt{font-size:13px;color:#555}
.weather-box .wtemp{font-size:36px;font-weight:800;color:#000;display:flex;align-items:center;gap:8px}
.weather-box .wico{font-size:32px}

/* SEARCH */
.search-bar{margin:12px 16px;position:relative}
.search-bar input{width:100%;padding:12px 16px 12px 42px;border-radius:25px;border:1px solid #ddd;background:#fff;font-size:14px;color:#333;outline:none;font-family:inherit;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.search-bar input:focus{border-color:var(--y);box-shadow:0 2px 12px rgba(255,204,0,0.15)}
.search-bar .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;color:#999}

/* CAROUSEL */
.carousel{display:flex;gap:12px;overflow-x:auto;padding:0 16px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.carousel::-webkit-scrollbar{display:none}
.carousel>.card{min-width:280px;max-width:320px;scroll-snap-align:start;flex-shrink:0}

/* GRID */
.grid{display:grid;gap:12px;padding:0 16px}.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}

/* MODULE TILES */
.tile{display:flex;align-items:center;gap:12px;padding:14px;background:#fff;border-radius:var(--rad);box-shadow:var(--shadow);cursor:pointer;transition:transform .15s;min-height:72px;box-sizing:border-box}
.tile:active{transform:scale(0.97)}
.tile .tico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}
.tile .tinfo h3{font-size:13px;font-weight:700;color:#222}
.tile .tinfo p{font-size:11px;color:#999;margin-top:2px}

/* STAT BOXES */
.stats{display:flex;gap:10px;padding:0 16px;margin:10px 0}
.sbox{flex:1;background:#fff;border-radius:12px;padding:12px 8px;text-align:center;box-shadow:var(--shadow)}
.sbox .sv{font-size:22px;font-weight:800;color:#000}.sbox .sl{font-size:9px;color:#999;margin-top:3px}

/* LIST ITEMS */
.litem{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .1s}
.litem:hover{background:#fafafa}
.litem:last-child{border-bottom:none}
.litem .li-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--yl);flex-shrink:0}
.litem .li-info{flex:1;min-width:0}
.litem .li-info h4{font-size:13px;font-weight:700;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.litem .li-info p{font-size:11px;color:#999;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* TAB BAR */
.tabs{display:flex;gap:6px;padding:0 16px;overflow-x:auto;margin:10px 0}
.tabs::-webkit-scrollbar{display:none}
.tabs button{padding:8px 16px;border-radius:20px;border:none;background:#eee;color:#666;font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer;transition:all .15s;font-family:inherit}
.tabs .ta{background:var(--y);color:#000}

/* MAP */
.map-wrap{border-radius:var(--rad);overflow:hidden;margin:0 16px 12px;height:300px;box-shadow:var(--shadow)}
.map-wrap .leaflet-container{height:100%;width:100%;background:#f8f8f8}

/* PROGRESS BAR */
.pbar{height:6px;border-radius:3px;background:#eee;overflow:hidden;margin-top:6px}
.pfill{height:100%;border-radius:3px;transition:width .5s ease}

/* LIVE BADGE */
.live{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;background:rgba(34,197,94,0.08);font-size:10px;font-weight:700;color:#16a34a}
.live .dot{width:6px;height:6px;border-radius:50%;background:#16a34a;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* CHAT */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 140px);height:calc(100dvh - 140px)}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.cmsg{max-width:82%;padding:11px 15px;border-radius:16px;font-size:13px;line-height:1.6;white-space:pre-wrap;animation:fadeIn .25s ease}
.cmsg-u{align-self:flex-end;background:var(--y);color:var(--hdr-text,#000);border-bottom-right-radius:4px}
.cmsg-a{align-self:flex-start;background:#f0f0f0;color:#333;border-bottom-left-radius:4px}
.chat-input{display:flex;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid #eee}
.chat-input input{flex:1;padding:10px 16px;border-radius:24px;border:1px solid #ddd;font-size:14px;outline:none;font-family:inherit}
.chat-input input:focus{border-color:var(--y)}
.chat-input button{width:40px;height:40px;border-radius:50%;border:none;background:var(--y);color:#000;font-size:18px;font-weight:700;cursor:pointer}

/* FORM */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:#666;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border-radius:12px;border:1px solid #ddd;font-size:14px;color:#333;outline:none;font-family:inherit;background:#fff}
.form-group input:focus,.form-group textarea:focus{border-color:var(--y)}
.btn-y{padding:12px 24px;border-radius:12px;border:none;background:var(--y);color:#000;font-weight:700;font-size:14px;cursor:pointer;width:100%}
.btn-y:disabled{opacity:.4}
.btn-o{padding:8px 16px;border-radius:20px;border:2px solid var(--y);background:none;color:#000;font-weight:700;font-size:12px;cursor:pointer}

/* LOADER */
.loader{display:flex;flex-direction:column;align-items:center;padding:60px 20px}
.spin{width:32px;height:32px;border:3px solid #eee;border-top-color:var(--y);border-radius:50%;animation:spin .7s linear infinite}
.loader p{margin-top:12px;font-size:13px;color:#999}

/* LANG DROPDOWN */
.lang-dd{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.15);overflow:hidden;z-index:300;min-width:140px}
.lang-dd button{display:flex;align-items:center;gap:8px;width:100%;padding:11px 16px;border:none;background:none;font-size:13px;color:#333;cursor:pointer;font-family:inherit;text-align:left}
.lang-dd button:hover{background:#f5f5f5}
.lang-dd .la{background:var(--yl);font-weight:700;color:#000}

/* NEWS CARD */
.ncard{background:#fff;border-radius:var(--rad);overflow:hidden;box-shadow:var(--shadow)}
.ncard img{width:100%;height:140px;object-fit:cover;background:#eee}
.ncard .nc-body{padding:12px 14px}
.ncard .nc-body h4{font-size:13px;font-weight:700;line-height:1.4;color:#222;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ncard .nc-body p{font-size:11px;color:#999;margin-top:4px}

/* EVENT CARD */
.ecard{background:#fff;border-radius:var(--rad);overflow:hidden;box-shadow:var(--shadow);display:flex}
.ecard .ec-date{width:70px;background:var(--y);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;flex-shrink:0}
.ecard .ec-date .ed{font-size:24px;font-weight:800;color:#000}.ecard .ec-date .em{font-size:11px;font-weight:700;color:rgba(0,0,0,0.6)}
.ecard .ec-info{padding:12px;flex:1;min-width:0}
.ecard .ec-info h4{font-size:13px;font-weight:700;color:#222}
.ecard .ec-info p{font-size:11px;color:#999;margin-top:3px}


.desk-nav{display:none;align-items:center;gap:2px;flex:1;justify-content:center}
.desk-nav button{padding:6px 12px;border-radius:8px;border:none;background:transparent;color:var(--hdr-text-sub,rgba(0,0,0,0.6));font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:4px}
.desk-nav button:hover{background:var(--hdr-ham-bg,rgba(0,0,0,0.08))}.desk-nav button.on{background:var(--hdr-ham-bg,rgba(0,0,0,0.12));color:var(--hdr-text,#000);font-weight:700}
.desk-nav .dn-ico{font-size:14px}
.hdr-logo{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.hdr-logo .lbadge{background:var(--hdr-badge-bg,#222);color:var(--hdr-badge-text,#FFCC00);font-weight:900;font-size:16px;padding:4px 10px;border-radius:6px;letter-spacing:-1px}
.hdr-logo .ltxt{font-size:10px;line-height:1.2;color:var(--hdr-text-sub,rgba(0,0,0,0.6))}
.hdr-logo .ltxt b{display:block;font-size:12px;font-weight:800;color:var(--hdr-text,#000)}
@media(min-width:768px){nav.mob-nav{display:none!important}.desk-nav{display:flex}.hdr{height:56px}main{padding-top:0;padding-bottom:20px}}
/* RTL */
[dir="rtl"] .drawer{left:auto;right:0;transform:translateX(100%)}
[dir="rtl"] .drawer.open{transform:none}
[dir="rtl"] .lang-dd{right:auto;left:0}
.user-dot{width:16px;height:16px;border-radius:50%;background:#2563eb;border:3px solid #fff;box-shadow:0 0 0 2px rgba(37,99,235,0.3),0 0 12px rgba(37,99,235,0.4);position:relative}
.user-dot::after{content:"";position:absolute;top:-6px;left:-6px;right:-6px;bottom:-6px;border-radius:50%;background:rgba(37,99,235,0.15);animation:userPulse 2s infinite}
@keyframes userPulse{0%{transform:scale(1);opacity:.4}50%{transform:scale(1.8);opacity:0}100%{transform:scale(1);opacity:0}}
.loc-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:20px;border:none;background:#2563eb;color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit}
.loc-btn.locating{background:#93c5fd;pointer-events:none}
.route-box{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:0 16px 12px;background:#fff;border-radius:var(--rad);box-shadow:var(--shadow);border-left:4px solid #2563eb}
.route-box .rv{font-size:18px;font-weight:800}
.route-box .rl{font-size:10px;color:#999}

/* === HOMESCREEN v3 — MAJOR VISUAL UPGRADE === */
/* Hero with city-color gradient background + skyline silhouette */
.hero-greeting{background:linear-gradient(135deg,var(--y),var(--yd));border-radius:0 0 28px 28px;padding:24px 20px 20px;box-shadow:0 8px 32px rgba(0,0,0,0.1);position:relative;overflow:hidden}
.hero-greeting::before{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 40'%3E%3Crect x='10' y='15' width='18' height='25' rx='1' fill='rgba(0,0,0,0.06)'/%3E%3Crect x='32' y='20' width='14' height='20' rx='1' fill='rgba(0,0,0,0.04)'/%3E%3Crect x='50' y='8' width='20' height='32' rx='1' fill='rgba(0,0,0,0.07)'/%3E%3Crect x='74' y='4' width='3' height='36' rx='1' fill='rgba(0,0,0,0.08)'/%3E%3Crect x='82' y='12' width='16' height='28' rx='1' fill='rgba(0,0,0,0.05)'/%3E%3Crect x='102' y='18' width='12' height='22' rx='1' fill='rgba(0,0,0,0.04)'/%3E%3Crect x='130' y='10' width='22' height='30' rx='1' fill='rgba(0,0,0,0.06)'/%3E%3Crect x='156' y='14' width='16' height='26' rx='1' fill='rgba(0,0,0,0.05)'/%3E%3Crect x='180' y='6' width='24' height='34' rx='1' fill='rgba(0,0,0,0.07)'/%3E%3Crect x='208' y='22' width='10' height='18' rx='1' fill='rgba(0,0,0,0.04)'/%3E%3Crect x='224' y='12' width='18' height='28' rx='1' fill='rgba(0,0,0,0.06)'/%3E%3Crect x='248' y='16' width='14' height='24' rx='1' fill='rgba(0,0,0,0.05)'/%3E%3Crect x='268' y='8' width='20' height='32' rx='1' fill='rgba(0,0,0,0.06)'/%3E%3Crect x='294' y='18' width='12' height='22' rx='1' fill='rgba(0,0,0,0.04)'/%3E%3Crect x='312' y='4' width='4' height='36' rx='1' fill='rgba(0,0,0,0.07)'/%3E%3Crect x='322' y='14' width='16' height='26' rx='1' fill='rgba(0,0,0,0.05)'/%3E%3Crect x='344' y='10' width='20' height='30' rx='1' fill='rgba(0,0,0,0.06)'/%3E%3Crect x='370' y='20' width='14' height='20' rx='1' fill='rgba(0,0,0,0.04)'/%3E%3Crect x='388' y='12' width='12' height='28' rx='1' fill='rgba(0,0,0,0.05)'/%3E%3C/svg%3E") repeat-x bottom/400px 40px;pointer-events:none;opacity:.5}
.hero-greeting::after{content:"";position:absolute;top:0;right:-20px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,0.08)}
.hero-greeting .greeting-text{font-size:28px;font-weight:900;color:#000;letter-spacing:-0.5px}
.hero-greeting .city-label{font-size:12px;color:rgba(0,0,0,0.5);font-weight:600;margin-top:2px}
.hero-weather{display:flex;align-items:center;gap:8px}
.hero-weather .hw-temp{font-size:42px;font-weight:900;color:#000;letter-spacing:-2px}
.hero-weather .hw-icon{font-size:36px}
.hero-weather .hw-feels{font-size:11px;color:rgba(0,0,0,0.45);text-align:right;font-weight:600}

/* Quick Actions — prominent, scrollable */
.quick-actions{display:flex;gap:12px;padding:16px 16px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.quick-actions::-webkit-scrollbar{display:none}
.qa-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 16px;border-radius:18px;border:none;background:var(--card);box-shadow:0 4px 16px rgba(0,0,0,0.07);cursor:pointer;font-family:inherit;min-width:76px;flex-shrink:0;transition:all .2s ease;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}
.qa-btn::after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:3px;border-radius:3px;background:var(--y);opacity:0;transition:opacity .2s}
.qa-btn:hover::after,.qa-btn:active::after{opacity:1}
.qa-btn:active{transform:scale(0.92);box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.qa-btn .qa-ico{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;transition:transform .2s}
.qa-btn:active .qa-ico{transform:scale(1.15)}
.qa-btn .qa-lbl{font-size:10px;font-weight:700;color:var(--text);white-space:nowrap;letter-spacing:-0.2px}

/* Tiles — colored left accent + arrow */
.tile-v2{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,0.05);cursor:pointer;transition:all .2s ease;min-height:76px;border:none;border-left:4px solid var(--y);-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}
.tile-v2:active{transform:scale(0.97);box-shadow:0 1px 6px rgba(0,0,0,0.08)}
.tile-v2:hover{box-shadow:0 6px 24px rgba(0,0,0,0.1);transform:translateY(-1px)}
.tile-v2 .tico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;transition:transform .2s}
.tile-v2:active .tico{transform:scale(1.1)}
.tile-v2 .tinfo{flex:1;min-width:0}
.tile-v2 .tinfo h3{font-size:14px;font-weight:700;color:var(--dark);letter-spacing:-0.2px}
.tile-v2 .tinfo p{font-size:11px;color:var(--sub);margin-top:3px;line-height:1.3}
.tile-v2 .tile-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:16px;color:#ccc;font-weight:300;transition:all .2s}
.tile-v2:hover .tile-arrow{color:var(--y);transform:translateY(-50%) translateX(3px)}
.tile-v2 .tile-badge{position:absolute;top:10px;right:10px}

/* Section Headers — bold with accent dot */
.sec-v2{padding:22px 16px 10px;display:flex;align-items:center;gap:8px}
.sec-v2 .sec-icon{font-size:20px}
.sec-v2 h2{font-size:16px;font-weight:800;color:var(--dark);letter-spacing:-0.3px}
.sec-v2 .sec-line{flex:1;height:2px;background:linear-gradient(90deg,var(--bor),transparent);margin-left:8px}

/* Skeleton Loading */
.tile-skeleton{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border-radius:16px;min-height:72px}
.tile-skeleton .ts-ico{width:44px;height:44px;border-radius:12px;background:var(--bor);animation:skeleton 1.5s infinite}
.tile-skeleton .ts-info{flex:1;display:flex;flex-direction:column;gap:6px}
.tile-skeleton .ts-line{height:12px;border-radius:6px;background:var(--bor);animation:skeleton 1.5s infinite}
.tile-skeleton .ts-line.short{width:60%}

/* Empty State */
.empty-state{display:flex;flex-direction:column;align-items:center;padding:48px 24px;text-align:center}
.empty-state .es-icon{font-size:48px;margin-bottom:12px;opacity:0.6}
.empty-state .es-title{font-size:16px;font-weight:700;color:var(--dark);margin-bottom:6px}
.empty-state .es-desc{font-size:13px;color:var(--sub);line-height:1.5;max-width:280px}

/* Enhanced News Cards — larger, better spacing */
.ncard-v2{background:var(--card);border-radius:18px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.08);transition:all .25s;min-width:280px;max-width:320px;scroll-snap-align:start;flex-shrink:0;cursor:pointer}
.ncard-v2:active{transform:scale(0.97)}
.ncard-v2:hover{box-shadow:0 8px 32px rgba(0,0,0,0.12);transform:translateY(-2px)}
.ncard-v2 .nc-img{width:100%;height:160px;object-fit:cover;background:var(--bor)}
.ncard-v2 .nc-img-placeholder{width:100%;height:160px;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(135deg,var(--y) 0%,var(--yd) 100%)}
.ncard-v2 .nc-body{padding:14px 16px}
.ncard-v2 .nc-date{font-size:10px;color:var(--sub);font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.ncard-v2 .nc-title{font-size:15px;font-weight:700;line-height:1.4;color:var(--dark);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:6px}
.ncard-v2 .nc-desc{font-size:12px;color:var(--sub);line-height:1.5;margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Stagger animation */
.grid-stagger > *:nth-child(1){animation-delay:0ms}
.grid-stagger > *:nth-child(2){animation-delay:50ms}
.grid-stagger > *:nth-child(3){animation-delay:100ms}
.grid-stagger > *:nth-child(4){animation-delay:150ms}
.grid-stagger > *:nth-child(5){animation-delay:200ms}
.grid-stagger > *:nth-child(6){animation-delay:250ms}

/* Info Banner — gradient card */
.info-banner{margin:0 16px 16px;padding:18px 20px;border-radius:18px;background:linear-gradient(135deg,var(--y),var(--yd));display:flex;align-items:center;gap:16px;box-shadow:0 6px 24px rgba(255,204,0,0.3);position:relative;overflow:hidden}
.info-banner::after{content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,0.12)}
.info-banner .ib-icon{font-size:32px;flex-shrink:0;position:relative;z-index:1}
.info-banner .ib-title{font-size:15px;font-weight:800;color:#000;position:relative;z-index:1}
.info-banner .ib-desc{font-size:12px;color:rgba(0,0,0,0.55);margin-top:3px;line-height:1.4;position:relative;z-index:1}

/* City Switcher */
.city-chip{padding:14px 18px;border-radius:18px;border:2px solid var(--bor);background:var(--card);cursor:pointer;white-space:nowrap;min-width:120px;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,0.05);transition:all .2s;flex-shrink:0}
.city-chip:active{transform:scale(0.95)}
.city-chip.active{border-color:var(--y);background:var(--yl);box-shadow:0 6px 20px rgba(255,204,0,0.2)}
.city-chip .cc-logo{font-size:14px;font-weight:900;letter-spacing:-0.3px;margin-bottom:4px}
.city-chip .cc-name{font-size:14px;font-weight:700;color:var(--dark)}
.city-chip .cc-mods{font-size:10px;color:var(--sub);margin-top:3px}

/* Search bar upgrade */
.search-bar-v2{margin:14px 16px;position:relative}
.search-bar-v2 input{width:100%;padding:14px 18px 14px 46px;border-radius:16px;border:2px solid var(--bor);background:var(--card);font-size:15px;color:var(--text);outline:none;font-family:inherit;box-shadow:0 2px 12px rgba(0,0,0,0.04);transition:all .2s}
.search-bar-v2 input:focus{border-color:var(--y);box-shadow:0 4px 20px rgba(255,204,0,0.15)}
.search-bar-v2 .si{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--sub)}

/* === SUBPAGE UPGRADES (Parken, etc.) === */
/* Page Hero Banner */
.page-hero{padding:20px 16px 16px;position:relative}
.page-hero .ph-title{font-size:22px;font-weight:900;color:var(--dark);letter-spacing:-0.5px;margin-bottom:4px}
.page-hero .ph-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Stat Cards v2 — colored gradient */
.stat-row{display:flex;gap:10px;padding:0 16px;margin:12px 0}
.stat-card{flex:1;padding:16px 12px;border-radius:16px;text-align:center;position:relative;overflow:hidden}
.stat-card::after{content:"";position:absolute;top:-20px;right:-20px;width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,0.15)}
.stat-card .sc-val{font-size:24px;font-weight:900;position:relative;z-index:1}
.stat-card .sc-lbl{font-size:10px;font-weight:600;margin-top:2px;position:relative;z-index:1;opacity:0.7}
.stat-card.sc-green{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}
.stat-card.sc-amber{background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff}
.stat-card.sc-red{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}
.stat-card.sc-blue{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}
.stat-card.sc-gray{background:var(--card);color:var(--dark);border:1px solid var(--bor)}
.stat-card.sc-gray .sc-lbl{color:var(--sub)}

/* Occupancy Bar */
.occ-bar{margin:0 16px 12px;padding:14px 16px;background:var(--card);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,0.05)}
.occ-bar .ob-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.occ-bar .ob-lbl{font-size:12px;color:var(--sub);font-weight:600}
.occ-bar .ob-val{font-size:14px;font-weight:800}
.occ-bar .ob-track{height:10px;border-radius:5px;background:var(--bor);overflow:hidden}
.occ-bar .ob-fill{height:100%;border-radius:5px;transition:width .8s ease}

/* Tab Switcher v2 */
.tab-switch{display:flex;gap:4px;padding:0 16px;margin:12px 0}
.tab-switch button{flex:1;padding:10px;border-radius:12px;border:none;background:var(--card);color:var(--sub);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.tab-switch button.ta{background:var(--y);color:#000;box-shadow:0 4px 12px rgba(255,204,0,0.3)}

/* Parking List Item v2 */
.pk-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);margin:0 16px 8px;border-radius:16px;box-shadow:0 2px 10px rgba(0,0,0,0.05);cursor:pointer;transition:all .2s;border-left:4px solid var(--y)}
.pk-item:active{transform:scale(0.98)}
.pk-item:hover{box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.pk-item .pk-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;flex-shrink:0}
.pk-item .pk-info{flex:1;min-width:0}
.pk-item .pk-name{font-size:14px;font-weight:700;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pk-item .pk-sub{font-size:11px;color:var(--sub);margin-top:3px}
.pk-item .pk-bar{height:5px;border-radius:3px;background:var(--bor);overflow:hidden;margin-top:6px}
.pk-item .pk-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}
.pk-item .pk-free{font-size:22px;font-weight:900;flex-shrink:0;min-width:50px;text-align:right}
.pk-item .pk-dist{display:flex;align-items:center;gap:4px;margin-top:4px}
.pk-item .pk-dist span{font-size:11px;color:#2563eb;font-weight:600}
.pk-item .pk-dist button{font-size:10px;padding:3px 10px;border-radius:8px;border:none;background:var(--y);color:#000;font-weight:700;cursor:pointer}

/* Map Container v2 */
.map-v2{border-radius:18px;overflow:hidden;margin:0 16px 16px;height:380px;box-shadow:0 4px 20px rgba(0,0,0,0.1);border:2px solid var(--bor)}
.map-v2 .leaflet-container{height:100%;width:100%;background:var(--bg)}

/* === GLOBAL COMPONENT UPGRADES (affects ALL pages) === */

/* Upgraded stat boxes — more padding, better typography, subtle border */
.sbox{flex:1;background:var(--card);border-radius:16px;padding:16px 10px;text-align:center;box-shadow:0 2px 10px rgba(0,0,0,0.05);border:1px solid var(--bor);transition:all .2s}
.sbox .sv{font-size:24px;font-weight:900;letter-spacing:-0.5px}.sbox .sl{font-size:10px;color:var(--sub);margin-top:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}

/* Upgraded list items — card style, left accent, hover effect */
.litem{display:flex;align-items:center;gap:14px;padding:14px 16px;margin:0 16px 8px;background:var(--card);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,0.04);cursor:pointer;transition:all .2s;border-left:3px solid var(--y);border-bottom:none}
.litem:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08);transform:translateY(-1px)}
.litem:active{transform:scale(0.98)}
.litem:last-child{border-bottom:none}
.litem .li-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--yl);flex-shrink:0}
.litem .li-info{flex:1;min-width:0}
.litem .li-info h4{font-size:14px;font-weight:700;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.litem .li-info p{font-size:11px;color:var(--sub);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Upgraded tab buttons — pill with shadow, animated active */
.tabs{display:flex;gap:4px;padding:0 16px;overflow-x:auto;margin:12px 0}
.tabs::-webkit-scrollbar{display:none}
.tabs button{flex:1;padding:10px 16px;border-radius:12px;border:none;background:var(--card);color:var(--sub);font-size:13px;font-weight:700;white-space:nowrap;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.tabs .ta{background:var(--y);color:#000;box-shadow:0 4px 12px rgba(255,204,0,0.3)}

/* Upgraded map container — taller, more rounded, better border */
.map-wrap{border-radius:18px;overflow:hidden;margin:0 16px 16px;height:360px;box-shadow:0 4px 20px rgba(0,0,0,0.08);border:2px solid var(--bor)}
.map-wrap .leaflet-container{height:100%;width:100%;background:var(--bg)}

/* Upgraded loader — skeleton cards instead of spinner */
.loader{display:flex;flex-direction:column;gap:12px;padding:16px}
.loader .spin{display:none}

/* Upgraded section header — consistent with sec-v2 */
.sec-hdr{padding:20px 16px 10px;display:flex;align-items:center;gap:8px}
.sec-hdr h2{font-size:16px;font-weight:800;color:var(--dark);letter-spacing:-0.3px;flex:1}
.sec-svg{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}
.sec-svg svg{width:20px;height:20px;stroke:var(--y);stroke-width:2}
.svg-tile svg{width:26px;height:26px;stroke:var(--y);stroke-width:1.8}
/* Toast Notifications */
.toast-container{position:fixed;top:70px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:calc(100% - 32px);max-width:400px}
.toast{padding:12px 16px;border-radius:12px;background:#1a1a2e;color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,0.2);animation:toastIn .3s ease;pointer-events:auto;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.toast.success{background:linear-gradient(135deg,#059669,#34d399);color:#fff}
.toast.error{background:linear-gradient(135deg,#dc2626,#f87171);color:#fff}
.toast.info{background:linear-gradient(135deg,#2563eb,#60a5fa);color:#fff}
.toast.out{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}
/* Pull to Refresh */
.ptr-indicator{position:fixed;top:50px;left:50%;transform:translateX(-50%);z-index:999;width:40px;height:40px;border-radius:50%;background:var(--card);box-shadow:0 4px 16px rgba(0,0,0,0.12);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s}
.ptr-indicator.active{opacity:1}
.ptr-indicator.loading{animation:ptrSpin .8s linear infinite}
.ptr-indicator svg{width:20px;height:20px;stroke:var(--y);stroke-width:2.5;fill:none;transition:transform .2s}
@keyframes ptrSpin{from{transform:translateX(-50%) rotate(0deg)}to{transform:translateX(-50%) rotate(360deg)}}
.sec-hdr .more{padding:6px 14px;border-radius:12px;border:2px solid var(--y);background:none;color:var(--y);font-size:11px;font-weight:700;cursor:pointer;transition:all .2s}
.sec-hdr .more:hover{background:var(--y);color:#000}

/* Upgraded live badge — slightly larger, bolder */
.live{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:rgba(34,197,94,0.1);font-size:11px;font-weight:700;color:#16a34a;letter-spacing:0.2px}
.live .dot{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulse 2s infinite}

/* Card upgrade — more rounded, better shadow */
.card{background:var(--card);border-radius:18px;box-shadow:0 4px 16px rgba(0,0,0,0.06);overflow:hidden;transition:all .2s}
.card:active{transform:scale(0.98)}
.card:hover{box-shadow:0 6px 24px rgba(0,0,0,0.1)}

/* Stats row spacing */
.stats{display:flex;gap:10px;padding:0 16px;margin:12px 0}

/* Form upgrades */
.form-group input,.form-group textarea,.form-group select{border-radius:14px;border:2px solid var(--bor);transition:all .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--y);box-shadow:0 0 0 3px rgba(255,204,0,0.15)}
.btn-y{border-radius:14px;font-size:15px;padding:14px 24px;transition:all .2s;box-shadow:0 4px 12px rgba(255,204,0,0.25)}
.btn-y:hover:not(:disabled){box-shadow:0 6px 20px rgba(255,204,0,0.4);transform:translateY(-1px)}
.btn-y:active{transform:scale(0.98)}
.btn-o{border-radius:12px;transition:all .2s}
.btn-o:hover{background:var(--y);color:#000}

/* Chat messages — better bubbles */
.cmsg{max-width:82%;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.6;white-space:pre-wrap;animation:fadeIn .25s ease}
.cmsg-u{background:var(--y);color:var(--hdr-text,#000);border-bottom-right-radius:4px;box-shadow:0 2px 8px rgba(255,204,0,0.2)}
.cmsg-a{background:var(--card);color:var(--text);border-bottom-left-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid var(--bor)}
.chat-input{gap:8px;padding:12px 16px;background:var(--card);border-top:1px solid var(--bor);box-shadow:0 -4px 16px rgba(0,0,0,0.04)}
.chat-input input{border-radius:24px;border:2px solid var(--bor);padding:12px 18px;font-size:15px}
.chat-input input:focus{border-color:var(--y);box-shadow:0 0 0 3px rgba(255,204,0,0.15)}
.chat-input button{width:44px;height:44px;border-radius:50%;font-size:20px;box-shadow:0 4px 12px rgba(255,204,0,0.3)}

/* News cards global upgrade */
.ncard{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,0.06);transition:all .2s}
.ncard:hover{box-shadow:0 6px 24px rgba(0,0,0,0.1)}
.ncard .nc-body{padding:14px 16px}
.ncard .nc-body h4{font-size:14px;line-height:1.4}

/* Drawer upgrade */
.drawer{width:300px;border-radius:0 20px 20px 0;box-shadow:8px 0 40px rgba(0,0,0,0.2)}
.drawer-item{border-radius:10px;margin:2px 8px;padding:12px 14px;font-size:14px}
.drawer-item:hover,.drawer-item.act{background:var(--yl);border-radius:10px}

/* Bottom nav upgrade */
nav{background:var(--card);border-top:none;box-shadow:0 -4px 24px rgba(0,0,0,0.08);border-radius:20px 20px 0 0}
.ni button{gap:3px;padding:6px 12px;font-size:10px;font-weight:600;border-radius:12px;transition:all .2s}
.ni .on{color:#000;background:var(--yl);border-radius:12px}
/* SVG Icon System */
.svg-nav{display:inline-flex;align-items:center;justify-content:center}
.svg-nav svg{width:20px;height:20px;stroke:var(--sub);stroke-width:1.8;transition:all .2s}
.ni .on .svg-nav svg{stroke:var(--y);stroke-width:2.2;filter:drop-shadow(0 1px 2px rgba(0,0,0,0.1))}
.dn-ico.svg-nav svg{width:16px;height:16px;stroke:currentColor}
.svg-qa{display:flex;align-items:center;justify-content:center}
.svg-qa svg{width:24px;height:24px;stroke-width:1.8;stroke:currentColor}
/* City Hero Image */
.city-hero{position:relative;margin:0 16px 16px;border-radius:20px;overflow:hidden;height:160px;background:linear-gradient(135deg,var(--y),#f59e0b);box-shadow:0 8px 32px rgba(0,0,0,0.12)}
.city-hero-inner{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px 20px;background:linear-gradient(0deg,rgba(0,0,0,0.5) 0%,transparent 60%);color:#fff;z-index:1}
.city-hero h2{font-size:22px;font-weight:900;letter-spacing:-0.5px;margin:0;text-shadow:0 2px 8px rgba(0,0,0,0.3)}
.city-hero p{font-size:12px;opacity:0.9;margin:4px 0 0;font-weight:500}
.city-skyline{position:absolute;bottom:0;left:0;right:0;height:60px;z-index:0}

/* Route box upgrade */
.route-box{border-radius:16px;border-left:4px solid #2563eb;box-shadow:0 4px 16px rgba(37,99,235,0.1)}

/* Search bar global */
.search-bar{margin:14px 16px}
.search-bar input{border-radius:16px;border:2px solid var(--bor);padding:14px 18px 14px 46px;font-size:15px;box-shadow:0 2px 10px rgba(0,0,0,0.04)}
.search-bar input:focus{border-color:var(--y);box-shadow:0 4px 20px rgba(255,204,0,0.15)}

/* Progress bar upgrade */
.pbar{height:8px;border-radius:4px;background:var(--bor)}
.pfill{border-radius:4px}

/* Language dropdown */
.lang-dd{border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,0.18)}
.lang-dd button{padding:12px 16px;font-size:14px;border-radius:8px;margin:2px 4px}

/* === ICON SYSTEM UPGRADE — Professional emoji containers === */
.qa-ico{background:linear-gradient(135deg,var(--ico-bg,#FFF8E1),var(--ico-bg2,#FFF3E0))!important;box-shadow:0 3px 12px rgba(0,0,0,0.08);border:1.5px solid rgba(0,0,0,0.04)}
.li-ico{background:linear-gradient(135deg,var(--ico-bg,var(--yl)),rgba(255,255,255,0.8))!important;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.tico{background:linear-gradient(135deg,var(--ico-bg,var(--yl)),rgba(255,255,255,0.6))!important;box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.pk-icon{box-shadow:0 2px 8px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}
.dic{background:linear-gradient(135deg,var(--yl),rgba(255,204,0,0.15))!important;box-shadow:0 2px 6px rgba(0,0,0,0.05)}
.stat-card{box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.ncard-v2{box-shadow:0 4px 20px rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.04)}

/* === DARK MODE FINE-TUNING === */
.dark-mode .qa-ico,.dark-mode .li-ico,.dark-mode .tico,.dark-mode .dic{border-color:rgba(255,255,255,0.08)!important;box-shadow:0 2px 8px rgba(0,0,0,0.2)!important}
.dark-mode .tile-v2{border-color:var(--bor);box-shadow:0 2px 10px rgba(0,0,0,0.15)}
.dark-mode .tile-v2:hover{box-shadow:0 4px 20px rgba(0,0,0,0.25)}
.dark-mode .pk-item{border-color:var(--bor);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.dark-mode .card{border:1px solid var(--bor)}
.dark-mode .ncard-v2{border-color:var(--bor)}
.dark-mode .litem{box-shadow:0 2px 6px rgba(0,0,0,0.12);border-color:var(--bor)}
.dark-mode .sbox{border-color:var(--bor);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.dark-mode .tabs button{background:var(--card);border:1px solid var(--bor)}
.dark-mode .tabs .ta{border-color:var(--y)}
.dark-mode .search-bar input,.dark-mode .search-bar-v2 input{background:var(--card);color:var(--text);border-color:var(--bor)}
.dark-mode .hero-greeting{box-shadow:0 8px 32px rgba(0,0,0,0.3)}
.dark-mode .info-banner{box-shadow:0 6px 24px rgba(0,0,0,0.3)}
.dark-mode .stat-card{box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.dark-mode .form-group input,.dark-mode .form-group textarea,.dark-mode .form-group select{background:var(--card);color:var(--text);border-color:var(--bor)}
.dark-mode .chat-input{background:var(--card);border-color:var(--bor)}
.dark-mode .chat-input input{background:var(--bg);color:var(--text);border-color:var(--bor)}
.dark-mode .overlay.open{background:rgba(0,0,0,0.6)}
.dark-mode .lang-dd{background:var(--card);border:1px solid var(--bor)}
.dark-mode .lang-dd button{color:var(--text)}
.dark-mode .lang-dd button:hover{background:var(--yl)}
.dark-mode .occ-bar{background:var(--card);border:1px solid var(--bor)}
.dark-mode .route-box{background:var(--card);border-color:var(--bor)}
.dark-mode .svg-nav svg{stroke:var(--sub)}
.dark-mode .ni .on .svg-nav svg{stroke:var(--y)}
.dark-mode .svg-qa svg{stroke:currentColor;opacity:0.9}
.dark-mode .hero-greeting{background:linear-gradient(135deg,rgba(255,204,0,0.2),rgba(255,204,0,0.05))!important}
.dark-mode .drawer{background:var(--card)}
.dark-mode .drawer-head{background:var(--y)}
.dark-mode .drawer-sep{background:var(--bor)}
.dark-mode .drawer-foot{border-color:var(--bor)}
.dark-mode .city-chip{background:var(--card);border-color:var(--bor)}
.dark-mode .city-chip.active{border-color:var(--y);background:var(--yl)}
.dark-mode .cc-name{color:var(--dark)}
.dark-mode nav{box-shadow:0 -4px 24px rgba(0,0,0,0.2)}

/* === ENHANCED SKELETON LOADERS === */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skel{background:linear-gradient(90deg,var(--bor) 25%,rgba(255,255,255,0.15) 37%,var(--bor) 63%);background-size:800px 100%;animation:shimmer 1.8s ease-in-out infinite;border-radius:8px}
.dark-mode .skel{background:linear-gradient(90deg,#2a2a3e 25%,#3a3a50 37%,#2a2a3e 63%);background-size:800px 100%}

/* Smooth page transitions */
main{animation:fadeIn .2s ease}
