*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050816;
  --bg-soft:#0b0f2a;
  --card:rgba(255,255,255,.05);
  --text:#f4f0e8;
  --muted:#b9b9c7;
  --line:rgba(255,255,255,.1);
  --gold-1:#fde68a;
  --gold-2:#fbbf24;
  --gold-3:#f59e0b;
  --gold-main:#fbbf24;
  --gold-soft:#fde68a;
  --gold-glow:rgba(251,191,36,.45);
  --container:min(1200px,92vw);
  --space:clamp(3rem,6vw,6rem);
  --radius:clamp(16px,2vw,28px);
  --ease-premium:cubic-bezier(.22,1,.36,1);
  --duration-fast:.3s;
  --duration-smooth:.6s;
}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Poppins',sans-serif;
  background:
    radial-gradient(circle at top,rgba(255,197,92,.12),transparent 28%),
    radial-gradient(circle at 80% 20%,rgba(59,130,246,.10),transparent 22%),
    var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  padding-bottom:env(safe-area-inset-bottom);
  transition-timing-function:var(--ease-premium);
}
main{position:relative;z-index:1}
img{max-width:100%;display:block;width:100%;height:auto}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}
button,a{min-height:44px}
button{cursor:pointer}
:focus-visible{outline:2px solid var(--gold-main);outline-offset:2px}
.container{width:var(--container);margin:auto}
.section{
  position:relative;
  padding:120px 0;
  z-index:1;
  scroll-margin-top:96px;
}
.section + .section{margin-top:24px}
.section::before{
  content:"";
  position:absolute;
  top:0;
  left:10%;
  width:80%;
  height:1px;
  background:rgba(255,255,255,.05);
}
.section-dark{
  background:linear-gradient(180deg,rgba(11,15,42,.92),rgba(5,8,22,.85));
}
.hero{
  padding-top:4.5rem;
  padding-bottom:5.5rem;
  z-index:2;
  will-change:transform;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:2rem;
  align-items:start;
}
.header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(5,8,22,.72);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  transition:all var(--duration-fast) var(--ease-premium);
}
.header.scrolled{
  background:rgba(5,8,22,.84);
  backdrop-filter:blur(22px);
  box-shadow:0 8px 30px rgba(0,0,0,.3);
  border-bottom-color:rgba(251,191,36,.15);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  min-height:78px;
  flex-wrap:wrap;
}


/* ===== CLEAN PROFESSIONAL LOGO SYSTEM ===== */

.brand{
  display:flex;
  align-items:center;
  gap:.9rem;
  padding:.2rem .35rem;
  background:transparent;
  border:none;
  backdrop-filter:none;
  box-shadow:none;
}

.brand picture,
.organised-by picture{
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:0;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:0;
}

/* MAIN HEADER LOGO */
.logo{
  width:auto;
  height:64px;
  object-fit:contain;
  object-position:left center;
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  max-width:260px;
  display:block;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.28));
  image-rendering:auto;
  transform:none !important;
  animation:none !important;
  transition:transform .25s ease, filter .25s ease;
}

.logo:hover{
  transform:scale(1.03);
  filter:drop-shadow(0 4px 14px rgba(251,191,36,.18));
}

/* FOOTER LOGOS */
.footer-logo{
  width:auto;
  height:48px;
  object-fit:contain;
  object-position:left center;
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  max-width:220px;
  display:block;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.22));
  image-rendering:auto;
  animation:none !important;
  transform:none !important;
  transition:transform .25s ease, filter .25s ease;
}

.footer-logo:hover{
  transform:scale(1.03);
  filter:drop-shadow(0 5px 16px rgba(251,191,36,.16));
}

/* NSD ORGANISER BLOCK */
.organised-by{
  display:flex;
  align-items:center;
  gap:.7rem;
  margin-top:.7rem;
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
}

.organised-by span{
  line-height:1.45;
  color:#d2d4de;
  font-size:.92rem;
}

/* REMOVE OLD FLOAT/GLOW EFFECTS */
.logo::before,
.logo::after,
.footer-logo::before,
.footer-logo::after{
  display:none !important;
}

/* MOBILE */
@media (max-width:640px){

  .logo{
    height:46px;
  }

  .footer-logo{
    height:34px;
  }

  .brand{
    gap:.55rem;
  }

  .organised-by{
    gap:.55rem;
  }
   /* NEW: adjust where #contact stops when scrolling from menu on mobile */
  #contact {
    scroll-margin-top: 0px;
  }
}



.brand-copy{display:flex;flex-direction:column}
.eyebrow{
  font-size:.72rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:rgba(253,230,138,.9)
}
.subtle{font-size:.78rem;color:var(--muted)}
.desktop-nav{
  display:flex;
  align-items:center;
  gap:1.2rem;
  flex-wrap:wrap;
}
.desktop-nav a{
  color:#d9d6e4;
  font-size:.95rem;
  transition:color .25s ease,transform .25s ease;
}
.desktop-nav a:hover{color:var(--gold-1);transform:translateY(-1px)}
.menu-btn{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  color:var(--text);
}
.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  padding:.8rem 1rem 1rem;
  background:rgba(5,8,22,.95);
}
.mobile-menu a{
  display:block;
  padding:.95rem 1rem;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  margin-top:.6rem;
}
.mobile-menu a:hover{border-color:rgba(251,191,36,.28)}
.mobile-cta{margin-top:.8rem;text-align:center}
.mobile-menu a.mobile-cta,
.mobile-menu .mobile-cta{
  background:linear-gradient(135deg,#fde68a,#fbbf24) !important;
  color:#17120a !important;
  border-color:transparent !important;
  font-weight:800 !important;
  text-align:center !important;
  box-shadow:0 0 18px rgba(251,191,36,.7),
             0 0 36px rgba(251,191,36,.4) !important;
  letter-spacing:.03em;
  animation:bookGlow 2s infinite ease-in-out;
}
.mobile-menu a.mobile-cta,.mobile-menu .mobile-cta{
  background:linear-gradient(135deg,#fde68a,#fbbf24) !important;
  color:#17120a !important;
  border-color:transparent !important;
  font-weight:800 !important;
  text-align:center !important;
  box-shadow:0 0 18px rgba(251,191,36,.7),0 0 36px rgba(251,191,36,.4) !important;
  animation:bookGlow 2s infinite ease-in-out;
  letter-spacing:.03em;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.55rem .95rem;
  border-radius:999px;
  border:1px solid rgba(253,230,138,.18);
  background:rgba(0,0,0,.18);
  color:#ece8df;
  font-size:.8rem;
  margin-bottom:1.1rem;
  backdrop-filter:blur(8px);
}
.hero h1,.section-head h2,.card h3,.glass-top h2{line-height:1.1}
.hero h1{
  font-size:clamp(2.2rem,6vw,4.8rem);
  font-weight:800;
  letter-spacing:-.03em;
  max-width:12ch;
}
.gold-text{
  display:block;
  background:linear-gradient(90deg,var(--gold-1),var(--gold-2),#fff3c4);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.lead{
  margin-top:1.3rem;
  color:#d1d3df;
  max-width:62ch;
  font-size:clamp(.95rem,1.5vw,1.1rem);
  line-height:1.8;
}
.hero-actions{
  display:flex;
  gap:.85rem;
  flex-wrap:wrap;
  margin-top:1.6rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  border-radius:999px;
  padding:.95rem 1.35rem;
  border:1px solid transparent;
  transition:transform var(--duration-fast) var(--ease-premium),filter var(--duration-fast) var(--ease-premium),background var(--duration-fast) var(--ease-premium),border-color var(--duration-fast) var(--ease-premium),box-shadow var(--duration-fast) var(--ease-premium);
  cursor:pointer;
  font-weight:700;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:scale(.96)}
.btn-primary{
  color:#17120a;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold-main));
  box-shadow:0 10px 30px rgba(251,191,36,.25);
}
.btn-primary:hover{box-shadow:0 0 30px var(--gold-glow)}
.btn-secondary{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.75rem;
  margin-top:1.8rem;
}
.stat,.card,.image-card,.gallery-card{
  position:relative;
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:0 24px 90px rgba(0,0,0,.28);
  backdrop-filter:blur(20px);
}
.stat{
  padding:1rem;
}
.stat-label{
  display:block;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#a8a8b7;
  margin-bottom:.45rem;
}
.stat strong{font-size:.95rem;font-weight:600}
.glass{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  padding:1.2rem;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(24px);
}
.glass-top h2{font-size:1.9rem;margin-top:.45rem}
.glass-top p{margin-top:.7rem;color:#d4d1de}
.micro{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.28em;
  color:rgba(253,230,138,.85);
}
.chip-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.7rem;
  margin-top:1rem;
}
.chip{
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.05);
  padding:.9rem 1rem;
  font-size:.92rem;
  color:#ece7df;
}
.accent-card{
  margin-top:1rem;
  padding:1rem 1.05rem;
  border-radius:22px;
  border:1px solid rgba(251,191,36,.18);
  background:linear-gradient(135deg,rgba(251,191,36,.12),rgba(255,255,255,.03));
}
.section-head{
  max-width:45rem;
  margin-bottom:2rem;
}
.section-tag{
  display:inline-flex;
  padding:.45rem .8rem;
  border-radius:999px;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.24em;
  color:rgba(253,230,138,.9);
  border:1px solid rgba(253,230,138,.16);
  background:rgba(251,191,36,.09);
  margin-bottom:.9rem;
}
.section-head h2{
  font-size:clamp(1.8rem,4vw,3.35rem);
  font-weight:800;
}
.section-head p{
  margin-top:.9rem;
  color:#c7c9d7;
  max-width:68ch;
  font-size:clamp(.92rem,1.5vw,1.05rem);
  line-height:1.8;
}
.two-col,.contact-grid{
  display:grid;
  gap:1.1rem;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.card{
  padding:clamp(1rem,2vw,1.35rem);
  overflow:hidden;
}
.card:hover,.image-card:hover,.gallery-card:hover{
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 25px 60px rgba(0,0,0,.35);
}
.card h3{font-size:clamp(1.25rem,2.5vw,1.55rem);margin-bottom:.9rem}
.card p{color:#c9ccda}
.benefit-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.7rem;
  margin-top:1.15rem;
}
.mini-card{
  padding:.95rem 1rem;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
}
.number-list{display:grid;gap:.9rem}
.number-list>div{
  display:flex;
  gap:.85rem;
  align-items:flex-start;
  padding:.92rem;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}
.number-list span{
  width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);color:#f8d97c;font-weight:700;flex:0 0 auto
}
.card-grid,.gallery-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.image-card,.gallery-card{overflow:hidden;transform-style:preserve-3d;transition:transform .3s ease}
.image-card picture,.gallery-card picture{display:block;line-height:0}
.image-card img,.gallery-card img{width:100%;object-fit:cover}
.image-card img{height:250px}
.gallery-card img{height:290px}
.image-card-copy{padding:1rem 1rem 1.1rem}
.image-card-copy h3{font-size:1.1rem;margin-bottom:.4rem}
.image-card-copy p{color:#c8cddd;font-size:.94rem}
.gallery-card{position:relative}
.gallery-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:1rem;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82));
}
.gallery-overlay span{
  display:inline-block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.2em;
  color:rgba(253,230,138,.85);
  margin-bottom:.25rem;
}
.gallery-overlay h3{font-size:1.2rem}
.highlight-grid{display:grid;gap:.75rem;margin-top:1rem}
.highlight-item{
  display:flex;
  gap:.8rem;
  padding:.95rem;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
}
.highlight-item strong{font-size:1.2rem;color:var(--gold-1)}
.highlight-item b{display:block;margin-bottom:.15rem}
.highlight-item p{color:#c8ccda;font-size:.95rem}
.price-table{margin-top:1rem;border-radius:22px;overflow:hidden;border:1px solid var(--line)}
.price-head,.price-row{
  display:grid;
  grid-template-columns:1.2fr .8fr 1fr;
  gap:.75rem;
  padding:.95rem 1rem;
}
.price-head{
  background:rgba(255,255,255,.09);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.7rem;
  color:#d9d6e4;
  font-weight:700;
}
.price-row{
  background:rgba(0,0,0,.18);
  border-top:1px solid rgba(255,255,255,.08);
  font-size:.95rem;
}
.price-row span:last-child{color:#f6d979;font-weight:700}
.note{
  margin-top:1rem;
  padding:1rem;
  border-radius:18px;
  border:1px solid rgba(251,191,36,.18);
  background:linear-gradient(135deg,rgba(251,191,36,.09),rgba(255,255,255,.03));
  color:#e9e2d3;
}
.contact-grid{align-items:start}
.contact-form{
  margin-top:1rem;
  display:grid;
  gap:.8rem;
}
.contact-form input,.contact-form textarea{
  width:100%;
  padding:.95rem 1rem;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.22);
  color:var(--text);
  outline:none;
  transition:border-color var(--duration-fast) var(--ease-premium),box-shadow var(--duration-fast) var(--ease-premium),transform var(--duration-fast) var(--ease-premium);
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#7f8597}
.contact-form input:focus,.contact-form textarea:focus{
  border-color:rgba(251,191,36,.45);
  box-shadow:0 0 0 4px rgba(251,191,36,.08);
}
.submit-btn{width:100%;margin-top:.2rem}
.stack{display:grid;gap:1rem}
.whatsapp-link{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  margin-top:.9rem;
  padding:.85rem 1rem;
  border-radius:18px;
  border:1px solid rgba(253,230,138,.22);
  background:rgba(251,191,36,.08);
  color:#f5e2a0;
}
.footer{
  border-top:1px solid var(--line);
  background:rgba(0,0,0,.32);
  padding:3rem 0 1rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:2rem;
  align-items:start;
}
.footer h4{
  color:#f8e7b4;
  margin-bottom:10px;
  font-size:.98rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.footer-links ul{list-style:none;padding:0}
.footer-links li{margin:8px 0}
.footer-links a{
  color:#ccc;
  text-decoration:none;
  transition:color .3s ease;
}
.footer-links a:hover{color:#fbbf24}
.footer-brand{
  display:flex;
  flex-direction:column;
  gap:.65rem;
}
.organised-by{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:8px;
  text-decoration:none;
}
.organised-by p{
  font-size:.9rem;
  color:#bbb;
  margin:0;
}
.footer-bottom{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  text-align:center;
  margin-top:2rem;
  padding-top:1.2rem;
  border-top:1px solid rgba(255,255,255,.08);
}

.footer-bottom p{
  color:#bfc3d4;
  font-size:.92rem;
  letter-spacing:.04em;
  margin:0;
}

#loader{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  background:#050816;
  transition:opacity .6s ease,visibility .6s ease;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:700;
  letter-spacing:.28em;
  background:linear-gradient(90deg,#fde68a,#fbbf24,#fff);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation:glowPulse 1.5s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{opacity:.65;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}
.bg-orb{
  position:fixed;
  border-radius:999px;
  filter:blur(70px);
  z-index:0;
  pointer-events:none;
}
.orb-1{width:380px;height:380px;left:-120px;top:20px;background:rgba(251,191,36,.10)}
.orb-2{width:420px;height:420px;right:-140px;top:220px;background:rgba(56,189,248,.08)}
.cursor-light{
  position:fixed;
  width:320px;
  height:320px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,215,0,.12),transparent 70%);
  pointer-events:none;
  transform:translate(-50%,-50%);
  z-index:0;
}
.reveal{
  opacity:0;
  transform:translateY(22px) scale(.98);
  transition:opacity var(--duration-smooth) var(--ease-premium),transform var(--duration-smooth) var(--ease-premium);
}
.reveal.active{opacity:1;transform:translateY(0) scale(1)}
.floating-menu{
  position:fixed;
  right:18px;
  bottom:calc(18px + env(safe-area-inset-bottom));
  z-index:70;
}
.main-float-btn{
  width:60px;
  height:60px;
  border-radius:50%;
  border:none;
  font-size:28px;
  cursor:pointer;
  background:linear-gradient(135deg,#fde68a,#fbbf24);
  color:#000;
  box-shadow:0 0 25px rgba(255,215,0,.5);
  transition:all .3s ease;
}
.main-float-btn.active{transform:rotate(45deg)}
.floating-options{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin-bottom:10px;
  opacity:0;
  pointer-events:none;
  transform:translateY(20px);
  transition:all .3s ease;
}
.floating-options.show{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.float-btn{
  width:50px;
  height:50px;
  margin:6px 0;
  border-radius:50%;
  border:none;
  font-size:18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(10px);
  color:#fff;
  transition:all .3s ease;
}
.float-btn:hover{
  background:linear-gradient(135deg,#fde68a,#fbbf24);
  color:#000;
  transform:scale(1.1);
}
.scroll-top{
  position:fixed;
  left:18px;
  bottom:calc(18px + env(safe-area-inset-bottom));
  width:48px;
  height:48px;
  border:none;
  border-radius:50%;
  cursor:pointer;
  background:linear-gradient(135deg,#fde68a,#fbbf24);
  color:#000;
  box-shadow:0 12px 24px rgba(251,191,36,.22);
  display:none;
  z-index:70;
}
.scroll-top.show{display:grid;place-items:center}
.gold-glow{box-shadow:0 0 25px var(--gold-glow)}
.card,
.image-card,
.gallery-card,
.stat{
  background:var(--card);
}
.card,
.image-card,
.gallery-card{
  overflow:hidden;
}
.card::before,
.image-card::before,
.gallery-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at var(--x,50%) var(--y,50%),rgba(251,191,36,.15),transparent 60%);
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
}
.card:hover::before,
.image-card:hover::before,
.gallery-card:hover::before{opacity:1}
img.logo{width:auto}
@media (max-width:1080px){
  .hero-grid,.two-col,.contact-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:860px){
  .desktop-nav,.desktop-cta{display:none}
  .menu-btn{display:inline-grid;place-items:center;margin-left:auto}
  .mobile-menu.show{display:block}
  .hero-grid,.two-col,.contact-grid{grid-template-columns:1fr}
  .hero{padding-top:3rem}
  .stats-grid{grid-template-columns:1fr 1fr}
  .section{padding:4.2rem 0}
  .hero-actions .btn,.submit-btn,.whatsapp-link,.mobile-cta{width:100%}
}
@media (max-width:640px){
  .container{width:min(100% - 1rem, 1180px)}
  .nav{min-height:72px}
  .brand-copy{
    display:flex;
    flex-direction:column;
  }
  .hero h1{max-width:100%;font-size:clamp(2.1rem,11vw,3.3rem)}
  .hero .lead{font-size:.98rem;line-height:1.8}
  .hero-actions{flex-direction:column}
  .stats-grid,.benefit-grid,.chip-grid{grid-template-columns:1fr}
  .price-head{display:none}
  .price-row,.price-head{grid-template-columns:1fr}
  .price-row{padding:1rem}
  .price-row span{display:block}
  .price-row span:nth-child(1)::before{content:'Stall type: ';color:#a7aab9;font-weight:500}
  .price-row span:nth-child(2)::before{content:'Size: ';color:#a7aab9;font-weight:500}
  .price-row span:nth-child(3)::before{content:'Investment: ';color:#a7aab9;font-weight:500}
  .gallery-card img,.image-card img{height:205px}
  .floating-menu{right:12px;bottom:calc(12px + env(safe-area-inset-bottom));transform:scale(.95)}
  .scroll-top{left:12px;bottom:calc(12px + env(safe-area-inset-bottom))}
  .footer-grid{align-items:flex-start}
  .footer-brand{align-items:flex-start}
  .footer-logo{height:38px}
}
@media (max-width:768px){
  .cursor-light{display:none}
  .card::before,
  .image-card::before,
  .gallery-card::before{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}

/* ===== PREMIUM FOOTER SOCIAL UPGRADE ===== */

.footer {
  position: relative;
  overflow: hidden;
}

.footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 0%, rgba(251,191,36,.10), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(59,130,246,.06), transparent 25%);
  opacity: .9;
}

.footer-grid,
.footer-bottom {
  position: relative;
  z-index: 1;
}

.footer-social {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.social-icons {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.social-btn {
  width: 48px;
  height: 48px;
  min-width: 48px;
  min-height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #fff;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(12px);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  position: relative;
  overflow: hidden;
  transition:
    transform .35s cubic-bezier(.22,1,.36,1),
    box-shadow .35s ease,
    background .35s ease,
    border-color .35s ease;
  animation: socialFloat 5s ease-in-out infinite;
}

.social-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(251,191,36,.28), transparent 68%);
  opacity: 0;
  transition: opacity .3s ease;
}

.social-btn:hover {
  transform: translateY(-4px) scale(1.08);
  border-color: rgba(255,255,255,.2);
  box-shadow: 0 14px 30px rgba(0,0,0,.28);
}

.social-btn:hover::before {
  opacity: 1;
}

.social-btn.fb:hover {
  background: linear-gradient(135deg, #1877f2, #0f5cc8);
}

.social-btn.ig:hover {
  background: linear-gradient(135deg, #f9ce34, #ee2a7b 55%, #6228d7);
}

.social-btn.ln:hover {
  background: linear-gradient(135deg, #0a66c2, #084c92);
}

.social-btn:nth-child(2) {
  animation-delay: .4s;
}

.social-btn:nth-child(3) {
  animation-delay: .8s;
}

@keyframes socialFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

@media (max-width: 640px) {
  .social-icons {
    gap: 10px;
  }

  .social-btn {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    font-size: 17px;
  }
}

/* === Additional styles for final website === */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* WhatsApp social button */
.social-btn.wa {
  background: rgba(37, 211, 102, 0.12);
  border-color: rgba(37, 211, 102, 0.3);
  color: #25D366;
}
.social-btn.wa:hover {
  background: rgba(37, 211, 102, 0.2);
}

/* Ensure contact links look good */
.footer-contact a:hover,
.card a:hover {
  color: var(--gold-1);
}

/* highlight-grid 5-item for why section */
@media (min-width: 768px) {
  .highlight-grid {
    grid-template-columns: 1fr;
  }
}

/* Loader text */
.loader-logo {
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--gold-1);
  letter-spacing: .3em;
}


/* Form submission status */
.form-status{
  margin-top: .9rem;
  font-size: .95rem;
  line-height: 1.5;
  min-height: 1.4em;
}
.form-status.success{color:#9ef0b6;}
.form-status.error{color:#ffb4b4;}
.form-status.loading{color:#fde68a;}
.honeypot{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}
/* ===== BOOK STALL FLOAT BUTTON ===== */

.book-stall-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;

  min-width:140px !important;
  height:50px !important;

  padding:0 20px !important;

  border-radius:999px !important;

  background:linear-gradient(135deg,#fde68a,#fbbf24) !important;

  color:#111 !important;

  font-size:13px !important;
  font-weight:800 !important;

  letter-spacing:1px;

  text-transform:uppercase;

  text-decoration:none !important;

  box-shadow:
    0 0 14px rgba(251,191,36,.75),
    0 0 32px rgba(251,191,36,.45);

  animation:bookGlow 2s infinite ease-in-out;
}

.book-stall-btn:hover{
  transform:scale(1.06);
}

@keyframes bookGlow{

  0%{
    transform:scale(1);
  }

  50%{
    transform:scale(1.05);
  }

  100%{
    transform:scale(1);
  }
}
/* ===== FORM VALIDATION & ANTI-SPAM STYLES ===== */

/* Real-time validation states */
.contact-form input:focus,
.contact-form textarea:focus {
  border-color: rgba(251,191,36,.45);
  box-shadow: 0 0 0 4px rgba(251,191,36,.08);
}

/* Error state */
.contact-form input.input-error,
.contact-form textarea.input-error {
  border-color: rgba(239,68,68,.6) !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important;
  background: rgba(239,68,68,.06) !important;
}

/* Shake animation for errors */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

.shake {
  animation: shake 0.4s ease-in-out;
}

/* Enhanced form status messages */
.form-status {
  margin-top: 0.9rem;
  font-size: 0.95rem;
  line-height: 1.5;
  min-height: 1.4em;
  padding: 0.75rem 1rem;
  border-radius: 14px;
  font-weight: 500;
}

.form-status.success {
  color: #065f46;
  background: rgba(52,211,153,.12);
  border: 1px solid rgba(52,211,153,.25);
}

.form-status.error {
  color: #7f1d1d;
  background: rgba(248,113,113,.12);
  border: 1px solid rgba(248,113,113,.25);
}

.form-status.loading {
  color: #92400e;
  background: rgba(251,191,36,.12);
  border: 1px solid rgba(251,191,36,.25);
}

/* Submit button disabled state */
.submit-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  filter: grayscale(0.3);
}

/* Honeypot field — hidden from humans, visible to bots */
.honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

/* Focus-visible improvements for accessibility */
.contact-form input:focus-visible,
.contact-form textarea:focus-visible {
  outline: 2px solid var(--gold-main);
  outline-offset: 2px;
}

/* Mobile form improvements */
@media (max-width: 640px) {
  .form-status {
    font-size: 0.88rem;
    padding: 0.6rem 0.85rem;
  }

  .contact-form input,
  .contact-form textarea {
    font-size: 16px; /* Prevents iOS zoom on focus */
  }
}
