/* ---------- Design tokens ---------- */
:root{
  --teal: #0e6e63;
  --teal-dark: #0a4f47;
  --terracotta: #e0703a;
  --terracotta-dark: #c4592a;
  --cream: #fdf8f0;
  --ink: #1b2321;
  --ink-soft: #4c5a56;
  --border: #e4ddd0;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(15, 40, 35, 0.08);
  --font-head: 'Poppins', 'Segoe UI', system-ui, sans-serif;
  --font-body: 'Inter', 'Segoe UI', system-ui, sans-serif;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
}
img{ max-width: 100%; display:block; }
a{ color: inherit; text-decoration: none; }
ul{ list-style: none; margin:0; padding:0; }

.container{
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 24px;
}

.eyebrow{
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--terracotta-dark);
  margin: 0 0 10px;
}
.eyebrow.center{ text-align: center; }

.section-title{
  font-family: var(--font-head);
  font-weight: 700;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  margin: 0 0 16px;
  color: var(--teal-dark);
}
.section-title.center{ text-align: center; }

.section-sub{
  color: var(--ink-soft);
  max-width: 640px;
}
.section-sub.center{ margin: 0 auto 48px; text-align: center; }

/* ---------- Buttons ---------- */
.btn{
  display: inline-block;
  padding: 14px 28px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.95rem;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primary{
  background: var(--terracotta);
  color: #fff;
}
.btn-primary:hover{ background: var(--terracotta-dark); transform: translateY(-2px); }
.btn-ghost{
  background: transparent;
  border-color: rgba(255,255,255,0.6);
  color: #fff;
}
.btn-ghost:hover{ background: rgba(255,255,255,0.12); transform: translateY(-2px); }
.btn-full{ width: 100%; text-align: center; border: none; }

/* ---------- Header ---------- */
.site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(253, 248, 240, 0.9);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}
.nav-wrap{
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
}
.logo{
  display: flex;
  align-items: center;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--teal-dark);
}
.logo span{ color: var(--terracotta); }
.logo img{
  height: 44px;
  width: auto;
  display: block;
}
.main-nav{
  display: flex;
  align-items: center;
  gap: 28px;
  font-weight: 500;
  font-size: 0.95rem;
}
.main-nav a{ color: var(--ink); transition: color .15s ease; }
.main-nav a:hover{ color: var(--terracotta); }
.nav-cta{
  background: var(--teal);
  color: #fff !important;
  padding: 10px 20px;
  border-radius: 999px;
}
.nav-cta:hover{ background: var(--teal-dark); }

.nav-toggle{
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
}
.nav-toggle span{
  width: 24px; height: 2px; background: var(--teal-dark);
}

/* ---------- Hero ---------- */
.hero{
  position: relative;
  min-height: clamp(560px, 92vh, 820px);
  display: flex;
  align-items: center;
  overflow: hidden;
  color: #fff;
  background: var(--teal-dark);
}
.hero-video{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.hero-bg{
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(224,112,58,0.3), transparent 45%),
    linear-gradient(135deg, rgba(10,79,71,0.8), rgba(14,110,99,0.6) 60%, rgba(12,90,81,0.82));
  z-index: 1;
}
.hero-bg.video-overlay{
  background:
    radial-gradient(circle at 20% 20%, rgba(224,112,58,0.18), transparent 45%),
    linear-gradient(135deg, rgba(10,79,71,0.4), rgba(14,110,99,0.22) 60%, rgba(12,90,81,0.42));
}
.hero-bg::after{
  content: "";
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 120px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 120px);
  opacity: 0.5;
}
.hero-content{ position: relative; z-index: 2; padding-top: 76px; max-width: 720px; }
.hero h1{
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  line-height: 1.12;
  margin: 0 0 20px;
}
.hero-video ~ .hero-content h1,
.hero-video ~ .hero-content .eyebrow,
.hero-video ~ .hero-content .hero-sub{
  text-shadow: 0 2px 16px rgba(0,0,0,0.45);
}
.hero-sub{
  font-size: 1.1rem;
  color: rgba(255,255,255,0.9);
  max-width: 560px;
  margin: 0 0 32px;
}
.hero-actions{ display: flex; gap: 16px; flex-wrap: wrap; }

/* ---------- Feature image ---------- */
.feature-image{ padding: 56px 0 0; background: var(--cream); }
.feature-image-frame{
  height: clamp(320px, 55vw, 640px);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: rgba(255,255,255,0.9);
  font-weight: 600;
  font-size: 1.05rem;
  line-height: 1.5;
  box-shadow: var(--shadow);
}
.feature-image-frame small{
  display: block;
  margin-top: 8px;
  font-weight: 500;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.75);
}
.feature-image-frame img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ph-feature{
  background:
    linear-gradient(135deg, rgba(14,110,99,0.92), rgba(224,112,58,0.85)),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.06) 0 12px, transparent 12px 24px);
}

/* ---------- Pillars ---------- */
.pillars{ padding: 100px 0 80px; }
.pillar-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.pillar-card{
  background: #fff;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform .2s ease;
}
.pillar-card:hover{ transform: translateY(-6px); }
.pillar-media{
  height: 190px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.85);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  overflow: hidden;
}
.pillar-media img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.ph-padel{ background: linear-gradient(135deg, var(--teal), #12897a); }
.ph-kids{ background: linear-gradient(135deg, #f0a24c, var(--terracotta)); }
.ph-cafe{ background: linear-gradient(135deg, #6b4a3a, #94684f); }
.pillar-body{ padding: 24px; }
.pillar-body h3{
  font-family: var(--font-head);
  color: var(--teal-dark);
  margin: 0 0 10px;
  font-size: 1.3rem;
}
.pillar-body p{ color: var(--ink-soft); margin: 0 0 14px; }
.pillar-link{ font-weight: 600; color: var(--terracotta-dark); }
.pillar-link:hover{ text-decoration: underline; }

/* ---------- Why ---------- */
.why{ background: #fff; padding: 90px 0; }
.why-grid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  align-items: center;
}
.why-copy p{ color: var(--ink-soft); }
.why-list{ margin-top: 20px; display: grid; gap: 12px; }
.why-list li{
  padding-left: 28px;
  position: relative;
  font-weight: 600;
  color: var(--teal-dark);
}
.why-list li::before{
  content: "\2713";
  position: absolute; left: 0; top: 0;
  color: var(--terracotta);
  font-weight: 800;
}
.why-media{
  height: 360px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, #f0a24c, var(--teal));
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.9);
  font-weight: 600;
  overflow: hidden;
}
.why-media img{ width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---------- Gallery ---------- */
.gallery{ padding: 90px 0; }
.gallery-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.gallery-grid.cols-2{
  grid-template-columns: repeat(2, 1fr);
  max-width: 760px;
  margin: 0 auto;
}
.gallery-item{
  aspect-ratio: 4 / 3;
  border-radius: 12px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  font-size: 0.85rem;
}
.gallery-item img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.ph-g1{ background: linear-gradient(135deg, var(--teal), #0c5a51); }
.ph-g2{ background: linear-gradient(135deg, var(--terracotta), #b6461f); }
.ph-g3{ background: linear-gradient(135deg, #6b4a3a, #94684f); }
.ph-g4{ background: linear-gradient(135deg, #12897a, var(--teal-dark)); }
.ph-g5{ background: linear-gradient(135deg, #f0a24c, var(--terracotta-dark)); }
.ph-g6{ background: linear-gradient(135deg, #94684f, #4c3527); }
.gallery-note{ text-align: center; margin-top: 24px; color: var(--ink-soft); }
.gallery-note a{ color: var(--terracotta-dark); font-weight: 600; }

/* ---------- Visit ---------- */
.visit{ background: #fff; padding: 90px 0; }
.visit-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.visit-card{
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px;
}
.visit-card h3{
  font-family: var(--font-head);
  color: var(--teal-dark);
  margin: 0 0 12px;
}
.placeholder-note{
  font-size: 0.82rem;
  color: var(--terracotta-dark);
  background: #fbe9dd;
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 14px;
}
.hours-list li{
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 0;
  border-bottom: 1px dashed var(--border);
  font-size: 0.92rem;
}
.hours-list li:last-child{ border-bottom: none; }
.hours-list li span:first-child{ color: var(--teal-dark); font-weight: 600; }
.hours-list li span:last-child{ color: var(--ink-soft); }
.map-embed{
  margin-top: 16px;
  height: 220px;
  border-radius: 10px;
  overflow: hidden;
}
.map-embed iframe{ display: block; }
.social-links{ display: flex; gap: 14px; margin-top: 8px; }
.social-links a{
  font-weight: 600;
  color: var(--teal-dark);
  border: 1px solid var(--border);
  padding: 8px 16px;
  border-radius: 999px;
  transition: background .15s ease, color .15s ease;
}
.social-links a:hover{ background: var(--teal); color: #fff; border-color: var(--teal); }

/* ---------- Contact ---------- */
.contact{ padding: 90px 0; }
.contact-wrap{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
}
.contact-copy p{ color: var(--ink-soft); }
.contact-form{
  background: #fff;
  padding: 32px;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  display: grid;
  gap: 18px;
}
.form-row{ display: grid; gap: 6px; }
.form-row label{ font-size: 0.85rem; font-weight: 600; color: var(--ink-soft); }
.form-row input,
.form-row select,
.form-row textarea{
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  background: var(--cream);
  color: var(--ink);
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{
  outline: none;
  border-color: var(--teal);
}
.form-note{ text-align: center; font-size: 0.9rem; color: var(--teal-dark); min-height: 1.2em; margin: 0; }

/* ---------- Footer ---------- */
.site-footer{ background: var(--teal-dark); color: rgba(255,255,255,0.85); padding: 40px 0; }
.footer-wrap{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.site-footer .logo{ color: #fff; }
.site-footer .logo span{ color: #f0a24c; }
.site-footer p{ margin: 0; font-size: 0.9rem; }
.site-footer .social-links a{ color: #fff; border-color: rgba(255,255,255,0.3); }
.site-footer .social-links a:hover{ background: rgba(255,255,255,0.15); }
.footer-nav{ display: flex; gap: 20px; font-weight: 600; font-size: 0.9rem; }
.footer-nav a:hover{ color: #f0a24c; }

/* ---------- Sub-page hero ---------- */
.hero-page{
  min-height: clamp(320px, 46vh, 460px);
}
.hero-page .hero-content{ padding-top: 120px; padding-bottom: 40px; }
.hero-page .hero-sub{ margin-bottom: 0; }

/* ---------- Placeholder note (dark background variant) ---------- */
.placeholder-note.on-dark{
  background: rgba(255,255,255,0.16);
  color: #fff;
}
.badge-soon{
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #fff;
  background: var(--terracotta);
  padding: 3px 10px;
  border-radius: 999px;
  margin-left: 10px;
  vertical-align: middle;
}

/* ---------- Menu (Food page) ---------- */
.menu{ padding: 90px 0; background: #fff; }
.menu-note{ text-align: center; margin: -24px 0 48px; }
.menu-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}
.menu-category h3{
  font-family: var(--font-head);
  color: var(--teal-dark);
  border-bottom: 2px solid var(--border);
  padding-bottom: 10px;
  margin: 0 0 18px;
}
.menu-category-note{
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--terracotta-dark);
  margin-left: 8px;
  vertical-align: middle;
}
.menu-item{
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--border);
}
.menu-item:last-child{ border-bottom: none; }
.menu-item-name{ font-weight: 600; color: var(--ink); }
.menu-item-desc{ font-size: 0.85rem; color: var(--ink-soft); margin-top: 2px; }
.menu-item-price{ font-weight: 700; color: var(--terracotta-dark); white-space: nowrap; }

/* ---------- Full menu CTA (Food page) ---------- */
.full-menu{ padding: 90px 0; background: var(--cream); }
.full-menu-cta{ text-align: center; margin-top: 8px; }

/* ---------- Full menu viewer page ---------- */
.menu-pages{ padding: 60px 0 100px; background: var(--cream); }
.menu-pages-grid{
  display: grid;
  gap: 32px;
  max-width: 720px;
  margin: 0 auto;
}
.menu-pages-grid img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
  box-shadow: var(--shadow);
}

/* ---------- Info grid (Play activities / Padel sessions) ---------- */
.info{ padding: 90px 0; background: #fff; }
.info + .info{ padding-top: 0; }
.info-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.info-card{
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 26px;
}
.info-card h3{
  font-family: var(--font-head);
  color: var(--teal-dark);
  margin: 0 0 10px;
  font-size: 1.15rem;
}
.info-card p{ color: var(--ink-soft); margin: 0; }
.info-card.is-soon{ border-style: dashed; }
.single-card-wrap{ max-width: 480px; margin: 32px auto 0; }
.single-card-wrap .info-card{ text-align: center; }

/* ---------- Photo mosaic (Play page) ---------- */
.mosaic{ padding: 56px 0 0; background: var(--cream); }
.mosaic-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 205px;
  gap: 14px;
}
.mosaic-item{ border-radius: 14px; overflow: hidden; box-shadow: var(--shadow); }
.mosaic-item img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.mosaic-item.m-large{ grid-column: span 2; grid-row: span 2; }

/* ---------- Zones (Play page: Indoor / Outdoor / Classes) ---------- */
.zones{ padding: 90px 0; background: #fff; }
.zone-block{ margin-top: 64px; }
.zone-block:first-of-type{ margin-top: 48px; }
.zone-block-head{ margin-bottom: 24px; }
.zone-block-head h3{
  font-family: var(--font-head);
  color: var(--teal-dark);
  font-size: 1.4rem;
  margin: 0 0 8px;
}
.zone-block-head p{ color: var(--ink-soft); max-width: 680px; margin: 0; }
.zone-block-head p.one-line{ max-width: none; white-space: nowrap; }
.zone-block-head p.two-line{ max-width: 800px; }

.sub-zone{ margin-top: 32px; }
.sub-zone:first-of-type{ margin-top: 28px; }
.sub-zone h4{
  font-family: var(--font-head);
  color: var(--teal-dark);
  font-size: 1.1rem;
  margin: 0 0 8px;
}
.sub-zone > p{ color: var(--ink-soft); max-width: 680px; margin: 0 0 16px; }

.indoor-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.indoor-card{
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.indoor-card .photo{ height: 170px; overflow: hidden; }
.indoor-card .photo img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.indoor-card .badge-wrap{ padding: 16px 16px 0; }
.indoor-card .badge-wrap img{ height: 30px; width: auto; display: block; }
.indoor-card-body{ padding: 12px 16px 20px; }
.indoor-card-body p{ color: var(--ink-soft); margin: 8px 0 0; }
.indoor-card-price{
  font-weight: 700;
  color: var(--terracotta-dark);
  margin: 8px 0 0 !important;
}

.single-zone{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  align-items: stretch;
}
.single-zone img{ width: 100%; height: 100%; min-height: 260px; object-fit: cover; display: block; }
.single-zone-body{ padding: 32px; align-self: center; }
.single-zone-body p{ color: var(--ink-soft); margin: 0 0 4px; }
.single-zone-body .menu-item:first-child{ margin-top: 8px; }
.single-zone.fixed-size{ height: 380px; }
.single-zone.fixed-size.tall{ height: 470px; }
.single-zone.fixed-size img{ height: 100%; }
.single-zone.fixed-size .single-zone-body{ height: 100%; overflow: auto; }
.single-zone.poster-zone{ grid-template-columns: 280px 1fr; }
.single-zone.poster-zone img{ object-fit: contain; background: var(--cream); padding: 16px; }

/* ---------- CTA banner (booking sections on sub-pages) ---------- */
.cta-banner{
  background: linear-gradient(135deg, var(--teal-dark), var(--teal) 70%);
  color: #fff;
  padding: 80px 0;
  text-align: center;
}
.cta-banner .eyebrow{ color: #f0c9a8; }
.cta-banner .section-title{ color: #fff; }
.cta-banner p{ color: rgba(255,255,255,0.88); max-width: 560px; margin: 0 auto 28px; }
.cta-banner-actions{ display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; }

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .pillar-grid{ grid-template-columns: 1fr; }
  .why-grid{ grid-template-columns: 1fr; }
  .visit-grid{ grid-template-columns: 1fr; }
  .contact-wrap{ grid-template-columns: 1fr; }
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }
  .menu-grid{ grid-template-columns: 1fr; gap: 32px; }
  .info-grid{ grid-template-columns: 1fr; }
  .indoor-grid{ grid-template-columns: 1fr; }
  .single-zone{ grid-template-columns: 1fr; }
  .single-zone img{ min-height: 220px; }
  .single-zone.poster-zone{ grid-template-columns: 1fr; }
  .single-zone.fixed-size, .single-zone.fixed-size.tall{ height: auto; }
  .single-zone.fixed-size img{ height: 220px; }
  .single-zone.fixed-size .single-zone-body{ height: auto; }
  .zone-block-head p.one-line{ white-space: normal; }
}

@media (max-width: 720px){
  .main-nav{
    position: fixed;
    top: 76px; left: 0; right: 0;
    background: var(--cream);
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    border-bottom: 1px solid var(--border);
    max-height: 0;
    overflow: hidden;
    overflow-y: auto;
    transition: max-height .25s ease;
  }
  .main-nav.open{ max-height: calc(100vh - 76px); }
  .main-nav a{ width: 100%; padding: 16px 24px; border-bottom: 1px solid var(--border); }
  .nav-cta{ margin: 12px 24px; border-radius: 999px; text-align: center; }
  .nav-toggle{ display: flex; }
  .gallery-grid{ grid-template-columns: 1fr 1fr; }
  .cta-banner-actions{ flex-direction: column; align-items: stretch; }
  .footer-wrap{ justify-content: flex-start; }
  .mosaic-grid{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 130px; }
  .mosaic-item.m-large{ grid-column: span 2; grid-row: span 1; }
}
