*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0f;--surface:#16161e;--border:#252530;
  --accent:#e8533a;--accent2:#f0834e;--green:#3ecf8e;--yellow:#f5c842;
  --text:#f0efe8;--text2:#8888a0;--text3:#44445a;
}
html,body{font-family:'Syne',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}

/* INTRO */
#intro{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;transition:opacity .8s}
#intro.hidden{opacity:0;pointer-events:none}
.intro-bug{font-size:64px;margin-bottom:1rem;display:block;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse-m{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.9);opacity:0.5}}
.intro-tag{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-bottom:10px}
.intro-h1{font-size:clamp(26px,5vw,52px);font-weight:800;line-height:1.1;margin-bottom:12px}
.intro-h1 em{color:var(--accent);font-style:normal}
.intro-sub{font-size:14px;color:var(--text2);max-width:440px;margin:0 auto 2rem;line-height:1.7}
.dest-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:1.75rem}
.dest-btn{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px 22px;cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif;color:var(--text);text-align:center;min-width:140px}
.dest-btn:hover{border-color:var(--accent);transform:translateY(-3px)}
.dest-btn.sel{border-color:var(--accent);background:#1a100d}
.dest-btn .df{font-size:32px;display:block;margin-bottom:8px}
.dest-btn .dn{font-size:14px;font-weight:700}
.dest-btn .dr{font-size:11px;color:var(--accent2);font-family:'DM Mono',monospace;margin-top:3px}
.go-btn{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:14px 36px;font-family:'Syne',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 0 32px rgba(232,83,58,.3)}
.go-btn:hover{background:var(--accent2);transform:translateY(-2px)}
.go-btn:disabled{opacity:.3;cursor:default;transform:none;box-shadow:none}
.intro-legal{margin-top:1.25rem;font-family:'DM Mono',monospace;font-size:10px;display:flex;flex-wrap:wrap;gap:6px 14px;justify-content:center}
.intro-legal a{color:var(--text3);text-decoration:none;transition:color .2s}
.intro-legal a:hover{color:var(--text2)}

/* MAP */
#map{flex:1;z-index:1}
.leaflet-tile-pane{filter:brightness(0.35) saturate(0.3) hue-rotate(200deg)}
.leaflet-container{background:#0a0a0f}

/* PANEL */
#panel{
  position:fixed;bottom:0;left:0;right:0;z-index:500;
  background:linear-gradient(transparent,rgba(10,10,15,.97) 25%);
  padding:3rem 1.5rem 1.5rem;
  pointer-events:none;
}
#panel.active{pointer-events:all}
.panel-inner{max-width:620px;margin:0 auto}
.p-stage{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-bottom:6px;opacity:0;transform:translateY(8px);transition:all .4s}
.p-title{font-size:20px;font-weight:700;margin-bottom:8px;opacity:0;transform:translateY(8px);transition:all .4s .08s}
.p-body{font-size:13px;color:var(--text2);line-height:1.75;margin-bottom:1.25rem;opacity:0;transform:translateY(8px);transition:all .4s .16s;max-width:520px}
.p-body strong{color:var(--yellow)}
.p-actions{display:flex;gap:8px;opacity:0;transform:translateY(8px);transition:all .4s .22s}
.panel-shown .p-stage,.panel-shown .p-title,.panel-shown .p-body,.panel-shown .p-actions{opacity:1;transform:translateY(0)}
.p-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:11px 22px;font-family:'Syne',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s}
.p-btn:hover{background:var(--accent2)}
.p-skip{background:rgba(255,255,255,.05);color:var(--text2);border:1px solid var(--border);border-radius:10px;padding:11px 18px;font-family:'Syne',sans-serif;font-size:13px;cursor:pointer;transition:all .2s}
.p-skip:hover{border-color:var(--text2);color:var(--text)}

/* DOTS */
#dots{position:fixed;top:1rem;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:500}
.dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);transition:all .4s}
.dot.done{background:var(--accent);opacity:.6}
.dot.active{background:var(--accent2);box-shadow:0 0 10px var(--accent2)}

/* PLANE MARKER */
.plane-icon{font-size:24px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.8))}

/* CITY POPUP custom */
.leaflet-popup-content-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:'Syne',sans-serif;box-shadow:0 8px 32px rgba(0,0,0,.6)}
.leaflet-popup-tip{background:var(--surface)}
.leaflet-popup-content{margin:12px 16px;font-size:13px;line-height:1.6}

/* Remove o chrome branco padrão das tooltips do Leaflet */
.leaflet-tooltip{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}
.leaflet-tooltip::before{display:none!important}

/* CTA */
#cta{position:fixed;inset:0;z-index:900;background:rgba(10,10,15,.97);display:none;overflow-y:auto;padding:2rem 1.5rem}
#cta.show{display:block}
.cta-inner{max-width:560px;margin:0 auto;padding-bottom:2rem}
.cta-top{text-align:center;padding:1rem 0 1.5rem}
.cta-h{font-size:clamp(22px,4vw,36px);font-weight:800;margin-bottom:8px}
.cta-h span{color:var(--green)}
.cta-sub3{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:1.5rem}
.stats3{display:flex;gap:10px;margin-bottom:1.75rem}
.s3b{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;text-align:center}
.s3b-n{font-size:28px;font-weight:800;color:var(--accent)}
.s3b-l{font-size:11px;color:var(--text2);font-family:'DM Mono',monospace;margin-top:3px}
.prev-wrap{margin-bottom:1.5rem}
.pi2{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:10px;display:flex;gap:14px;align-items:flex-start;cursor:pointer;transition:all .2s;text-decoration:none;color:inherit}
.pi2:hover{border-color:var(--green);transform:translateX(4px)}
.pi2-e{font-size:28px;flex-shrink:0}
.pi2-t{font-size:14px;font-weight:700;margin-bottom:3px}
.pi2-d{font-size:12px;color:var(--text2);line-height:1.5}
.pi2-badge{font-family:'DM Mono',monospace;font-size:10px;color:var(--green);border:1px solid rgba(62,207,142,.4);border-radius:4px;padding:2px 7px;display:inline-block;margin-top:6px}
.replay3{width:100%;background:transparent;color:var(--text2);border:1px solid var(--border);border-radius:10px;padding:12px;font-family:'Syne',sans-serif;font-size:14px;cursor:pointer;transition:all .2s;margin-top:4px}
.replay3:hover{border-color:var(--text);color:var(--text)}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────── */

/* Tablet */
@media (max-width: 768px) {
  .intro-bug{font-size:48px}
  .intro-sub{font-size:13px;margin-bottom:1.5rem}
  .dest-btn{min-width:110px;padding:13px 16px}
  .dest-btn .df{font-size:26px}

  #panel{padding:2rem 1.25rem 1.25rem}
  .p-title{font-size:18px}
  .p-body{font-size:12.5px;margin-bottom:1rem}

  .s3b-n{font-size:23px}
  .cta-inner{padding-bottom:1.5rem}
}

/* Mobile */
@media (max-width:480px) {
  /* Intro */
  .intro-bug{font-size:38px;margin-bottom:.75rem}
  .intro-h1{margin-bottom:10px}
  .intro-sub{font-size:12.5px;margin-bottom:1.25rem;max-width:100%}
  .intro-tag{font-size:10px}
  .dest-row{gap:8px}
  .dest-btn{min-width:96px;padding:11px 10px;border-radius:12px}
  .dest-btn .df{font-size:22px;margin-bottom:5px}
  .dest-btn .dn{font-size:12px}
  .dest-btn .dr{font-size:10px}
  .go-btn{padding:12px 24px;font-size:14px;width:100%;max-width:280px}

  /* Panel — compacto para mostrar mais mapa */
  #panel{padding:2rem .875rem .875rem}
  #panel{padding-bottom:calc(.875rem + env(safe-area-inset-bottom, 0px))}
  .panel-inner{max-width:100%}
  .p-stage{font-size:9px}
  .p-title{font-size:15px;margin-bottom:6px}
  .p-body{font-size:11.5px;line-height:1.6;margin-bottom:.75rem}
  .p-actions{flex-direction:column;gap:6px}
  .p-btn{width:100%;padding:11px 16px;font-size:13px;text-align:center;border-radius:9px}
  .p-skip{width:100%;text-align:center;padding:9px 16px;font-size:12px}

  /* Progress dots */
  .dot{width:6px;height:6px}
  #dots{gap:5px;top:.6rem}

  /* CTA */
  #cta{padding:1.25rem 1rem}
  #cta{padding-bottom:calc(1.25rem + env(safe-area-inset-bottom, 0px))}
  .cta-top{padding:.5rem 0 1.25rem}
  .cta-h{font-size:clamp(18px,5.5vw,28px)}
  .cta-sub3{font-size:13px;margin-bottom:1.25rem}
  .stats3{gap:7px;margin-bottom:1.25rem}
  .s3b{padding:12px 6px;border-radius:12px}
  .s3b-n{font-size:20px}
  .s3b-l{font-size:10px}
  .prev-wrap{margin-bottom:1.25rem}
  .pi2{padding:12px;gap:10px;border-radius:12px}
  .pi2-e{font-size:22px}
  .pi2-t{font-size:13px}
  .pi2-d{font-size:11px;line-height:1.45}
  .replay3{padding:11px;font-size:13px}
}

/* Mobile pequeno (≤380px) */
@media (max-width:380px) {
  .dest-btn{min-width:86px;padding:10px 8px}
  .dest-btn .df{font-size:20px}
  .dest-btn .dn{font-size:11px}
  .dest-row{gap:6px}
  .p-title{font-size:14px}
  .p-body{font-size:11px}
  .stats3{flex-direction:column;gap:6px}
  .s3b{padding:10px 12px;display:flex;align-items:center;gap:12px;text-align:left}
  .s3b-n{font-size:22px;flex-shrink:0}
  .s3b-l{margin-top:0}
}
