/* ══════════════════════════════════════════════════════════════
   Falafel Concept — Welcome Popup v2 (D3 World Map)
   Brand colors: #0C6650 deep green · #67aa07 lime · #edb106 gold
   ══════════════════════════════════════════════════════════════ */

.wm-backdrop{
  position:fixed;inset:0;z-index:9998;
  background:rgba(5,12,9,0.72);
  opacity:0;pointer-events:none;
  transition:opacity 0.35s ease;
}
.wm-backdrop.visible{opacity:1;pointer-events:auto}

.wm-popup{
  position:fixed;top:50%;left:50%;z-index:9999;
  width:520px;max-width:calc(100vw - 32px);
  background:#0a1612;
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,0.65);
  transform:translate(-50%,-50%) scale(0.96);
  opacity:0;pointer-events:none;
  transition:transform 0.35s cubic-bezier(0.2,0.9,0.3,1),opacity 0.3s ease;
  overflow:hidden;
  font-family:'Cairo',system-ui,sans-serif;
  color:#f0ede8;
}
.wm-popup.visible{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}

/* Close button — minimal */
.wm-close{
  position:absolute;top:14px;right:14px;z-index:5;
  width:28px;height:28px;
  background:transparent;border:none;
  color:rgba(240,237,232,0.35);cursor:pointer;
  font-size:22px;line-height:1;padding:0;font-family:inherit;font-weight:300;
  transition:color 0.15s;
}
.wm-close:hover{color:#f0ede8}

/* Header — flag + greeting */
.wm-head{
  display:flex;align-items:center;gap:16px;
  padding:32px 44px 14px 32px;
}
.wm-flag{ font-size:46px;line-height:1;flex-shrink:0; }
.wm-head-text{min-width:0;flex:1}
.wm-greeting{
  font-size:0.68rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:#edb106;line-height:1;
  opacity:0.95;
}
.wm-country{
  font-size:1.4rem;font-weight:800;color:#f0ede8;
  letter-spacing:-0.01em;margin-top:7px;line-height:1.15;
}

/* Map wrapper — D3 SVG Globe container (deep-space backdrop) */
.wm-map-wrap{
  position:relative;
  margin:6px 24px 16px;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(237,177,6,0.08) 0%, transparent 65%),
    linear-gradient(180deg, #050a18 0%, #02050d 100%);
  border:1px solid rgba(237,177,6,0.14);
  border-radius:14px;
  overflow:hidden;
}
.wm-world{
  width:100%;
  height:260px;
  display:block;
  position:relative;
  z-index:1;
}
.wm-world svg{
  display:block;
  /* Subtle gold halo around the globe */
  filter: drop-shadow(0 0 18px rgba(237,177,6,0.18));
}
/* Soft starfield-like overlay */
.wm-map-wrap::after{
  content:'';
  position:absolute;inset:0;
  pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(237,177,6,0.35), transparent 50%),
    radial-gradient(1px 1px at 75% 18%, rgba(255,255,255,0.25), transparent 50%),
    radial-gradient(1px 1px at 35% 78%, rgba(103,170,7,0.30), transparent 50%),
    radial-gradient(1px 1px at 88% 65%, rgba(237,177,6,0.25), transparent 50%),
    radial-gradient(1px 1px at 12% 86%, rgba(255,255,255,0.22), transparent 50%),
    radial-gradient(1px 1px at 60% 8%, rgba(255,255,255,0.18), transparent 50%);
  opacity:0.7;
  z-index:0;
}

/* Loading state */
.wm-map-loading{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:rgba(240,237,232,0.5);
  font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;
  font-weight:600;
  pointer-events:none;
  background:#0a1612;
  z-index:1;
}

/* Pulse ring (current visitor — gold) */
.wm-pulse-ring{
  transform-origin:center;
  transform-box:fill-box;
  animation:wmPulseRing 2.2s cubic-bezier(0.16,1,0.3,1) infinite;
}
.wm-pulse-ring-delayed{ animation-delay:1.1s; }
@keyframes wmPulseRing{
  0%   { transform:scale(0.5); opacity:0.9; }
  100% { transform:scale(3.2); opacity:0;   }
}

/* Flag markers — circular crop + glow */
.wm-flag-img{
  clip-path: circle(50%);
  -webkit-clip-path: circle(50%);
}
.wm-flag-marker{
  filter: drop-shadow(0 0 4px rgba(255,255,255,0.55));
  transition: filter 0.2s ease, transform 0.2s ease;
  transform-box: fill-box;
  transform-origin: center;
}
.wm-flag-marker:hover{
  filter: drop-shadow(0 0 8px rgba(255,255,255,0.85));
}
.wm-flag-current{
  filter: drop-shadow(0 0 10px rgba(237,177,6,0.85));
}
.wm-flag-current:hover{
  filter: drop-shadow(0 0 14px rgba(237,177,6,1));
}
.wm-flag-glow{ pointer-events:none; }
.wm-flag-ring{ pointer-events:none; }

/* Tooltip on hover */
.wm-tooltip{
  position:absolute;
  pointer-events:none;
  background:rgba(10,22,18,0.96);
  color:#f0ede8;
  font-size:0.74rem;
  font-weight:600;
  padding:6px 10px;
  border-radius:7px;
  border:1px solid rgba(237,177,6,0.30);
  box-shadow:0 6px 16px rgba(0,0,0,0.4);
  opacity:0;
  transform:translateY(2px);
  transition:opacity 0.16s ease, transform 0.16s ease;
  white-space:nowrap;
  z-index:3;
}
.wm-tooltip.visible{ opacity:1; transform:translateY(0); }
.wm-tooltip strong{ color:#edb106; font-weight:800; }

/* Message */
.wm-msg{
  padding:0 32px 20px;
  font-size:0.92rem;color:rgba(240,237,232,0.78);
  line-height:1.65;margin:0;
}
.wm-msg strong{color:#edb106;font-weight:700}

/* CTA */
.wm-cta{
  display:block;margin:0 32px 22px;text-align:center;
  padding:14px 18px;border-radius:10px;text-decoration:none;
  background:#67aa07;
  color:#0a0f0d;font-size:0.78rem;font-weight:800;
  letter-spacing:0.1em;text-transform:uppercase;
  transition:background 0.2s,transform 0.2s,box-shadow 0.2s;
  font-family:inherit;
}
.wm-cta:hover{
  background:#76bb09;
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(103,170,7,0.30);
}
.wm-cta:active{transform:translateY(0)}

/* Footer */
.wm-foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 32px 18px;
  font-size:0.6rem;color:rgba(240,237,232,0.42);
  letter-spacing:0.1em;text-transform:uppercase;font-weight:700;
}
.wm-foot-live{display:flex;align-items:center;gap:7px;color:#67aa07}
.wm-foot-live::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:#67aa07;
  animation:wmLive 1.6s ease-in-out infinite;
  box-shadow:0 0 8px rgba(103,170,7,0.6);
}
@keyframes wmLive{0%,100%{opacity:1}50%{opacity:0.35}}

.wm-foot-progress{flex:1;height:1px;background:rgba(255,255,255,0.04);position:relative;overflow:hidden}
.wm-foot-progress::after{
  content:'';position:absolute;inset:0 100% 0 0;
  background:#edb106;
  animation:wmProgress 8s linear forwards;
  opacity:0.7;
}
.wm-popup.paused .wm-foot-progress::after{animation-play-state:paused}
@keyframes wmProgress{from{right:100%}to{right:0}}

.wm-foot-stats{
  color:rgba(240,237,232,0.5);
  letter-spacing:0.06em;text-transform:none;
  font-variant-numeric:tabular-nums;font-weight:600;
}

/* Mobile */
@media(max-width:560px){
  .wm-popup{width:calc(100vw - 24px);max-width:440px;border-radius:16px}
  .wm-head{padding:28px 40px 12px 24px;gap:13px}
  .wm-flag{font-size:38px}
  .wm-country{font-size:1.2rem}
  .wm-map-wrap{margin:6px 18px 14px}
  .wm-world{height:220px}
  .wm-msg{padding:0 24px 18px;font-size:0.86rem}
  .wm-cta{margin:0 24px 18px;padding:13px 16px}
  .wm-foot{padding:10px 24px 16px}
}
