*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --dark:#312C51;
  --purple:#48426D;
  --peach:#F0C38E;
  --pink:#F1AA9B;
  --cream:#FAF8F5;
  --glass:rgba(49,44,81,0.6);
  --card:rgba(255,255,255,0.04);
  --border:rgba(240,195,142,0.15);
}
html{scroll-behavior:smooth;}
body{background:var(--dark);font-family:'Nunito',sans-serif;color:#fff;overflow-x:hidden;}
::selection{background:var(--peach);color:var(--dark);}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--dark);}
::-webkit-scrollbar-thumb{background:var(--purple);border-radius:6px;}

/* ══════════════════════════════
   HERO
══════════════════════════════ */
.hero{
  min-height:100vh;
  background:linear-gradient(135deg,var(--dark) 0%,#1e1a3a 50%,var(--purple) 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;padding:100px 5% 60px;
}
.hero-orb{
  position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;
}
.orb1{width:500px;height:500px;background:rgba(240,195,142,.08);top:-150px;right:-150px;}
.orb2{width:400px;height:400px;background:rgba(241,170,155,.06);bottom:-100px;left:-100px;}
.orb3{width:300px;height:300px;background:rgba(72,66,109,.4);top:50%;left:50%;transform:translate(-50%,-50%);}

.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;max-width:1200px;width:100%;z-index:1;
}
.hero-left{ }
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(240,195,142,.1);border:1px solid var(--border);
  color:var(--peach);font-family:'Poppins',sans-serif;font-size:.8rem;font-weight:500;
  padding:7px 16px;border-radius:50px;margin-bottom:24px;
}
.hero-badge i{font-size:.75rem;}
.hero-h1{
  font-family:'Fredoka One',cursive;
  font-size:clamp(2.8rem,5vw,4.5rem);
  line-height:1.1;color:#fff;margin-bottom:20px;
}
.hero-h1 .accent{
  background:linear-gradient(135deg,var(--peach),var(--pink));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-p{
  font-family:'Poppins',sans-serif;font-size:1rem;
  color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:36px;max-width:480px;
}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;}
.hstat{text-align:center;}
.hstat-num{font-family:'Fredoka One',cursive;font-size:1.8rem;color:var(--peach);}
.hstat-label{font-size:.75rem;color:rgba(255,255,255,.45);font-family:'Poppins',sans-serif;margin-top:2px;}

/* Floating card right */
.hero-right{position:relative;display:flex;align-items:center;justify-content:center;}
.float-card{
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:24px;padding:32px;width:100%;max-width:380px;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  animation:floatY 4s ease-in-out infinite;
}
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.fc-title{font-family:'Fredoka One',cursive;font-size:1.2rem;color:var(--peach);margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.fc-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.fc-icon-box{
  width:40px;height:40px;border-radius:10px;
  background:rgba(240,195,142,.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--peach);font-size:.9rem;flex-shrink:0;
}
.fc-info label{display:block;font-size:.7rem;color:rgba(255,255,255,.4);font-family:'Poppins',sans-serif;}
.fc-info span{font-family:'Nunito',sans-serif;font-weight:700;font-size:.9rem;}
.fc-divider{border:none;border-top:1px solid rgba(255,255,255,.06);margin:16px 0;}
.fc-btn{
  width:100%;padding:13px;border-radius:14px;border:none;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark);font-family:'Fredoka One',cursive;font-size:1rem;
  cursor:pointer;transition:.3s;letter-spacing:.5px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.fc-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(240,195,142,.3);}

/* Floating mini badges */
.fbadge{
  position:absolute;
  background:rgba(255,255,255,.08);backdrop-filter:blur(12px);
  border:1px solid var(--border);border-radius:14px;
  padding:10px 14px;display:flex;align-items:center;gap:8px;
  font-size:.78rem;font-family:'Nunito',sans-serif;font-weight:700;
  animation:floatY 3s ease-in-out infinite;
}
.fb1{top:-20px;left:-30px;animation-delay:.5s;}
.fb2{bottom:-10px;right:-20px;animation-delay:1.2s;}
.fbadge i{color:var(--peach);}

/* ══════════════════════════════
   SECTION BASE
══════════════════════════════ */
section{padding:90px 5%;}
.sec-label{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(240,195,142,.08);border:1px solid var(--border);
  color:var(--peach);font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:600;
  padding:6px 16px;border-radius:50px;margin-bottom:16px;letter-spacing:.5px;text-transform:uppercase;
}
.sec-title{
  font-family:'Fredoka One',cursive;
  font-size:clamp(2rem,4vw,3rem);
  color:#fff;margin-bottom:12px;line-height:1.1;
}
.sec-sub{
  font-family:'Poppins',sans-serif;font-size:.95rem;
  color:rgba(255,255,255,.5);max-width:550px;line-height:1.8;
}
.text-peach{color:var(--peach);}
.text-center{text-align:center;margin:0 auto;}

/* ══════════════════════════════
   FLOOR MAP
══════════════════════════════ */
.map-sec{background:linear-gradient(180deg,var(--dark) 0%,#1a1730 100%);}
.map-wrap{
  max-width:1100px;margin:0 auto;
}
.map-filters{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px;justify-content:center;
}
.mf-btn{
  display:flex;align-items:center;gap:8px;
  padding:9px 20px;border-radius:50px;border:1px solid var(--border);
  background:transparent;color:rgba(255,255,255,.65);
  font-family:'Nunito',sans-serif;font-weight:700;font-size:.85rem;
  cursor:pointer;transition:.3s;
}
.mf-btn:hover,.mf-btn.active{background:rgba(240,195,142,.12);border-color:var(--peach);color:var(--peach);}
.mf-dot{width:8px;height:8px;border-radius:50%;}

.floor-map{
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:24px;padding:32px;
  position:relative;min-height:400px;
}
.map-legend{
  display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px;
}
.leg-item{display:flex;align-items:center;gap:8px;font-size:.8rem;font-family:'Poppins',sans-serif;color:rgba(255,255,255,.6);}
.leg-box{width:14px;height:14px;border-radius:4px;}

.tables-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(110px,1fr));
  gap:14px;
}
.table-card{
  background:rgba(255,255,255,.04);
  border:2px solid rgba(255,255,255,.08);
  border-radius:16px;padding:16px 12px;
  text-align:center;cursor:pointer;
  transition:.35s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.table-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  opacity:0;transition:.3s;
}
.table-card:hover:not(.booked){transform:translateY(-4px);border-color:var(--peach);box-shadow:0 12px 32px rgba(240,195,142,.2);}
.table-card.selected{border-color:var(--peach);background:rgba(240,195,142,.1);transform:translateY(-4px);}
.table-card.booked{opacity:.4;cursor:not-allowed;}
.table-card i{font-size:1.6rem;color:var(--peach);display:block;margin-bottom:8px;position:relative;z-index:1;}
.table-card.booked i{color:rgba(255,255,255,.3);}
.tc-num{font-family:'Fredoka One',cursive;font-size:.95rem;color:#fff;position:relative;z-index:1;}
.tc-seats{font-size:.72rem;color:rgba(255,255,255,.45);font-family:'Poppins',sans-serif;position:relative;z-index:1;}
.tc-zone{
  position:absolute;top:6px;right:6px;
  font-size:.6rem;padding:2px 7px;border-radius:50px;
  font-family:'Poppins',sans-serif;font-weight:600;
}
.zone-in{background:rgba(240,195,142,.15);color:var(--peach);}
.zone-out{background:rgba(241,170,155,.15);color:var(--pink);}
.zone-priv{background:rgba(72,66,109,.5);color:#bbb;}

/* ══════════════════════════════
   BOOKING FORM
══════════════════════════════ */
.form-sec{background:#0f0d1f;}
.booking-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;max-width:1100px;margin:0 auto;
  align-items:start;
}
.form-card{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:24px;padding:36px;
}
.form-card h3{
  font-family:'Fredoka One',cursive;font-size:1.4rem;color:var(--peach);
  margin-bottom:28px;display:flex;align-items:center;gap:10px;
}
.form-card h3 i{font-size:1.1rem;}

/* STEPS */
.steps-bar{display:flex;align-items:center;margin-bottom:32px;gap:0;}
.step-item{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;
  position:relative;
}
.step-item:not(:last-child)::after{
  content:'';position:absolute;top:16px;left:calc(50% + 16px);right:calc(-50% + 16px);
  height:2px;background:rgba(255,255,255,.08);z-index:0;
}
.step-item.done::after,.step-item.active::after{background:var(--peach);}
.step-circle{
  width:32px;height:32px;border-radius:50%;
  border:2px solid rgba(255,255,255,.15);
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fredoka One',cursive;font-size:.85rem;color:rgba(255,255,255,.4);
  transition:.4s;position:relative;z-index:1;
}
.step-item.active .step-circle{
  border-color:var(--peach);color:var(--peach);
  box-shadow:0 0 20px rgba(240,195,142,.3);
  background:rgba(240,195,142,.1);
}
.step-item.done .step-circle{
  border-color:var(--peach);background:var(--peach);color:var(--dark);
}
.step-label{font-size:.68rem;color:rgba(255,255,255,.4);font-family:'Poppins',sans-serif;text-align:center;}
.step-item.active .step-label,.step-item.done .step-label{color:var(--peach);}

/* FORM PANELS */
.form-panel{display:none;}
.form-panel.active{display:block;animation:fadeUp .4s ease;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

.field-group{margin-bottom:20px;}
.field-group label{
  display:flex;align-items:center;gap:8px;
  font-family:'Poppins',sans-serif;font-size:.82rem;font-weight:500;
  color:rgba(255,255,255,.6);margin-bottom:8px;
}
.field-group label i{color:var(--peach);font-size:.8rem;}
.field-input{
  width:100%;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);border-radius:12px;
  padding:12px 16px;color:#fff;
  font-family:'Nunito',sans-serif;font-size:.9rem;font-weight:600;
  outline:none;transition:.3s;appearance:none;
}
.field-input:focus{border-color:var(--peach);background:rgba(240,195,142,.05);box-shadow:0 0 0 3px rgba(240,195,142,.08);}
.field-input::placeholder{color:rgba(255,255,255,.25);}
.field-input option{background:#312C51;}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

/* GUEST SELECTOR */
.guest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.guest-btn{
  padding:12px 8px;border-radius:12px;
  border:1px solid rgba(255,255,255,.1);
  background:transparent;color:rgba(255,255,255,.6);
  font-family:'Fredoka One',cursive;font-size:.9rem;
  cursor:pointer;transition:.3s;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.guest-btn i{font-size:.85rem;}
.guest-btn:hover,.guest-btn.active{
  border-color:var(--peach);color:var(--peach);
  background:rgba(240,195,142,.1);
  transform:translateY(-2px);
}

/* TIME SLOTS */
.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.time-slot{
  padding:10px 6px;border-radius:10px;
  border:1px solid rgba(255,255,255,.1);
  background:transparent;color:rgba(255,255,255,.65);
  font-family:'Nunito',sans-serif;font-weight:700;font-size:.8rem;
  cursor:pointer;transition:.3s;text-align:center;
}
.time-slot:hover:not(.unavail){border-color:var(--peach);color:var(--peach);background:rgba(240,195,142,.08);}
.time-slot.selected{border-color:var(--peach);background:rgba(240,195,142,.15);color:var(--peach);}
.time-slot.unavail{opacity:.3;cursor:not-allowed;text-decoration:line-through;}

/* OCCASION */
.occasion-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.occ-btn{
  padding:14px 10px;border-radius:12px;
  border:1px solid rgba(255,255,255,.1);background:transparent;
  color:rgba(255,255,255,.65);font-family:'Nunito',sans-serif;font-weight:700;font-size:.82rem;
  cursor:pointer;transition:.3s;display:flex;flex-direction:column;align-items:center;gap:6px;
}
.occ-btn i{font-size:1.2rem;color:rgba(255,255,255,.4);transition:.3s;}
.occ-btn:hover,.occ-btn.active{border-color:var(--peach);color:var(--peach);background:rgba(240,195,142,.08);}
.occ-btn.active i,.occ-btn:hover i{color:var(--peach);}

/* SEATING */
.seating-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.seat-btn{
  padding:16px 8px;border-radius:12px;
  border:1px solid rgba(255,255,255,.1);background:transparent;
  color:rgba(255,255,255,.65);font-family:'Nunito',sans-serif;font-weight:700;font-size:.8rem;
  cursor:pointer;transition:.3s;display:flex;flex-direction:column;align-items:center;gap:6px;
  text-align:center;
}
.seat-btn i{font-size:1.4rem;color:rgba(255,255,255,.35);transition:.3s;}
.seat-btn:hover,.seat-btn.active{border-color:var(--peach);color:var(--peach);background:rgba(240,195,142,.08);}
.seat-btn.active i,.seat-btn:hover i{color:var(--peach);}

/* FORM NAV BTNS */
.form-nav{display:flex;justify-content:space-between;margin-top:28px;gap:12px;}
.btn-prev{
  padding:12px 24px;border-radius:12px;border:1px solid rgba(255,255,255,.15);
  background:transparent;color:rgba(255,255,255,.7);
  font-family:'Fredoka One',cursive;font-size:.9rem;cursor:pointer;transition:.3s;
  display:flex;align-items:center;gap:8px;
}
.btn-prev:hover{border-color:var(--peach);color:var(--peach);}
.btn-next{
  flex:1;padding:13px 24px;border-radius:12px;border:none;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark);font-family:'Fredoka One',cursive;font-size:.95rem;
  cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(240,195,142,.3);}

/* SUMMARY CARD */
.summary-card{
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:24px;padding:32px;position:sticky;top:90px;
}
.summary-card h3{font-family:'Fredoka One',cursive;font-size:1.2rem;color:var(--peach);margin-bottom:24px;display:flex;align-items:center;gap:10px;}
.sum-row{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.05);
}
.sum-row:last-of-type{border-bottom:none;}
.sum-icon{
  width:36px;height:36px;border-radius:10px;
  background:rgba(240,195,142,.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--peach);font-size:.85rem;flex-shrink:0;
}
.sum-key{font-size:.75rem;color:rgba(255,255,255,.4);font-family:'Poppins',sans-serif;margin-bottom:2px;}
.sum-val{font-family:'Nunito',sans-serif;font-weight:700;font-size:.92rem;color:#fff;}
.sum-placeholder{color:rgba(255,255,255,.25);font-style:italic;font-size:.82rem;}

.policy-box{
  background:rgba(240,195,142,.05);border:1px solid rgba(240,195,142,.1);
  border-radius:14px;padding:16px;margin-top:20px;
}
.policy-box p{font-size:.78rem;font-family:'Poppins',sans-serif;color:rgba(255,255,255,.45);line-height:1.7;}
.policy-box p i{color:var(--peach);margin-right:4px;}

/* CONFIRM SCREEN */
.confirm-screen{
  display:none;text-align:center;padding:20px 0;
}
.confirm-screen.show{display:block;animation:fadeUp .5s ease;}
.confirm-icon{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-size:2rem;color:var(--dark);
  box-shadow:0 0 40px rgba(240,195,142,.4);
  animation:scaleIn .5s cubic-bezier(.4,0,.2,1);
}
@keyframes scaleIn{from{transform:scale(0);}to{transform:scale(1);}}
.confirm-screen h2{font-family:'Fredoka One',cursive;font-size:1.8rem;color:var(--peach);margin-bottom:8px;}
.confirm-screen p{font-family:'Poppins',sans-serif;font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.7;}
.confirm-id{
  background:rgba(240,195,142,.08);border:1px solid var(--border);
  border-radius:12px;padding:14px;margin:20px 0;
  font-family:'Fredoka One',cursive;font-size:1.3rem;color:var(--peach);
  letter-spacing:2px;
}

/* ══════════════════════════════
   AMENITIES
══════════════════════════════ */
.amenities-sec{background:var(--dark);}
.amenities-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:20px;max-width:1100px;margin:50px auto 0;
}
.am-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:20px;padding:28px 22px;text-align:center;
  transition:.35s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.am-card::before{
  content:'';position:absolute;bottom:-60px;left:50%;transform:translateX(-50%);
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(240,195,142,.12),transparent);
  transition:.4s;
}
.am-card:hover{transform:translateY(-8px);border-color:rgba(240,195,142,.25);}
.am-card:hover::before{bottom:-20px;}
.am-icon{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,rgba(240,195,142,.15),rgba(241,170,155,.1));
  display:flex;align-items:center;justify-content:center;
  color:var(--peach);font-size:1.4rem;margin:0 auto 16px;
  transition:.3s;
}
.am-card:hover .am-icon{background:linear-gradient(135deg,var(--peach),var(--pink));color:var(--dark);transform:scale(1.1);}
.am-title{font-family:'Fredoka One',cursive;font-size:1.05rem;color:#fff;margin-bottom:6px;}
.am-desc{font-family:'Poppins',sans-serif;font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.6;}

/* ══════════════════════════════
   TESTIMONIALS
══════════════════════════════ */
.review-sec{background:#0f0d1f;}
.reviews-track{
  display:flex;gap:20px;overflow-x:auto;padding:10px 0 20px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  max-width:1100px;margin:50px auto 0;
}
.reviews-track::-webkit-scrollbar{height:4px;}
.reviews-track::-webkit-scrollbar-thumb{background:var(--purple);border-radius:4px;}
.rev-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:20px;padding:28px;min-width:300px;max-width:320px;
  flex-shrink:0;scroll-snap-align:start;
  transition:.3s;
}
.rev-card:hover{border-color:var(--border);transform:translateY(-4px);}
.rev-stars{color:var(--peach);font-size:.85rem;margin-bottom:14px;}
.rev-text{font-family:'Poppins',sans-serif;font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:18px;}
.rev-user{display:flex;align-items:center;gap:12px;}
.rev-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--dark));
  display:flex;align-items:center;justify-content:center;
  font-family:'Fredoka One',cursive;font-size:1rem;color:var(--peach);
  border:2px solid var(--border);flex-shrink:0;
}
.rev-name{font-family:'Nunito',sans-serif;font-weight:800;font-size:.88rem;}
.rev-meta{font-family:'Poppins',sans-serif;font-size:.72rem;color:rgba(255,255,255,.4);}

/* ══════════════════════════════
   FAQ
══════════════════════════════ */
.faq-sec{background:var(--dark);}
.faq-wrap{max-width:750px;margin:50px auto 0;}
.faq-item{
  border-bottom:1px solid rgba(255,255,255,.07);
}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;background:transparent;border:none;
  color:#fff;font-family:'Nunito',sans-serif;font-weight:700;font-size:.95rem;
  cursor:pointer;text-align:left;gap:16px;transition:.3s;
}
.faq-q:hover{color:var(--peach);}
.faq-q i{color:var(--peach);font-size:.85rem;flex-shrink:0;transition:.35s;}
.faq-item.open .faq-q i{transform:rotate(45deg);}
.faq-a{
  max-height:0;overflow:hidden;transition:.4s cubic-bezier(.4,0,.2,1);
}
.faq-item.open .faq-a{max-height:200px;}
.faq-a p{
  padding:0 0 20px;
  font-family:'Poppins',sans-serif;font-size:.85rem;
  color:rgba(255,255,255,.55);line-height:1.8;
}

/* ══════════════════════════════
   CTA BANNER
══════════════════════════════ */
.cta-sec{
  background:linear-gradient(135deg,var(--purple) 0%,var(--dark) 100%);
  padding:80px 5%;text-align:center;
  position:relative;overflow:hidden;
}
.cta-sec::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(240,195,142,.08),transparent);
  top:-200px;left:50%;transform:translateX(-50%);
  pointer-events:none;
}
.cta-sec h2{font-family:'Fredoka One',cursive;font-size:clamp(2rem,4vw,3.2rem);color:#fff;margin-bottom:14px;}
.cta-sec p{font-family:'Poppins',sans-serif;font-size:.95rem;color:rgba(255,255,255,.55);margin-bottom:32px;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.cta-btn-primary{
  padding:14px 36px;border-radius:14px;border:none;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark);font-family:'Fredoka One',cursive;font-size:1rem;
  cursor:pointer;transition:.3s;display:flex;align-items:center;gap:8px;
}
.cta-btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(240,195,142,.3);}
.cta-btn-outline{
  padding:13px 36px;border-radius:14px;border:2px solid rgba(240,195,142,.4);
  background:transparent;color:var(--peach);font-family:'Fredoka One',cursive;font-size:1rem;
  cursor:pointer;transition:.3s;display:flex;align-items:center;gap:8px;
}
.cta-btn-outline:hover{border-color:var(--peach);background:rgba(240,195,142,.08);}

/* RESPONSIVE */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:40px;text-align:center;}
  .hero-p{margin:0 auto 36px;}
  .hero-stats{justify-content:center;}
  .hero-right{justify-content:center;}
  .fbadge{display:none;}
  .booking-grid{grid-template-columns:1fr;}
  .summary-card{position:static;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .nav-links,.nav-cta{display:none;}
  .ham{display:flex;}
  .mob-bar{display:block;}
  body{padding-bottom:70px;}
}
@media(max-width:600px){
  section{padding:70px 5%;}
  .hero{padding:90px 5% 50px;}
  .footer-grid{grid-template-columns:1fr;}
  .hero-h1{font-size:2.4rem;}
  .field-row{grid-template-columns:1fr;}
  .time-grid{grid-template-columns:repeat(2,1fr);}
  .guest-grid{grid-template-columns:repeat(4,1fr);}
  .occasion-grid{grid-template-columns:1fr 1fr;}
  .seating-grid{grid-template-columns:1fr 1fr 1fr;}
}

/* PARTICLE CANVAS */
#particles{position:fixed;top:0;left:0;pointer-events:none;z-index:0;opacity:.35;}

/* TOAST */
.toast{
  position:fixed;bottom:100px;right:24px;z-index:9999;
  background:rgba(25,22,50,.97);border:1px solid var(--border);
  border-radius:14px;padding:14px 20px;
  display:flex;align-items:center;gap:10px;
  font-family:'Nunito',sans-serif;font-weight:700;font-size:.88rem;
  transform:translateX(120%);transition:.4s cubic-bezier(.4,0,.2,1);
  box-shadow:0 12px 40px rgba(0,0,0,.4);max-width:300px;
}
.toast.show{transform:translateX(0);}
.toast i{color:var(--peach);font-size:1rem;}
