/* ===== RESET & ROOT ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#001F3F;
  --secondary:#003B73;
  --accent:#00B4D8;
  --accent-dark:#0090AC;
  --emergency:#E63946;
  --success:#2A9D8F;
  --warn:#FF7B00;
  --gold:#FFD700;
  --bg:#F5F7FA;
  --text:#1B263B;
  --text-muted:#5A6A82;
  --border:#D0DCE8;
  --white:#ffffff;
  --glass-bg:rgba(255,255,255,0.08);
  --glass-border:rgba(255,255,255,0.18);
  --surface:#EDF2F7;
  --fs-base:16px;
}
html{scroll-behavior:smooth;font-size:var(--fs-base)}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}

/* Skip Nav Accessibility */
.skip-nav{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:9999;border-radius:0 0 8px 0;text-decoration:none;font-weight:600;transition:top .2s}
.skip-nav:focus{top:0}

/* ===== UTILITY BAR ===== */
.util-bar{background:var(--primary);padding:0 2rem;display:flex;align-items:center;gap:1rem;height:36px;overflow:hidden;position:sticky;top:0;z-index:1000;border-bottom:1px solid rgba(255,255,255,0.06)}
.util-emergency{display:flex;align-items:center;gap:.75rem;flex:1}
.util-link{color:rgba(255,255,255,0.8);font-size:11px;font-weight:500;text-decoration:none;display:flex;align-items:center;gap:.35rem;white-space:nowrap;padding:3px 8px;border-radius:4px;transition:background .2s}
.util-link:hover{background:rgba(255,255,255,0.1);color:#fff}
.util-link .num{font-family:'JetBrains Mono',monospace;color:var(--gold);font-weight:600}
.util-sep{color:rgba(255,255,255,0.2);font-size:12px}
.util-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.font-ctrl{display:flex;align-items:center;gap:2px}
.font-btn{background:transparent;border:none;color:rgba(255,255,255,0.6);cursor:pointer;padding:2px 5px;border-radius:3px;font-family:'Inter',sans-serif;line-height:1;transition:all .2s}
.font-btn:hover{background:rgba(255,255,255,0.1);color:#fff}
.lang-toggle{display:flex;gap:2px;border:1px solid rgba(255,255,255,0.2);border-radius:5px;overflow:hidden}
.lang-btn{background:transparent;border:none;color:rgba(255,255,255,0.6);font-size:11px;cursor:pointer;padding:3px 9px;font-family:'Inter','Noto Sans Tamil',sans-serif;transition:all .2s}
.lang-btn.active{background:var(--accent);color:#fff}

/* ===== ALERT TICKER ===== */
.ticker-bar{background:linear-gradient(90deg,#7B0000,var(--emergency),#7B0000);padding:0 1.5rem;display:flex;align-items:center;gap:1rem;height:32px;overflow:hidden;position:sticky;top:36px;z-index:999}
.ticker-badge{background:#fff;color:var(--emergency);font-size:9px;font-weight:800;padding:2px 7px;border-radius:3px;letter-spacing:.8px;white-space:nowrap;flex-shrink:0}
.ticker-wrap{flex:1;overflow:hidden;display:flex;align-items:center}
.ticker-inner{display:flex;gap:3rem;animation:ticker 30s linear infinite;white-space:nowrap}
.ticker-inner span{color:#fff;font-size:11px;font-weight:500}
.ticker-inner span::before{content:'● ';color:var(--gold);font-size:8px;vertical-align:middle;margin-right:4px}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-stop{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);color:#fff;font-size:10px;padding:2px 8px;border-radius:4px;cursor:pointer;flex-shrink:0;font-family:inherit;transition:background .2s}
.ticker-stop:hover{background:rgba(255,255,255,0.25)}

/* ===== MAIN HEADER ===== */
.main-header{background:var(--secondary);position:sticky;top:68px;z-index:998;border-bottom:1px solid rgba(255,255,255,0.06)}
.header-inner{max-width:1440px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;gap:2rem;height:76px}
.brand{display:flex;align-items:center;gap:1rem;flex-shrink:0;text-decoration:none}
.emblem{width:52px;height:52px;background:linear-gradient(135deg,var(--gold),#E6A000);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 0 0 3px rgba(255,215,0,0.2),0 4px 16px rgba(0,0,0,0.3);flex-shrink:0}
.brand-text{line-height:1.2}
.brand-name{color:#fff;font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;letter-spacing:.5px;white-space:nowrap;display:block}
.brand-sub{color:rgba(255,255,255,0.5);font-size:10px;letter-spacing:.3px;display:block}
.brand-sub-ta{color:rgba(255,255,255,0.35);font-size:9px;font-family:'Noto Sans Tamil',sans-serif;display:block}
.header-search{flex:1;max-width:360px;position:relative}
.header-search input{width:100%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:#fff;padding:.5rem 1rem .5rem 2.5rem;border-radius:8px;font-size:13px;font-family:inherit;outline:none;transition:all .2s}
.header-search input:focus{background:rgba(255,255,255,0.12);border-color:var(--accent)}
.header-search input::placeholder{color:rgba(255,255,255,0.35)}
.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:rgba(255,255,255,0.4);font-size:14px;pointer-events:none}
.header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}
.icon-btn{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.75);width:38px;height:38px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;text-decoration:none}
.icon-btn:hover{background:rgba(255,255,255,0.15);color:#fff}
.login-btn{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;padding:.45rem 1rem;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.375rem;transition:all .2s}
.login-btn:hover{background:rgba(255,255,255,0.18)}
.sos-btn{background:linear-gradient(135deg,var(--emergency),#A31020);color:#fff;border:none;padding:.45rem 1.25rem;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.375rem;letter-spacing:.5px;box-shadow:0 2px 16px rgba(230,57,70,0.5);animation:sos-pulse 2.5s ease-in-out infinite}
@keyframes sos-pulse{0%,100%{box-shadow:0 2px 16px rgba(230,57,70,0.5)}50%{box-shadow:0 2px 28px rgba(230,57,70,0.8)}}
.sos-btn:hover{transform:scale(1.04)}
.hamburger{display:none;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);color:#fff;width:38px;height:38px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;font-size:18px}

/* ===== STICKY NAV ===== */
.sticky-nav{background:rgba(0,31,63,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.07);position:sticky;top:144px;z-index:997}
.nav-inner{max-width:1440px;margin:0 auto;padding:0 2rem;display:flex;align-items:center}
.nav-links{display:flex;list-style:none;gap:0;width:100%;justify-content:center}
.nav-links li a{color:rgba(255,255,255,0.7);text-decoration:none;font-size:13px;font-weight:600;padding:.85rem 1.1rem;display:block;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;position:relative}
.nav-links li a:hover,.nav-links li a.active{color:#fff;border-bottom-color:var(--accent)}

/* ===== MOBILE DRAWER ===== */
.mobile-drawer{display:none;position:fixed;top:0;right:-320px;width:300px;height:100vh;background:var(--primary);z-index:9999;transition:right .3s ease;padding:2rem 1.5rem;overflow-y:auto;box-shadow:-4px 0 24px rgba(0,0,0,0.4)}
.mobile-drawer.open{right:0;display:block}
.drawer-close{background:rgba(255,255,255,0.1);border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:18px;margin-bottom:2rem}
.drawer-links{list-style:none;display:flex;flex-direction:column;gap:.25rem}
.drawer-links a{color:rgba(255,255,255,0.8);text-decoration:none;padding:.75rem 1rem;border-radius:8px;font-size:15px;display:block;transition:all .2s}
.drawer-links a:hover{background:rgba(255,255,255,0.08);color:#fff}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:9998}
.overlay.open{display:block}

/* ===== HERO ===== */
.hero{background:linear-gradient(160deg,#000D1A 0%,#001F3F 50%,#003B73 100%);min-height:600px;display:flex;align-items:center;position:relative;overflow:hidden;padding:5rem 2rem}
#hero-canvas{position:absolute;inset:0;pointer-events:none;opacity:.6}
.hero-grid{max-width:1440px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(0,180,216,0.12);border:1px solid rgba(0,180,216,0.3);color:rgba(255,255,255,0.85);font-size:11px;font-weight:600;padding:.4rem .9rem;border-radius:20px;letter-spacing:.5px;margin-bottom:1.5rem}
.hero-dot{width:6px;height:6px;background:var(--success);border-radius:50%;animation:blink 1.5s ease-in-out infinite;box-shadow:0 0 6px rgba(42,157,143,0.8)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero h1{font-family:'Rajdhani',sans-serif;font-size:clamp(32px,4vw,56px);font-weight:700;color:#fff;line-height:1.1;margin-bottom:1.25rem;letter-spacing:.5px}
.hero h1 .accent{color:var(--accent)}
.hero h1 .ta-text{display:block;font-family:'Noto Sans Tamil',sans-serif;font-size:clamp(18px,2vw,26px);font-weight:400;color:rgba(255,255,255,0.45);margin-top:.25rem;letter-spacing:0}
.hero-sub{color:rgba(255,255,255,0.6);font-size:16px;line-height:1.7;margin-bottom:2rem;max-width:500px}
.search-bar{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.18);border-radius:12px;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:2rem;backdrop-filter:blur(8px)}
.search-bar input{background:transparent;border:none;color:#fff;font-size:14px;font-family:inherit;flex:1;outline:none}
.search-bar input::placeholder{color:rgba(255,255,255,0.35)}
.search-bar-icon{color:rgba(255,255,255,0.4);font-size:18px;flex-shrink:0}
.search-bar-btn{background:var(--accent);color:#fff;border:none;padding:.5rem 1.25rem;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .2s;flex-shrink:0}
.search-bar-btn:hover{background:var(--accent-dark)}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:3rem}
.cta-primary{background:var(--accent);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.5rem;transition:all .2s}
.cta-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}
.cta-secondary{background:rgba(255,255,255,0.08);color:#fff;border:1px solid rgba(255,255,255,0.2);padding:.75rem 1.5rem;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.5rem;transition:all .2s}
.cta-secondary:hover{background:rgba(255,255,255,0.14)}
.cta-outline{background:transparent;color:rgba(255,255,255,0.65);border:1px solid rgba(255,255,255,0.12);padding:.75rem 1.25rem;border-radius:10px;font-size:14px;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.5rem;transition:all .2s}
.cta-outline:hover{color:#fff;background:rgba(255,255,255,0.06)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem}
.stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1rem 1.125rem;backdrop-filter:blur(12px);transition:all .3s;cursor:default}
.stat-card:hover{background:rgba(255,255,255,0.12);transform:translateY(-3px)}
.stat-num{font-family:'Rajdhani',sans-serif;font-size:28px;font-weight:700;color:var(--gold);display:block;margin-bottom:.1rem;letter-spacing:.5px}
.stat-label{font-size:11px;color:rgba(255,255,255,0.5);line-height:1.3}
.stat-trend{font-size:10px;color:var(--success);font-weight:600;display:flex;align-items:center;gap:.2rem;margin-top:.3rem}

/* Command Center */
.cc-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:20px;padding:1.5rem;backdrop-filter:blur(12px);width:100%}
.cc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.cc-title{color:#fff;font-size:13px;font-weight:600;font-family:'Rajdhani',sans-serif;letter-spacing:.5px}
.cc-live{display:flex;align-items:center;gap:.375rem;font-size:11px;color:var(--success);font-weight:600}
.cc-dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 8px rgba(42,157,143,0.7);animation:blink 1.5s ease-in-out infinite}
.cc-map-area{background:#000D1A;border:1px solid rgba(255,255,255,0.06);border-radius:12px;height:200px;margin-bottom:1rem;position:relative;overflow:hidden}
.map-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(0,180,216,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,180,216,0.05) 1px,transparent 1px);background-size:28px 28px}
.map-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:120px;background:radial-gradient(circle,rgba(0,180,216,0.12),transparent 70%);border-radius:50%}
.map-pin-cc{position:absolute;border-radius:50%;cursor:pointer}
.pin-ps{background:#00B4D8;box-shadow:0 0 0 2px rgba(0,180,216,0.3)}
.pin-alert{background:var(--emergency);box-shadow:0 0 0 2px rgba(230,57,70,0.3);animation:pin-p 1.5s ease-in-out infinite}
.pin-patrol{background:var(--success);box-shadow:0 0 0 2px rgba(42,157,143,0.3)}
@keyframes pin-p{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}
.cc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem}
.cc-met{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:8px;padding:.625rem;text-align:center}
.cc-met-val{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:600;color:#fff}
.cc-met-lbl{font-size:9px;color:rgba(255,255,255,0.4);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.cc-footer{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,0.06)}
.cc-footer span{font-size:10px;color:rgba(255,255,255,0.35)}
.cc-footer .green{color:var(--success)}

/* ===== SECTIONS COMMON ===== */
.section{max-width:1440px;margin:0 auto;padding:4rem 2rem}
.section-eyebrow{display:block;font-size:11px;font-weight:700;letter-spacing:2px;color:var(--accent);text-transform:uppercase;margin-bottom:.75rem;text-align:center}
.section-title{font-family:'Rajdhani',sans-serif;font-size:clamp(26px,3vw,38px);font-weight:700;color:var(--primary);line-height:1.15;margin-bottom:.875rem;letter-spacing:.3px;text-align:center}
.section-desc{color:var(--text-muted);font-size:15px;line-height:1.65;max-width:600px;margin:0 auto;text-align:center}
.section-header{text-align:center;margin-bottom:3rem}

/* ===== QUICK SERVICES ===== */
.services-wrap{background:#fff;border-bottom:1px solid var(--border)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.25rem}
.svc-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:1.5rem 1.25rem;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;text-decoration:none}
.svc-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--secondary));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,180,216,0.12)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{width:50px;height:50px;border-radius:12px;background:rgba(0,180,216,0.1);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:1rem;transition:all .25s;color:var(--accent)}
.svc-card:hover .svc-icon{background:var(--accent);color:#fff}
.svc-name{font-size:14px;font-weight:600;color:var(--primary);margin-bottom:.375rem;line-height:1.3;font-family:'Rajdhani',sans-serif;letter-spacing:.3px}
.svc-desc{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:.875rem}
.svc-link{font-size:11px;font-weight:600;color:var(--accent);display:flex;align-items:center;justify-content:space-between}
.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.5px}
.tag-live{background:rgba(42,157,143,0.12);color:var(--success)}
.tag-new{background:rgba(0,180,216,0.12);color:var(--accent)}
.tag-hot{background:rgba(230,57,70,0.1);color:var(--emergency)}

/* ===== LIVE DASHBOARD / STATS ===== */
.stats-wrap{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);padding:4rem 2rem;position:relative;overflow:hidden}
.stats-wrap::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;border-radius:50%;background:rgba(0,180,216,0.06);pointer-events:none}
.stats-inner{max-width:1440px;margin:0 auto}
.stats-header{text-align:center;margin-bottom:3rem}
.stats-header .section-title{color:#fff}
.stats-header .section-desc{color:rgba(255,255,255,0.5)}
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem}
.stat-big{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;padding:1.75rem 1.5rem;text-align:center;backdrop-filter:blur(12px);transition:all .3s;position:relative;overflow:hidden}
.stat-big::before{content:'';position:absolute;bottom:-30px;left:-30px;width:100px;height:100px;border-radius:50%;background:rgba(0,180,216,0.06)}
.stat-big:hover{transform:translateY(-4px);background:rgba(255,255,255,0.1);color:#fff}
.stat-big-num{font-family:'Rajdhani',sans-serif;font-size:42px;font-weight:700;color:var(--gold);display:block;line-height:1}
.stat-big-label{font-size:13px;color:rgba(255,255,255,0.6);margin-top:.5rem}
.stat-big-icon{font-size:28px;margin-bottom:.875rem;display:block}

/* ===== NEARBY STATIONS MAP ===== */
.map-wrap{background:var(--primary)}
.map-wrap .section-eyebrow{color:var(--accent)}
.map-wrap .section-title{color:#fff}
.map-wrap .section-desc{color:rgba(255,255,255,0.5)}
#station-map{height:420px;border-radius:12px;border:1px solid rgba(255,255,255,0.1)}
.station-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:1.5rem}
.station-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:1.25rem;transition:all .2s;color:#fff}
.station-card:hover{background:rgba(255,255,255,0.09);transform:translateY(-2px)}
.station-card-name{font-family:'Rajdhani',sans-serif;font-weight:600;color:#fff;font-size:15px;margin-bottom:.375rem}
.station-card-info{font-size:12px;color:rgba(255,255,255,0.5);line-height:1.6;margin-bottom:.875rem}
.station-card-info i{margin-right:.375rem;color:var(--accent)}
.dir-btn{background:var(--accent);color:#fff;border:none;padding:.4rem 1rem;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.35rem;text-decoration:none;transition:background .2s;width:fit-content}
.dir-btn:hover{background:var(--accent-dark)}

/* ===== ANALYTICS ===== */
.analytics-wrap{background:var(--bg)}
.analytics-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}
.chart-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.5rem}
.chart-title{font-size:14px;font-weight:600;color:var(--primary);font-family:'Rajdhani',sans-serif;letter-spacing:.3px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.period-btns{display:flex;gap:.25rem}
.period-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:11px;padding:.25rem .625rem;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .2s}
.period-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.bar-chart{display:flex;align-items:flex-end;gap:.75rem;height:160px}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%}
.bar-col{width:100%;border-radius:5px 5px 0 0;transition:opacity .2s;cursor:pointer;min-height:20px}
.bar-col:hover{opacity:.8}
.bar-lbl{font-size:10px;color:var(--text-muted);font-weight:500}
.mini-chart{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.25rem;margin-bottom:1rem}
.mini-chart:last-child{margin-bottom:0}
.mini-label{font-size:13px;font-weight:600;color:var(--primary);margin-bottom:1rem;font-family:'Rajdhani',sans-serif}
.donut-wrap{display:flex;align-items:center;gap:1rem}
.donut-legend{flex:1}
.d-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.d-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.d-text{font-size:11px;color:var(--text-muted)}
.d-val{font-size:11px;font-weight:600;color:var(--primary);margin-left:auto}
.progress-rows{display:flex;flex-direction:column;gap:.875rem}
.pr-row{display:flex;flex-direction:column;gap:.375rem}
.pr-top{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}
.pr-top strong{color:var(--primary)}
.pr-bar-wrap{height:6px;background:var(--surface);border-radius:3px;overflow:hidden}
.pr-bar-fill{height:100%;border-radius:3px;transition:width 1.2s ease}

/* ===== COMMISSIONER ===== */
.comm-wrap{background:var(--primary);position:relative;overflow:hidden}
.comm-deco{position:absolute;right:-100px;top:-100px;width:500px;height:500px;border-radius:50%;background:rgba(0,180,216,0.04);pointer-events:none}
.comm-grid{display:grid;grid-template-columns:1fr 2.5fr;gap:4rem;align-items:center}
.portrait-frame{width:280px;height:350px;border-radius:20px;background:linear-gradient(135deg,rgba(0,180,216,0.15),rgba(0,31,63,0.8));border:2px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.portrait-placeholder{display:flex;flex-direction:column;align-items:center;gap:1rem;color:rgba(255,255,255,0.5)}
.portrait-avatar{width:110px;height:110px;border-radius:50%;background:rgba(255,255,255,0.07);border:3px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;font-size:46px}
.portrait-badge{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(90deg,var(--accent),var(--secondary));color:#fff;font-size:11px;font-weight:600;padding:.6rem 1rem;text-align:center;letter-spacing:.3px}
.comm-content .section-title{text-align:left;color:#fff;margin-bottom:1.5rem}
.comm-content .section-eyebrow{text-align:left;color:var(--accent)}
blockquote{border-left:3px solid var(--accent);padding-left:1.5rem;margin-bottom:2rem}
blockquote p{color:rgba(255,255,255,0.75);font-size:16px;line-height:1.7;font-style:italic}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.mission-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;padding:1.25rem;backdrop-filter:blur(8px)}
.mission-card-label{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.mission-card-text{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.55}

/* ===== ORG CHART ===== */
.org-wrap{background:#fff}
.org-chart{display:flex;flex-direction:column;align-items:center;gap:0}
.org-level{display:flex;justify-content:center;gap:1.25rem;width:100%;position:relative;padding:.5rem 0}
.org-node{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:.875rem 1.25rem;text-align:center;cursor:pointer;transition:all .25s;min-width:140px;position:relative}
.org-node:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(0,180,216,0.15);transform:translateY(-2px)}
.org-node.top{background:var(--primary);border-color:var(--primary);min-width:220px}
.org-node.top .org-name{color:#fff}
.org-node.top .org-role{color:rgba(255,255,255,0.5)}
.org-node.top .org-badge{background:rgba(255,215,0,0.15);color:var(--gold)}
.org-name{font-size:13px;font-weight:600;color:var(--primary);margin-bottom:.25rem;font-family:'Rajdhani',sans-serif}
.org-role{font-size:11px;color:var(--text-muted)}
.org-badge{display:inline-flex;align-items:center;background:rgba(0,180,216,0.1);color:var(--accent);font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;margin-top:.375rem;letter-spacing:.5px}
.org-connector{width:2px;height:28px;background:var(--border);margin:0 auto}

/* ===== SPECIAL UNITS ===== */
.units-wrap{background:var(--bg)}
.units-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.unit-card{background:#fff;border:1.5px solid var(--border);border-radius:16px;overflow:hidden;transition:all .3s;cursor:pointer}
.unit-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,180,216,0.12)}
.unit-banner{height:100px;display:flex;align-items:center;padding:1.5rem;gap:1rem;position:relative;overflow:hidden}
.unit-icon{font-size:36px;flex-shrink:0;position:relative;z-index:1}
.unit-banner-text{position:relative;z-index:1;text-align:left}
.unit-banner-name{font-family:'Rajdhani',sans-serif;font-size:18px;font-weight:700;color:#fff;line-height:1.2}
.unit-banner-tagline{font-size:11px;color:rgba(255,255,255,0.6)}
.unit-body{padding:1.25rem}
.unit-stats{display:flex;gap:1rem;margin-bottom:1rem}
.unit-stat{text-align:center;flex:1}
.unit-stat-num{font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:600;color:var(--primary)}
.unit-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.unit-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.875rem;border-top:1px solid var(--border)}
.unit-cta{background:var(--accent);color:#fff;border:none;padding:.4rem 1rem;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s}
.unit-cta:hover{background:var(--accent-dark)}
.unit-contact{font-size:12px;color:var(--text-muted)}

/* ===== CITIZEN SERVICES WIZARD ===== */
.citizen-wrap{background:linear-gradient(160deg,var(--primary),var(--secondary))}
.citizen-wrap .section-eyebrow{color:var(--accent)}
.citizen-wrap .section-title{color:#fff}
.citizen-wrap .section-desc{color:rgba(255,255,255,0.5)}
.wizard-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:20px;padding:2rem;backdrop-filter:blur(12px)}
.wizard-steps{display:flex;gap:0;margin-bottom:2rem;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,0.12)}
.wizard-step{flex:1;padding:.625rem .5rem;text-align:center;font-size:11px;font-weight:600;color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.03);cursor:pointer;transition:all .2s;border-right:1px solid rgba(255,255,255,0.08);letter-spacing:.3px}
.wizard-step:last-child{border-right:none}
.wizard-step.active{background:var(--accent);color:#fff}
.wizard-step.done{background:rgba(42,157,143,0.2);color:var(--success)}
.wizard-content{display:none}
.wizard-content.active{display:block}
.form-group{margin-bottom:1.25rem;text-align:left}
.form-label{display:block;font-size:12px;font-weight:600;color:rgba(255,255,255,0.7);margin-bottom:.5rem;letter-spacing:.3px;text-align:left}
.form-control{width:100%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.15);color:#fff;padding:.65rem 1rem;border-radius:8px;font-size:14px;font-family:inherit;outline:none;transition:all .2s}
.form-control:focus{border-color:var(--accent);background:rgba(255,255,255,0.1)}
.form-control option{background:var(--primary);color:#fff}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.wizard-btns{display:flex;gap:.875rem;margin-top:1.5rem}
.btn-next{background:var(--accent);color:#fff;border:none;padding:.65rem 1.5rem;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s}
.btn-next:hover{background:var(--accent-dark)}
.btn-back{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.7);border:1px solid rgba(255,255,255,0.15);padding:.65rem 1.5rem;border-radius:8px;font-size:14px;cursor:pointer;font-family:inherit;transition:all .2s}
.btn-back:hover{background:rgba(255,255,255,0.14)}
.upload-zone{border:2px dashed rgba(255,255,255,0.2);border-radius:10px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover{border-color:var(--accent);background:rgba(0,180,216,0.05)}
.upload-icon{font-size:32px;color:var(--accent);display:block;margin-bottom:.75rem}
.upload-text{color:rgba(255,255,255,0.6);font-size:13px}
.upload-hint{color:rgba(255,255,255,0.35);font-size:11px;margin-top:.375rem}
.confirm-box{background:rgba(42,157,143,0.1);border:1px solid rgba(42,157,143,0.3);border-radius:12px;padding:1.5rem;text-align:center;margin-bottom:1.5rem}
.confirm-icon{font-size:48px;margin-bottom:.875rem;display:block}
.confirm-id{font-family:'JetBrains Mono',monospace;font-size:20px;color:var(--success);font-weight:600;display:block;margin-bottom:.5rem}
.confirm-msg{color:rgba(255,255,255,0.65);font-size:13px}

/* ===== SAFETY HUB ===== */
.safety-wrap{background:var(--bg)}
.safety-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.safety-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:1.5rem;transition:all .25s;cursor:pointer;overflow:hidden;position:relative;text-align:left}
.safety-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,0.08);border-color:var(--accent)}
.safety-cat{display:inline-flex;align-items:center;gap:.4rem;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:1rem;padding:.25rem .625rem;border-radius:4px}
.safety-icon{font-size:32px;margin-bottom:.875rem;display:block}
.safety-title{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:var(--primary);margin-bottom:.5rem}
.safety-desc{font-size:13px;color:var(--text-muted);line-height:1.55;margin-bottom:1rem}
.safety-link{font-size:12px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:.375rem}
.alert-banner{background:linear-gradient(90deg,rgba(230,57,70,0.08),rgba(230,57,70,0.04));border:1px solid rgba(230,57,70,0.2);border-radius:12px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;text-align:left}
.alert-icon{font-size:28px;flex-shrink:0}
.alert-title{font-weight:600;color:var(--emergency);font-size:14px;margin-bottom:.25rem;font-family:'Rajdhani',sans-serif}
.alert-text{font-size:13px;color:var(--text-muted)}

/* ===== COMMUNITY ===== */
.community-wrap{background:var(--primary)}
.community-wrap .section-title{color:#fff}
.community-wrap .section-eyebrow{color:var(--accent)}
.community-wrap .section-desc{color:rgba(255,255,255,0.5)}
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin-bottom:3rem}
.event-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;padding:1.25rem;backdrop-filter:blur(8px);transition:all .25s;text-align:left;color:#fff}
.event-card:hover{transform:translateY(-3px);background:rgba(255,255,255,0.1)}
.event-date{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);font-weight:600;margin-bottom:.625rem;display:flex;align-items:center;gap:.375rem}
.event-title{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:.5rem}
.event-loc{font-size:12px;color:rgba(255,255,255,0.5);margin-bottom:1rem;display:flex;align-items:center;gap:.375rem}
.event-register{background:var(--accent);color:#fff;border:none;padding:.4rem 1rem;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s}
.event-register:hover{background:var(--accent-dark)}
.friends-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:20px;padding:2.5rem;backdrop-filter:blur(12px);display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.friends-title{font-family:'Rajdhani',sans-serif;font-size:28px;font-weight:700;color:#fff;margin-bottom:1rem;line-height:1.2;text-align:left}
.friends-sub{color:rgba(255,255,255,0.6);font-size:14px;line-height:1.6;margin-bottom:1.5rem;text-align:left}
.friends-benefits{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1.5rem}
.friends-benefit{display:flex;align-items:center;gap:.75rem;font-size:13px;color:rgba(255,255,255,0.7);text-align:left}
.friends-benefit-icon{width:28px;height:28px;border-radius:50%;background:rgba(42,157,143,0.2);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.friends-form{background:rgba(0,0,0,0.2);border-radius:16px;padding:1.75rem}
.friends-form-title{font-family:'Rajdhani',sans-serif;font-size:18px;font-weight:600;color:#fff;margin-bottom:1.25rem;text-align:left}

/* ===== EMERGENCY SECTION ===== */
.emergency-wrap{background:var(--bg)}
.emergency-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.sos-ring{position:relative;display:flex;align-items:center;justify-content:center;width:260px;height:260px;margin:0 auto}
.sos-ring::before,.sos-ring::after{content:'';position:absolute;border-radius:50%;border:1px solid rgba(230,57,70,0.2);animation:ring-expand 2.5s ease-out infinite}
.sos-ring::before{width:220px;height:220px;animation-delay:.5s}
.sos-ring::after{width:260px;height:260px}
@keyframes ring-expand{0%{transform:scale(.8);opacity:.8}100%{transform:scale(1.05);opacity:0}}
.sos-main-btn{width:160px;height:160px;border-radius:50%;background:linear-gradient(135deg,var(--emergency),#A31020);border:3px solid rgba(255,255,255,0.15);color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:inherit;box-shadow:0 8px 40px rgba(230,57,70,0.5);transition:all .2s;position:relative;z-index:1}
.sos-main-btn:hover{transform:scale(1.04);box-shadow:0 12px 50px rgba(230,57,70,0.7)}
.sos-icon{font-size:32px}
.sos-text{font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;letter-spacing:2px;margin-top:2px}
.sos-sub{font-size:9px;color:rgba(255,255,255,0.7);letter-spacing:.5px;text-align:center}
.sos-hint{text-align:center;font-size:13px;color:var(--text-muted);margin-top:1.5rem;max-width:240px;margin-left:auto;margin-right:auto}
.helplines{display:flex;flex-direction:column;gap:.75rem}
.helpline-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s;text-decoration:none}
.helpline-card:hover{border-color:var(--accent);transform:translateX(4px);box-shadow:0 4px 16px rgba(0,180,216,0.1)}
.helpline-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.helpline-info{flex:1;text-align:left}
.helpline-name{font-size:13px;font-weight:600;color:var(--primary);font-family:'Rajdhani',sans-serif}
.helpline-num{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:700;color:var(--emergency)}
.helpline-arrow{color:var(--accent);font-size:18px;flex-shrink:0}

/* ===== NEWS ===== */
.news-wrap{background:var(--surface)}
.news-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}
.news-main{display:flex;flex-direction:column;gap:1rem}
.news-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;overflow:hidden;display:flex;gap:0;transition:all .25s;cursor:pointer;text-decoration:none}
.news-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.06)}
.news-img{width:90px;min-height:90px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}
.news-body{padding:1rem 1.25rem;flex:1;text-align:left}
.news-cat{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.news-title{font-size:14px;font-weight:600;color:var(--primary);line-height:1.4;margin-bottom:.5rem;font-family:'Rajdhani',sans-serif}
.news-meta{font-size:11px;color:var(--text-muted)}
.news-sidebar{display:flex;flex-direction:column;gap:1rem}
.social-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:1.25rem;text-align:left}
.social-title{font-weight:600;color:var(--primary);font-size:14px;margin-bottom:1rem;font-family:'Rajdhani',sans-serif}
.social-links{display:flex;gap:.625rem}
.social-link{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;text-decoration:none;transition:transform .2s}
.social-link:hover{transform:scale(1.1)}
.update-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:1.25rem;text-align:left}
.update-title{font-weight:600;color:var(--primary);font-size:14px;margin-bottom:1rem;font-family:'Rajdhani',sans-serif}
.update-item{display:flex;gap:.75rem;margin-bottom:.875rem;padding-bottom:.875rem;border-bottom:1px solid var(--border)}
.update-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.update-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:.35rem}
.update-text{font-size:12px;color:var(--text-muted);line-height:1.5;text-align:left}
.update-date{font-size:10px;color:rgba(90,106,130,0.6);margin-top:.25rem}

/* ===== CONTACT ===== */
.contact-wrap{background:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
#contact-map{height:320px;border-radius:12px;border:1px solid var(--border);margin-bottom:1.5rem}
.contact-info-list{display:flex;flex-direction:column;gap:1rem;text-align:left}
.contact-info-item{display:flex;gap:.875rem;align-items:flex-start}
.contact-info-icon{width:40px;height:40px;border-radius:10px;background:rgba(0,180,216,0.1);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--accent);flex-shrink:0}
.contact-info-label{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.3px;text-transform:uppercase;margin-bottom:.25rem}
.contact-info-val{font-size:14px;color:var(--primary);font-weight:500}
.contact-form-title{font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;color:var(--primary);margin-bottom:1.5rem;text-align:left}
.cf-group{margin-bottom:1.25rem;text-align:left}
.cf-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:.5rem;letter-spacing:.3px;text-align:left}
.cf-input{width:100%;background:#fff;border:1.5px solid var(--border);color:var(--text);padding:.7rem 1rem;border-radius:8px;font-size:14px;font-family:inherit;outline:none;transition:all .2s}
.cf-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,180,216,0.08)}
.cf-input::placeholder{color:rgba(90,106,130,0.5)}
.cf-textarea{resize:vertical;min-height:120px}
.cf-submit{background:var(--accent);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s;display:flex;align-items:center;gap:.5rem}
.cf-submit:hover{background:var(--accent-dark)}

/* ===== FEEDBACK / CHAT ===== */
.feedback-wrap{background:var(--primary)}
.feedback-wrap .section-title{color:#fff}
.feedback-wrap .section-eyebrow{color:var(--accent)}
.feedback-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.feedback-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;backdrop-filter:blur(8px)}
.feedback-title{font-family:'Rajdhani',sans-serif;font-size:18px;font-weight:600;color:#fff;margin-bottom:1.25rem;text-align:left}
.stars{display:flex;gap:.375rem;margin-bottom:1.5rem}
.star{font-size:28px;cursor:pointer;color:rgba(255,255,255,0.2);transition:color .15s,transform .15s}
.star:hover,.star.active{color:var(--gold)}
.star:hover{transform:scale(1.1)}
.chat-widget{position:fixed;bottom:2rem;right:2rem;z-index:9996}
.chat-toggle{width:56px;height:56px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 20px rgba(0,180,216,0.4);transition:all .2s;display:flex;align-items:center;justify-content:center}
.chat-toggle:hover{background:var(--accent-dark);transform:scale(1.06)}
.chat-panel{position:absolute;bottom:70px;right:0;width:320px;background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,0.15);border:1px solid var(--border);overflow:hidden;display:none;flex-direction:column}
.chat-panel.open{display:flex}
.chat-head{background:var(--primary);padding:1rem 1.25rem;display:flex;align-items:center;gap:.75rem}
.chat-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.chat-head-info{flex:1;text-align:left}
.chat-head-name{font-size:14px;font-weight:600;color:#fff;font-family:'Rajdhani',sans-serif}
.chat-head-status{font-size:11px;color:rgba(255,255,255,0.55)}
.chat-close{background:rgba(255,255,255,0.1);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:14px;flex-shrink:0}
.chat-msgs{flex:1;overflow-y:auto;padding:1rem;max-height:260px;display:flex;flex-direction:column;gap:.625rem;background:#F8FAFC;text-align:left}
.chat-msg{padding:.65rem .875rem;border-radius:10px;font-size:13px;line-height:1.5;max-width:85%;white-space:pre-line}
.chat-msg.bot{background:#fff;border:1px solid var(--border);color:var(--text);align-self:flex-start;border-bottom-left-radius:3px}
.chat-msg.user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:3px}
.chat-quick{padding:.75rem 1rem;border-top:1px solid var(--border);display:flex;gap:.375rem;flex-wrap:wrap;background:#fff}
.quick-btn{background:rgba(0,180,216,0.1);border:1px solid rgba(0,180,216,0.2);color:var(--accent);font-size:11px;font-weight:600;padding:.3rem .65rem;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .2s}
.quick-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.chat-input-wrap{padding:.75rem 1rem;border-top:1px solid var(--border);display:flex;gap:.5rem;background:#fff}
#chatInput{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:.5rem .75rem;font-size:13px;font-family:inherit;outline:none;color:var(--text)}
#chatInput:focus{border-color:var(--accent)}
.chat-send{background:var(--accent);border:none;color:#fff;width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:16px;transition:background .2s;flex-shrink:0}
.chat-send:hover{background:var(--accent-dark)}

/* ===== FOOTER ===== */
.footer{background:#000D1A;border-top:1px solid rgba(255,255,255,0.05);color:rgba(255,255,255,0.7)}
.footer-inner{max-width:1440px;margin:0 auto;padding:3rem 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;gap:2.5rem;margin-bottom:2.5rem}
.footer-brand .brand-name{font-size:18px;margin-bottom:.5rem}
.footer-brand .brand-sub{font-size:11px;margin-bottom:1rem;display:block}
.footer-desc{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.65;margin-bottom:1.25rem;text-align:left}
.footer-title{font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;color:#fff;letter-spacing:.5px;margin-bottom:1.25rem;text-align:left}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.5rem;padding:0;text-align:left}
.footer-links a{color:rgba(255,255,255,0.45);font-size:13px;text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--accent)}
.footer-emergency-list{display:flex;flex-direction:column;gap:.625rem}
.footer-num{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:8px;padding:.5rem .875rem}
.footer-num-label{font-size:12px;color:rgba(255,255,255,0.5)}
.footer-num-val{font-family:'JetBrains Mono',monospace;font-size:16px;color:var(--gold);font-weight:600}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.3)}
.footer-legal{display:flex;gap:1.25rem}
.footer-legal a{font-size:12px;color:rgba(255,255,255,0.3);text-decoration:none;transition:color .2s}
.footer-legal a:hover{color:var(--accent)}

/* ===== ACCESSIBILITY / RESPONSIVE ===== */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}

@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .comm-grid{grid-template-columns:1fr}
  .comm-portrait{display:none}
  .analytics-grid,.news-grid,.contact-grid,.feedback-grid,.friends-card{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .util-bar{height:auto;padding:.375rem 1rem;flex-wrap:wrap;gap:.375rem}
  .util-emergency .util-sep{display:none}
  .util-link{font-size:10px;padding:2px 5px}
  .main-header{top:0;position:sticky}
  .ticker-bar{position:relative;top:auto}
  .sticky-nav{top:76px}
  .header-inner{height:64px;padding:0 1rem;gap:1rem}
  .brand-sub-ta,.header-search{display:none}
  .hamburger{display:flex}
  .nav-links{display:none}
  .hero{padding:3rem 1rem}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .mission-grid,.form-grid{grid-template-columns:1fr}
  .units-grid,.events-grid{grid-template-columns:1fr}
  .emergency-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .util-right .font-ctrl{display:none}
}
@media(max-width:480px){
  .hero-cta{flex-direction:column}
  .hero-stats{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:28px}
}

/* ===== FOCUS VISIBLE ===== */
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ===== LEAFLET POPUP CUSTOM ===== */
.cp-popup strong{font-family:'Rajdhani',sans-serif;font-size:15px;color:var(--primary)}
.cp-popup small{font-size:12px;color:var(--text-muted)}
.cp-popup a{background:var(--accent);color:#fff;padding:4px 12px;border-radius:6px;text-decoration:none;font-size:12px;font-weight:600;display:inline-block;margin-top:6px}
