/* ============================================================
   ASK AUNTY MIMI — SRHR INTELLIGENCE PLATFORM
   Premium Design System | Built by Pinch Africa
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&display=swap');

:root {
  /* Brand Palette */
  --primary: #7C3AED;
  --primary-light: #A855F7;
  --primary-dark: #5B21B6;
  --accent: #06B6D4;
  --accent-warm: #F97316;
  --success: #10B981;
  --danger: #EF4444;
  --warning: #F59E0B;
  --crisis: #DC2626;

  /* Backgrounds */
  --bg-deep: #FAFAFA;
  --bg-dark: #F0F4F8;
  --bg-card: #FFFFFF;
  --bg-card-hover: #F8FAFC;
  --bg-glass: rgba(255,255,255,0.75);

  /* Text */
  --text-primary: #111827;
  --text-secondary: #4B5563;
  --text-muted: #9CA3AF;

  /* Borders */
  --border: rgba(0,0,0,0.07);
  --border-accent: rgba(124,58,237,0.2);

  /* Gradients */
  --grad-primary: linear-gradient(135deg, #7C3AED, #A855F7);
  --grad-cyan: linear-gradient(135deg, #06B6D4, #0284C7);
  --grad-warm: linear-gradient(135deg, #F97316, #EA580C);
  --grad-success: linear-gradient(135deg, #10B981, #059669);
  --grad-danger: linear-gradient(135deg, #EF4444, #DC2626);
  --grad-hero: radial-gradient(ellipse at 20% 50%, rgba(6,182,212,0.07) 0%, transparent 60%),
               radial-gradient(ellipse at 80% 20%, rgba(124,58,237,0.05) 0%, transparent 50%),
               linear-gradient(180deg, #FAFAFA 0%, #F0F4F8 100%);

  /* Shadows */
  --shadow-card: 0 2px 20px rgba(0,0,0,0.06), 0 1px 4px rgba(0,0,0,0.04);
  --shadow-glow: 0 0 40px rgba(124,58,237,0.12);
  --shadow-btn: 0 8px 30px rgba(124,58,237,0.30);

  /* Spacing */
  --nav-h: 72px;
  --radius-card: 20px;
  --radius-btn: 12px;
  --radius-sm: 8px;

  /* Animation */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── RESET ─────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Plus Jakarta Sans', 'Inter', sans-serif;
  background: var(--bg-deep);
  color: var(--text-primary);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 9999;
  opacity: 0.4;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }

/* ── SCROLLBAR ─────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: rgba(124,58,237,0.3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary); }

/* ── UTIL ──────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.gradient-text {
  background: linear-gradient(135deg, #7C3AED, #06B6D4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-label {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(124,58,237,0.08); border: 1px solid rgba(124,58,237,0.18);
  color: var(--primary); padding: 6px 16px; border-radius: 50px;
  font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px;
  margin-bottom: 16px;
}
.section-title {
  font-size: clamp(28px, 4vw, 48px); font-weight: 900;
  line-height: 1.12; letter-spacing: -0.03em; margin-bottom: 16px;
}
.section-desc {
  font-size: 16px; color: var(--text-secondary); max-width: 600px;
  line-height: 1.7; margin-bottom: 48px;
}
.section { padding: 100px 0; }
.section-dark {
  background: #F0F4F8;
  border-top: 1px solid rgba(0,0,0,0.05);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

/* ── BUTTONS ───────────────────────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--grad-primary);
  color: #fff; padding: 14px 28px; border-radius: var(--radius-btn);
  font-size: 14px; font-weight: 700; transition: all 0.3s var(--ease);
  box-shadow: var(--shadow-btn);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(124,58,237,0.4); }
.btn-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--bg-card); border: 1px solid rgba(0,0,0,0.08);
  color: var(--text-primary); padding: 14px 28px; border-radius: var(--radius-btn);
  font-size: 14px; font-weight: 600; transition: all 0.3s var(--ease);
  backdrop-filter: blur(10px);
}
.btn-secondary:hover { border-color: var(--border-accent); background: var(--bg-card-hover); transform: translateY(-2px); }
.btn-whatsapp {
  display: inline-flex; align-items: center; gap: 10px;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff; padding: 14px 28px; border-radius: var(--radius-btn);
  font-size: 14px; font-weight: 700; transition: all 0.3s var(--ease);
  width: 100%; justify-content: center; margin-top: 20px;
}
.btn-whatsapp:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(37,211,102,0.4); }
.btn-webchat {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--grad-primary);
  color: #fff; padding: 14px 28px; border-radius: var(--radius-btn);
  font-size: 14px; font-weight: 700; transition: all 0.3s var(--ease);
  width: 100%; justify-content: center; margin-top: 20px;
}
.btn-webchat:hover { transform: translateY(-2px); box-shadow: var(--shadow-btn); }

/* ── NAVIGATION ────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: var(--nav-h); transition: all 0.4s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(255,255,255,0.88);
  backdrop-filter: blur(15px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}
.nav-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  height: 100%; display: flex; align-items: center; gap: 40px;
}
.nav-logo { display: flex; align-items: center; gap: 12px; margin-right: auto; }
.logo-icon {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--grad-primary); display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 20px rgba(124,58,237,0.3);
}
.logo-icon span { font-size: 13px; font-weight: 900; color: #fff; }
.logo-icon.small { width: 32px; height: 32px; border-radius: 10px; }
.logo-icon.small span { font-size: 11px; }
.logo-name { font-size: 15px; font-weight: 800; color: var(--text-primary); }
.logo-sub { font-size: 10px; color: var(--text-muted); font-weight: 500; letter-spacing: 0.5px; }
.nav-links { display: flex; align-items: center; gap: 8px; }
.nav-link {
  padding: 8px 14px; border-radius: 8px; font-size: 13px; font-weight: 600;
  color: var(--text-secondary); transition: all 0.2s; white-space: nowrap;
}
.nav-link:hover { color: var(--text-primary); background: rgba(0,0,0,0.04); }
.nav-btn-ghost {
  padding: 9px 18px; border-radius: var(--radius-btn); font-size: 13px; font-weight: 700;
  color: var(--primary); border: 1px solid rgba(124,58,237,0.25);
  transition: all 0.2s; white-space: nowrap;
}
.nav-btn-ghost:hover { background: rgba(124,58,237,0.06); }
.nav-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: var(--radius-btn); font-size: 13px; font-weight: 700;
  background: var(--grad-primary); color: #fff;
  box-shadow: 0 4px 16px rgba(124,58,237,0.3); white-space: nowrap;
  transition: all 0.2s;
}
.nav-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(124,58,237,0.4); }
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  padding: 8px; border-radius: 8px;
  background: #F8FAFC; border: 1px solid rgba(0,0,0,0.08);
}
.nav-hamburger span {
  display: block; width: 20px; height: 2px;
  background: var(--text-primary); border-radius: 2px;
  transition: all 0.3s;
}

/* ── HERO ──────────────────────────────────────────── */
.hero {
  min-height: 100vh; display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center; gap: 60px;
  padding: calc(var(--nav-h) + 60px) 80px 80px;
  background: var(--grad-hero); position: relative; overflow: hidden;
  max-width: 1400px; margin: 0 auto;
}
@media(max-width:768px) {
  .hero { grid-template-columns:1fr; padding: calc(var(--nav-h) + 40px) 24px 60px; gap:40px; }
  .hero-visual { display:none; }
}
.hero-bg-orbs { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: 0.25;
}
.orb-1 { width: 500px; height: 500px; background: rgba(124,58,237,0.15); top: -100px; left: -100px; animation: orbFloat 8s ease-in-out infinite; }
.orb-2 { width: 350px; height: 350px; background: rgba(6,182,212,0.15); top: 200px; right: -50px; animation: orbFloat 10s ease-in-out infinite reverse; }
.orb-3 { width: 250px; height: 250px; background: rgba(249,115,22,0.12); bottom: 0; left: 30%; animation: orbFloat 6s ease-in-out infinite 2s; }
@keyframes orbFloat { 0%,100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-30px) scale(1.05); } }

/* HERO SLIDER */
.hero-slider {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.hero-slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0; transition: opacity 1.2s ease;
}
.hero-slide.active { opacity: 1; }
.hero-slide-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg,
    rgba(250,250,250,0.88) 0%,
    rgba(240,244,248,0.82) 100%);
  z-index: 1;
}
.hero-content, .hero-visual, .hero-bg-orbs {
  position: relative; z-index: 2;
}
.hero-slider-dots {
  position: absolute; bottom: 32px; left: 50%;
  transform: translateX(-50%); z-index: 3;
  display: flex; gap: 8px;
}
.slider-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(124,58,237,0.25);
  border: none; padding: 0; cursor: pointer;
  transition: all 0.3s;
}
.slider-dot.active {
  background: var(--primary); width: 24px; border-radius: 4px;
}

.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(124,58,237,0.08); border: 1px solid rgba(124,58,237,0.2);
  padding: 8px 18px; border-radius: 50px; font-size: 12px; font-weight: 600;
  color: var(--primary); margin-bottom: 24px;
}
.badge-dot { width: 8px; height: 8px; background: var(--success); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { opacity:1; box-shadow: 0 0 0 0 rgba(16,185,129,0.4); } 50% { opacity:0.8; box-shadow: 0 0 0 8px rgba(16,185,129,0); } }

.hero-title { font-size: clamp(36px, 5vw, 62px); font-weight: 900; line-height: 1.08; letter-spacing: -0.04em; margin-bottom: 20px; }
.hero-desc { font-size: 17px; color: var(--text-secondary); line-height: 1.75; margin-bottom: 36px; max-width: 520px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 52px; }
.hero-stats {
  display: flex; align-items: center; gap: 0;
  background: rgba(255,255,255,0.9); border: 1px solid rgba(0,0,0,0.07);
  border-radius: 16px; padding: 20px 28px; backdrop-filter: blur(10px);
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  width: fit-content;
}
.stat-item { text-align: center; padding: 0 20px; }
.stat-num { font-size: 24px; font-weight: 900; letter-spacing: -0.03em; }
.stat-label { font-size: 10px; color: var(--text-muted); margin-top: 2px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.stat-divider { width: 1px; height: 36px; background: var(--border); flex-shrink: 0; }

/* ── HERO CHAT PREVIEW ─────────────────────────────── */
.hero-visual { display: flex; align-items: center; justify-content: center; position: relative; z-index: 1; }
.chat-preview-card {
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(124,58,237,0.15);
  border-radius: 24px; width: 340px; backdrop-filter: blur(20px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.10), 0 4px 16px rgba(124,58,237,0.08);
  overflow: hidden;
}
.chat-header {
  padding: 16px 20px; border-bottom: 1px solid rgba(0,0,0,0.06);
  display: flex; align-items: center; gap: 12px;
  background: rgba(124,58,237,0.05);
}
.chat-avatar {
  width: 40px; height: 40px; border-radius: 50%; overflow: hidden;
  background: var(--grad-primary); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.avatar-fallback { width:40px; height:40px; background: var(--grad-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:13px; color:#fff; }
.chat-info { flex: 1; }
.chat-name { font-size: 13px; font-weight: 700; }
.chat-status { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--success); }
.online-dot { width: 6px; height: 6px; background: var(--success); border-radius: 50%; animation: pulse 2s infinite; }
.chat-lock { color: var(--success); font-size: 14px; }
.chat-messages { padding: 16px; display: flex; flex-direction: column; gap: 10px; min-height: 180px; }
.msg-bubble { max-width: 85%; }
.msg-mimi { align-self: flex-start; }
.msg-user { align-self: flex-end; }
.msg-text {
  padding: 10px 14px; border-radius: 16px; font-size: 12.5px; line-height: 1.5; font-weight: 500;
}
.msg-mimi .msg-text { background: rgba(124,58,237,0.08); border: 1px solid rgba(124,58,237,0.15); color: var(--text-primary); border-bottom-left-radius: 4px; }
.msg-user .msg-text { background: var(--grad-primary); border-bottom-right-radius: 4px; color: #fff; }
.msg-time { font-size: 10px; color: var(--text-muted); margin-top: 4px; }
.msg-mimi .msg-time { text-align: left; }
.msg-user .msg-time { text-align: right; }
.typing .msg-text { padding: 12px 16px; }
.typing-dots { display: flex; gap: 4px; }
.typing-dots span {
  width: 6px; height: 6px; background: var(--primary-light); border-radius: 50%;
  animation: typingBounce 1.2s infinite;
}
.typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.typing-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBounce { 0%,60%,100% { transform: translateY(0); } 30% { transform: translateY(-6px); } }
.chat-input-bar {
  padding: 12px 16px; border-top: 1px solid var(--border);
  display: flex; gap: 8px;
}
.chat-input-bar input {
  flex: 1; background: rgba(0,0,0,0.04); border: 1px solid var(--border);
  border-radius: 20px; padding: 8px 14px; color: var(--text-primary); font-size: 12px;
  font-family: inherit; outline: none;
}
.send-btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--grad-primary); color: #fff; font-size: 12px;
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.2s;
}
.send-btn:hover { transform: scale(1.1); }

/* ── TRUST RIBBON ──────────────────────────────────── */
.trust-ribbon {
  background: #FFFFFF;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 20px 0; overflow: hidden;
}
.trust-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; gap: 40px; }
.trust-label { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-muted); white-space: nowrap; }
.trust-logos { display: flex; gap: 24px; flex-wrap: wrap; }
.trust-logo {
  font-size: 11px; font-weight: 700; color: var(--text-secondary); white-space: nowrap;
  padding: 6px 14px; border-radius: 8px; background: #F8FAFC; border: 1px solid rgba(0,0,0,0.06);
}

/* ── STEPS GRID ────────────────────────────────────── */
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media(max-width:900px) { .steps-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .steps-grid { grid-template-columns: 1fr; } }
.step-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px 24px;
  position: relative; overflow: hidden; transition: all 0.3s var(--ease);
  box-shadow: var(--shadow-card);
}
.step-card:hover { border-color: rgba(124,58,237,0.25); box-shadow: 0 8px 32px rgba(124,58,237,0.10); transform: translateY(-4px); }
.step-num {
  font-size: 64px; font-weight: 900; color: rgba(124,58,237,0.07);
  position: absolute; top: -10px; right: 12px; line-height: 1; letter-spacing: -0.05em;
}
.step-icon { font-size: 28px; margin-bottom: 16px; }
.step-icon i { background: var(--grad-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.step-card h3 { font-size: 16px; font-weight: 800; margin-bottom: 10px; }
.step-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; }

/* ── SERVICES GRID ────────────────────────────────── */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media(max-width:900px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .services-grid { grid-template-columns: 1fr; } }
.service-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px 24px;
  transition: all 0.3s var(--ease); cursor: default;
  box-shadow: var(--shadow-card); position: relative; overflow: hidden;
  padding-right: calc(45% + 24px);
}
.service-card::before {
  content: ''; position: absolute; top: 0; right: 0;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(124,58,237,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.service-card:hover { border-color: rgba(124,58,237,0.2); box-shadow: 0 8px 32px rgba(0,0,0,0.08); transform: translateY(-4px); }
.service-card-img {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: 45%; background-size: cover; background-position: center;
  opacity: 0.12; border-radius: 0 var(--radius-card) var(--radius-card) 0;
}
@media(max-width:500px) {
  .service-card-img { display: none; }
  .service-card { padding-right: 24px; }
}
.service-icon {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #fff; margin-bottom: 16px;
}
.service-card h3 { font-size: 16px; font-weight: 800; margin-bottom: 10px; }
.service-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 16px; }
.service-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.service-tags span {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 4px 10px; border-radius: 50px;
  background: rgba(124,58,237,0.06); border: 1px solid rgba(124,58,237,0.15);
  color: var(--primary);
}

/* ── LANGUAGE CARDS ────────────────────────────────── */
.lang-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media(max-width:900px) { .lang-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .lang-grid { grid-template-columns: 1fr; } }
.lang-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px 24px;
  text-align: center; transition: all 0.3s var(--ease); cursor: default;
  box-shadow: var(--shadow-card);
}
.lang-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); }
.lang-flag { font-size: 36px; margin-bottom: 12px; }
.lang-name { font-size: 18px; font-weight: 900; margin-bottom: 4px; }
.lang-region { font-size: 11px; color: var(--text-muted); margin-bottom: 16px; font-weight: 600; }
.lang-sample {
  font-size: 12px; color: var(--text-secondary); font-style: italic;
  background: rgba(124,58,237,0.05); border: 1px solid rgba(124,58,237,0.12);
  border-radius: 10px; padding: 10px 12px; margin-bottom: 14px; line-height: 1.5;
}
.lang-badge {
  display: inline-block; font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.5px; padding: 4px 12px; border-radius: 50px;
  background: rgba(16,185,129,0.15); border: 1px solid rgba(16,185,129,0.3); color: var(--success);
}

/* ── PRIVACY SPLIT ─────────────────────────────────── */
.privacy-split { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
@media(max-width:768px) { .privacy-split { grid-template-columns: 1fr; } }
.privacy-features { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.pf-item { display: flex; align-items: center; gap: 12px; font-size: 14px; color: var(--text-secondary); font-weight: 500; }
.pf-item i { color: var(--success); font-size: 16px; flex-shrink: 0; }
.shield-card {
  background: #FFFFFF; border: 1px solid rgba(124,58,237,0.15);
  border-radius: 24px; padding: 36px; text-align: center;
  box-shadow: 0 8px 32px rgba(124,58,237,0.08);
}
.shield-icon { font-size: 56px; margin-bottom: 16px; }
.shield-icon i { background: var(--grad-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.shield-title { font-size: 18px; font-weight: 800; margin-bottom: 24px; }
.shield-checks { display: flex; flex-direction: column; gap: 12px; text-align: left; }
.sc-row { display: flex; align-items: center; gap: 12px; font-size: 13px; font-weight: 600; padding: 10px 14px; background: rgba(16,185,129,0.05); border-radius: 10px; color: var(--text-primary); }
.sc-icon.green { color: var(--success); }
.shield-footer { font-size: 11px; color: var(--text-muted); margin-top: 20px; font-weight: 600; }

/* ── CHAT OPTIONS ──────────────────────────────────── */
.chat-options { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 800px; }
@media(max-width:600px) { .chat-options { grid-template-columns: 1fr; } }
.chat-option-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-card); padding: 32px; position: relative;
  transition: all 0.3s var(--ease);
}
.chat-option-card:hover { border-color: var(--border-accent); transform: translateY(-4px); }
.chat-option-card.featured { border-color: var(--border-accent); background: rgba(124,58,237,0.04); }
.co-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--grad-primary); color: #fff; font-size: 11px; font-weight: 800;
  padding: 4px 16px; border-radius: 50px; white-space: nowrap;
}
.co-icon {
  width: 56px; height: 56px; border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: #fff; margin-bottom: 16px;
}
.chat-option-card h3 { font-size: 18px; font-weight: 800; margin-bottom: 10px; }
.chat-option-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 16px; }
.co-features { display: flex; flex-direction: column; gap: 8px; }
.co-features span { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-secondary); font-weight: 600; }
.co-features i { color: var(--success); }

/* ── CRISIS BANNER ─────────────────────────────────── */
.crisis-banner {
  background: linear-gradient(135deg, rgba(220,38,38,0.08), rgba(239,68,68,0.05));
  border-top: 2px solid rgba(220,38,38,0.3);
  padding: 16px 24px;
}
.crisis-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; justify-content: center; }
.crisis-icon { color: var(--crisis); font-size: 18px; }
.crisis-text { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.crisis-btn {
  background: var(--crisis); color: #fff; padding: 8px 20px; border-radius: 8px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.5px;
  transition: transform 0.2s;
}
.crisis-btn:hover { transform: scale(1.05); }

/* ── FOOTER ────────────────────────────────────────── */
.footer {
  background: #F0F4F8;
  border-top: 1px solid rgba(0,0,0,0.06);
  padding: 60px 0 30px;
}
.footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.footer-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 40px; }
.footer-tagline { font-size: 12px; color: var(--text-muted); font-weight: 500; margin-top: 2px; }
.footer-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-bottom: 40px; }
@media(max-width:600px) { .footer-links { grid-template-columns: 1fr 1fr; } }
.footer-col { display: flex; flex-direction: column; gap: 10px; }
.footer-col-title { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.2px; color: var(--primary); margin-bottom: 6px; }
.footer-col a { font-size: 13px; color: var(--text-secondary); font-weight: 500; transition: color 0.2s; }
.footer-col a:hover { color: var(--primary); }
.footer-bottom {
  border-top: 1px solid rgba(0,0,0,0.06); padding-top: 24px;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: var(--text-muted);
}
.footer-bottom a { color: var(--primary); font-weight: 600; }
.footer-compliance { display: flex; gap: 16px; flex-wrap: wrap; }
.footer-compliance span { font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: 6px; background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06); }

/* ── ANIMATIONS ────────────────────────────────────── */
.animate-in { opacity: 0; transform: translateY(24px); transition: all 0.8s var(--ease); }
.animate-in.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }
.animate-card { opacity: 0; transform: translateY(20px); transition: all 0.6s var(--ease); }
.animate-card.visible { opacity: 1; transform: translateY(0); }

/* ── MOBILE MENU ───────────────────────────────────── */
@media(max-width:900px) {
  .nav-hamburger { display:flex; }
  .nav-links {
    display: none; position: absolute; top: var(--nav-h); left: 0; right: 0;
    background: rgba(255,255,255,0.97); backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border); padding: 20px 24px;
    flex-direction: column; gap: 8px;
  }
  .nav-links.open { display: flex; }
  .nav-link, .nav-btn-ghost, .nav-btn { width: 100%; text-align: center; justify-content: center; }
}

/* ── WEBCHAT PAGE ──────────────────────────────────── */
.webchat-page { min-height:100vh; display:flex; flex-direction:column; background: var(--bg-dark); }
.webchat-header {
  padding: 20px 24px; border-bottom: 1px solid rgba(0,0,0,0.07);
  background: rgba(255,255,255,0.9); backdrop-filter: blur(15px);
  display: flex; align-items: center; gap: 16px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.webchat-header .back-btn {
  width: 36px; height: 36px; border-radius: 10px; background: #F8FAFC;
  border: 1px solid rgba(0,0,0,0.07); display: flex; align-items: center; justify-content: center;
  color: var(--text-primary); font-size: 14px; transition: all 0.2s;
}
.webchat-header .back-btn:hover { border-color: var(--border-accent); }
.wc-status { display:flex; align-items:center; gap:6px; font-size:11px; color: var(--success); font-weight:700; }
.privacy-pill {
  margin-left: auto; display: flex; align-items: center; gap: 8px;
  background: rgba(16,185,129,0.1); border: 1px solid rgba(16,185,129,0.3);
  padding: 6px 14px; border-radius: 50px; font-size: 11px; font-weight: 700; color: var(--success);
}
.lang-switcher {
  display: flex; gap: 6px; padding: 12px 24px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.6);
}
.lang-btn {
  padding: 6px 14px; border-radius: 8px; font-size: 12px; font-weight: 700;
  color: var(--text-secondary); background: var(--bg-card); border: 1px solid var(--border);
  transition: all 0.2s;
}
.lang-btn.active { background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.2); color: var(--primary); }
.lang-btn:hover { border-color: var(--border-accent); color: var(--text-primary); }
.webchat-body { flex:1; display:flex; flex-direction:column; max-width:800px; width:100%; margin:0 auto; padding:24px; gap:12px; overflow-y:auto; }
.wc-msg { max-width:75%; animation: msgSlide 0.3s var(--ease); }
@keyframes msgSlide { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.wc-msg.bot { align-self:flex-start; }
.wc-msg.user { align-self:flex-end; }
.wc-bubble {
  padding:12px 16px; border-radius:18px; font-size:14px; line-height:1.6; font-weight:500;
}
.wc-msg.bot .wc-bubble { background:rgba(124,58,237,0.08); border:1px solid rgba(124,58,237,0.15); border-bottom-left-radius:4px; color: var(--text-primary); }
.wc-msg.user .wc-bubble { background: var(--grad-primary); color:#fff; border-bottom-right-radius:4px; }
.wc-meta { font-size:10px; color:var(--text-muted); margin-top:4px; padding: 0 4px; }
.wc-msg.user .wc-meta { text-align:right; }
.wc-quick-replies { display:flex; gap:8px; flex-wrap:wrap; padding: 0 24px 12px; max-width:800px; width:100%; margin:0 auto; }
.quick-reply {
  padding: 8px 16px; border-radius: 20px; font-size: 12px; font-weight: 700;
  background: #FFFFFF; border: 1px solid rgba(124,58,237,0.2);
  color: var(--primary); cursor: pointer; transition: all 0.2s;
}
.quick-reply:hover { background: rgba(124,58,237,0.06); transform: translateY(-1px); }
.wc-input-area {
  padding: 16px 24px; border-top: 1px solid var(--border);
  background: rgba(255,255,255,0.9); backdrop-filter: blur(20px);
}
.wc-input-row { display:flex; gap:10px; max-width:800px; margin:0 auto; }
.wc-input {
  flex:1; background: rgba(0,0,0,0.04); border: 1px solid var(--border);
  border-radius: 14px; padding: 14px 18px; color: var(--text-primary);
  font-size: 14px; font-family: inherit; outline: none;
  transition: border-color 0.2s; resize:none; min-height:50px; max-height:120px;
}
.wc-input:focus { border-color: var(--border-accent); background: rgba(124,58,237,0.03); }
.wc-send {
  width: 50px; height: 50px; border-radius: 14px; background: var(--grad-primary);
  color: #fff; font-size: 18px; display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; flex-shrink:0;
}
.wc-send:hover { transform: scale(1.08); box-shadow: 0 4px 20px rgba(124,58,237,0.4); }
.wc-footer-note { text-align:center; font-size:11px; color:var(--text-muted); margin-top:8px; }
.crisis-alert-banner {
  background: rgba(220,38,38,0.08); border: 1px solid rgba(220,38,38,0.3);
  border-radius: 12px; padding: 14px 18px; margin: 0 24px;
  display: none;
}
.crisis-alert-banner.show { display: flex; align-items: center; gap: 12px; }
.crisis-alert-banner i { color: var(--crisis); font-size: 18px; }
.crisis-alert-text { flex:1; font-size:13px; font-weight:600; }
.crisis-call-btn { background: var(--crisis); color:#fff; padding:8px 16px; border-radius:8px; font-size:12px; font-weight:800; white-space:nowrap; }

/* ── FACILITIES MAP PAGE ────────────────────────────── */
.facilities-page { min-height:100vh; display:grid; grid-template-columns:380px 1fr; grid-template-rows: var(--nav-h) 1fr; }
.fac-sidebar {
  grid-column:1; grid-row:2; background: #FFFFFF;
  border-right: 1px solid var(--border); display:flex; flex-direction:column;
  overflow: hidden;
}
.fac-map-area { grid-column:2; grid-row:1/3; position:relative; }
.fac-nav { grid-column:1/3; grid-row:1; }
.fac-nav-bar {
  background: rgba(255,255,255,0.92) !important;
  backdrop-filter: blur(15px);
  border-bottom: 1px solid rgba(0,0,0,0.07) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.fac-sidebar-header {
  padding: 20px; border-bottom: 1px solid var(--border);
  background: #FFFFFF;
}
.fac-search {
  display: flex; gap: 8px; margin-top: 12px;
}
.fac-search input {
  flex:1; background: #F8FAFC; border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 14px; color: var(--text-primary);
  font-size: 13px; font-family: inherit; outline: none;
}
.fac-search input:focus { border-color: var(--border-accent); }
.fac-search button {
  width:40px; height:40px; border-radius:10px; background: var(--grad-primary);
  color:#fff; font-size:14px; display:flex; align-items:center; justify-content:center;
}
.fac-filters { display:flex; gap:6px; flex-wrap:wrap; padding: 12px 20px; border-bottom: 1px solid var(--border); }
.fac-filter-btn {
  padding: 5px 12px; border-radius: 6px; font-size: 11px; font-weight: 700;
  background: #F8FAFC; border: 1px solid var(--border); color: var(--text-secondary);
  cursor: pointer; transition: all 0.2s; text-transform:uppercase; letter-spacing:0.5px;
}
.fac-filter-btn.active { background: rgba(124,58,237,0.1); border-color: rgba(124,58,237,0.3); color: var(--primary); }
.fac-filter-btn.youth { background: rgba(16,185,129,0.08); border-color: rgba(16,185,129,0.25); color: var(--success); }
.fac-filter-btn.youth.active { background: rgba(16,185,129,0.15); }
.fac-list { flex:1; overflow-y:auto; padding:12px; display:flex; flex-direction:column; gap:8px; background: #FAFAFA; }
.fac-item {
  background: #FFFFFF; border: 1px solid var(--border);
  border-radius: 12px; padding: 14px; cursor: pointer; transition: all 0.2s;
}
.fac-item:hover { border-color: var(--border-accent); background: var(--bg-card-hover); }
.fac-item.selected { border-color: var(--primary); background: rgba(124,58,237,0.04); }
.fac-item-header { display:flex; align-items:flex-start; gap:10px; margin-bottom:8px; }
.fac-icon { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.fac-icon.hospital { background: rgba(239,68,68,0.10); color: var(--danger); }
.fac-icon.clinic { background: rgba(124,58,237,0.10); color: var(--primary); }
.fac-icon.health-centre { background: rgba(16,185,129,0.10); color: var(--success); }
.fac-name { font-size:13px; font-weight:700; line-height:1.3; }
.fac-type { font-size:10px; color: var(--text-muted); font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }
.fac-badges { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:8px; }
.badge-youth { background:rgba(16,185,129,0.10); border:1px solid rgba(16,185,129,0.25); color:var(--success); font-size:9px; font-weight:800; padding:2px 8px; border-radius:50px; display:flex; align-items:center; gap:4px; }
.badge-srhr { background:rgba(124,58,237,0.10); border:1px solid rgba(124,58,237,0.25); color:var(--primary); font-size:9px; font-weight:800; padding:2px 8px; border-radius:50px; }
.badge-pep { background:rgba(249,115,22,0.10); border:1px solid rgba(249,115,22,0.25); color:#ea580c; font-size:9px; font-weight:800; padding:2px 8px; border-radius:50px; }
.badge-prep { background:rgba(6,182,212,0.10); border:1px solid rgba(6,182,212,0.25); color:var(--accent); font-size:9px; font-weight:800; padding:2px 8px; border-radius:50px; }
.fac-stars { display:flex; gap:2px; align-items:center; }
.fac-stars i { font-size:11px; color:#ca8a04; }
.fac-stars .star-count { font-size:11px; color:var(--text-muted); margin-left:4px; font-weight:600; }
.fac-province { font-size:11px; color: var(--text-muted); display:flex; align-items:center; gap:4px; margin-top:6px; }
.fac-panel-overlay {
  position:absolute; bottom:0; left:0; right:0; z-index:500;
  background: rgba(255,255,255,0.98); border-top: 1px solid var(--border-accent);
  transform: translateY(100%); transition: transform 0.4s var(--ease);
  max-height: 60vh; overflow-y: auto; border-radius: 20px 20px 0 0;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.10);
}
.fac-panel-overlay.open { transform: translateY(0); }
.fac-panel { padding: 24px; }
.fac-panel-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:20px; }
.fac-panel-close { width:32px; height:32px; border-radius:8px; background:#F8FAFC; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-primary); font-size:14px; cursor:pointer; }
.fac-panel-name { font-size:20px; font-weight:900; margin-bottom:4px; }
.fac-panel-details { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:20px; }
.fac-detail-item { background:#F8FAFC; border:1px solid var(--border); border-radius:10px; padding:12px; }
.fac-detail-label { font-size:10px; color:var(--text-muted); font-weight:700; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:4px; }
.fac-detail-value { font-size:13px; font-weight:700; color:var(--text-primary); }
.review-section { margin-top:20px; }
.review-title { font-size:14px; font-weight:800; margin-bottom:12px; }
.review-list { display:flex; flex-direction:column; gap:10px; margin-bottom:16px; }
.review-item { background:#F8FAFC; border:1px solid var(--border); border-radius:10px; padding:12px; }
.review-stars { display:flex; gap:2px; margin-bottom:6px; }
.review-stars i { font-size:12px; color:#ca8a04; }
.review-text { font-size:12px; color:var(--text-secondary); line-height:1.5; }
.review-meta { font-size:10px; color:var(--text-muted); margin-top:6px; font-weight:600; }
.add-review { border-top:1px solid var(--border); padding-top:16px; }
.add-review-title { font-size:13px; font-weight:800; margin-bottom:12px; }
.star-picker { display:flex; gap:6px; margin-bottom:12px; }
.star-pick { font-size:22px; cursor:pointer; color:var(--text-muted); transition:color 0.15s; }
.star-pick.active { color:#ca8a04; }
.review-input {
  width:100%; background:rgba(0,0,0,0.03); border:1px solid var(--border);
  border-radius:10px; padding:10px 14px; color:var(--text-primary); font-size:13px;
  font-family:inherit; outline:none; resize:none; min-height:80px; margin-bottom:10px;
}
.review-input:focus { border-color: var(--border-accent); }
.submit-review {
  display:flex; width:100%; justify-content:center; padding:10px; border-radius:10px;
  background:var(--grad-primary); color:#fff; font-size:13px; font-weight:800;
}
#map { width:100%; height:100%; }
.leaflet-popup-content-wrapper { background: rgba(255,255,255,0.98) !important; border: 1px solid rgba(124,58,237,0.2) !important; border-radius: 14px !important; color: #111827 !important; box-shadow: 0 20px 60px rgba(0,0,0,0.12) !important; }
.leaflet-popup-tip { background: rgba(255,255,255,0.98) !important; }
.leaflet-popup-content { margin: 16px 18px !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.map-popup-name { font-size:15px; font-weight:800; margin-bottom:4px; }
.map-popup-type { font-size:11px; color:#4B5563; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:10px; }
.map-popup-badges { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:10px; }
.map-popup-btn { background: linear-gradient(135deg,#7C3AED,#A855F7); color:#fff; padding:8px 16px; border-radius:8px; font-size:12px; font-weight:700; width:100%; text-align:center; cursor:pointer; margin-top:8px; }
.fac-stats-bar { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-bottom:1px solid var(--border); background: #FFFFFF; }
.fac-stat { padding:14px 16px; text-align:center; border-right:1px solid var(--border); }
.fac-stat:last-child { border-right:none; }
.fac-stat-num { font-size:20px; font-weight:900; color: var(--text-primary); }
.fac-stat-label { font-size:10px; color:var(--text-muted); font-weight:700; text-transform:uppercase; letter-spacing:0.5px; }
@media(max-width:900px) { .facilities-page { grid-template-columns:1fr; grid-template-rows:var(--nav-h) auto 1fr; } .fac-sidebar { grid-column:1; grid-row:3; max-height:40vh; } .fac-map-area { grid-column:1; grid-row:2; height:50vh; } .fac-nav { grid-column:1; } }

/* ── LOGIN PAGE ─────────────────────────────────────── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background: var(--grad-hero); }
.login-card { width:100%; max-width:420px; background: rgba(255,255,255,0.92); border:1px solid rgba(124,58,237,0.15); border-radius:28px; padding:40px 36px; backdrop-filter:blur(20px); box-shadow: var(--shadow-glow); }
.login-logo { text-align:center; margin-bottom:32px; }
.login-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(124,58,237,0.08); border:1px solid rgba(124,58,237,0.18); color:var(--primary); padding:6px 16px; border-radius:50px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:1px; margin-bottom:16px; }
.login-title { font-size:28px; font-weight:900; letter-spacing:-0.03em; }
.login-sub { font-size:13px; color:var(--text-secondary); margin-top:6px; }
.form-group { margin-bottom:18px; }
.form-label { display:block; font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:var(--text-secondary); margin-bottom:8px; }
.form-input { width:100%; background:rgba(0,0,0,0.03); border:1px solid var(--border); border-radius:12px; padding:13px 16px; color:var(--text-primary); font-size:14px; font-family:inherit; outline:none; transition:border-color 0.2s; font-weight:600; }
.form-input:focus { border-color:var(--border-accent); background:rgba(124,58,237,0.02); }
.login-btn { width:100%; padding:15px; border-radius:12px; background:var(--grad-primary); color:#fff; font-size:14px; font-weight:800; display:flex; align-items:center; justify-content:center; gap:10px; transition:all 0.3s; box-shadow:var(--shadow-btn); }
.login-btn:hover { transform:translateY(-2px); box-shadow: 0 14px 40px rgba(124,58,237,0.4); }
.form-error { background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.25); color:#dc2626; padding:10px 14px; border-radius:10px; font-size:12px; font-weight:700; margin-bottom:16px; display:none; }
.form-divider { display:flex; align-items:center; gap:12px; margin:24px 0; color:var(--text-muted); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; }
.form-divider::before, .form-divider::after { content:''; flex:1; height:1px; background:var(--border); }

/* ── DASHBOARD ──────────────────────────────────────── */
.dash-page { display:grid; grid-template-columns: 260px 1fr; grid-template-rows: 64px 1fr; min-height:100vh; background:var(--bg-deep); }
.dash-nav { grid-column:1/3; grid-row:1; background:rgba(255,255,255,0.95); border-bottom:1px solid var(--border); display:flex; align-items:center; padding:0 24px; gap:20px; backdrop-filter:blur(20px); z-index:100; box-shadow: 0 2px 12px rgba(0,0,0,0.04); }
.dash-sidebar { grid-column:1; grid-row:2; background:#F8FAFC; border-right:1px solid var(--border); padding:20px 12px; display:flex; flex-direction:column; gap:4px; overflow-y:auto; }
.dash-content { grid-column:2; grid-row:2; overflow-y:auto; padding:28px; }
.sidebar-section { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); padding:8px 12px 4px; margin-top:12px; }
.sidebar-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:10px; cursor:pointer;
  transition:all 0.2s; color:var(--text-secondary); font-size:13px; font-weight:600;
}
.sidebar-item:hover { background:#FFFFFF; color:var(--text-primary); }
.sidebar-item.active { background:rgba(124,58,237,0.08); border:1px solid rgba(124,58,237,0.18); color:var(--primary); }
.sidebar-item i { width:18px; text-align:center; font-size:14px; }
.sidebar-badge { margin-left:auto; background:var(--danger); color:#fff; font-size:9px; font-weight:800; padding:2px 7px; border-radius:50px; }
.dash-title-bar { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; }
.dash-title { font-size:24px; font-weight:900; letter-spacing:-0.03em; }
.dash-subtitle { font-size:13px; color:var(--text-secondary); margin-top:4px; }
.kpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:28px; }
@media(max-width:1200px) { .kpi-grid { grid-template-columns:repeat(2,1fr); } }
.kpi-card { background:#FFFFFF; border:1px solid var(--border); border-radius:var(--radius-card); padding:22px; transition:all 0.3s; box-shadow: var(--shadow-card); }
.kpi-card:hover { border-color:var(--border-accent); transform:translateY(-2px); }
.kpi-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.kpi-icon { width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:18px; color:#fff; }
.kpi-trend { font-size:11px; font-weight:700; display:flex; align-items:center; gap:4px; }
.kpi-trend.up { color:var(--success); }
.kpi-trend.down { color:var(--danger); }
.kpi-num { font-size:32px; font-weight:900; letter-spacing:-0.04em; margin-bottom:4px; }
.kpi-label { font-size:12px; color:var(--text-secondary); font-weight:600; }
.dash-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
@media(max-width:1000px) { .dash-grid-2 { grid-template-columns:1fr; } }
.dash-panel { background:#FFFFFF; border:1px solid var(--border); border-radius:var(--radius-card); overflow:hidden; box-shadow: var(--shadow-card); }
.dash-panel-header { padding:18px 22px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; background:rgba(124,58,237,0.03); }
.dash-panel-title { font-size:14px; font-weight:800; }
.dash-panel-body { padding:20px 22px; }
.live-dot { width:8px; height:8px; background:var(--success); border-radius:50%; animation:pulse 2s infinite; }
.session-table { width:100%; border-collapse:collapse; }
.session-table th { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); padding:8px 10px; text-align:left; border-bottom:1px solid var(--border); }
.session-table td { padding:10px 10px; font-size:12px; font-weight:600; border-bottom:1px solid rgba(0,0,0,0.04); }
.risk-badge { padding:3px 8px; border-radius:50px; font-size:10px; font-weight:800; text-transform:uppercase; }
.risk-low { background:rgba(16,185,129,0.10); color:var(--success); }
.risk-medium { background:rgba(245,158,11,0.10); color:var(--warning); }
.risk-high { background:rgba(239,68,68,0.10); color:var(--danger); }
.risk-crisis { background:rgba(220,38,38,0.12); color:var(--crisis); animation:pulseRed 1s infinite; }
@keyframes pulseRed { 0%,100% { opacity:1; } 50% { opacity:0.6; } }
.intervene-btn { background:var(--danger); color:#fff; padding:4px 10px; border-radius:6px; font-size:10px; font-weight:800; cursor:pointer; transition:all 0.2s; }
.intervene-btn:hover { background:var(--crisis); }
.sentiment-chart { height:200px; position:relative; }
.heatmap-placeholder { background:rgba(124,58,237,0.04); border-radius:12px; height:220px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; border:1px dashed rgba(124,58,237,0.2); }
.heatmap-placeholder i { font-size:40px; color:var(--primary); opacity:0.4; }
.alert-feed { display:flex; flex-direction:column; gap:8px; }
.alert-item { display:flex; align-items:flex-start; gap:12px; padding:12px 14px; border-radius:10px; border-left:3px solid; }
.alert-item.crisis { background:rgba(220,38,38,0.06); border-color:var(--crisis); }
.alert-item.high { background:rgba(239,68,68,0.05); border-color:var(--danger); }
.alert-item.medium { background:rgba(245,158,11,0.05); border-color:var(--warning); }
.alert-item.info { background:rgba(6,182,212,0.05); border-color:var(--accent); }
.alert-icon { font-size:16px; flex-shrink:0; margin-top:1px; }
.alert-item.crisis .alert-icon { color:var(--crisis); }
.alert-item.high .alert-icon { color:var(--danger); }
.alert-item.medium .alert-icon { color:var(--warning); }
.alert-item.info .alert-icon { color:var(--accent); }
.alert-text { font-size:12px; color:var(--text-secondary); line-height:1.5; }
.alert-text strong { color:var(--text-primary); font-weight:800; display:block; margin-bottom:2px; }
.alert-time { font-size:10px; color:var(--text-muted); margin-left:auto; white-space:nowrap; flex-shrink:0; }
.counselor-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
@media(max-width:800px) { .counselor-grid { grid-template-columns:repeat(2,1fr); } .dash-page { grid-template-columns:1fr; } .dash-sidebar { display:none; } .dash-content { grid-column:1; } .dash-nav { grid-column:1; } }
.counselor-card { background:#FFFFFF; border:1px solid var(--border); border-radius:14px; padding:16px; text-align:center; box-shadow: var(--shadow-card); }
.cc-avatar { width:44px; height:44px; border-radius:14px; margin:0 auto 10px; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:14px; color:#fff; }
.cc-name { font-size:13px; font-weight:800; margin-bottom:2px; }
.cc-status { font-size:11px; display:flex; align-items:center; justify-content:center; gap:5px; }
.cc-status .dot { width:6px; height:6px; border-radius:50%; }
.cc-sessions { font-size:11px; color:var(--text-muted); margin-top:6px; font-weight:600; }

/* ════════════════════════════════════════════════════════════
   2030 UPGRADES — Stealth Mode, Low-Data, QR, Scorecard
   ════════════════════════════════════════════════════════════ */

/* ── STEALTH MODE ─────────────────────────────────────── */
#stealthOverlay {
  position:fixed; inset:0; z-index:99999; display:none;
  background:#FAFAFA; overflow-y:auto;
}
.stealth-page { font-family:'Georgia','Times New Roman',serif; color:#333; }
.stealth-nav {
  background:#fff; border-bottom:1px solid #e0e0e0; padding:16px 32px;
  display:flex; align-items:center; justify-content:space-between;
}
.stealth-logo {
  font-size:18px; font-weight:700; color:#2563EB; cursor:pointer;
}
.stealth-nav-links { display:flex; gap:24px; }
.stealth-nav-links a { color:#555; font-size:14px; font-weight:500; text-decoration:none; }
.stealth-nav-links a:hover { color:#2563EB; }
.stealth-content { max-width:960px; margin:0 auto; padding:40px 24px; }
.stealth-hero {
  background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:40px;
  margin-bottom:32px; text-align:center;
}
.stealth-hero h1 { font-size:28px; color:#1a1a1a; margin-bottom:12px; }
.stealth-hero p { font-size:15px; color:#666; max-width:600px; margin:0 auto; line-height:1.7; }
.stealth-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; }
.stealth-article {
  background:#fff; border:1px solid #e5e7eb; border-radius:10px; padding:24px;
  transition:box-shadow 0.2s;
}
.stealth-article:hover { box-shadow:0 4px 12px rgba(0,0,0,0.08); }
.stealth-thumb { font-size:36px; margin-bottom:12px; }
.stealth-article h3 { font-size:16px; color:#1a1a1a; margin-bottom:8px; }
.stealth-article p { font-size:13px; color:#666; line-height:1.6; }
.stealth-date { font-size:11px; color:#999; margin-top:8px; display:block; }
.stealth-footer-hint {
  text-align:center; margin-top:40px; padding:16px;
  background:#f0f0f0; border-radius:8px; color:#999; font-size:12px;
}
html.stealth-mode body > *:not(#stealthOverlay) { display:none !important; }
html.stealth-mode #stealthOverlay { display:block !important; }

/* ── LOW-DATA / LOAD-SHEDDING MODE ────────────────────── */
html.low-data-mode {
  --bg-deep: #F5F5F5;
  --bg-dark: #EBEBEB;
}
html.low-data-mode .hero-bg-orbs,
html.low-data-mode .orb,
html.low-data-mode video,
html.low-data-mode .hero-visual,
html.low-data-mode .chat-preview-card,
html.low-data-mode .trust-ribbon,
html.low-data-mode img:not(.qr-image):not([role="icon"]) {
  display:none !important;
}
html.low-data-mode .hero { grid-template-columns:1fr; min-height:auto; padding-bottom:40px; }
html.low-data-mode * { animation:none !important; transition:none !important; }
html.low-data-mode .nav { backdrop-filter:none; background:rgba(255,255,255,0.97); }
html.low-data-mode .btn-primary,
html.low-data-mode .btn-secondary { box-shadow:none; }
html.low-data-mode .kpi-card,
html.low-data-mode .dash-panel,
html.low-data-mode .service-card,
html.low-data-mode .step-card { backdrop-filter:none; }

.low-data-banner {
  display:flex; align-items:center; gap:10px;
  background:rgba(245,158,11,0.10); border:1px solid rgba(245,158,11,0.25);
  color:#d97706; padding:8px 16px; border-radius:8px;
  font-size:12px; font-weight:700; margin:0;
}

.offline-banner {
  display:flex; align-items:center; gap:10px;
  background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.25);
  color:#dc2626; padding:10px 16px; border-radius:8px;
  font-size:12px; font-weight:700;
}

/* ── QR REFERRAL CARD ─────────────────────────────────── */
.qr-referral-card {
  background:#FFFFFF; border:1px solid rgba(124,58,237,0.15);
  border-radius:var(--radius-card); overflow:hidden;
  box-shadow: 0 8px 32px rgba(124,58,237,0.10);
  animation: msgSlide 0.4s var(--ease);
}
.qr-header {
  display:flex; align-items:center; gap:12px;
  padding:16px 20px; background:rgba(124,58,237,0.05);
  border-bottom:1px solid var(--border);
}
.qr-icon {
  width:40px; height:40px; border-radius:12px;
  background:var(--grad-primary); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:18px;
}
.qr-title { font-size:14px; font-weight:800; }
.qr-sub { font-size:11px; color:var(--text-muted); font-weight:600; }
.qr-body { padding:20px; text-align:center; }
.qr-image-wrap {
  width:180px; height:180px; margin:0 auto 16px;
  background:#F8FAFC; border-radius:16px;
  padding:12px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
}
.qr-image { width:100%; height:100%; object-fit:contain; border-radius:8px; }
.qr-code-text {
  font-family:monospace; font-size:16px; font-weight:900;
  color:var(--primary); letter-spacing:2px; margin-bottom:8px;
}
.qr-facility { font-size:14px; font-weight:700; margin-bottom:2px; }
.qr-district { font-size:12px; color:var(--text-muted); font-weight:600; margin-bottom:4px; }
.qr-topic { font-size:11px; color:var(--accent); font-weight:700; text-transform:uppercase; letter-spacing:0.5px; }
.qr-footer {
  padding:14px 20px; border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.qr-privacy { font-size:10px; color:var(--success); font-weight:700; display:flex; align-items:center; gap:6px; }
.qr-actions { display:flex; gap:8px; }
.qr-btn {
  padding:6px 14px; border-radius:8px; font-size:11px; font-weight:700;
  background:#F8FAFC; border:1px solid var(--border); color:var(--text-primary);
  cursor:pointer; transition:all 0.2s; display:flex; align-items:center; gap:5px;
}
.qr-btn:hover { border-color:var(--border-accent); background:var(--bg-card-hover); }

/* ── ACCOUNTABILITY SCORECARD ────────────────────────── */
.scorecard-section { margin-top:24px; border-top:1px solid var(--border); padding-top:20px; }
.scorecard-title {
  font-size:14px; font-weight:800; margin-bottom:16px;
  display:flex; align-items:center; gap:8px;
}
.scorecard-title i { color:var(--accent-warm); }
.scorecard-grid { display:flex; flex-direction:column; gap:10px; }
.scorecard-item {
  display:flex; align-items:center; gap:12px;
  background:#F8FAFC; border:1px solid var(--border); border-radius:10px; padding:12px 14px;
}
.scorecard-metric {
  flex:1; font-size:12px; font-weight:700;
}
.scorecard-bar-wrap {
  flex:2; height:8px; background:rgba(0,0,0,0.06); border-radius:50px; overflow:hidden;
}
.scorecard-bar {
  height:100%; border-radius:50px; transition:width 0.8s var(--ease);
}
.scorecard-bar.excellent { background:var(--success); }
.scorecard-bar.good { background:var(--accent); }
.scorecard-bar.fair { background:var(--warning); }
.scorecard-bar.poor { background:var(--danger); }
.scorecard-score {
  font-size:13px; font-weight:900; min-width:36px; text-align:right;
}
.scorecard-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; border-radius:50px; font-size:11px; font-weight:800;
  margin-top:12px;
}
.scorecard-badge.gold { background:rgba(245,158,11,0.12); border:1px solid rgba(245,158,11,0.25); color:#d97706; }
.scorecard-badge.silver { background:rgba(148,163,184,0.12); border:1px solid rgba(148,163,184,0.25); color:#64748B; }
.scorecard-badge.bronze { background:rgba(249,115,22,0.12); border:1px solid rgba(249,115,22,0.25); color:#ea580c; }
.scorecard-badge.needs-improvement { background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.25); color:var(--danger); }

.scorecard-submit {
  display:flex; width:100%; padding:10px; border-radius:10px; justify-content:center;
  background:var(--grad-cyan); color:#fff; font-size:12px; font-weight:800;
  margin-top:12px; cursor:pointer; transition:all 0.2s;
}
.scorecard-submit:hover { transform:translateY(-1px); }

/* ── BROADCAST PUSH PANEL ─────────────────────────────── */
.broadcast-modal {
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,0.4); backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
}
.broadcast-modal.open { display:flex; }
.broadcast-card {
  background:#FFFFFF; border:1px solid rgba(124,58,237,0.15);
  border-radius:24px; padding:32px; max-width:480px; width:90%;
  box-shadow:0 20px 60px rgba(0,0,0,0.12);
}
.broadcast-title { font-size:18px; font-weight:900; margin-bottom:4px; }
.broadcast-sub { font-size:13px; color:var(--text-secondary); margin-bottom:20px; }
.broadcast-textarea {
  width:100%; min-height:100px; background:rgba(0,0,0,0.03);
  border:1px solid var(--border); border-radius:12px; padding:14px;
  color:var(--text-primary); font-size:13px; font-family:inherit;
  outline:none; resize:vertical; margin-bottom:12px;
}
.broadcast-textarea:focus { border-color:var(--border-accent); }
.broadcast-options { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.broadcast-opt {
  padding:6px 14px; border-radius:8px; font-size:11px; font-weight:700;
  background:#F8FAFC; border:1px solid var(--border); color:var(--text-secondary);
  cursor:pointer; transition:all 0.2s;
}
.broadcast-opt.active { border-color:rgba(124,58,237,0.25); color:var(--primary); background:rgba(124,58,237,0.06); }
.broadcast-actions { display:flex; gap:10px; justify-content:flex-end; }
.broadcast-cancel {
  padding:10px 20px; border-radius:10px; font-size:13px; font-weight:700;
  background:#F8FAFC; border:1px solid var(--border); color:var(--text-secondary);
  cursor:pointer;
}
.broadcast-send {
  padding:10px 24px; border-radius:10px; font-size:13px; font-weight:800;
  background:var(--grad-success); color:#fff; cursor:pointer;
  display:flex; align-items:center; gap:8px;
}

/* ── CRISIS BANNER 2.0 — One-Tap Call ─────────────────── */
.crisis-banner-v2 {
  position:fixed; bottom:0; left:0; right:0; z-index:9990;
  background:rgba(220,38,38,0.96);
  backdrop-filter:blur(10px); padding:14px 24px;
  display:none; align-items:center; gap:16px;
  border-top:2px solid #DC2626;
  animation: slideUpBanner 0.4s var(--ease);
}
.crisis-banner-v2.show { display:flex; }
@keyframes slideUpBanner { from { transform:translateY(100%); } to { transform:translateY(0); } }
.crisis-banner-v2 .cb-icon { font-size:24px; animation:pulseRed 1s infinite; }
.crisis-banner-v2 .cb-text { flex:1; font-size:13px; font-weight:700; color:#fff; }
.crisis-banner-v2 .cb-text strong { font-size:14px; display:block; margin-bottom:2px; }
.cb-call-btns { display:flex; gap:8px; }
.cb-call-btn {
  padding:10px 18px; border-radius:10px; font-size:12px; font-weight:800;
  color:#fff; display:flex; align-items:center; gap:6px;
  text-decoration:none; white-space:nowrap; transition:transform 0.2s;
}
.cb-call-btn:hover { transform:scale(1.05); }
.cb-call-btn.police { background:rgba(255,255,255,0.2); }
.cb-call-btn.crisis { background:rgba(255,255,255,0.3); }
.cb-call-btn.ambulance { background:rgba(255,255,255,0.15); }

/* ── MAP LOADING ──────────────────────────────────────── */
#mapLoading {
  position:absolute; inset:0; z-index:400;
  background:var(--bg-deep); display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:16px;
}
#mapLoading .spinner {
  width:40px; height:40px; border:3px solid var(--border);
  border-top-color:var(--primary); border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── FACILITY COUNT BADGE ─────────────────────────────── */
.facility-count-badge {
  position:absolute; top:12px; right:12px; z-index:600;
  background:#FFFFFF; border:1px solid rgba(124,58,237,0.2);
  border-radius:50px; padding:8px 16px;
  font-size:12px; font-weight:700; color:var(--primary);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}

/* ── IMPACT GRID ──────────────────────────────────────── */
.impact-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
@media(max-width:900px) { .impact-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .impact-grid { grid-template-columns: 1fr; } }
.impact-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px; text-align: center;
  transition: all 0.3s var(--ease); box-shadow: var(--shadow-card);
}
.impact-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
.impact-icon {
  width: 56px; height: 56px; border-radius: 16px; margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center; font-size: 24px; color: #fff;
}
.impact-num { font-size: 36px; font-weight: 900; letter-spacing: -0.04em; margin-bottom: 4px; color: var(--text-primary); }
.impact-label { font-size: 13px; font-weight: 800; color: var(--text-primary); margin-bottom: 8px; }
.impact-desc { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }

/* ── TESTIMONIALS ─────────────────────────────────────── */
.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media(max-width:900px) { .testimonial-grid { grid-template-columns: 1fr; } }
.testimonial-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px;
  transition: all 0.3s var(--ease); box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
}
.testimonial-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); }
.testimonial-quote { flex: 1; margin-bottom: 20px; }
.testimonial-quote p { font-size: 14px; color: var(--text-secondary); line-height: 1.7; margin-top: 12px; font-style: italic; }
.testimonial-author {
  display: flex; align-items: center; gap: 12px;
  padding-top: 16px; border-top: 1px solid rgba(0,0,0,0.06);
}
.testimonial-author img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.ta-name { font-size: 13px; font-weight: 800; }
.ta-location { font-size: 11px; color: var(--text-muted); font-weight: 600; }

/* ── FEATURE SHOWCASE ─────────────────────────────────── */
.features-showcase { display: flex; flex-direction: column; gap: 40px; }
.feature-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
  align-items: center; background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: 24px; padding: 0; overflow: hidden; box-shadow: var(--shadow-card);
  transition: all 0.3s var(--ease);
}
.feature-row:hover { border-color: rgba(124,58,237,0.2); box-shadow: 0 12px 40px rgba(0,0,0,0.08); }
.feature-row.reverse { direction: rtl; }
.feature-row.reverse > * { direction: ltr; }
.feature-img { height: 100%; min-height: 280px; overflow: hidden; }
.feature-content { padding: 36px; }
.feature-badge {
  display: inline-block; font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; padding: 4px 12px; border-radius: 50px;
  background: rgba(124,58,237,0.08); border: 1px solid rgba(124,58,237,0.18);
  color: var(--primary); margin-bottom: 12px;
}
.feature-content h3 { font-size: 22px; font-weight: 900; margin-bottom: 12px; letter-spacing: -0.02em; }
.feature-content p { font-size: 14px; color: var(--text-secondary); line-height: 1.7; margin-bottom: 20px; }
.feature-specs { display: flex; flex-wrap: wrap; gap: 12px; }
.feature-specs span {
  font-size: 12px; font-weight: 700; color: var(--text-secondary);
  display: flex; align-items: center; gap: 6px;
}
.feature-specs i { color: var(--success); font-size: 12px; }
@media(max-width:768px) {
  .feature-row, .feature-row.reverse { grid-template-columns: 1fr; direction: ltr; }
  .feature-row.reverse > * { direction: ltr; }
  .feature-img { min-height: 200px; }
}

/* ── CONTENT PAGE LAYOUT ──────────────────────────────── */
.content-page { padding-top: calc(var(--nav-h) + 40px); min-height: 100vh; background: var(--bg-deep); }
.page-hero {
  text-align: center; padding: 60px 24px 40px;
  background: var(--grad-hero); position: relative; overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(124,58,237,0.06) 0%, transparent 60%);
}
.page-hero .section-label, .page-hero .section-title, .page-hero .section-desc {
  position: relative; z-index: 1;
}
.page-hero .section-desc { margin: 0 auto 32px; }
.content-body { max-width: 1200px; margin: 0 auto; padding: 48px 24px 80px; }

/* Resource Cards */
.resource-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media(max-width:900px) { .resource-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .resource-grid { grid-template-columns: 1fr; } }
.resource-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); overflow: hidden;
  transition: all 0.3s var(--ease); cursor: pointer; box-shadow: var(--shadow-card);
}
.resource-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
.resource-card-img { width: 100%; height: 180px; object-fit: cover; }
.resource-card-body { padding: 20px; }
.resource-card-body h3 { font-size: 16px; font-weight: 800; margin-bottom: 8px; }
.resource-card-body p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 14px; }
.resource-tag {
  display: inline-block; font-size: 10px; font-weight: 700; text-transform: uppercase;
  padding: 3px 10px; border-radius: 50px; margin-right: 6px;
  background: rgba(124,58,237,0.06); border: 1px solid rgba(124,58,237,0.15); color: var(--primary);
}

/* FAQ Accordion */
.faq-section { margin-bottom: 40px; }
.faq-section-title {
  font-size: 18px; font-weight: 900; margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px; color: var(--text-primary);
}
.faq-item {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: 14px; margin-bottom: 10px; overflow: hidden;
  box-shadow: var(--shadow-card); transition: all 0.2s;
}
.faq-item:hover { border-color: rgba(124,58,237,0.15); }
.faq-question {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px; cursor: pointer; font-size: 14px; font-weight: 700;
  color: var(--text-primary); transition: color 0.2s; gap: 12px;
}
.faq-question:hover { color: var(--primary); }
.faq-question i { font-size: 14px; color: var(--text-muted); transition: transform 0.3s; flex-shrink: 0; }
.faq-item.open .faq-question i { transform: rotate(180deg); color: var(--primary); }
.faq-answer {
  display: none; padding: 0 20px 18px; font-size: 13px;
  color: var(--text-secondary); line-height: 1.7;
}
.faq-item.open .faq-answer { display: block; }

/* Partner / About Cards */
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media(max-width:900px) { .team-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .team-grid { grid-template-columns: 1fr; } }
.team-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 24px; text-align: center;
  transition: all 0.3s var(--ease); box-shadow: var(--shadow-card);
}
.team-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); }
.team-card img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; border: 3px solid rgba(124,58,237,0.15); }
.team-card h4 { font-size: 14px; font-weight: 800; margin-bottom: 4px; }
.team-card .role { font-size: 11px; color: var(--primary); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; }

.partner-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media(max-width:900px) { .partner-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:500px) { .partner-grid { grid-template-columns: 1fr; } }
.partner-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); padding: 28px; text-align: center;
  transition: all 0.3s var(--ease); box-shadow: var(--shadow-card);
}
.partner-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); }
.partner-card .partner-logo { font-size: 36px; margin-bottom: 12px; }
.partner-card h4 { font-size: 14px; font-weight: 800; margin-bottom: 6px; }
.partner-card p { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }

/* Story cards */
.story-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media(max-width:700px) { .story-grid { grid-template-columns: 1fr; } }
.story-card {
  background: #FFFFFF; border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-card); overflow: hidden;
  transition: all 0.3s var(--ease); box-shadow: var(--shadow-card);
  display: grid; grid-template-columns: 200px 1fr;
}
.story-card:hover { border-color: rgba(124,58,237,0.2); transform: translateY(-4px); }
.story-card-img { width: 100%; height: 100%; object-fit: cover; min-height: 200px; }
.story-card-body { padding: 24px; display: flex; flex-direction: column; }
.story-card-body h3 { font-size: 16px; font-weight: 800; margin-bottom: 8px; }
.story-card-body p { font-size: 13px; color: var(--text-secondary); line-height: 1.7; flex: 1; }
.story-meta { margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(0,0,0,0.06); font-size: 11px; color: var(--text-muted); font-weight: 600; display: flex; gap: 16px; }
@media(max-width:500px) { .story-card { grid-template-columns: 1fr; } .story-card-img { height: 180px; } }

/* Timeline */
.timeline { position: relative; padding-left: 28px; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: rgba(124,58,237,0.15); }
.timeline-item { position: relative; margin-bottom: 32px; }
.timeline-dot { position: absolute; left: -24px; top: 4px; width: 12px; height: 12px; border-radius: 50%; background: var(--grad-primary); border: 2px solid #fff; box-shadow: 0 0 0 3px rgba(124,58,237,0.15); }
.timeline-item h4 { font-size: 15px; font-weight: 800; margin-bottom: 4px; }
.timeline-item .timeline-date { font-size: 11px; color: var(--primary); font-weight: 700; margin-bottom: 8px; }
.timeline-item p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; }

/* ── RESPONSIVE FIXES ─────────────────────────────────── */
@media(max-width:600px) {
  .cb-call-btns { flex-direction:column; gap:4px; }
  .qr-footer { flex-direction:column; gap:8px; }
  .scorecard-item { flex-direction:column; align-items:stretch; gap:6px; }
  .broadcast-card { padding:24px; }
}
