
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
margin:0;
font-family:Inter,sans-serif;
background:#07020d;
color:white;
overflow-x:hidden;
}
.glow{
position:fixed;
border-radius:999px;
filter:blur(120px);
opacity:.45;
z-index:-1;
}
.pink{width:420px;height:420px;background:#ff00cc;top:-100px;left:35%}
.blue{width:450px;height:450px;background:#00d9ff;bottom:-120px;right:-100px}
.yellow{width:300px;height:300px;background:#ffcc00;top:40%;left:-100px}

header{
max-width:1250px;
margin:20px auto;
padding:18px 30px;
display:grid;
grid-template-columns:1fr auto 1fr;
align-items:center;
background:rgba(255,255,255,.08);
border:1px solid rgba(255,255,255,.1);
border-radius:999px;
backdrop-filter:blur(16px);
}

.main-logo{
height:82px;
width:auto;
object-fit:contain;
justify-self:start;
}

nav{
display:flex;
gap:18px;
justify-content:center;
}

nav a{
padding:14px 22px;
border-radius:999px;
background:rgba(255,255,255,.1);
border:1px solid rgba(255,255,255,.1);
color:white;
text-decoration:none;
font-weight:900;
letter-spacing:.08em;
font-size:13px;
transition:.3s;
}

nav a:hover{
background:white;
color:black;
}

.hero{
max-width:1200px;
margin:auto;
padding:90px 20px;
text-align:center;
}

.fun-banner{
display:inline-block;
padding:20px 34px;
border-radius:999px;
background:linear-gradient(90deg,#ff00c8,#ff5a00,#ffe600,#00e5ff);
color:black;
font-weight:900;
font-size:clamp(18px,3vw,34px);
letter-spacing:.08em;
box-shadow:0 20px 40px rgba(255,0,180,.35);
margin-bottom:35px;
}

.hero h1{
font-size:clamp(60px,10vw,120px);
line-height:.9;
margin:0;
font-weight:900;
letter-spacing:-.06em;
}

.hero h1 span{
background:linear-gradient(90deg,#ffe986,#ff42c6,#43f0ff);
-webkit-background-clip:text;
color:transparent;
}

.hero p{
max-width:850px;
margin:25px auto 0;
font-size:20px;
line-height:1.8;
color:rgba(255,255,255,.75);
}

.split-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:30px;
margin-top:70px;
}

.split-card{
padding:35px;
border-radius:42px;
display:grid;
align-content:space-between;
min-height:520px;
overflow:hidden;
box-shadow:0 30px 90px rgba(0,0,0,.35);
}

.adult-card{
background:linear-gradient(135deg,#b3008f,#19042f,#000);
}

.family-card{
background:linear-gradient(135deg,#009ed1,#091946,#000);
}

.split-card small{
font-size:12px;
font-weight:900;
letter-spacing:.3em;
color:#fff0a8;
}

.split-card h2{
font-size:70px;
line-height:.9;
margin:15px 0;
}

.split-card p{
line-height:1.7;
font-size:18px;
color:rgba(255,255,255,.75);
}

.split-card img{
width:100%;
max-height:260px;
object-fit:contain;
}

.section{
max-width:1200px;
margin:auto;
padding:90px 20px;
}

.section-top{
display:flex;
justify-content:space-between;
align-items:end;
gap:20px;
}

.section-top small{
font-size:12px;
font-weight:900;
letter-spacing:.3em;
color:#fff0a8;
}

.section-top h2{
font-size:70px;
line-height:.9;
margin:12px 0 0;
}

.ticket-btn{
padding:16px 24px;
border-radius:999px;
background:linear-gradient(90deg,#ffe600,#ff31c4,#00e5ff);
color:black;
font-weight:900;
text-decoration:none;
}

.ticket-btn.white{
background:white;
}

.cards{
display:grid;
gap:24px;
margin-top:40px;
}

.cards.two{
grid-template-columns:1fr 1fr;
}

.cards.three{
grid-template-columns:1fr 1fr 1fr;
}

.card{
padding:22px;
border-radius:32px;
background:rgba(255,255,255,.08);
border:1px solid rgba(255,255,255,.1);
backdrop-filter:blur(14px);
}

.img-wrap{
background:rgba(0,0,0,.35);
border-radius:24px;
padding:20px;
min-height:230px;
display:grid;
place-items:center;
}

.img-wrap img{
width:100%;
max-height:210px;
object-fit:contain;
}

.card span{
display:inline-block;
margin-top:18px;
padding:8px 12px;
border-radius:999px;
background:#ff45c7;
color:black;
font-size:11px;
font-weight:900;
letter-spacing:.15em;
}

.card span.family{
background:#4fe8ff;
}

.card h3{
font-size:32px;
margin:18px 0 10px;
}

.card p{
line-height:1.7;
color:rgba(255,255,255,.75);
}

.contact{
padding:80px 20px;
}

.contact-box{
max-width:1200px;
margin:auto;
padding:42px;
border-radius:40px;
background:rgba(255,255,255,.08);
border:1px solid rgba(255,255,255,.1);
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
}

.contact-box small{
font-size:12px;
font-weight:900;
letter-spacing:.3em;
color:#fff0a8;
}

.contact-box h2{
font-size:60px;
margin:12px 0;
}

.details p{
font-size:20px;
}

.contact-form{
display:grid;
gap:18px;
}

.contact-form input,
.contact-form textarea{
padding:18px 20px;
border-radius:18px;
border:1px solid rgba(255,255,255,.12);
background:rgba(0,0,0,.3);
color:white;
font-family:inherit;
font-size:16px;
}

.contact-form textarea{
min-height:180px;
resize:vertical;
}

.contact-form button{
padding:18px;
border:none;
border-radius:999px;
background:linear-gradient(90deg,#ffe600,#ff31c4,#00e5ff);
font-weight:900;
font-size:15px;
cursor:pointer;
}

footer{
padding:20px;
text-align:center;
color:rgba(255,255,255,.5);
}

@media(max-width:900px){
header{
grid-template-columns:1fr;
gap:18px;
margin:12px;
border-radius:32px;
}
.main-logo{
justify-self:center;
}
nav{
flex-wrap:wrap;
}
.split-grid,
.cards.two,
.cards.three,
.contact-box{
grid-template-columns:1fr;
}
.section-top{
flex-direction:column;
align-items:flex-start;
}
.hero h1{
font-size:60px;
}
.split-card h2,
.section-top h2,
.contact-box h2{
font-size:48px;
}
}
.contact-form {
  display: grid;
  gap: 16px;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color: white;
  font-size: 16px;
  outline: none;
}

.contact-form textarea {
  min-height: 150px;
  resize: vertical;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: rgba(255,255,255,.55);
}

.contact-form button {
  padding: 18px 24px;
  border: none;
  border-radius: 999px;
  background: linear-gradient(90deg,#ffe600,#ff31c4,#00e5ff);
  color: black;
  font-weight: 900;
  font-size: 15px;
  cursor: pointer;
  text-transform: uppercase;
  .contact-form {
    display: flex;
    flex-direction: column;
    gap: 15px;
    max-width: 600px;
    width: 100%;
    margin: auto;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08);
    color: white;
    font-size: 16px;
    backdrop-filter: blur(10px);
}

.contact-form textarea {
    min-height: 140px;
}

.contact-form button {
    padding: 16px;
    border: none;
    border-radius: 999px;
    background: linear-gradient(90deg,#ff31c4,#00e5ff);
    color: white;
    font-weight: bold;
    font-size: 16px;
    cursor: pointer;
    transition: 0.3s;
}

.contact-form button:hover {
    transform: scale(1.03);
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: rgba(255,255,255,0.7);
}
}