/* ════════════════════════════════════════════════════════════
   inДія — Mughal Manuscript × Diwali Night
   Premium dark theme for Indian immigrants in Ukraine
   ════════════════════════════════════════════════════════════ */

/* ─── Fonts ─── */
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT@0,9..144,300..700,0..100;1,9..144,300..700,0..100&family=Tiro+Devanagari+Hindi:ital@0;1&family=Manrope:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;700&family=Cinzel+Decorative:wght@400;700;900&display=swap");

/* ─── Tokens ─── */
:root{
  /* Surface — Mughal night sky */
  --bg-deep:    #0c0820;
  --bg-paper:   #15102e;
  --bg-velvet:  #1e1742;
  --bg-elev:    #251a52;

  /* Jewel accents */
  --marigold:   #f4a528;
  --marigold-2: #f7c053;
  --vermillion: #e63946;
  --sindoor:    #c4361f;
  --gold:       #d4a256;
  --gold-2:     #b7894a;
  --gold-glow:  #f4d27a;
  --peacock:    #4ec5b5;
  --ivory:      #f5ecd6;

  /* Text */
  --text-1: #f3e8c8;   /* warm ivory headings */
  --text-2: #c4b89a;   /* muted gold body */
  --text-3: #8a7d65;   /* dim subtitles */
  --text-4: #5d543f;   /* faint */

  /* Borders */
  --line-gold: rgba(212,162,86,.32);
  --line-dim:  rgba(212,162,86,.14);
  --line-bright: rgba(244,210,122,.5);

  /* Glow */
  --glow-marigold: 0 0 28px rgba(244,165,40,.35);
  --glow-vermillion: 0 0 32px rgba(230,57,70,.45);
  --glow-gold: 0 0 18px rgba(212,162,86,.45);

  /* Shadows */
  --shad-1: 0 4px 14px rgba(0,0,0,.35);
  --shad-2: 0 8px 24px rgba(0,0,0,.45), 0 1px 0 rgba(244,210,122,.06) inset;
  --shad-deep: 0 12px 40px rgba(0,0,0,.5), 0 0 0 1px rgba(244,210,122,.06) inset;

  /* Type */
  --display: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --hindi: "Tiro Devanagari Hindi", "Noto Serif Devanagari", serif;
  --body: "Manrope", system-ui, sans-serif;
  --mono: "JetBrains Mono", "SF Mono", Consolas, monospace;
  --ornament: "Cinzel Decorative", "Fraunces", serif;

  /* Radii */
  --r-xs:6px; --r-sm:10px; --r-md:16px; --r-lg:22px; --r-xl:30px;
  --r-arch:50% 50% 18px 18px / 90px 90px 18px 18px;  /* Mughal arch */

  /* Layout */
  --tabbar-h: calc(76px + env(safe-area-inset-bottom));
  --raid-h: 36px;
}

/* ─── Reset ─── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
[hidden]{display:none !important}
html,body{height:100%;overscroll-behavior-y:contain}
button{font:inherit;border:0;background:0;cursor:pointer;color:inherit;-webkit-tap-highlight-color:transparent}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
input,textarea{user-select:text;font:inherit}
img,svg{display:block;max-width:100%}

/* ─── Scrollbars — gold, subtle, intuitive ─── */
*{scrollbar-width:thin;scrollbar-color:rgba(212,162,86,.35) transparent}
*::-webkit-scrollbar{width:4px;height:4px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:rgba(212,162,86,.35);border-radius:4px}
*::-webkit-scrollbar-thumb:hover{background:rgba(244,210,122,.6)}
*::-webkit-scrollbar-corner{background:transparent}
html,body{scrollbar-width:none}
html::-webkit-scrollbar,body::-webkit-scrollbar{width:0;height:0;display:none}

body{
  font-family:var(--body);
  font-size:15px;line-height:1.5;
  color:var(--text-1);
  background:var(--bg-deep);
  user-select:none;
  overflow-x:hidden;
  /* Atmospheric base: deep night + warm diya glow corners */
  background-image:
    radial-gradient(60% 40% at 8% 0%, rgba(244,165,40,.12) 0%, transparent 70%),
    radial-gradient(45% 35% at 100% 25%, rgba(230,57,70,.08) 0%, transparent 65%),
    radial-gradient(55% 50% at 50% 100%, rgba(78,197,181,.06) 0%, transparent 70%),
    linear-gradient(180deg, #0c0820 0%, #15102e 50%, #0c0820 100%);
  background-attachment:fixed;
}

/* Subtle grain overlay across whole app */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(244,210,122,.03) 1px, transparent 2px),
    radial-gradient(circle at 70% 60%, rgba(244,210,122,.025) 1px, transparent 2px);
  background-size:14px 14px, 22px 22px;
  opacity:.7;
  mix-blend-mode:screen;
}

/* Faint mandala backdrop */
body::after{
  content:"";position:fixed;top:-150px;right:-150px;width:480px;height:480px;
  pointer-events:none;z-index:0;opacity:.04;
  background:
    repeating-conic-gradient(from 0deg, transparent 0deg 10deg, var(--gold) 10deg 11deg),
    radial-gradient(circle, transparent 30%, var(--gold) 31%, var(--gold) 32%, transparent 33%),
    radial-gradient(circle, transparent 50%, var(--gold) 51%, var(--gold) 52%, transparent 53%);
  border-radius:50%;
  animation:mandalaSpin 240s linear infinite;
}
@keyframes mandalaSpin{to{transform:rotate(360deg)}}

/* ─── Typography ─── */
h1,h2,h3{font-family:var(--display);font-weight:400;font-variation-settings:"opsz" 144, "SOFT" 50;letter-spacing:-.01em;line-height:1.05;color:var(--text-1)}
.t-hi{font-family:var(--hindi);font-weight:400}
.t-display{font-family:var(--display);font-variation-settings:"opsz" 144, "SOFT" 100;font-style:italic;font-weight:400}
.t-ornament{font-family:var(--ornament);font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.t-mono{font-family:var(--mono);font-feature-settings:"ss01","cv01"}

/* ─── App container ─── */
.app{
  position:relative;z-index:2;
  min-height:100vh;
  padding-top:env(safe-area-inset-top);
  padding-bottom:var(--tabbar-h);
}
.app.has-raid{padding-top:calc(env(safe-area-inset-top) + var(--raid-h))}

/* ═══════════════════════════════════════════════
   RAID BAR — "Status of the Sky"
   ═══════════════════════════════════════════════ */
.raid-bar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  height:var(--raid-h);
  padding:0 16px;padding-top:env(safe-area-inset-top);
  display:flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  border-bottom:1px solid var(--line-gold);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.raid-bar--silent{
  background:linear-gradient(180deg, rgba(20,40,30,.85), rgba(12,8,32,.9));
  color:var(--peacock);
}
.raid-bar--alert{
  background:linear-gradient(180deg, rgba(120,20,30,.95), rgba(60,8,16,.95));
  color:#fff;
  animation:raidPulse 1.4s ease-in-out infinite;
}
.raid-dot{
  width:8px;height:8px;border-radius:50%;background:currentColor;
  box-shadow:0 0 12px currentColor;
}
.raid-bar--alert .raid-dot{animation:raidBlink .55s ease-in-out infinite}
.raid-region{margin-left:auto;opacity:.75;font-weight:500;letter-spacing:.1em}
.raid-bar{text-decoration:none}
.raid-go{
  margin-left:6px;font-size:18px;font-weight:400;line-height:1;
  opacity:.55;transition:opacity .2s, transform .2s;
}
.raid-bar:hover .raid-go,.raid-bar:active .raid-go{opacity:1;transform:translateX(2px)}
@keyframes raidPulse{0%,100%{box-shadow:inset 0 0 0 rgba(230,57,70,0)}50%{box-shadow:inset 0 -20px 40px rgba(230,57,70,.4)}}
@keyframes raidBlink{0%,100%{opacity:1}50%{opacity:.25}}

/* ═══════════════════════════════════════════════
   ALERT ACTION CARDS — home tab quick access
   ═══════════════════════════════════════════════ */
.alert-cards{
  display:grid;grid-template-columns:1fr;gap:10px;
  margin:6px 16px 0;
}
.alert-card{
  display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:12px;align-items:center;
  padding:14px 14px;border-radius:var(--r-md);
  text-decoration:none;color:var(--text-1);font-family:var(--body);
  border:1px solid var(--line-gold);
  background:linear-gradient(135deg, rgba(30,23,66,.7), rgba(20,15,40,.85));
  box-shadow:var(--shad-2);
  transition:transform .15s ease, border-color .25s, background .25s;
  position:relative;overflow:hidden;
}
.alert-card:active{transform:scale(.985)}
.alert-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 0% 0%, rgba(244,210,122,.06), transparent 60%);
  pointer-events:none;
}
.alert-card--hot{
  background:linear-gradient(135deg, rgba(140,30,40,.55), rgba(60,10,20,.85));
  border-color:rgba(230,57,70,.55);
  animation:cardPulse 1.6s ease-in-out infinite;
}
.alert-card--cool{border-color:rgba(78,197,181,.35)}
.alert-card--shelter{border-color:rgba(244,165,40,.4)}
.ac-ic{font-size:30px;line-height:1;text-align:center}
.ac-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.ac-hi{font-family:var(--hindi);font-size:17px;font-weight:400;color:#fff;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ac-sub{font-size:11px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}
.alert-card--hot .ac-sub{color:#f7c053}
.ac-arrow{font-size:22px;color:var(--gold);opacity:.65;font-weight:300}
@keyframes cardPulse{0%,100%{box-shadow:0 8px 24px rgba(0,0,0,.45),0 0 0 rgba(230,57,70,0)}50%{box-shadow:0 8px 24px rgba(0,0,0,.45),0 0 24px rgba(230,57,70,.45)}}

/* ═══════════════════════════════════════════════
   RAID MAP view — schematic map + active list
   ═══════════════════════════════════════════════ */
.raid-head{
  position:sticky;top:0;z-index:5;
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;
  padding:14px 14px 10px;
  background:linear-gradient(180deg, rgba(15,10,38,.95), rgba(12,8,32,.75));
  border-bottom:1px solid var(--line-dim);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.raid-close{
  width:36px;height:36px;border-radius:50%;
  background:rgba(244,210,122,.08);border:1px solid var(--line-gold);
  color:var(--gold);font-size:22px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.raid-close:active{transform:scale(.92)}
.raid-title{min-width:0;display:flex;flex-direction:column;gap:2px}
.raid-sub{font-family:var(--ornament);font-size:10px;letter-spacing:.22em;color:var(--marigold)}
.raid-title h2{font-family:var(--display);font-size:22px;line-height:1.1;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.raid-title h2 small{font-family:var(--body);font-size:11px;letter-spacing:.16em;color:var(--text-3);text-transform:uppercase;font-weight:400}
.hl-alert{color:#fff}
.hl-quiet{color:var(--peacock)}
.raid-bar-update{
  grid-column:1 / -1;
  height:2px;background:var(--line-dim);border-radius:2px;overflow:hidden;
}
.raid-bar-update span{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg, var(--marigold), var(--gold-glow));
}
.raid-bar-update.running span{animation:raidProgress 60s linear forwards}
@keyframes raidProgress{0%{width:0}100%{width:100%}}

.raid-canvas-wrap{
  position:relative;
  margin:14px 16px 0;
  border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line-gold);
  background:
    radial-gradient(120% 80% at 50% 30%, rgba(70,40,110,.45), transparent 60%),
    radial-gradient(60% 50% at 80% 90%, rgba(230,120,70,.18), transparent 70%),
    radial-gradient(50% 60% at 15% 75%, rgba(78,197,181,.12), transparent 70%),
    linear-gradient(180deg, #15102e, #0a0720 90%);
  box-shadow:var(--shad-2), inset 0 0 60px rgba(244,210,122,.06);
  touch-action:pan-y;
}
/* parchment grain */
.raid-canvas-wrap::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 .82 0 0 0 0 .48 0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.18'/></svg>");
  mix-blend-mode:overlay;opacity:.55;
}
/* mughal corner ornaments */
.raid-canvas-wrap::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:3;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' fill='none' stroke='%23d4a256' stroke-width='1' opacity='.7'><path d='M2 14 Q2 2 14 2 M20 2 Q14 2 12 8 Q10 12 6 14 M2 20 Q2 14 8 12 Q12 10 14 6'/><circle cx='8' cy='8' r='1.2' fill='%23f4d27a'/></svg>") top left / 44px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' fill='none' stroke='%23d4a256' stroke-width='1' opacity='.7' transform='scale(-1,1)'><path d='M2 14 Q2 2 14 2 M20 2 Q14 2 12 8 Q10 12 6 14 M2 20 Q2 14 8 12 Q12 10 14 6'/><circle cx='8' cy='8' r='1.2' fill='%23f4d27a'/></svg>") top right / 44px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' fill='none' stroke='%23d4a256' stroke-width='1' opacity='.7' transform='scale(1,-1)'><path d='M2 14 Q2 2 14 2 M20 2 Q14 2 12 8 Q10 12 6 14 M2 20 Q2 14 8 12 Q12 10 14 6'/><circle cx='8' cy='8' r='1.2' fill='%23f4d27a'/></svg>") bottom left / 44px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' fill='none' stroke='%23d4a256' stroke-width='1' opacity='.7' transform='scale(-1,-1)'><path d='M2 14 Q2 2 14 2 M20 2 Q14 2 12 8 Q10 12 6 14 M2 20 Q2 14 8 12 Q12 10 14 6'/><circle cx='8' cy='8' r='1.2' fill='%23f4d27a'/></svg>") bottom right / 44px no-repeat;
}
.raid-canvas{height:60vh;min-height:340px;background:transparent;position:relative;z-index:1}
.raid-canvas .leaflet-container{background:transparent !important;font-family:var(--body)}
.raid-canvas .leaflet-tile-pane{display:none !important}
.raid-canvas .leaflet-control-attribution{display:none !important}

/* legend chip — compass rose / N marker, top-right inside canvas */
.raid-compass{
  position:absolute;top:10px;right:10px;z-index:4;pointer-events:none;
  width:44px;height:44px;border-radius:50%;
  background:radial-gradient(circle, rgba(15,10,38,.85), rgba(15,10,38,.4));
  border:1px solid var(--line-gold);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ornament);font-size:9px;letter-spacing:.18em;color:var(--gold);
}
.raid-compass::before{
  content:"";position:absolute;top:3px;left:50%;width:1px;height:8px;
  background:linear-gradient(180deg, var(--marigold), transparent);
  transform:translateX(-50%);
}
/* legend chip */
.raid-legend{
  position:absolute;bottom:10px;left:10px;z-index:4;pointer-events:none;
  display:flex;gap:10px;align-items:center;
  padding:6px 10px;border-radius:20px;
  background:rgba(12,8,32,.7);border:1px solid var(--line-dim);
  backdrop-filter:blur(8px);
  font-family:var(--body);font-size:10px;letter-spacing:.08em;color:var(--text-2);
}
.raid-legend .lg-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;vertical-align:middle}
.raid-legend .lg-hot{background:#e63946;box-shadow:0 0 6px rgba(230,57,70,.8)}
.raid-legend .lg-cool{background:#5a4d8c}

.raid-canvas-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(12,8,32,.55);backdrop-filter:blur(2px);z-index:5;
  color:var(--text-2);font-family:var(--body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
}

/* active oblast pulse — multi-layer */
.rc-alert{animation:rcPulse 1.4s ease-in-out infinite}
@keyframes rcPulse{
  0%,100%{filter:drop-shadow(0 0 4px rgba(230,57,70,.55))}
  50%{filter:drop-shadow(0 0 16px rgba(244,90,80,1)) drop-shadow(0 0 4px rgba(255,200,100,.6))}
}
.rc-halo{animation:rcHalo 2.2s ease-out infinite;transform-origin:center}
@keyframes rcHalo{
  0%{opacity:.6;stroke-width:1}
  100%{opacity:0;stroke-width:.4}
}
.rc-halo2{animation:rcHalo 2.2s ease-out .8s infinite;transform-origin:center}

/* capital labels (divIcon) */
.rc-cap{
  font-family:var(--hindi);font-size:11px;color:#fff;
  text-shadow:0 0 4px rgba(230,57,70,.9), 0 1px 2px rgba(0,0,0,.9);
  white-space:nowrap;pointer-events:none;
  transform:translate(8px, -6px);font-weight:600;
}
.rc-cap small{display:block;font-family:var(--body);font-size:8px;letter-spacing:.1em;color:var(--gold);opacity:.85;text-transform:uppercase;font-weight:400;text-shadow:0 1px 2px rgba(0,0,0,.9)}

.raid-tip{
  background:rgba(20,15,40,.95) !important;color:var(--text-1) !important;
  border:1px solid var(--line-gold) !important;border-radius:8px !important;
  font-family:var(--body) !important;font-size:11px !important;
  padding:6px 10px !important;
}
.raid-tip .rt-hi{font-family:var(--hindi);font-size:13px;color:#fff}
.raid-tip .rt-ua{font-size:10px;color:var(--text-3)}
.raid-tip::before{display:none !important}

.raid-meta{
  margin:10px 16px 0;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--body);font-size:11px;color:var(--text-3);letter-spacing:.1em;
}
.rm-source{text-transform:uppercase}
.rm-time{color:var(--gold);font-family:var(--mono);font-size:11px}

.raid-list{margin:14px 16px 28px}
.rl-head{
  font-family:var(--ornament);font-size:11px;letter-spacing:.22em;
  color:var(--marigold);margin-bottom:10px;
}
.rl-empty{
  padding:14px;border-radius:var(--r-sm);
  background:rgba(78,197,181,.08);border:1px solid rgba(78,197,181,.25);
  color:var(--peacock);font-family:var(--body);font-size:13px;text-align:center;
}
.rl-grid{display:grid;grid-template-columns:1fr;gap:8px}
.rl-item{
  display:grid;grid-template-columns:24px minmax(0,1fr) auto;gap:10px;align-items:center;
  padding:10px 12px;border-radius:var(--r-sm);
  background:linear-gradient(90deg, rgba(140,30,40,.25), rgba(20,15,40,.4));
  border:1px solid rgba(230,57,70,.3);
}
.rl-flame{font-size:16px;line-height:1}
.rl-hi{font-family:var(--hindi);color:#fff;font-size:15px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rl-ua{font-family:var(--body);font-size:9px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase;grid-column:2;line-height:1.2}
.rl-since{font-family:var(--mono);font-size:10px;color:var(--gold);grid-row:1 / span 2;grid-column:3}

/* ═══════════════════════════════════════════════
   TAB BAR — "Gates / द्वार"
   ═══════════════════════════════════════════════ */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:40;
  height:var(--tabbar-h);
  padding:8px 10px env(safe-area-inset-bottom);
  display:grid;grid-template-columns:repeat(5,1fr);gap:4px;
  background:linear-gradient(180deg, rgba(15,8,32,.6), rgba(12,8,32,.98) 30%);
  border-top:1px solid var(--line-gold);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
.tabbar::before{
  content:"";position:absolute;top:-1px;left:20%;right:20%;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
}
.tab{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;color:var(--text-3);
  transition:transform .15s, color .25s;
  position:relative;border-radius:var(--r-md);
  padding:8px 4px;
}
.tab-ic{font-size:22px;line-height:1;filter:grayscale(.4);transition:filter .2s, transform .2s}
.tab-lbl{font-family:var(--body);font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.tab:active{transform:scale(.92)}
.tab.is-active{color:var(--marigold)}
.tab.is-active .tab-ic{filter:grayscale(0) drop-shadow(0 0 6px rgba(244,165,40,.5));transform:translateY(-2px)}
/* Active indicator — tilak drop */
.tab.is-active::before{
  content:"";position:absolute;top:-6px;left:50%;
  width:8px;height:14px;
  background:radial-gradient(circle at 50% 70%, var(--marigold), var(--vermillion));
  border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
  transform:translateX(-50%);
  box-shadow:0 0 10px rgba(244,165,40,.6);
  animation:tilakDrop .35s cubic-bezier(.4,1.6,.5,1);
}
@keyframes tilakDrop{from{transform:translateX(-50%) translateY(-8px) scale(.5);opacity:0}to{transform:translateX(-50%) translateY(0) scale(1);opacity:1}}

/* SOS tab — ornate vermillion medallion */
.tab--sos{
  background:radial-gradient(circle at 50% 35%, var(--vermillion), var(--sindoor) 70%);
  color:#fff !important;
  box-shadow:
    0 0 0 1px var(--gold) inset,
    0 0 0 3px var(--bg-deep) inset,
    0 0 0 4px var(--gold) inset,
    0 4px 18px rgba(230,57,70,.5),
    var(--glow-vermillion);
  margin-top:-12px;
  animation:sosBreath 3.5s ease-in-out infinite;
}
.tab--sos .tab-ic{font-size:24px;filter:drop-shadow(0 0 8px rgba(255,255,255,.4))}
.tab--sos .tab-lbl{color:var(--gold-glow);text-shadow:0 0 8px rgba(244,210,122,.6)}
.tab--sos.is-active::before{display:none}
@keyframes sosBreath{
  0%,100%{box-shadow:0 0 0 1px var(--gold) inset,0 0 0 3px var(--bg-deep) inset,0 0 0 4px var(--gold) inset,0 4px 18px rgba(230,57,70,.5)}
  50%{box-shadow:0 0 0 1px var(--gold-glow) inset,0 0 0 3px var(--bg-deep) inset,0 0 0 4px var(--gold-glow) inset,0 4px 28px rgba(230,57,70,.8),0 0 36px rgba(244,210,122,.4)}
}

/* ═══════════════════════════════════════════════
   VIEW container
   ═══════════════════════════════════════════════ */
.view{padding:24px 18px 32px;animation:viewIn .4s cubic-bezier(.2,.8,.2,1)}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════════════
   HEADERS
   ═══════════════════════════════════════════════ */
.salaam{
  display:flex;flex-direction:column;gap:4px;margin-bottom:22px;
  position:relative;padding-bottom:18px;
  padding-right:108px;
  min-height:120px;
}
.salaam::before{
  content:"";
  position:absolute;top:-14px;right:-14px;
  width:128px;height:128px;
  background:url("/mughal_manuscript_animation.svg") center/contain no-repeat;
  filter:drop-shadow(0 0 22px rgba(244,210,122,.55)) drop-shadow(0 0 6px rgba(224,122,26,.4));
  pointer-events:none;
  animation:salaam-float 9s ease-in-out infinite;
  z-index:2;
}
@keyframes salaam-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-5px) rotate(4deg)}
}
.salaam h1{
  font-family:var(--hindi);
  font-size:42px;line-height:1;
  color:var(--ivory);
  font-weight:400;
  text-shadow:0 0 40px rgba(244,210,122,.15);
}
.salaam h1 .accent{
  font-family:var(--display);font-style:italic;
  color:var(--marigold);font-variation-settings:"opsz" 144, "SOFT" 100;
  font-weight:300;
}
.salaam .sub{
  display:flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.28em;
  color:var(--gold);font-weight:600;
}
.salaam .sub::before{
  content:"";width:24px;height:1px;background:var(--gold);
  box-shadow:0 0 6px var(--gold);
}
.salaam::after{
  content:"❖";position:absolute;bottom:0;left:0;right:0;
  text-align:center;color:var(--gold);font-size:10px;letter-spacing:1.5em;
  opacity:.55;padding-left:1.5em;
}

/* ═══════════════════════════════════════════════
   ORNATE SECTION DIVIDER
   ═══════════════════════════════════════════════ */
.divider{
  display:flex;align-items:center;gap:14px;
  margin:36px 0 18px;
  color:var(--gold);
}
.divider::before,.divider::after{
  content:"";flex:1;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 40%, var(--gold) 60%, transparent);
  opacity:.5;
}
.divider .label{
  font-family:var(--ornament);font-weight:700;
  font-size:10.5px;letter-spacing:.32em;
  color:var(--gold-glow);
  display:flex;align-items:center;gap:8px;
}
.divider .label::before,.divider .label::after{content:"❖";font-family:var(--display);opacity:.6;font-size:9px}
.divider .label-hi{
  font-family:var(--hindi);font-size:13px;letter-spacing:.02em;
  color:var(--marigold);text-transform:none;
}

/* ═══════════════════════════════════════════════
   CARDS WITH ORNATE CORNERS
   ═══════════════════════════════════════════════ */
.scroll{
  position:relative;
  background:linear-gradient(180deg, var(--bg-paper) 0%, var(--bg-velvet) 100%);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  padding:18px;
  box-shadow:var(--shad-2);
}
.scroll::before,.scroll::after,
.scroll > .corner-tl, .scroll > .corner-tr,
.scroll > .corner-bl, .scroll > .corner-br{
  position:absolute;width:14px;height:14px;
  pointer-events:none;
}
/* Gold corner brackets — like manuscript frame */
.scroll::before{
  content:"";top:6px;left:6px;
  border-top:1.5px solid var(--gold);
  border-left:1.5px solid var(--gold);
  border-radius:2px 0 0 0;
}
.scroll::after{
  content:"";bottom:6px;right:6px;
  border-bottom:1.5px solid var(--gold);
  border-right:1.5px solid var(--gold);
  border-radius:0 0 2px 0;
}
.scroll .corner-tr{
  top:6px;right:6px;
  border-top:1.5px solid var(--gold);
  border-right:1.5px solid var(--gold);
  border-radius:0 2px 0 0;
}
.scroll .corner-bl{
  bottom:6px;left:6px;
  border-bottom:1.5px solid var(--gold);
  border-left:1.5px solid var(--gold);
  border-radius:0 0 0 2px;
}
.scroll + .scroll{margin-top:12px}

/* Inner padding for content (away from corners) */
.scroll-inner{padding:8px 4px}

/* ═══════════════════════════════════════════════
   STATUS BANNER (Mughal arch shape)
   ═══════════════════════════════════════════════ */
.status-arch{
  position:relative;
  background:linear-gradient(180deg, rgba(78,197,181,.08), rgba(78,197,181,.02));
  border:1.5px solid rgba(78,197,181,.35);
  border-radius:80px 80px 14px 14px / 60px 60px 14px 14px;
  padding:24px 22px 18px;
  text-align:center;
  margin-bottom:8px;
  box-shadow:inset 0 1px 0 rgba(78,197,181,.15), 0 6px 22px rgba(78,197,181,.08);
}
.status-arch--alert{
  background:linear-gradient(180deg, rgba(230,57,70,.2), rgba(230,57,70,.05));
  border-color:rgba(230,57,70,.55);
  box-shadow:inset 0 1px 0 rgba(230,57,70,.2), 0 6px 28px rgba(230,57,70,.25), var(--glow-vermillion);
  animation:archThrob 2.2s ease-in-out infinite;
}
@keyframes archThrob{
  0%,100%{box-shadow:inset 0 1px 0 rgba(230,57,70,.2),0 6px 28px rgba(230,57,70,.25)}
  50%{box-shadow:inset 0 1px 0 rgba(230,57,70,.4),0 6px 40px rgba(230,57,70,.5),0 0 60px rgba(230,57,70,.3)}
}
.status-arch .symbol{
  font-size:30px;line-height:1;margin-bottom:8px;
  filter:drop-shadow(0 0 12px currentColor);
}
.status-arch--silent .symbol{color:var(--peacock)}
.status-arch--alert .symbol{color:var(--marigold-2)}
.status-arch h3{
  font-family:var(--hindi);font-size:24px;line-height:1.15;
  margin-bottom:4px;color:var(--ivory);
}
.status-arch .sub{
  font-family:var(--body);font-size:11px;
  text-transform:uppercase;letter-spacing:.22em;
  color:var(--text-2);
}
.status-arch--alert h3{color:#ffe5b0}
.status-arch--alert .sub{color:#ffcfa3}
.status-arch .cta{
  display:inline-block;margin-top:14px;
  background:var(--marigold);color:var(--bg-deep);
  font-family:var(--body);font-weight:800;font-size:12px;
  letter-spacing:.12em;text-transform:uppercase;
  padding:10px 22px;border-radius:24px;
  box-shadow:var(--glow-marigold);
  position:relative;
}
.status-arch .cta::after{
  content:"→";margin-left:8px;font-weight:400;
}

/* ═══════════════════════════════════════════════
   THE SIX DOORS — medallion grid
   ═══════════════════════════════════════════════ */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.door{
  position:relative;
  aspect-ratio:1;
  border-radius:18px;
  background:
    radial-gradient(circle at 50% 30%, rgba(244,210,122,.12), transparent 60%),
    linear-gradient(180deg, var(--bg-velvet), var(--bg-paper));
  border:1px solid var(--line-gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  padding:8px;
  transition:transform .15s, box-shadow .25s, border-color .25s;
  overflow:hidden;
}
.door::before{
  content:"";position:absolute;inset:5px;
  border:1px dashed var(--line-dim);
  border-radius:14px;
  pointer-events:none;
}
.door::after{
  content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;
  background:conic-gradient(from 0deg, transparent 0deg 350deg, rgba(244,210,122,.4) 360deg);
  transform:translate(-50%,-50%) rotate(0deg);
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.door:active{transform:scale(.94)}
.door:active::after{opacity:.5;animation:doorSpark .6s linear}
@keyframes doorSpark{to{transform:translate(-50%,-50%) rotate(360deg)}}
.door .door-ic{font-size:28px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.door .door-lbl{
  font-family:var(--hindi);font-size:13px;font-weight:400;
  color:var(--text-1);line-height:1;text-align:center;
}
.door .door-sub{
  font-family:var(--body);font-size:8.5px;font-weight:700;
  color:var(--gold);letter-spacing:.18em;text-transform:uppercase;
}

/* ═══════════════════════════════════════════════
   LEDGER (currency) — paper accounting feel
   ═══════════════════════════════════════════════ */
.ledger{
  background:linear-gradient(180deg, rgba(245,236,214,.04) 0%, rgba(212,162,86,.02) 100%);
  border:1px solid var(--line-gold);
  border-radius:14px;
  padding:18px 16px;
  position:relative;
  overflow:hidden;
}
.ledger::before{
  content:"";position:absolute;top:0;bottom:0;left:32px;width:1px;
  background:repeating-linear-gradient(to bottom, var(--line-dim) 0 4px, transparent 4px 8px);
}
.ledger-row{display:flex;align-items:baseline;gap:14px;padding:8px 0}
.ledger-row+.ledger-row{border-top:1px dashed var(--line-dim)}
.ledger-pair{
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.06em;color:var(--gold);
  flex-shrink:0;white-space:nowrap;
}
.ledger-val{
  font-family:var(--display);font-style:italic;font-size:26px;
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-weight:400;line-height:1;color:var(--ivory);
  text-shadow:0 0 14px rgba(244,210,122,.2);
  margin-left:auto;
}
.ledger-val .unit{
  font-family:var(--body);font-size:11px;font-style:normal;
  color:var(--text-3);letter-spacing:.1em;margin-left:4px;
  text-shadow:none;
}
.ledger{cursor:pointer; transition:border-color .2s, transform .1s}
.ledger:hover{border-color:var(--marigold)}
.ledger:active{transform:scale(.99)}
.ledger-hint{
  font-family:var(--body);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);font-weight:600;
  text-align:center;margin-top:10px;padding-top:10px;
  border-top:1px dashed var(--line-dim);opacity:.85;
}

/* ═══════════════════════════════════════════════
   WEATHER PANEL — celestial
   ═══════════════════════════════════════════════ */
.sky-panel{
  background:
    radial-gradient(circle at 20% 30%, rgba(244,210,122,.12), transparent 50%),
    linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:16px;
  padding:18px;
  position:relative;overflow:hidden;
  cursor:pointer; transition:border-color .2s;
}
.sky-panel:hover{border-color:var(--marigold)}
.sky-head{display:flex;align-items:center;gap:18px}
.sky-chevron{
  font-size:16px;color:var(--gold);
  transition:transform .25s ease;
  margin-left:auto;align-self:center;
}
.sky-panel.is-open .sky-chevron{transform:rotate(180deg)}
.sky-forecast{
  margin-top:14px;padding-top:14px;
  border-top:1px dashed var(--line-dim);
  display:grid;grid-template-columns:1fr;gap:8px;
  animation:skyExpand .3s ease-out;
}
@keyframes skyExpand{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.day-row{
  display:grid;grid-template-columns:62px 32px 1fr 56px;
  align-items:center;gap:10px;
  padding:8px 4px;border-radius:8px;
  transition:background .15s;
}
.day-row:hover{background:rgba(244,210,122,.04)}
.day-row:first-child{
  background:rgba(244,210,122,.08);
  border:1px solid var(--line-dim);
  padding:10px 8px;
}
.day-dow{
  font-family:var(--hindi);font-size:14px;color:var(--ivory);
  display:flex;flex-direction:column;gap:2px;line-height:1;
}
.day-num{
  font-family:var(--mono);font-size:9px;
  color:var(--gold);letter-spacing:.1em;
}
.day-ic{font-size:20px;text-align:center}
.day-temps{
  display:flex;gap:10px;align-items:baseline;justify-content:flex-end;
  font-family:var(--display);font-size:18px;font-style:italic;
}
.t-max{color:var(--ivory);font-weight:500}
.t-min{color:var(--text-3);font-size:14px}
.day-rain{
  font-family:var(--mono);font-size:10px;
  color:var(--peacock);text-align:right;letter-spacing:.05em;
}
.sky-panel::after{
  content:"";position:absolute;top:-30px;right:-30px;width:120px;height:120px;
  background:radial-gradient(circle, rgba(244,210,122,.18) 0%, transparent 60%);
  pointer-events:none;
}
.sky-orb{
  width:56px;height:56px;flex-shrink:0;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  background:radial-gradient(circle at 30% 30%, var(--gold-glow), var(--marigold) 70%, transparent);
  box-shadow:0 0 30px rgba(244,165,40,.4), inset 0 0 12px rgba(255,255,255,.2);
}
.sky-body{flex:1}
.sky-temp{
  font-family:var(--display);font-style:italic;font-size:34px;
  font-variation-settings:"opsz" 144, "SOFT" 100;font-weight:400;line-height:1;
  color:var(--ivory);
}
.sky-temp .unit{font-size:18px;color:var(--gold);font-style:normal}
.sky-cond{
  font-family:var(--hindi);font-size:15px;color:var(--text-2);
  margin-top:4px;
}
.sky-meta{
  font-family:var(--body);font-size:10px;text-transform:uppercase;
  letter-spacing:.2em;color:var(--text-3);margin-top:6px;font-weight:600;
}

/* ═══════════════════════════════════════════════
   EMERGENCY STAMPS (home preview)
   ═══════════════════════════════════════════════ */
.stamps{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px}
.stamp{
  padding:12px 12px;
  border-radius:10px;
  display:grid;
  grid-template-columns:auto auto minmax(0,1fr);
  grid-template-rows:auto auto;
  align-items:center;column-gap:8px;row-gap:2px;
  min-width:0;overflow:hidden;
  background:linear-gradient(180deg, var(--vermillion), var(--sindoor));
  color:#fff;text-decoration:none;
  box-shadow:0 6px 16px rgba(230,57,70,.35), inset 0 1px 0 rgba(255,255,255,.15);
  border:1px solid rgba(244,210,122,.3);
  position:relative;
  transition:transform .1s;
}
.stamp:active{transform:scale(.96)}
.stamp .ic{
  grid-row:1/3;grid-column:1;
  font-size:22px;align-self:center;
}
.stamp .num{
  grid-row:1/3;grid-column:2;
  font-family:var(--mono);font-weight:700;font-size:20px;
  letter-spacing:.05em;align-self:center;
}
.stamp .sub-hi{
  grid-row:1;grid-column:3;
  font-family:var(--hindi);font-size:12px;line-height:1.05;
  font-weight:400;
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.stamp .sub{
  grid-row:2;grid-column:3;
  font-family:var(--body);font-weight:700;font-size:8px;
  letter-spacing:.14em;text-transform:uppercase;opacity:.8;
  line-height:1;
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.stamp--blue{background:linear-gradient(180deg, var(--bg-elev), var(--bg-velvet));border-color:var(--gold)}
.stamp--gold{background:linear-gradient(180deg, var(--marigold), #c4801b);color:var(--bg-deep)}
.stamp--gold .sub{color:rgba(12,8,32,.7)}
.stamp--gold .sub-hi{color:var(--bg-deep)}

/* ═══════════════════════════════════════════════
   CURRENCY CONVERTER MODAL
   ═══════════════════════════════════════════════ */
.ccy-overlay{
  position:fixed;inset:0;z-index:90;
  background:rgba(8,5,20,.78);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:flex-end;justify-content:center;
  padding:0;
  animation:cpFadeIn .25s ease-out;
}
.ccy-card{
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:18px 18px 0 0;
  width:100%;max-width:520px;
  max-height:88vh;overflow-y:auto;
  padding:18px 18px 32px;
  animation:cardSlideUp .3s ease-out;
}
@keyframes cardSlideUp{from{transform:translateY(40px);opacity:.5}to{transform:none;opacity:1}}
.ccy-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ccy-title{
  font-family:var(--hindi);font-size:24px;color:var(--ivory);
}
.ccy-title .ccy-en{
  font-family:var(--body);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);font-weight:700;
  margin-left:8px;
}
.ccy-close{
  width:32px;height:32px;border-radius:50%;
  background:rgba(244,210,122,.08);border:1px solid var(--line-dim);
  color:var(--gold);font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.ccy-close:active{transform:scale(.92)}
.ccy-loading{
  font-family:var(--hindi);font-size:16px;color:var(--text-2);
  text-align:center;padding:40px 0;
}
.ccy-conv{
  display:grid;gap:8px;
  background:rgba(8,5,20,.4);
  border:1px solid var(--line-dim);
  border-radius:14px;padding:14px;
  margin-bottom:18px;
  box-sizing:border-box;
  width:100%;
  overflow:hidden;
}
.ccy-row{
  display:flex;gap:8px;
  width:100%;box-sizing:border-box;
  min-width:0;
}
.ccy-amt{
  flex:1 1 0;
  min-width:0;width:0;
  font-family:var(--display);font-size:22px;font-style:italic;
  font-weight:400;color:var(--ivory);
  background:rgba(244,210,122,.05);
  border:1px solid var(--line-gold);
  border-radius:10px;padding:10px 12px;
  outline:none;
  box-sizing:border-box;
  transition:border-color .15s;
}
.ccy-amt:focus{border-color:var(--marigold)}
.ccy-amt[readonly]{color:var(--marigold);font-weight:500}
.ccy-pick{
  flex:0 0 104px;
  min-width:0;
  font-family:var(--mono);font-size:13px;font-weight:700;
  color:var(--ivory);
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23f4d27a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat right 10px center / 10px 6px,
    linear-gradient(180deg, rgba(244,210,122,.12), rgba(244,210,122,.05));
  border:1px solid var(--line-gold);
  border-radius:10px;padding:10px 24px 10px 8px;
  outline:none;cursor:pointer;
  letter-spacing:.05em;
  box-sizing:border-box;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  color-scheme:dark;
}
.ccy-pick:focus{border-color:var(--marigold);box-shadow:0 0 0 2px rgba(244,210,122,.18)}
.ccy-pick option{
  background:#15102e;color:var(--ivory);
  font-family:var(--mono);font-weight:600;
  padding:8px;
}
.ccy-pick option:checked{background:rgba(244,210,122,.18);color:var(--marigold)}
.ccy-arrow{
  font-size:22px;color:var(--gold);
  text-align:center;cursor:pointer;
  padding:4px;line-height:1;
  transition:transform .2s;
}
.ccy-arrow:hover{transform:rotate(180deg);color:var(--marigold)}
.ccy-list-head{
  font-family:var(--body);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);font-weight:700;
  margin-bottom:8px;padding-left:4px;
}
.ccy-list{display:grid;gap:2px}
.ccy-list-row{
  display:grid;grid-template-columns:28px 42px 1fr auto;
  align-items:center;gap:10px;
  padding:10px 8px;border-radius:8px;
  font-size:13px;
}
.ccy-list-row:nth-child(odd){background:rgba(244,210,122,.03)}
.ccy-list-flag{font-size:18px;text-align:center}
.ccy-list-code{
  font-family:var(--mono);font-weight:700;color:var(--gold);
  letter-spacing:.05em;
}
.ccy-list-name{font-family:var(--hindi);font-size:13px;color:var(--text-2)}
.ccy-list-rate{
  font-family:var(--display);font-style:italic;font-size:16px;
  color:var(--ivory);
}
.ccy-foot{
  font-family:var(--body);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-3);
  text-align:center;margin-top:14px;
}

/* ═══════════════════════════════════════════════
   SOS VIEW — Temple Bell
   ═══════════════════════════════════════════════ */
.sos-hero{
  text-align:center;padding:8px 0 24px;
  position:relative;
}
.sos-hero .symbol{
  font-size:48px;line-height:1;display:block;
  color:var(--vermillion);
  filter:drop-shadow(0 0 24px rgba(230,57,70,.6));
  animation:bellSwing 4s ease-in-out infinite;
}
@keyframes bellSwing{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
.sos-hero h1{
  font-family:var(--hindi);font-size:36px;line-height:1.05;
  margin-top:8px;color:var(--ivory);
}
.sos-hero h1 em{font-family:var(--display);font-style:italic;color:var(--vermillion);font-weight:300}
.sos-hero .sub{
  font-family:var(--body);font-size:10.5px;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-top:6px;font-weight:600;
}

.sos-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.sos-card{
  position:relative;
  background:linear-gradient(180deg, var(--vermillion), var(--sindoor));
  border:2px solid var(--gold);
  border-radius:20px;
  padding:24px 14px 20px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  min-height:160px;justify-content:center;
  box-shadow:
    0 10px 30px rgba(230,57,70,.35),
    inset 0 1px 0 rgba(255,255,255,.2),
    inset 0 0 0 1px rgba(12,8,32,.2),
    var(--glow-vermillion);
  transition:transform .12s;
}
.sos-card::before{
  content:"";position:absolute;inset:6px;border:1px dashed rgba(244,210,122,.4);
  border-radius:14px;pointer-events:none;
}
.sos-card:active{transform:scale(.96)}
.sos-card .ic{font-size:38px;line-height:1;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.sos-card .num{
  font-family:var(--mono);font-weight:700;font-size:36px;
  color:var(--gold-glow);letter-spacing:-.02em;line-height:1;
  text-shadow:0 0 16px rgba(244,210,122,.7), 0 2px 4px rgba(0,0,0,.5);
}
.sos-card .lbl-hi{
  font-family:var(--hindi);font-size:14px;color:#fff;line-height:1.15;
}
.sos-card .lbl-en{
  font-family:var(--body);font-size:8.5px;font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.sos-card--embassy{
  background:linear-gradient(180deg, #ff9933 0%, #ffffff 50%, #138808 100%);
}
.sos-card--embassy .ic,
.sos-card--embassy .lbl-hi,
.sos-card--embassy .lbl-en{color:var(--bg-deep);text-shadow:0 0 4px rgba(255,255,255,.8)}
.sos-card--embassy .num{color:var(--bg-deep);text-shadow:0 0 4px rgba(255,255,255,.8)}
.sos-card--shelter{
  background:linear-gradient(180deg, var(--bg-velvet), var(--bg-elev));
}
.sos-card--blue{background:linear-gradient(180deg, var(--bg-elev), var(--bg-velvet))}

/* ═══════════════════════════════════════════════
   PHRASE SCROLLS (SOS)
   ═══════════════════════════════════════════════ */
.phrase{
  position:relative;
  background:
    linear-gradient(180deg, rgba(245,236,214,.05), rgba(212,162,86,.02));
  border:1px solid var(--line-gold);
  border-radius:16px;
  padding:20px 18px 18px;
  margin-top:18px;
}
.phrase::before, .phrase::after{
  content:"";position:absolute;width:14px;height:14px;
}
.phrase::before{top:8px;left:8px;border-top:1.5px solid var(--gold);border-left:1.5px solid var(--gold);border-radius:2px 0 0 0}
.phrase::after{bottom:8px;right:8px;border-bottom:1.5px solid var(--gold);border-right:1.5px solid var(--gold);border-radius:0 0 2px 0}
.phrase-eyebrow{
  font-family:var(--ornament);font-size:9.5px;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--marigold);margin-bottom:10px;
  display:flex;align-items:center;gap:6px;
}
.phrase-eyebrow::before{content:"❖";color:var(--gold)}
.phrase-uk{
  font-family:var(--display);font-size:20px;line-height:1.3;
  font-variation-settings:"opsz" 32, "SOFT" 50;font-weight:400;
  color:var(--ivory);margin-bottom:6px;
}
.phrase-hi{
  font-family:var(--hindi);font-size:14px;color:var(--text-2);
  line-height:1.4;margin-bottom:14px;
}
.phrase-actions{display:flex;gap:8px;flex-wrap:wrap}
.phrase-btn{
  background:transparent;color:var(--marigold);
  border:1px solid var(--marigold);
  font-family:var(--body);font-weight:700;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;
  padding:9px 14px;border-radius:20px;
  display:inline-flex;align-items:center;gap:6px;
  transition:background .2s, color .2s, box-shadow .2s;
}
.phrase-btn:active{background:var(--marigold);color:var(--bg-deep);box-shadow:var(--glow-marigold)}
.phrase-btn--solid{
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep);border-color:transparent;
}
.phrase-btn--ghost{border-color:var(--peacock);color:var(--peacock)}
.phrase-btn--ghost:active{background:var(--peacock);color:var(--bg-deep)}

/* ═══════════════════════════════════════════════
   Skeleton / placeholders
   ═══════════════════════════════════════════════ */
.skel{
  background:linear-gradient(90deg, rgba(212,162,86,.06) 25%, rgba(244,210,122,.18) 50%, rgba(212,162,86,.06) 75%);
  background-size:200% 100%;
  animation:skelShine 1.6s ease-in-out infinite;
  border-radius:6px;height:16px;
}
@keyframes skelShine{0%{background-position:200% 0}100%{background-position:-200% 0}}

.placeholder{
  padding:60px 24px;text-align:center;color:var(--text-3);
  background:linear-gradient(180deg, var(--bg-paper), transparent);
  border:1px dashed var(--line-gold);border-radius:18px;
  margin-top:18px;
}
.placeholder .ic{font-size:54px;display:block;margin-bottom:14px;filter:drop-shadow(0 0 16px var(--marigold))}
.placeholder strong{color:var(--marigold);display:block;font-family:var(--ornament);font-size:13px;letter-spacing:.2em;text-transform:uppercase}
.placeholder p{margin-top:10px;font-family:var(--hindi);font-size:14px;color:var(--text-2);line-height:1.5}

/* ═══════════════════════════════════════════════
   LANGUAGE VIEW — Phrasebook / Translator / Alphabet
   ═══════════════════════════════════════════════ */

/* Top tab switcher (within language view) */
.lang-tabs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:14px;
  padding:6px;margin-bottom:18px;
  position:relative;
}
.lang-tab{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 6px;
  border-radius:10px;
  color:var(--text-3);
  font-family:var(--body);font-weight:700;font-size:12px;
  letter-spacing:.04em;
  transition:color .25s, background .25s;
  white-space:nowrap;
}
.lang-tab span{font-family:var(--hindi);font-weight:400;font-size:13px;letter-spacing:0}
.lang-tab.is-active{
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep);
  box-shadow:0 4px 14px rgba(244,165,40,.35), inset 0 1px 0 rgba(255,255,255,.2);
}
.lang-tab.is-active span{color:var(--bg-deep)}

.lang-pane{display:none}
.lang-pane.is-active{display:block;animation:viewIn .35s cubic-bezier(.2,.8,.2,1)}

/* ─── Category strip (horizontal scroll) ─── */
.cat-strip{
  display:flex;gap:8px;
  overflow-x:auto;overflow-y:hidden;
  padding:6px 2px 12px;
  margin:0 -18px;padding-left:18px;padding-right:18px;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.cat-strip::-webkit-scrollbar{display:none}
.cat-chip{
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:10px 12px 8px;
  border-radius:14px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-dim);
  min-width:74px;
  transition:transform .12s, border-color .25s, box-shadow .25s;
}
.cat-chip .cat-ic{font-size:22px;line-height:1;filter:grayscale(.4)}
.cat-chip .cat-lbl{font-family:var(--hindi);font-size:12px;color:var(--text-1);line-height:1.1}
.cat-chip .cat-en{font-family:var(--body);font-size:8px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3)}
.cat-chip:active{transform:scale(.95)}
.cat-chip.is-active{
  background:linear-gradient(180deg, var(--bg-velvet), var(--bg-elev));
  border-color:var(--marigold);
  box-shadow:0 0 0 1px var(--marigold) inset, 0 4px 18px rgba(244,165,40,.25);
}
.cat-chip.is-active .cat-ic{filter:grayscale(0) drop-shadow(0 0 8px rgba(244,165,40,.5))}
.cat-chip.is-active .cat-en{color:var(--marigold)}

/* ─── Phrase cards ─── */
.phrase-list{display:flex;flex-direction:column;gap:10px}
.pcard{
  position:relative;
  background:linear-gradient(180deg, rgba(245,236,214,.05), rgba(212,162,86,.02));
  border:1px solid var(--line-gold);
  border-radius:14px;
  padding:14px 14px 12px;
}
.pcard::before{
  content:"";position:absolute;top:6px;left:6px;width:10px;height:10px;
  border-top:1.5px solid var(--gold);border-left:1.5px solid var(--gold);
  border-radius:2px 0 0 0;pointer-events:none;
}
.pcard::after{
  content:"";position:absolute;bottom:6px;right:6px;width:10px;height:10px;
  border-bottom:1.5px solid var(--gold);border-right:1.5px solid var(--gold);
  border-radius:0 0 2px 0;pointer-events:none;
}
.pcard-hi{
  font-family:var(--hindi);font-size:18px;line-height:1.3;
  color:var(--ivory);margin-bottom:4px;
}
.pcard-uk{
  font-family:var(--display);font-style:italic;font-size:15px;line-height:1.3;
  font-variation-settings:"opsz" 32, "SOFT" 60;
  color:var(--text-2);margin-bottom:10px;
}
.pcard-actions{display:flex;gap:6px;flex-wrap:wrap}
.pcard-btn{
  font-family:var(--body);font-weight:700;font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;
  padding:7px 11px;border-radius:14px;
  border:1px solid var(--line-gold);
  background:transparent;color:var(--text-2);
  display:inline-flex;align-items:center;gap:4px;
  transition:transform .1s, background .2s, color .2s, border-color .2s;
}
.pcard-btn:active{transform:scale(.94)}
.pcard-btn--ua{border-color:var(--peacock);color:var(--peacock)}
.pcard-btn--ua:active{background:var(--peacock);color:var(--bg-deep)}
.pcard-btn--hi{border-color:var(--marigold);color:var(--marigold)}
.pcard-btn--hi:active{background:var(--marigold);color:var(--bg-deep)}
.pcard-btn--copy{margin-left:auto;padding:7px 9px;font-size:13px}

/* ─── Translator card ─── */
.trans-card{
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:18px;
  padding:18px;
  position:relative;
  box-shadow:var(--shad-2);
}
.trans-dir{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
  background:var(--bg-deep);
  border-radius:12px;padding:4px;
  margin-bottom:14px;
}
.dir-btn{
  padding:9px 6px;
  font-family:var(--body);font-weight:700;font-size:11px;
  letter-spacing:.06em;color:var(--text-3);
  border-radius:8px;
  transition:background .2s, color .2s;
}
.dir-btn.is-active{
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep);
  box-shadow:0 2px 8px rgba(244,165,40,.3);
}
.trans-input-wrap{
  position:relative;
  background:var(--bg-deep);
  border:1px solid var(--line-dim);
  border-radius:12px;
  overflow:hidden;
}
.trans-input{
  width:100%;background:transparent;border:0;outline:0;
  color:var(--ivory);
  font-family:var(--hindi);font-size:16px;line-height:1.4;
  padding:14px 50px 14px 14px;
  resize:vertical;min-height:80px;max-height:200px;
}
.trans-input::placeholder{color:var(--text-3);font-style:italic}
.mic-btn{
  position:absolute;right:8px;bottom:8px;
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(180deg, var(--peacock), #3a9285);
  color:#fff;font-size:18px;
  box-shadow:0 4px 12px rgba(78,197,181,.4);
  display:flex;align-items:center;justify-content:center;
  transition:transform .1s, box-shadow .25s;
}
.mic-btn:active{transform:scale(.92)}
.mic-btn.is-recording{
  background:linear-gradient(180deg, var(--vermillion), var(--sindoor));
  animation:micPulse 1s ease-in-out infinite;
}
@keyframes micPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(230,57,70,.5)}
  50%{box-shadow:0 0 0 12px rgba(230,57,70,0)}
}
.trans-go{
  display:block;width:100%;
  margin:12px 0;
  padding:14px;
  font-family:var(--body);font-weight:800;font-size:13px;
  letter-spacing:.18em;text-transform:uppercase;
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep);
  border-radius:12px;
  box-shadow:0 6px 18px rgba(244,165,40,.35), inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .1s;
}
.trans-go:active{transform:scale(.98)}
.trans-output{
  background:var(--bg-deep);
  border:1px dashed var(--line-gold);
  border-radius:12px;
  padding:14px;
  min-height:80px;
}
.trans-eyebrow{
  font-family:var(--ornament);font-size:9px;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;
}
.trans-result{
  font-family:var(--display);font-style:italic;font-size:20px;line-height:1.3;
  font-variation-settings:"opsz" 32, "SOFT" 50;
  color:var(--ivory);margin-bottom:10px;
  word-break:break-word;
}
.trans-hint{
  margin-top:12px;
  font-family:var(--body);font-size:10px;color:var(--text-3);
  letter-spacing:.04em;text-align:center;
}
.trans-hint span{color:var(--gold)}

/* ─── Alphabet ─── */
.abc-intro{text-align:center;margin-bottom:14px;padding:0 8px}
.abc-eyebrow{
  font-family:var(--ornament);font-size:10px;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:6px;
}
.abc-intro p{
  font-family:var(--hindi);font-size:13px;color:var(--text-2);
}
.abc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.abc-tile{
  position:relative;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:12px;
  padding:12px 8px 10px;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  transition:transform .12s, border-color .25s, box-shadow .25s;
  overflow:hidden;
  min-height:108px;
}
.abc-tile::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
  opacity:.4;
}
.abc-letter{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-variation-settings:"opsz" 144, "SOFT" 80;
  font-size:24px;line-height:1;
  color:var(--marigold);
  text-shadow:0 0 12px rgba(244,165,40,.3);
}
.abc-hi{
  font-family:var(--hindi);font-size:12px;color:var(--text-2);
  line-height:1;margin-top:2px;
}
.abc-ex{
  font-family:var(--display);font-style:italic;font-size:11px;
  color:var(--ivory);margin-top:6px;line-height:1.1;
  text-align:center;
}
.abc-ex-hi{
  font-family:var(--hindi);font-size:10px;color:var(--text-3);
  line-height:1;
}
.abc-tile:active{transform:scale(.95)}
.abc-tile.is-playing{
  border-color:var(--marigold);
  box-shadow:0 0 0 1px var(--marigold) inset, 0 0 22px rgba(244,165,40,.4);
}
.abc-tile.is-playing .abc-letter{
  text-shadow:0 0 18px rgba(244,165,40,.7);
}

/* ═══════════════════════════════════════════════
   MAP VIEW — Leaflet + chips + list
   ═══════════════════════════════════════════════ */
/* Region switcher button in salaam header */
.region-btn{
  align-self:flex-start;
  margin-top:10px;
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 12px;border-radius:18px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  color:var(--ivory);
  box-shadow:0 4px 14px rgba(0,0,0,.3), inset 0 1px 0 rgba(244,210,122,.08);
  transition:border-color .2s, transform .1s;
  position:relative;z-index:3;
}
.region-btn:active{transform:scale(.96)}
.region-btn:hover{border-color:var(--marigold)}
.region-btn .region-ic{font-size:12px}
.region-btn .region-name{
  font-family:var(--hindi);font-size:13px;line-height:1;
  color:var(--marigold);
}
.region-btn .region-arrow{font-size:10px;color:var(--text-3);margin-left:2px}

/* City picker modal */
.city-picker{
  position:fixed;inset:0;z-index:90;
  background:rgba(8,5,20,.75);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  padding:24px 18px;
  animation:cpFadeIn .25s ease-out;
}
@keyframes cpFadeIn{from{opacity:0}to{opacity:1}}
.cp-card{
  position:relative;
  width:100%;max-width:420px;max-height:90vh;overflow-y:auto;
  background:linear-gradient(180deg, var(--bg-paper) 0%, var(--bg-velvet) 50%, var(--bg-paper) 100%);
  border:1.5px solid var(--line-gold);
  border-radius:22px;
  padding:24px 22px 22px;
  box-shadow:var(--shad-deep), 0 0 60px rgba(244,165,40,.15);
  animation:cpSlideUp .4s cubic-bezier(.2,.8,.2,1);
}
@keyframes cpSlideUp{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.cp-card::before,
.cp-card::after{
  content:"";position:absolute;width:18px;height:18px;
  pointer-events:none;
}
.cp-card::before{top:8px;left:8px;border-top:1.5px solid var(--gold);border-left:1.5px solid var(--gold);border-radius:3px 0 0 0}
.cp-card::after{bottom:8px;right:8px;border-bottom:1.5px solid var(--gold);border-right:1.5px solid var(--gold);border-radius:0 0 3px 0}
.cp-close{
  position:absolute;top:8px;right:14px;
  width:32px;height:32px;border-radius:50%;
  color:var(--gold);font-size:22px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.cp-close:hover{background:rgba(244,210,122,.1)}
.cp-eyebrow{
  font-family:var(--ornament);font-size:10px;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:6px;
}
.cp-card h2{
  font-family:var(--hindi);font-size:30px;line-height:1;
  color:var(--ivory);margin-bottom:6px;
}
.cp-sub{
  font-family:var(--body);font-size:11px;color:var(--text-3);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;
}
.cp-detected{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(90deg, rgba(78,197,181,.15), rgba(78,197,181,.04));
  border:1px solid rgba(78,197,181,.4);
  border-radius:12px;padding:10px 12px;
  font-family:var(--body);font-size:12px;color:var(--text-2);
  margin-bottom:14px;
}
.cp-detected strong{color:var(--peacock);font-family:var(--hindi);font-weight:400;font-size:15px}
.cp-detected-dot{
  width:8px;height:8px;border-radius:50%;background:var(--peacock);
  box-shadow:0 0 10px var(--peacock);
  animation:youPulse 1.6s ease-in-out infinite;
}
.cp-section{margin-top:14px}
.cp-section-title{
  font-family:var(--body);font-size:9.5px;font-weight:800;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.cp-section-title::after{
  content:"";flex:1;height:1px;
  background:linear-gradient(90deg, var(--gold), transparent);
  opacity:.4;
}
.cp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cp-city{
  padding:14px 8px 10px;
  background:linear-gradient(180deg, var(--bg-velvet), var(--bg-paper));
  border:1px solid var(--line-dim);
  border-radius:14px;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  transition:transform .12s, border-color .2s, box-shadow .25s;
}
.cp-city:active{transform:scale(.94)}
.cp-city:hover{
  border-color:var(--marigold);
  box-shadow:0 0 0 1px var(--marigold) inset, 0 4px 18px rgba(244,165,40,.2);
}
.cp-city .cp-hi{
  font-family:var(--hindi);font-size:15px;color:var(--ivory);line-height:1;
}
.cp-city .cp-en{
  font-family:var(--body);font-size:8.5px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);
}
.cp-hint{
  margin-top:16px;
  font-family:var(--body);font-size:10px;
  color:var(--text-3);text-align:center;letter-spacing:.06em;
}

.layer-strip{
  display:flex;gap:7px;margin-bottom:14px;
  overflow-x:auto;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;
}
.layer-strip::-webkit-scrollbar{display:none}
.lyr-chip{
  flex-shrink:0;
  padding:8px 11px 7px;
  border-radius:14px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-dim);
  display:flex;align-items:center;gap:7px;
  transition:border-color .2s, background .2s;
}
.lyr-chip .lyr-ic{font-size:16px;line-height:1}
.lyr-chip .lyr-hi{font-family:var(--hindi);font-size:12px;color:var(--text-1);line-height:1}
.lyr-chip .lyr-en{font-family:var(--body);font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.lyr-chip.is-active{
  border-color:var(--lyr-color);
  background:linear-gradient(180deg, color-mix(in srgb, var(--lyr-color) 14%, var(--bg-paper)), var(--bg-velvet));
  box-shadow:0 0 0 1px var(--lyr-color) inset, 0 4px 14px color-mix(in srgb, var(--lyr-color) 25%, transparent);
}
.lyr-chip.is-active .lyr-en{color:var(--lyr-color)}

.map-wrap{
  position:relative;
  height:340px;
  border-radius:18px;
  overflow:hidden;
  border:1.5px solid var(--line-gold);
  box-shadow:var(--shad-2);
  background:#0c0820;
}
.leaflet-map{position:absolute;inset:0;background:#1a1545;z-index:1}
.map-wrap .leaflet-tile{filter:brightness(.7) contrast(1.15) saturate(.85) hue-rotate(-8deg)}
.map-wrap .leaflet-control-attribution{
  font-size:9px;background:rgba(12,8,32,.7);color:var(--text-3);padding:1px 5px;
}
.map-wrap .leaflet-control-attribution a{color:var(--gold)}
.map-wrap .leaflet-control-zoom a{
  background:var(--bg-paper);color:var(--gold);
  border-color:var(--line-gold);
}
.map-wrap .leaflet-control-zoom a:hover{background:var(--bg-velvet);color:var(--marigold)}

.poi-pin{
  width:32px;height:32px;border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.45), 0 0 0 2px rgba(244,210,122,.8);
  color:#fff;font-size:15px;
  border:1.5px solid var(--ivory);
}
.poi-pin > *{transform:rotate(45deg)}
.poi-pin--you{
  background:radial-gradient(circle, var(--peacock), #2d7d75)!important;
  animation:youPulse 1.6s ease-in-out infinite;
}
@keyframes youPulse{0%,100%{box-shadow:0 0 0 0 rgba(78,197,181,.5),0 4px 12px rgba(0,0,0,.45)}50%{box-shadow:0 0 0 14px rgba(78,197,181,0),0 4px 12px rgba(0,0,0,.45)}}

.map-overlay{
  position:absolute;inset:0;z-index:5;
  background:rgba(12,8,32,.55);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.map-status{
  font-family:var(--ornament);font-size:11px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
  padding:10px 18px;border-radius:20px;
  background:rgba(20,12,40,.85);
  border:1px solid var(--line-gold);
}

.map-locate{
  position:absolute;right:12px;bottom:12px;z-index:6;
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(180deg, var(--peacock), #2d7d75);
  color:#fff;font-size:18px;
  box-shadow:0 6px 18px rgba(78,197,181,.4), inset 0 1px 0 rgba(255,255,255,.2);
  border:2px solid var(--gold);
}
.map-locate:active{transform:scale(.94)}

/* Leaflet popup theming */
.leaflet-popup-content-wrapper{
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet))!important;
  color:var(--ivory)!important;
  border:1px solid var(--line-gold);
  border-radius:14px!important;
  box-shadow:var(--shad-deep)!important;
}
.leaflet-popup-tip{background:var(--bg-velvet)!important;border:1px solid var(--line-gold)}
.leaflet-popup-close-button{color:var(--gold)!important}
.poi-popup{font-family:var(--body);font-size:12px;padding:2px 4px 4px;min-width:180px}
.poi-popup strong{font-family:var(--display);font-style:italic;font-size:16px;color:var(--ivory);display:block;margin-bottom:4px;line-height:1.2}
.poi-popup .popup-hi{font-family:var(--hindi);font-size:13px;color:var(--marigold);margin-bottom:4px}
.poi-popup .popup-addr{color:var(--text-3);font-size:11px;margin-bottom:6px;line-height:1.4}
.poi-popup .popup-tel,
.poi-popup .popup-url,
.poi-popup .popup-go{
  display:inline-block;margin:3px 6px 3px 0;
  padding:5px 9px;border-radius:10px;
  background:rgba(244,210,122,.1);
  color:var(--marigold)!important;
  font-weight:700;font-size:10.5px;letter-spacing:.06em;
  text-decoration:none;
  border:1px solid var(--line-gold);
}
.poi-popup .popup-go{
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep)!important;border-color:transparent;
  display:block;margin-top:8px;text-align:center;
}

/* Result list under map */
.map-list{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.map-list-head{
  display:flex;align-items:center;gap:8px;
  font-family:var(--ornament);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:4px;
}
.map-list-head strong{color:var(--marigold);font-family:var(--body);font-size:12px;letter-spacing:.06em;text-transform:none;font-weight:800}
.map-item{
  width:100%;
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-dim);
  border-radius:12px;
  text-align:left;
  transition:border-color .2s;
}
.map-item:hover{border-color:var(--line-gold)}
.map-item .mi-body,.map-item .mi-num{cursor:pointer}
.mi-num{
  flex-shrink:0;
  width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-weight:700;font-size:12px;
  color:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.4);
}
.mi-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.mi-name{font-family:var(--display);font-style:italic;font-size:14px;color:var(--ivory);line-height:1.2}
.mi-hi{font-family:var(--hindi);font-size:11.5px;color:var(--marigold);line-height:1.2}
.mi-addr{font-family:var(--body);font-size:10px;color:var(--text-3);letter-spacing:.04em;line-height:1.3}
.mi-go{color:var(--gold);font-size:18px;flex-shrink:0}
.mi-speak,.mi-focus{
  flex-shrink:0;
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;
  background:rgba(244,210,122,.08);
  border:1px solid var(--line-dim);
  color:var(--gold);
  transition:transform .1s, background .2s, border-color .2s, color .2s;
}
.mi-speak{color:var(--peacock);border-color:rgba(78,197,181,.35)}
.mi-speak:hover{background:rgba(78,197,181,.15);border-color:var(--peacock)}
.mi-focus{font-size:18px}
.mi-focus:hover{background:rgba(244,165,40,.15);border-color:var(--marigold);color:var(--marigold)}
.mi-speak:active,.mi-focus:active{transform:scale(.9)}

.popup-speak{
  display:inline-block;margin:3px 6px 3px 0;
  padding:5px 9px;border-radius:10px;
  background:rgba(78,197,181,.12);
  color:var(--peacock);
  font-weight:700;font-size:10.5px;letter-spacing:.06em;
  border:1px solid rgba(78,197,181,.4);
  cursor:pointer;
}
.popup-speak:hover{background:rgba(78,197,181,.22)}

/* ═══════════════════════════════════════════════
   COMMUNITY VIEW
   ═══════════════════════════════════════════════ */

/* Embassy arch (top hero) — saffron/white/green tricolor wash */
.embassy-arch{
  position:relative;
  background:
    linear-gradient(180deg, rgba(255,153,51,.18) 0%, rgba(245,236,214,.06) 40%, rgba(19,136,8,.12) 100%),
    linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1.5px solid var(--line-gold);
  border-radius:80px 80px 16px 16px / 60px 60px 16px 16px;
  padding:22px 22px 18px;
  text-align:center;
  box-shadow:var(--shad-deep), inset 0 1px 0 rgba(244,210,122,.1);
  margin-bottom:8px;
}
.ea-symbol{
  font-size:36px;line-height:1;margin-bottom:6px;
  filter:drop-shadow(0 0 14px rgba(244,210,122,.4));
}
.ea-eyebrow{
  font-family:var(--ornament);font-size:9.5px;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:4px;
}
.embassy-arch h3{
  font-family:var(--hindi);font-size:26px;line-height:1.1;
  color:var(--ivory);margin-bottom:2px;
}
.ea-sub{
  font-family:var(--body);font-size:10.5px;
  text-transform:uppercase;letter-spacing:.22em;
  color:var(--text-2);margin-bottom:14px;
}
.ea-actions{
  display:flex;gap:8px;justify-content:center;flex-wrap:wrap;
  margin-bottom:12px;
}
.ea-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;border-radius:22px;
  font-family:var(--body);font-weight:800;font-size:11px;
  letter-spacing:.1em;
  background:rgba(244,165,40,.12);
  color:var(--marigold);
  border:1px solid var(--marigold);
}
.ea-btn--call{
  background:linear-gradient(180deg, var(--marigold), #c4801b);
  color:var(--bg-deep);
  border-color:transparent;
  box-shadow:0 4px 16px rgba(244,165,40,.35);
  letter-spacing:.04em;
}
.ea-meta{
  font-family:var(--body);font-size:10px;
  color:var(--text-3);letter-spacing:.1em;
}

/* Events strip — horizontal scroll cards */
.events-strip{
  display:flex;gap:10px;
  overflow-x:auto;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  margin:0 -18px;padding:0 18px 8px;
}
.events-strip::-webkit-scrollbar{display:none}
.event-card{
  flex-shrink:0;width:200px;
  display:flex;gap:12px;
  padding:12px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:14px;
  position:relative;
}
.event-date{
  flex-shrink:0;
  width:48px;height:54px;border-radius:10px;
  background:linear-gradient(180deg, var(--vermillion), var(--sindoor));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#fff;
  border:1px solid var(--gold);
  box-shadow:0 3px 10px rgba(230,57,70,.35);
}
.event-day{
  font-family:var(--display);font-style:italic;font-size:22px;
  font-variation-settings:"opsz" 144;
  font-weight:600;line-height:1;
  color:var(--gold-glow);
}
.event-month{
  font-family:var(--body);font-size:8.5px;font-weight:800;
  letter-spacing:.16em;line-height:1;margin-top:2px;
}
.event-body{flex:1;min-width:0}
.event-ic{font-size:18px;line-height:1;margin-bottom:2px}
.event-hi{font-family:var(--hindi);font-size:14px;color:var(--ivory);line-height:1.1}
.event-en{font-family:var(--body);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:1px}
.event-note{font-family:var(--body);font-size:10px;color:var(--text-3);margin-top:5px;line-height:1.35}

/* Link rows (sections) */
.link-stack{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.link-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  background:linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-dim);
  border-radius:14px;
  text-decoration:none;
  transition:border-color .2s, transform .1s;
}
.link-row:hover{border-color:var(--line-gold)}
.link-row:active{transform:scale(.99)}
.lr-ic{font-size:22px;line-height:1;flex-shrink:0;width:34px;text-align:center}
.lr-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.lr-hi{font-family:var(--hindi);font-size:14px;color:var(--ivory);line-height:1.15}
.lr-en{font-family:var(--display);font-style:italic;font-size:12px;color:var(--text-2);line-height:1.2}
.lr-sub{font-family:var(--body);font-size:9.5px;color:var(--text-3);letter-spacing:.04em;line-height:1.3}
.lr-tag{
  flex-shrink:0;
  font-family:var(--body);font-weight:800;font-size:8.5px;
  letter-spacing:.18em;
  padding:5px 8px;border-radius:8px;
  background:rgba(244,210,122,.08);
  border:1px solid var(--line-gold);
  color:var(--gold);
}
.lr-tag--fb{color:#5b8def;border-color:rgba(91,141,239,.5);background:rgba(91,141,239,.1)}
.lr-tag--tg{color:#3bb7e8;border-color:rgba(59,183,232,.5);background:rgba(59,183,232,.1)}
.lr-tag--phone{color:var(--vermillion);border-color:rgba(230,57,70,.5);background:rgba(230,57,70,.1)}
.lr-tag--mail{color:var(--peacock);border-color:rgba(78,197,181,.5);background:rgba(78,197,181,.1)}

/* Guide cards */
.guide-stack{display:flex;flex-direction:column;gap:8px}
.guide-card{
  display:flex;align-items:center;gap:14px;
  padding:14px;
  background:
    radial-gradient(circle at 0% 0%, rgba(244,210,122,.08), transparent 70%),
    linear-gradient(180deg, var(--bg-paper), var(--bg-velvet));
  border:1px solid var(--line-gold);
  border-radius:14px;
  text-decoration:none;
  position:relative;
  transition:transform .1s, box-shadow .25s;
}
.guide-card:active{transform:scale(.99)}
.guide-card:hover{box-shadow:0 4px 18px rgba(244,165,40,.15)}
.gc-ic{
  font-size:24px;line-height:1;flex-shrink:0;
  width:42px;height:42px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(244,210,122,.1);
  border:1px solid var(--line-gold);
}
.gc-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.gc-hi{font-family:var(--hindi);font-size:14px;color:var(--ivory);line-height:1.15}
.gc-en{font-family:var(--body);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.gc-why{font-family:var(--body);font-size:10px;color:var(--text-3);margin-top:3px;line-height:1.35}
.gc-arrow{color:var(--marigold);font-size:20px;flex-shrink:0;font-weight:300}

/* ─── Staggered reveal on load ─── */
.stag-1{animation:slideUp .5s .05s both cubic-bezier(.2,.8,.2,1)}
.stag-2{animation:slideUp .5s .12s both cubic-bezier(.2,.8,.2,1)}
.stag-3{animation:slideUp .5s .2s both cubic-bezier(.2,.8,.2,1)}
.stag-4{animation:slideUp .5s .3s both cubic-bezier(.2,.8,.2,1)}
.stag-5{animation:slideUp .5s .4s both cubic-bezier(.2,.8,.2,1)}
.stag-6{animation:slideUp .5s .5s both cubic-bezier(.2,.8,.2,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
