/* ===================================================================
   Gong Therapy Meditation — warm ivory & gold
   =================================================================== */

:root{
  --ivory:      #F6F1E7;
  --ivory-2:    #EFE7D6;
  --ivory-3:    #E8DEC9;
  --bronze:     #B08542;
  --bronze-deep:#8A6630;
  --charcoal:   #2A2622;
  --charcoal-2: #4A443C;
  --muted:      #79705F;
  --line:       rgba(42,38,34,0.12);
  --line-soft:  rgba(42,38,34,0.08);
  --white:      #FFFDF8;
  --shadow-sm:  0 2px 18px rgba(42,38,34,0.07);
  --shadow-md:  0 14px 50px rgba(42,38,34,0.13);
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Jost", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--charcoal);
  background:var(--ivory);
  line-height:1.7;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; }

/* ---------- language visibility ---------- */
html[data-lang="it"] [data-l="en"], html[data-lang="it"] [data-l="de"]{ display:none; }
html[data-lang="en"] [data-l="it"], html[data-lang="en"] [data-l="de"]{ display:none; }
html[data-lang="de"] [data-l="it"], html[data-lang="de"] [data-l="en"]{ display:none; }

/* ---------- layout helpers ---------- */
.container{ width:90%; max-width:var(--maxw); margin:0 auto; }
.section{ padding:clamp(70px,9vw,130px) 0; position:relative; }

.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(36px,6vw,90px);
  align-items:center;
}

/* ---------- typography ---------- */
h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.1; color:var(--charcoal); }
.section-title{
  font-size:clamp(2rem,4.6vw,3.4rem);
  font-weight:500;
  letter-spacing:.3px;
  margin-bottom:.5em;
}
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  font-weight:400;
  color:var(--bronze);
  margin-bottom:1.1em;
}
.eyebrow-light{ color:#E9CF9A; }
.lead{ font-size:1.18rem; color:var(--charcoal-2); margin-bottom:1.1em; }
p{ color:var(--charcoal-2); margin-bottom:1em; }
p:last-child{ margin-bottom:0; }

.section-head.center{ text-align:center; max-width:680px; margin:0 auto clamp(40px,5vw,68px); }
.section-head.center .eyebrow{ margin-bottom:1em; }
.section-intro-text{ font-size:1.1rem; color:var(--muted); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-weight:400; font-size:.85rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:1.05em 2em; border-radius:999px;
  transition:all .35s var(--ease); white-space:nowrap; cursor:pointer;
}
.btn-gold{ background:var(--bronze); color:var(--white); box-shadow:0 8px 24px rgba(176,133,66,.32); }
.btn-gold:hover{ background:var(--bronze-deep); transform:translateY(-2px); box-shadow:0 12px 30px rgba(176,133,66,.4); }
.btn-outline{ border:1px solid var(--bronze); color:var(--bronze-deep); }
.btn-outline:hover{ background:var(--bronze); color:var(--white); transform:translateY(-2px); }
.btn-ghost-light{ border:1px solid rgba(255,255,255,.55); color:#fff; }
.btn-ghost-light:hover{ background:rgba(255,255,255,.14); transform:translateY(-2px); }
.btn-pill{ padding:.7em 1.5em; font-size:.78rem; }

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{
  position:fixed; top:0; left:0; width:100%; z-index:100;
  padding:20px 0;
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(246,241,231,.92);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  padding:12px 0; box-shadow:var(--shadow-sm);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

.brand{ display:flex; align-items:center; gap:12px; color:#fff; transition:color .4s var(--ease); }
.site-header.scrolled .brand{ color:var(--charcoal); }
.brand-mark{ display:flex; color:var(--bronze); flex:none; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:var(--serif); font-size:1.35rem; font-weight:600; letter-spacing:.3px; }
.brand-sub{ font-family:var(--sans); font-size:.62rem; letter-spacing:.42em; text-transform:uppercase; opacity:.8; margin-top:3px; }

.nav{ display:flex; gap:30px; margin-left:auto; }
.nav a{
  font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.9);
  font-weight:300; position:relative; padding:4px 0; transition:color .3s;
}
.site-header.scrolled .nav a{ color:var(--charcoal-2); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--bronze); transition:width .3s var(--ease);
}
.nav a:hover{ color:var(--bronze); }
.nav a:hover::after{ width:100%; }

.header-actions{ display:flex; align-items:center; gap:16px; }
.lang-toggle{ display:flex; align-items:center; gap:5px; font-size:.8rem; letter-spacing:.08em; color:rgba(255,255,255,.85); }
.site-header.scrolled .lang-toggle{ color:var(--charcoal-2); }
.lang-opt{ opacity:.5; transition:opacity .3s, color .3s; padding:2px; }
.lang-opt.active{ opacity:1; color:var(--bronze); font-weight:500; }
.lang-sep{ opacity:.4; }
.book-cta{ background:var(--bronze); color:var(--white); }
.book-cta:hover{ background:var(--bronze-deep); }

.menu-toggle{ display:none; flex-direction:column; gap:5px; width:30px; padding:4px; }
.menu-toggle span{ display:block; height:1.6px; width:100%; background:#fff; transition:all .3s var(--ease); }
.site-header.scrolled .menu-toggle span{ background:var(--charcoal); }
.menu-toggle.open span:nth-child(1){ transform:translateY(6.6px) rotate(45deg); }
.menu-toggle.open span:nth-child(2){ opacity:0; }
.menu-toggle.open span:nth-child(3){ transform:translateY(-6.6px) rotate(-45deg); }

/* keep header controls visible over the ivory mobile-menu overlay */
body.menu-open .brand{ color:var(--charcoal); }
body.menu-open .lang-toggle{ color:var(--charcoal-2); }
body.menu-open .menu-toggle span{ background:var(--charcoal); }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:99; background:var(--ivory);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu nav{ display:flex; flex-direction:column; align-items:center; gap:26px; text-align:center; }
.mobile-menu nav a{ font-family:var(--serif); font-size:1.9rem; color:var(--charcoal); }
.mobile-menu nav a.btn{ font-family:var(--sans); font-size:.85rem; margin-top:10px; }

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  overflow:hidden; color:#fff;
}
.hero-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
}
.hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(20,17,14,.55) 0%, rgba(20,17,14,.25) 35%, rgba(20,17,14,.45) 75%, rgba(20,17,14,.78) 100%),
    radial-gradient(120% 80% at 50% 30%, rgba(20,17,14,0) 40%, rgba(20,17,14,.4) 100%);
}
.hero-content{ position:relative; z-index:2; padding:120px 0 90px; max-width:860px; }
.hero-title{
  color:#fff;
  font-size:clamp(2.6rem,6.6vw,5rem); font-weight:500; line-height:1.06; letter-spacing:.5px;
  margin-bottom:.4em; text-shadow:0 2px 30px rgba(0,0,0,.45);
}
.hero-sub{
  font-size:clamp(1.05rem,2vw,1.32rem); font-weight:300; color:rgba(255,255,255,.92);
  max-width:560px; margin-bottom:2.2em; text-shadow:0 1px 16px rgba(0,0,0,.3);
}
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; }

.scroll-cue{ position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:2; }
.scroll-cue-line{ display:block; width:1px; height:54px; background:linear-gradient(180deg, rgba(255,255,255,.8), rgba(255,255,255,0)); position:relative; overflow:hidden; }
.scroll-cue-line::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%; background:#fff; animation:scrollcue 2.2s var(--ease) infinite; }
@keyframes scrollcue{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(260%);} }

/* ===================================================================
   INTRO / WHAT IS
   =================================================================== */
.section-intro{ background:var(--ivory); }
.intro-media img{ width:100%; border-radius:6px; box-shadow:var(--shadow-md); aspect-ratio:4/3.2; object-fit:cover; }
.stat-row{ display:flex; gap:48px; margin-top:36px; padding-top:30px; border-top:1px solid var(--line); }
.stat{ display:flex; flex-direction:column; }
.stat-num{ font-family:var(--serif); font-size:2.6rem; color:var(--bronze); line-height:1; }
.stat-label{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* ===================================================================
   QUOTE BAND
   =================================================================== */
.quote-band{
  position:relative; background-size:cover; background-position:center; background-attachment:fixed;
  padding:clamp(90px,12vw,160px) 0; text-align:center;
}
.quote-overlay{ position:absolute; inset:0; background:rgba(20,17,14,.6); }
.quote-band .container{ position:relative; z-index:1; }
.quote-band blockquote{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(1.5rem,3.4vw,2.6rem); line-height:1.4; color:#fff; max-width:900px; margin:0 auto;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
}

/* ===================================================================
   BENEFITS
   =================================================================== */
.section-benefits{ background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-2) 100%); }
.benefits-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.benefit-card{
  background:var(--white); border:1px solid var(--line-soft); border-radius:8px;
  padding:42px 34px; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
}
.benefit-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(176,133,66,.3); }
.benefit-icon{
  display:flex; align-items:center; justify-content:center; width:56px; height:56px; border-radius:50%;
  border:1px solid var(--bronze); color:var(--bronze); font-size:1.5rem; margin-bottom:22px;
}
.benefit-card h3{ font-size:1.45rem; margin-bottom:.4em; }
.benefit-card p{ font-size:.98rem; color:var(--muted); margin:0; }

/* ===================================================================
   ABOUT
   =================================================================== */
.section-about{ background:var(--ivory-2); }
.grid-2-reverse .about-media{ order:1; }
.about-media{ position:relative; padding-bottom:46px; padding-right:42px; }
.about-img-main{ width:100%; border-radius:6px; box-shadow:var(--shadow-md); aspect-ratio:3/3.6; object-fit:cover; }
.about-img-accent{
  position:absolute; right:0; bottom:0; width:48%; border-radius:6px; border:6px solid var(--ivory-2);
  box-shadow:var(--shadow-md); aspect-ratio:3/3.5; object-fit:cover;
}
.about-copy .btn{ margin-top:14px; }
.about-spiritual-name{ font-family:var(--serif); font-style:italic; font-size:1.35rem; color:var(--bronze); letter-spacing:.04em; margin:-0.45em 0 1.1em; }

/* ===================================================================
   EXPERIENCES
   =================================================================== */
.section-experiences{ background:linear-gradient(180deg, var(--ivory-2) 0%, var(--ivory) 100%); }
.exp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.exp-card{
  background:var(--white); border-radius:8px; overflow:hidden; border:1px solid var(--line-soft);
  display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.exp-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.exp-img{ overflow:hidden; aspect-ratio:4/3; }
.exp-img img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.exp-card:hover .exp-img img{ transform:scale(1.06); }
.exp-body{ padding:28px 28px 32px; }
.exp-body h3{ font-size:1.5rem; margin-bottom:.4em; }
.exp-body p{ font-size:.96rem; color:var(--muted); margin:0; }

.projects-band{
  margin-top:54px; display:grid; grid-template-columns:1fr 1fr; gap:40px;
  background:var(--charcoal); color:var(--ivory); border-radius:10px;
  padding:clamp(34px,5vw,58px);
}
.projects-band h3{ color:var(--ivory); font-size:1.7rem; margin-bottom:.4em; }
.projects-col h3::before{ content:""; display:block; width:40px; height:1px; background:var(--bronze); margin-bottom:18px; }
.projects-band p{ color:rgba(246,241,231,.74); font-size:1rem; margin:0; }

/* ===================================================================
   GALLERY
   =================================================================== */
.section-gallery{ background:var(--ivory); padding-bottom:clamp(70px,9vw,130px); }
/* Masonry via CSS columns — never leaves empty cells, shows photos uncropped */
.gallery-grid{ column-count:4; column-gap:12px; margin-top:10px; }
.gallery-item{
  display:block; width:100%; margin:0 0 12px; padding:0; overflow:hidden;
  position:relative; break-inside:avoid; border-radius:4px; line-height:0;
}
.gallery-item img{ width:100%; height:auto; transition:transform .8s var(--ease); }
.gallery-item::after{
  content:"⤢"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.6rem; line-height:1; background:rgba(42,38,34,.34); opacity:0; transition:opacity .4s;
}
.gallery-item:hover img{ transform:scale(1.06); }
.gallery-item:hover::after{ opacity:1; }

/* ===================================================================
   VIDEO GALLERY
   =================================================================== */
.section-videos{ background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-2) 100%); }
.video-grid{ column-count:4; column-gap:14px; }
.video-item{
  display:block; width:100%; margin:0 0 14px; padding:0; position:relative;
  break-inside:avoid; overflow:hidden; border-radius:6px; line-height:0; cursor:pointer;
  background:var(--charcoal); box-shadow:var(--shadow-sm);
}
.video-item img{ width:100%; height:auto; transition:transform .8s var(--ease), opacity .4s; }
.video-item::before{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,17,14,0) 40%, rgba(20,17,14,.45) 100%);
  opacity:.7; transition:opacity .4s; z-index:1;
}
.video-item:hover img{ transform:scale(1.05); }
.video-item:hover::before{ opacity:1; }
.video-play{
  position:absolute; inset:0; margin:auto; z-index:2;
  width:64px; height:64px; border-radius:50%;
  background:rgba(176,133,66,.9); backdrop-filter:blur(2px);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 22px rgba(20,17,14,.35); transition:transform .35s var(--ease), background .35s;
}
.video-play::after{
  content:""; width:0; height:0; margin-left:5px;
  border-left:19px solid #fff; border-top:12px solid transparent; border-bottom:12px solid transparent;
}
.video-item:hover .video-play{ transform:scale(1.1); background:var(--bronze); }

/* ===================================================================
   VIDEO LIGHTBOX
   =================================================================== */
.video-lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(20,17,14,.96);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s;
}
.video-lightbox.open{ opacity:1; visibility:visible; }
.vlb-stage{ display:flex; align-items:center; justify-content:center; max-width:92vw; }
#vlbVideo{ max-width:92vw; max-height:86vh; width:auto; height:auto; border-radius:6px; box-shadow:0 20px 80px rgba(0,0,0,.6); background:#000; outline:none; }
.video-lightbox .lightbox-close{ position:absolute; top:24px; right:30px; color:#fff; font-size:2.4rem; line-height:1; opacity:.85; transition:opacity .3s; }
.video-lightbox .lightbox-close:hover{ opacity:1; }

/* ===================================================================
   BOOKING
   =================================================================== */
.section-booking{ background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-2) 100%); }

/* experience selector */
.booking-tabs{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  max-width:1000px; margin:0 auto 24px;
}
.booking-tab{
  position:relative; text-align:left; cursor:pointer;
  background:var(--white); border:1px solid var(--line-soft); border-radius:10px;
  padding:22px 24px; display:flex; flex-direction:column; gap:7px; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
}
.booking-tab::before{
  content:""; position:absolute; left:0; top:0; height:100%; width:3px;
  background:var(--bronze); transform:scaleY(0); transform-origin:top; transition:transform .35s var(--ease);
}
.booking-tab:hover{ transform:translateY(-3px); box-shadow:var(--shadow-sm); border-color:rgba(176,133,66,.4); }
.booking-tab.is-active{ border-color:var(--bronze); box-shadow:0 10px 30px rgba(176,133,66,.16); }
.booking-tab.is-active::before{ transform:scaleY(1); }
.bt-name{ font-family:var(--serif); font-size:1.32rem; line-height:1.15; color:var(--charcoal); }
.bt-dur{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--bronze); }
.bt-meta{ font-size:.86rem; color:var(--muted); line-height:1.5; }

.booking-embed{ max-width:1000px; margin:0 auto; height:700px; border-radius:10px; overflow:hidden; }
.booking-embed .calendly-inline-widget{ height:100% !important; min-width:0 !important; }
.booking-embed iframe{ width:100%; height:100%; border:0; display:block; }
.booking-alt{ text-align:center; margin-top:18px; color:var(--muted); font-size:.95rem; }
.booking-alt a{ color:var(--bronze-deep); border-bottom:1px solid rgba(176,133,66,.4); padding-bottom:1px; transition:border-color .3s; }
.booking-alt a:hover{ border-color:var(--bronze); }
.booking-fallback{ max-width:620px; margin:0 auto; }
.booking-card{
  background:var(--white); border:1px solid var(--line-soft); border-radius:12px;
  padding:clamp(34px,5vw,52px); text-align:center; box-shadow:var(--shadow-sm);
}
.booking-card-text{ font-size:1.12rem; color:var(--charcoal-2); margin-bottom:1.6em; }
.booking-card-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ===================================================================
   CONTACT
   =================================================================== */
.section-contact{ background:var(--ivory-2); }
.contact-list{ margin-top:30px; display:flex; flex-direction:column; gap:6px; }
.contact-row{ display:flex; align-items:center; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.contact-ic{
  display:flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%;
  border:1px solid var(--bronze); color:var(--bronze); font-size:1.05rem; flex:none;
}
.contact-row a, .contact-row span#contact-location{ font-size:1.08rem; color:var(--charcoal-2); transition:color .3s; }
.contact-row a:hover{ color:var(--bronze); }
.contact-media img{ width:100%; border-radius:6px; box-shadow:var(--shadow-md); aspect-ratio:4/4.4; object-fit:cover; }

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{ background:var(--charcoal); color:var(--ivory); padding:60px 0 36px; }
.footer-inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:30px; }
.footer-brand{ display:flex; align-items:center; gap:12px; }
.footer-brand .brand-mark{ color:var(--bronze); }
.footer-name{ font-family:var(--serif); font-size:1.3rem; }
.footer-tag{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(246,241,231,.55); border-left:1px solid rgba(246,241,231,.2); padding-left:12px; }
.footer-nav{ display:flex; align-items:center; gap:26px; }
.footer-nav a{ font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(246,241,231,.7); transition:color .3s; }
.footer-nav a:hover{ color:var(--bronze); }
.footer-ig{ display:inline-flex; align-items:center; color:rgba(246,241,231,.7); }
.footer-ig svg{ display:block; }
.footer-copy{ width:100%; text-align:center; font-size:.78rem; color:rgba(246,241,231,.4); margin-top:30px; padding-top:24px; border-top:1px solid rgba(246,241,231,.12); }

/* ===================================================================
   LIGHTBOX
   =================================================================== */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(20,17,14,.94);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox-img{ max-width:90vw; max-height:86vh; border-radius:4px; box-shadow:0 20px 80px rgba(0,0,0,.6); }
.lightbox-close{ position:absolute; top:24px; right:30px; color:#fff; font-size:2.4rem; line-height:1; opacity:.8; transition:opacity .3s; }
.lightbox-close:hover{ opacity:1; }
.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); color:#fff; font-size:3rem; opacity:.6; padding:0 24px; transition:opacity .3s; }
.lightbox-nav:hover{ opacity:1; }
.lightbox-prev{ left:8px; }
.lightbox-next{ right:8px; }

/* ===================================================================
   REVEAL ANIMATION
   =================================================================== */
/* Content is fully visible without JS; only animate when JS is active. */
.js .reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.js .reveal.visible{ opacity:1; transform:none; }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:980px){
  .nav{ display:none; }
  .menu-toggle{ display:flex; }
  .book-cta{ display:none; }
  .benefits-grid{ grid-template-columns:repeat(2,1fr); }
  .exp-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ column-count:3; }
  .video-grid{ column-count:3; }
}
@media (max-width:720px){
  body{ font-size:16px; }
  .grid-2{ grid-template-columns:1fr; }
  .grid-2-reverse .about-media{ order:0; }
  .about-media{ padding-right:30px; padding-bottom:36px; max-width:460px; }
  .benefits-grid{ grid-template-columns:1fr; }
  .exp-grid{ grid-template-columns:1fr; }
  .projects-band{ grid-template-columns:1fr; gap:28px; }
  .gallery-grid{ column-count:2; }
  .video-grid{ column-count:2; }
  .stat-row{ gap:32px; }
  .hero-content{ padding:130px 0 100px; }
  .quote-band{ background-attachment:scroll; }
  .booking-tabs{ grid-template-columns:1fr; }
  .booking-embed{ height:1040px; }
  /* footer: tidy, breathable stack on mobile */
  .footer-inner{ flex-direction:column; text-align:center; gap:30px; }
  .footer-brand{ flex-direction:column; gap:10px; }
  .footer-tag{ border-left:none; padding-left:0; }
  .footer-nav{ flex-wrap:wrap; justify-content:center; gap:14px 22px; }
  .footer-copy{ margin-top:6px; padding-top:24px; }
}
@media (max-width:480px){
  .hero-actions .btn{ width:100%; }
  .booking-card-actions .btn{ width:100%; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; transition:none; }
}
