:root {
  --flamingo:#FF4E88; --mango:#FFB84D; --ocean:#00C2D1; --midnight:#0A0A1B; --sand:#F7E9D7;
  --sunrise1:#12122a; --sunrise2:#1e2a56; --sunrise3:#f7b267; --sunrise4:#ffd07b;
  --sunset1:#0d1323; --sunset2:#2b1c44; --sunset3:#fe6d73; --sunset4:#ffb88c;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:#0A0A1B;color:#fff}
a{color:var(--ocean);text-decoration:none}

/* ---------- GATE ---------- */
.gate {
  position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center;
  overflow:hidden; background:linear-gradient(180deg,var(--sunrise1),var(--sunrise2) 40%,var(--sunrise3) 75%,var(--sunrise4));
  transition:background 1.2s ease;
}
.gate.sunset {
  background:linear-gradient(180deg,var(--sunset1),var(--sunset2) 40%,var(--sunset3) 75%,var(--sunset4));
}
.sky-sun {
  position:absolute; width:220vmin; height:220vmin; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(255,220,160,.9), rgba(255,160,80,.5) 25%, transparent 55%);
  top:60%; left:50%; transform:translate(-50%,-50%);
  filter:blur(6px); transition: top 1.2s ease;
}
.gate.sunset .sky-sun{ top:90%; }

.gate-panel {
  position:relative; width:min(92vw,520px); padding:28px 22px 22px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:18px; backdrop-filter: blur(6px);
}
.gate h1 {
  font-family:Montserrat,Inter,sans-serif; font-weight:800; text-align:center; margin:0 0 10px;
  font-size:clamp(22px,5vw,34px);
}
.gate p{opacity:.9; text-align:center; margin:0 0 16px}
.pin-row{display:flex; gap:10px; margin:10px 0 14px}
.pin-row input{
  flex:1; padding:14px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.08); color:#fff; font-size:16px;
}
.btn{display:inline-block; width:100%; padding:12px 14px; border-radius:12px; border:none; cursor:pointer;
     font-weight:700; background:linear-gradient(90deg,var(--flamingo),var(--mango)); color:#111}
.msg{height:20px; font-size:13px; text-align:center; margin-top:8px; opacity:.9}

/* Fire */
.burn-wrap{position:relative}
.flames{pointer-events:none; position:absolute; inset:-10px -6px; display:none;}
.flame{
  position:absolute; width:8px; height:14px; border-radius:50% 50% 45% 45%;
  background:radial-gradient(ellipse at 50% 80%, #ffd27a 20%, #ff6f3c 55%, rgba(255,0,0,.6) 80%, transparent 100%);
  filter:blur(.4px); opacity:0; animation:flick 600ms infinite ease-in-out alternate;
}
@keyframes flick{from{transform:translateY(4px) scale(1); opacity:.65} to{transform:translateY(-8px) scale(1.1); opacity:1}}
.burning .flames{display:block;}
.burning input{animation:scorch 1.1s forwards ease-in;}
@keyframes scorch{0%{opacity:1; filter:none} 60%{opacity:.35; filter:blur(2px)} 100%{opacity:0; filter:blur(6px)}}

/* Tagline */
.tagline{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center;
  padding:18px; opacity:0; pointer-events:none; transition:opacity .6s ease;}
.tagline.show{opacity:1;}
.tagline h2{font-family:Montserrat,Inter,sans-serif; font-size:clamp(22px,6vw,44px); margin:0}

/* Water */
.wave{position:absolute; left:0; width:200%; height:40vh; background:
  radial-gradient(100% 60% at 50% 40%, rgba(255,255,255,.15), rgba(255,255,255,.06) 60%, transparent 61%) 0 0/50% 100% repeat-x,
  linear-gradient(180deg, rgba(0,194,209,.45), rgba(0,194,209,.85));
  border-top-left-radius:50% 60%; border-top-right-radius:50% 60%;
  transform:translateX(-25%); filter:drop-shadow(0 -2px 18px rgba(0,194,209,.45));
}
.wash{position:absolute; inset:0; pointer-events:none; display:none;}
.wash.show{display:block;}
.wash .wave1{bottom:-40vh; animation:surf 1.4s ease forwards;}
.wash .wave2{bottom:-60vh; animation:surf 1.7s .15s ease forwards; opacity:.9}
.wash .wave3{bottom:-80vh; animation:surf 2s .3s ease forwards; opacity:.8}
@keyframes surf{from{transform:translate(-25%,0)} to{transform:translate(-25%,-140vh)}}

/* ---------- MAIN SITE ---------- */
.wrap{max-width:1100px;margin:0 auto;padding:24px}
header.main{
  position:relative; overflow:hidden; border-radius:18px; margin:24px 0;
  background:radial-gradient(1200px 400px at -10% -20%, rgba(255,184,77,.35), transparent 60%),
             radial-gradient(1200px 400px at 110% 120%, rgba(255,78,136,.35), transparent 60%),
             linear-gradient(135deg, rgba(0,194,209,.25), rgba(10,10,27,.3) 60%);
  padding:72px 28px 88px; border:1px solid rgba(255,255,255,.12)
}
.hero h1{font-family:Montserrat,Inter,sans-serif;font-weight:800;letter-spacing:.3px;font-size:clamp(28px,5vw,56px);margin:0 0 8px}
.hero p{opacity:.9;font-size:clamp(14px,2.4vw,18px);margin:6px 0 22px}
.tagbar{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 18px}
.tag{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:6px 10px;border-radius:999px;font-size:13px}
.cta{display:flex;gap:12px;flex-wrap:wrap}
.btn.ghost{background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.2)}
section{margin:36px 0;
