/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,textarea,select{font:inherit}

/* === TOKENS === */
:root{
--color-primary:hsl(38,55%,50%);
--color-primary-hover:hsl(38,55%,40%);
--color-primary-light:hsl(38,50%,94%);
--color-secondary:hsl(25,40%,22%);
--color-accent:hsl(15,60%,48%);
--color-success:hsl(142,70%,42%);
--color-danger:hsl(0,80%,55%);
--bg-page:hsl(40,25%,97%);
--bg-card:hsl(40,15%,95%);
--bg-muted:hsl(38,20%,92%);
--bg-dark:hsl(30,15%,10%);
--bg-overlay:rgba(0,0,0,0.55);
--text-primary:hsl(30,10%,12%);
--text-secondary:hsl(30,8%,38%);
--text-muted:hsl(30,6%,55%);
--text-inverse:#fff;
--border:1px solid hsl(35,15%,85%);
--border-color:hsl(35,15%,85%);
--radius-sm:8px;--radius:12px;--radius-lg:20px;--radius-full:9999px;
--shadow-sm:0 2px 8px rgba(0,0,0,0.06);
--shadow:0 4px 16px rgba(0,0,0,0.08);
--shadow-md:0 8px 24px rgba(0,0,0,0.1);
--shadow-lg:0 16px 48px rgba(0,0,0,0.12);
--font-heading:'Cormorant Garamond',Georgia,serif;
--font-body:'Inter',system-ui,sans-serif;
--space-1:8px;--space-2:16px;--space-3:24px;--space-4:32px;--space-5:48px;--space-6:64px;--space-7:96px;
--ease:cubic-bezier(0.4,0,0.2,1);
--duration:300ms;
--transition:all 300ms cubic-bezier(0.4,0,0.2,1);
--container:1200px;
--header-height:80px;
}

/* === LAYOUT === */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--space-3)}
.section{padding:var(--space-5) 0}
.section--muted{background:var(--bg-muted)}
.section--dark{background:var(--bg-dark);color:var(--text-inverse)}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-3)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
.text-center{text-align:center}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--text-primary)}
h1{font-size:clamp(2rem,5vw,3.75rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.5rem);margin-bottom:var(--space-2)}
h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}
h4{font-size:1.25rem}
.eyebrow{font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-1)}
.section-intro{max-width:680px;margin:0 auto var(--space-5);color:var(--text-secondary);font-size:1.05rem;text-align:center}

/* === HEADER === */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(253,251,247,0.92);backdrop-filter:blur(12px);border-bottom:var(--border);transition:var(--transition);height:var(--header-height)}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);max-width:var(--container);margin:0 auto;padding:0 var(--space-3)}
.header__logos{display:flex;align-items:center;gap:var(--space-2)}
.header__logo-img{height:50px;width:auto;object-fit:contain}
.header__logo-divider{width:1px;height:32px;background:var(--border-color)}
.header__logo-owa{height:36px;width:auto;object-fit:contain}
.nav{display:flex;align-items:center;gap:var(--space-3)}
.nav__link{font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:var(--transition);position:relative}
.nav__link:hover,.nav__link.active{color:var(--color-primary)}
.nav__link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-primary);transition:var(--transition)}
.nav__link:hover::after,.nav__link.active::after{width:100%}
.header__cta{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;transition:var(--transition)}
.header__cta:hover{background:var(--color-primary-hover);transform:translateY(-2px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-primary);transition:var(--transition)}

/* === HERO === */
.hero{position:relative;height:calc(100vh - var(--header-height));height:calc(100svh - var(--header-height));display:flex;flex-direction:column;align-items:stretch;justify-content:center;overflow:hidden;margin-top:var(--header-height);-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}
.hero__slideshow{position:absolute;inset:0;z-index:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}

/* --- Flawless Video Flow + Ken Burns --- */
@keyframes zoomInContinuous {
  0% { transform: scale(1); }
  100% { transform: scale(1.15); }
}

.hero__slide {
  position:absolute;inset:0;
  opacity:0;
  z-index:0;
  background-size:cover;
  background-position:center;
  backface-visibility: hidden;
  transition: opacity 2.5s ease-in-out;
  will-change: opacity, transform;
}

/* Continuous forward motion for all slides for that "one long video" feel */
.hero__slide.animating {
  animation: zoomInContinuous 15s linear forwards;
}

.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,26,26,0.75),rgba(26,26,26,0.5));z-index:1}
.hero__content{position:relative;z-index:2;max-width:720px;padding:var(--space-5) 0}
.hero__eyebrow{font-family:var(--font-body);font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-2);font-weight:600}
.hero h1{color:#fff;margin-bottom:var(--space-2);line-height:1.15}
.hero__subtitle{color:rgba(255,255,255,0.85);font-size:1.15rem;line-height:1.7;margin-bottom:var(--space-4);max-width:600px}
.hero__trust{color:rgba(255,255,255,0.6);font-size:.9rem;margin-top:var(--space-3);font-style:italic}
.hero__actions{display:flex;gap:var(--space-2);flex-wrap:wrap}
/* Dots completely hidden */
.hero__indicators{display:none !important}
.hero__dot{display:none !important}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:.8em 2em;border-radius:var(--radius-full);font-weight:600;font-size:.95rem;transition:var(--transition);cursor:pointer;text-decoration:none;white-space:nowrap}
.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 16px rgba(200,151,62,0.3)}
.btn--primary:hover, .btn--primary:active{background:var(--color-primary-hover);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,151,62,0.4)}
.btn--secondary{background:transparent;color:#fff;border:2px solid rgba(255,255,255,0.5)}
.btn--secondary:hover, .btn--secondary:active{background:#fff;color:#111}
.btn--outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}
.btn--outline:hover, .btn--outline:active{background:var(--color-primary);color:#fff}
.btn--dark{background:var(--text-primary);color:var(--bg-page)}
.btn--dark:hover, .btn--dark:active{background:var(--color-secondary);color:#fff;transform:translateY(-2px)}
.btn--whatsapp{background:#25D366;color:#fff;gap:8px}
.btn--whatsapp:hover, .btn--whatsapp:active{background:#1da851;color:#fff;transform:translateY(-2px)}
.btn--sm{padding:.5em 1.25em;font-size:.85rem}
.btn--lg{padding:1em 2.5em;font-size:1.05rem}

/* === CARDS === */
.card{background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-6px)}
.card__img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__img{transform:scale(1.05)}
.card__body{padding:var(--space-3)}
.card__eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);margin-bottom:6px}
.card__title{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:8px}
.card__text{color:var(--text-secondary);font-size:.95rem;line-height:1.65}
.card__price{font-family:var(--font-heading);font-size:1.5rem;color:var(--color-primary);font-weight:700;margin-top:var(--space-2)}
.card__list{margin-top:var(--space-2)}
.card__list li{padding:6px 0;padding-left:24px;position:relative;color:var(--text-secondary);font-size:.9rem}
.card__list li::before{content:'✓';position:absolute;left:0;color:var(--color-primary);font-weight:700}

/* === ABOUT SPLIT === */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center}
.about-img-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden}
.about-img-wrap img{width:100%;height:auto;border-radius:var(--radius-lg)}
.about-img-wrap::after{content:'';position:absolute;inset:0;border:3px solid var(--color-primary);border-radius:var(--radius-lg);opacity:.3}
.about-text h2{margin-bottom:var(--space-2)}
.about-text p{color:var(--text-secondary);margin-bottom:var(--space-2);line-height:1.7}

/* === NOTICE BAR === */
.notice{background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius);padding:var(--space-2) var(--space-3);display:flex;align-items:flex-start;gap:var(--space-2);margin:var(--space-4) 0}
.notice__icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}
.notice__text{font-size:.95rem;color:var(--text-secondary);line-height:1.6}
.notice__text strong{color:var(--text-primary)}

/* === BENEFITS === */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.benefit-card{text-align:center;padding:var(--space-4) var(--space-3);background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border);transition:var(--transition)}
.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.benefit-icon{width:64px;height:64px;margin:0 auto var(--space-2);background:var(--color-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.benefit-card h4{font-family:var(--font-heading);margin-bottom:var(--space-1)}
.benefit-card ul{text-align:left;margin-top:var(--space-2)}
.benefit-card li{padding:4px 0;padding-left:20px;position:relative;color:var(--text-secondary);font-size:.9rem}
.benefit-card li::before{content:'•';position:absolute;left:4px;color:var(--color-primary)}

/* === PRICING === */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}
.price-card{text-align:center;padding:var(--space-4) var(--space-3);background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border);transition:var(--transition)}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.price-card.featured{border-color:var(--color-primary);position:relative}
.price-card.featured::before{content:'POPULAR';position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--color-primary);color:#fff;padding:4px 16px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.08em}
.price-card h4{font-family:var(--font-heading);margin-bottom:var(--space-1)}
.price-amount{font-family:var(--font-heading);font-size:2rem;color:var(--color-primary);font-weight:700;margin:var(--space-2) 0}
.price-amount span{font-size:.9rem;color:var(--text-muted);font-weight:400}

/* === PAYMENT === */
.payment-methods{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center;margin-top:var(--space-4)}
.payment-item{display:flex;align-items:center;gap:12px;padding:var(--space-2) var(--space-3);background:var(--bg-card);border:var(--border);border-radius:var(--radius);min-width:180px;transition:var(--transition)}
.payment-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.payment-item__icon{font-size:1.5rem}
.payment-item__name{font-weight:600;font-size:.95rem}

/* === FORM SYSTEM === */
.form-section{max-width:800px;margin:0 auto}
.stepper-progress{display:flex;justify-content:center;gap:var(--space-1);margin-bottom:var(--space-5)}
.step-indicator{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-full);font-size:.85rem;font-weight:600;color:var(--text-muted);background:var(--bg-muted);transition:var(--transition)}
.step-indicator.active{background:var(--color-primary);color:#fff}
.step-indicator.done{background:var(--color-success);color:#fff}
.step-panel{display:none}
.step-panel.active{display:block;animation:fadeIn .4s ease}
.form{display:flex;flex-direction:column;gap:var(--space-2)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}
.form-input,.form-select,.form-textarea{width:100%;padding:.75rem 1rem;background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border-color);border-radius:var(--radius);font-size:1rem;transition:var(--transition);outline:none;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(200,151,62,0.15)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:2.5rem;cursor:pointer}
.form-select option {background-color: var(--bg-card); color: var(--text-primary);}
.form-select option[disabled] {color: var(--text-muted);}
.form-textarea{resize:vertical;min-height:100px}
.form-input.error,.form-select.error{border-color:var(--color-danger)}
.form-error{font-size:.75rem;color:var(--color-danger)}

/* Autofill fix */
.form-input:-webkit-autofill,
.form-input:-webkit-autofill:hover, 
.form-input:-webkit-autofill:focus, 
.form-input:-webkit-autofill:active,
.form-select:-webkit-autofill,
.form-select:-webkit-autofill:hover, 
.form-select:-webkit-autofill:focus, 
.form-select:-webkit-autofill:active,
.form-textarea:-webkit-autofill,
.form-textarea:-webkit-autofill:hover, 
.form-textarea:-webkit-autofill:focus, 
.form-textarea:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px var(--bg-card) inset !important;
    -webkit-text-fill-color: var(--text-primary) !important;
    transition: background-color 5000s ease-in-out 0s;
}
.form-actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-3)}
.form-success{text-align:center;padding:var(--space-5);background:hsl(142,50%,95%);border:1px solid var(--color-success);border-radius:var(--radius-lg)}
.form-success h3{color:var(--color-success);margin-bottom:var(--space-1)}
.booking-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}
.booking-option{
  padding:var(--space-3);
  border:2px solid var(--border-color);
  border-radius:var(--radius);
  cursor:pointer;
  transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
  text-align:center;
  background:rgba(255,255,255,0.02);
  position:relative;
}
.booking-option:hover{
  border-color:var(--color-primary);
  background:rgba(192,139,46,0.08);
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}
.booking-option.selected{
  border-color:var(--color-primary);
  background:var(--color-primary) !important;
  box-shadow:0 0 20px rgba(192,139,46,0.4);
}
.booking-option.selected .booking-option__icon,
.booking-option.selected .booking-option__title {
  color: #1a1a1a !important; /* Force dark text on gold background */
}
.booking-option__icon{font-size:2rem;margin-bottom:8px;transition:color 0.3s ease;color:var(--color-primary);font-weight:700}
.booking-option__title{font-weight:600;font-size:.95rem;transition:color 0.3s ease}

/* === FAQ === */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:var(--border);overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;cursor:pointer;font-weight:600;font-size:1.05rem;transition:var(--transition)}
.faq-question:hover{color:var(--color-primary)}
.faq-question__icon{transition:transform .3s var(--ease);font-size:1.2rem;flex-shrink:0}
.faq-item.open .faq-question__icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease)}
.faq-item.open .faq-answer{max-height:300px;padding-bottom:var(--space-3)}
.faq-answer p{color:var(--text-secondary);line-height:1.7}

/* === CONTACT === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}
.contact-info{display:flex;flex-direction:column;gap:var(--space-3)}
.contact-item{display:flex;gap:var(--space-2);align-items:flex-start}
.contact-item__icon{width:48px;height:48px;background:var(--color-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.contact-item__text h4{margin-bottom:4px}
.contact-item__text p,.contact-item__text a{color:var(--text-secondary);font-size:.95rem}
.contact-item__text a:hover{color:var(--color-primary)}
.map-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:var(--border);height:480px}
.map-wrap iframe{width:100%;height:100%;border:0}
.map-overlay{position:absolute;top:auto;bottom:24px;left:16px;width:245px;background:#111;color:#fff;padding:20px;border:1px solid var(--color-primary);z-index:2;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:12px;border-radius:8px}
.map-overlay h4{font-family:var(--font-heading);color:var(--color-primary);font-size:1.15rem;margin:0;font-weight:600}
.map-overlay p{color:#ccc;font-size:0.82rem;line-height:1.5;margin:0}
.map-link{font-size:0.7rem;font-weight:700;color:#fff;text-decoration:none;letter-spacing:0.1em;text-transform:uppercase;margin-top:6px;transition:var(--transition);display:inline-block}
.map-link:hover{color:var(--color-primary)}
@media(max-width:768px){.map-overlay{bottom:20px;left:50%;transform:translateX(-50%);width:90%;padding:20px}}

/* === FOOTER === */
.footer{background:var(--bg-dark);color:rgba(255,255,255,0.7);padding:var(--space-5) 0 var(--space-3)}
.footer__top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid rgba(255,255,255,0.1)}
.footer__brand h3{color:#fff;font-family:var(--font-heading);margin-bottom:8px}
.footer__brand p{font-size:.9rem;max-width:300px}
.footer__links h5{color:#fff;margin-bottom:var(--space-2);font-family:var(--font-heading)}
.footer__links a{display:block;padding:4px 0;font-size:.9rem;transition:var(--transition)}
.footer__links a:hover{color:var(--color-primary)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);font-size:.8rem;flex-wrap:wrap;gap:var(--space-2)}
.footer__powered{display:flex;align-items:center;gap:8px;font-size:.8rem;opacity:.6}
.footer__powered img{height:24px}

/* === ANIMATIONS === */
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){
  .reveal{transition:none}
  .hero__slide:nth-child(even).active,
  .hero__slide:nth-child(even).prev,
  .hero__slide:nth-child(odd).active,
  .hero__slide:nth-child(odd).prev {
    animation: none;
  }
}

/* === WHATSAPP FLOAT === */
.whatsapp-float{position:fixed;bottom:24px;right:24px;z-index:9999;background:#25D366;border-radius:50%;width:58px;height:58px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.4);transition:transform .3s ease,box-shadow .3s ease;animation:waPulse 2s infinite;transform:translateZ(0);-webkit-transform:translateZ(0);will-change:transform}
.whatsapp-float:hover{transform:scale(1.12) translateZ(0);box-shadow:0 6px 28px rgba(37,211,102,0.6)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,0.7)}}
@media(max-width:640px) { .whatsapp-float{bottom:70px;right:16px;width:50px;height:50px;font-size:1.5rem} }

/* === GALLERY MOSAIC === */
.gallery-mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}
.gallery-mosaic__item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.gallery-mosaic__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-mosaic__item:hover img{transform:scale(1.08)}
.gallery-mosaic__item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-mosaic__item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.3),transparent);opacity:0;transition:opacity .3s ease}
.gallery-mosaic__item:hover::after{opacity:1}

/* === ACTIVITIES SECTION === */
.activities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-4);
}
.activity-card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: var(--border);
  overflow: hidden;
  transition: var(--transition);
  display: flex;
  flex-direction: column;
}
.activity-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary);
}
.activity-card__img-wrap {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.activity-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.activity-card:hover .activity-card__img-wrap img {
  transform: scale(1.06);
}
.activity-card__body {
  padding: var(--space-3);
  flex-grow: 1;
}
.activity-card__body h4 {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  margin-bottom: 8px;
  color: var(--text-primary);
}
.activity-card__body p {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* === MOBILE NAV === */
.mobile-nav{display:none;position:fixed;top:var(--header-height);left:0;width:100%;height:calc(100vh - var(--header-height));background:rgba(253,251,247,0.98);backdrop-filter:blur(16px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);opacity:0;pointer-events:none;transition:opacity .3s ease}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav .nav__link{font-size:1.2rem;padding:8px 0}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .nav{display:none}
  .header__cta{display:none}
  .hamburger{display:flex}
  .mobile-nav{display:flex}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
}
/* Tablet specific: 769px - 1024px */
@media(min-width:769px) and (max-width:1024px){
  .hero{min-height:600px;overflow:visible}
  .hero__marquee{position:absolute;bottom:0;left:0;width:100%;display:flex;z-index:10;font-size:.9rem;padding:11px 0}
  .hero h1{font-size:clamp(1.85rem,3.2vw,2.2rem);line-height:1.1;white-space:normal;word-wrap:break-word}
  .hero h1 br{display:none}
  .hero__subtitle{font-size:.95rem;max-width:92%;line-height:1.65}
  .hero__stat-num{font-size:1.7rem}
  .hero__stat-label{font-size:.7rem}
  .hero__stats{gap:var(--space-3)}
  .hero__stat-divider{height:40px}
  .hero__content{padding:65px var(--space-3) 110px;margin-top:0}
  .hero__badge{font-size:.7rem;padding:7px 16px;margin-top:10px}
  .btn--lg{padding:.85em 1.8em;font-size:1rem}
  .container{padding-inline:24px}
  .hero__powered{font-size:.72rem}
}
@media(max-width:768px){
  .about-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .hero__content{padding:60px var(--space-2) 100px;margin-top:0}
  .hero h1{font-size:clamp(1.65rem,4.5vw,1.95rem);line-height:1.12;white-space:normal;word-wrap:break-word}
  .hero h1 br{display:none}
  .hero__subtitle{font-size:.9rem;line-height:1.6;margin-bottom:var(--space-3);max-width:95%}
  .hero__badge{font-size:.65rem;padding:6px 14px;margin-top:8px}
  .booking-options{grid-template-columns:1fr}
  .gallery-mosaic{grid-template-columns:repeat(2,1fr)}
  .gallery-mosaic__item:nth-child(1){grid-column:span 2}
  .hero__stats{gap:28px;margin-bottom:var(--space-3)}
  .hero__stat-num{font-size:1.55rem}
  .hero__stat-label{font-size:.66rem}
  .hero__stat-divider{height:36px}
  .btn--lg{padding:.85em 1.6em;font-size:.98rem}
  .hero__marquee{position:absolute;bottom:0;left:0;width:100%;display:flex;z-index:10;font-size:.82rem;padding:10px 0}
  .container{padding-inline:var(--space-2)}
  .hero__powered{font-size:.7rem}
}
@media(max-width:640px){
  .activities-grid{grid-template-columns:1fr}
  .grid-auto{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero__actions{flex-direction:column;align-items:stretch;width:100%;gap:12px}
  .hero__actions .btn{width:100%;justify-content:center}
  .hero__actions .btn--secondary{display:none}
  .hero__stat-divider{display:none}
  .hero__stats{gap:var(--space-2);margin-bottom:var(--space-3)}
  .hero__marquee{position:absolute;bottom:0;left:0;width:100%;display:flex;z-index:10;font-size:.75rem;padding:9px 0}
  .stepper-progress{flex-direction:column;align-items:center}
  .payment-methods{flex-direction:column;align-items:center}
  .footer__top{flex-direction:column}
  .footer__bottom{flex-direction:column;justify-content:center;text-align:center;gap:16px}
  .gallery-mosaic{grid-template-columns:1fr}
  .gallery-mosaic__item:nth-child(1){grid-column:span 1;grid-row:span 1}
  .header__logo-owa{display:block;height:26px;width:auto}
  .header__logo-divider{display:none}
/* Mobile hero specific fixes */
  .hero{min-height:calc(100vh - var(--header-height));height:calc(100vh - var(--header-height));overflow:hidden}
  .hero__content{padding:60px 16px 110px;margin-top:0}
  .hero h1{font-size:clamp(1.5rem,6vw,1.9rem);line-height:1.15;margin-bottom:var(--space-2);white-space:normal;word-wrap:break-word}
  .hero h1 br{display:none}
  .hero__subtitle{font-size:.87rem;line-height:1.6;margin-bottom:var(--space-3);max-width:100%}
  .hero__badge{font-size:.62rem;padding:6px 14px;margin-bottom:var(--space-2);margin-top:10px}
  .hero__stat-num{font-size:1.4rem}
  .hero__stat-label{font-size:.6rem;letter-spacing:.06em}
  .hero__stats{gap:24px;justify-content:center;margin-bottom:var(--space-3)}
  .hero__stat{flex:0 0 auto}
  .btn--lg{padding:.85em 1.2em;font-size:.95rem}
  .hero__powered{display:none;}
  .header__logo-img{height:36px}
  .container{padding-inline:16px}
  .section{padding:var(--space-4) 0}
  .hero__actions{margin-bottom:var(--space-2);gap:12px}
}
@media(max-width:380px){
  .hero h1{font-size:1.4rem;line-height:1.15}
  .hero__subtitle{font-size:.82rem;margin-bottom:var(--space-2)}
  .hero__stats{gap:18px}
  .hero__stat-num{font-size:1.3rem}
  .hero__stat-label{font-size:.58rem}
  .btn--lg{padding:.8em 1.1em;font-size:.92rem}
  .hero__badge{font-size:.58rem;padding:5px 10px;margin-top:8px}
  .hero__content{padding:40px 12px 100px}
  .hero__powered{display:none;}
  .hero__marquee{font-size:.7rem;padding:8px 0}
}

/* === DARK THEME — applied to :root so tokens cascade everywhere === */
html.dark-theme {
  --bg-page: #111111;
  --bg-card: #1a1a1a;
  --bg-muted: #161616;
  --bg-dark: #0a0a0a;
  --text-primary: #f5f5f5;
  --text-secondary: #c8c8c8;
  --text-muted: #9e9e9e;
  --border-color: #333333;
  --border: 1px solid #333333;
  --bg-overlay: rgba(0,0,0,0.85);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.4);
  --shadow: 0 4px 16px rgba(0,0,0,0.5);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.6);
  --color-primary-light: rgba(192,139,46,0.15);
}
html.dark-theme .header { background: rgba(17,17,17,0.95); }
html.dark-theme .mobile-nav { background: rgba(17,17,17,0.98); }
html.dark-theme .notice { background: rgba(192,139,46,0.12); border-color: rgba(192,139,46,0.3); }
html.dark-theme .benefit-icon { background: rgba(192,139,46,0.15); }
html.dark-theme .contact-item__icon { background: rgba(192,139,46,0.15); }
html.dark-theme .form-input,
html.dark-theme .form-select,
html.dark-theme .form-textarea { background: #1a1a1a; border-color: var(--border-color); color: var(--text-primary); }
html.dark-theme .card { background: var(--bg-card); }
html.dark-theme .price-card { background: var(--bg-card); }
html.dark-theme .benefit-card { background: var(--bg-card); }
html.dark-theme .booking-option { border-color: var(--border-color); }
html.dark-theme .payment-item { background: var(--bg-card); border-color: var(--border-color); }
html.dark-theme .step-indicator { background: #222222; color: var(--text-secondary); }
html.dark-theme .faq-item { border-color: var(--border-color); }
html.dark-theme .modal { background: #161616; }
html.dark-theme .donate-payment-info { background: #111111; border-color: var(--border-color); }
html.dark-theme .platform-popup { background: #161616; }
html.dark-theme .platform-choice { background: #222222; border-color: var(--border-color); }
html.dark-theme .platform-choice:hover { background: #2a2a2a; border-color: var(--color-primary); }
html.dark-theme .header__logo-text { color: var(--text-primary); }
html.dark-theme .dark-mode-toggle { background: #222222; border-color: var(--border-color); color: var(--text-primary); }

/* === NEW HEADER STYLES === */
.header__inner { gap: var(--space-2); }
.header__logos { flex-shrink: 0; }
.header__logo-text { font-family: var(--font-heading); font-weight: 700; font-size: 1.35rem; color: var(--text-primary); margin-left: 10px; letter-spacing: .06em; line-height: 1; white-space: nowrap; }
.header__actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.dark-mode-toggle { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: var(--bg-muted); color: var(--text-primary); transition: var(--transition); border: var(--border); cursor: pointer; flex-shrink: 0; }
.dark-mode-toggle:hover { background: var(--color-primary); color: #fff; transform: scale(1.08); }
.header__donate { display: none; }
.header__donate-icon { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: transparent; color: var(--color-primary); border: 2px solid var(--color-primary); cursor: pointer; flex-shrink: 0; transition: var(--transition); }
.header__donate-icon:hover { background: var(--color-primary); color: #fff; transform: scale(1.08); }
@media(min-width:1025px) { .header__donate { display: inline-flex; color: var(--text-primary); border-color: var(--color-primary); } }
@media(max-width:640px) { 
  .header__logo-text { display: block; font-size: 1.28rem; margin-left: 6px; transform: translateY(1px); } 
  .header__logo-img { height: 36px; width: 36px; } 
  .header__inner { padding: 0 16px; } 
  :root { --header-height: 70px; }
  .dark-mode-toggle { width: 36px; height: 36px; }
  .header__donate-icon { width: 36px; height: 36px; }
}
@media(max-width:380px) { 
  .header__logo-text { font-size: 1.15rem; margin-left: 4px; transform: translateY(1px); } 
  .header__logo-img { height: 32px; width: 32px; } 
  :root { --header-height: 65px; }
}

/* === HERO — CENTERED PREMIUM LAYOUT === */
.hero .container { display:flex; align-items:center; justify-content:center; width:100%; height:100%; }
.hero__content { position:relative; z-index:2; text-align:center; max-width:820px; padding:var(--space-4) var(--space-3) 100px; }
.hero__badge { display: inline-block; background: rgba(192,139,46,0.25); border: 1px solid rgba(192,139,46,0.5); color: #fff; font-size: .8rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; padding: 8px 20px; border-radius: var(--radius-full); margin-bottom: var(--space-3); backdrop-filter: blur(4px); }
.hero h1 { color: #fff; margin-bottom: var(--space-3); line-height: 1.1; font-size: clamp(2.4rem, 6vw, 4.5rem); }
.hero__subtitle { color: rgba(255,255,255,.82); font-size: 1.1rem; line-height: 1.75; margin-bottom: var(--space-4); max-width: 620px; margin-inline: auto; }
.hero__stats { display: flex; align-items: center; justify-content: center; gap: var(--space-3); margin-bottom: var(--space-4); flex-wrap: wrap; }
.hero__stat { text-align: center; }
.hero__stat-num { display: block; font-family: var(--font-heading); font-size: 2rem; font-weight: 700; color: var(--color-primary); line-height: 1; }
.hero__stat-label { display: block; font-size: .75rem; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .1em; margin-top: 4px; }
.hero__stat-divider { width: 1px; height: 44px; background: rgba(255,255,255,.2); }
.hero__actions { display: flex; gap: var(--space-2); flex-wrap: wrap; justify-content: center; margin-bottom: var(--space-3); }
.hero__powered { color: rgba(255,255,255,.5); font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; }
.hero__powered strong { color: rgba(255,255,255,.8); }

@media(max-width:768px) {
  .hero { min-height: auto; }
  .hero__content { padding: 40px var(--space-2) 90px; }
}
@media(max-width:640px) {
  .hero { min-height: auto; }
  .hero__content { padding: 10px 16px 80px; }
  .hero h1 { font-size: clamp(2rem, 8vw, 2.3rem); margin-bottom: var(--space-2); }
  .hero__subtitle { font-size: .9rem; margin-bottom: var(--space-3); line-height: 1.5; }
  .hero__stats { gap: 10px; margin-bottom: var(--space-3); }
  .hero__stat-num { font-size: 1.4rem; }
  .hero__badge { padding: 6px 14px; font-size: .7rem; margin-bottom: 12px; }
}

/* === HERO MARQUEE === */
.hero__marquee { position: absolute; bottom: 0; left: 0; width: 100%; background: var(--color-primary); color: #fff; padding: 13px 0; overflow: hidden; white-space: nowrap; z-index: 10; font-family: var(--font-heading); font-weight: 600; font-size: 1.05rem; letter-spacing: .06em; display: flex; box-shadow: 0 -4px 24px rgba(0,0,0,0.25); }
.marquee-track { display: inline-flex; animation: marqueeScroll 50s linear infinite; transform: translateZ(0); -webkit-transform: translateZ(0); will-change: transform; }
.marquee-text { padding-right: 3rem; display: inline-block; }
@keyframes marqueeScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-33.333%); } }

/* === MODAL BASE === */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 10000; display: flex; align-items: flex-start; justify-content: center; padding: var(--space-3); overflow-y: auto; opacity: 0; pointer-events: none; transition: opacity .35s ease; backdrop-filter: blur(6px); }
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal { background: var(--bg-page); border-radius: var(--radius-lg); width: 100%; max-width: 680px; box-shadow: var(--shadow-lg); position: relative; animation: scaleIn .35s var(--ease); margin: auto; overflow: hidden; }
.modal__close { position: absolute; top: var(--space-2); right: var(--space-2); width: 36px; height: 36px; border-radius: 50%; background: var(--bg-muted); border: var(--border); color: var(--text-primary); font-size: 1.3rem; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 1; transition: var(--transition); }
.modal__close:hover { background: var(--color-primary); color: #fff; }
.modal__header { background: linear-gradient(135deg, var(--color-secondary), hsl(30,25%,18%)); padding: var(--space-4) var(--space-4) var(--space-3); text-align: center; }
.modal__logo-row { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: var(--space-3); }
.modal__logo { height: 44px; width: auto; object-fit: contain; border-radius: 8px; }
.modal__logo--owa { height: 36px; }
.modal__logo-div { width: 1px; height: 32px; background: rgba(255,255,255,0.25); }
.modal__eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--color-primary); margin-bottom: 6px; }
.modal__header h2 { color: #fff; font-size: 1.8rem; margin-bottom: 8px; }
.modal__sub { color: rgba(255,255,255,.75); font-size: .92rem; line-height: 1.65; max-width: 480px; margin: 0 auto; }
.modal__body { padding: var(--space-4); }

/* === DONATE AMOUNTS === */
.donate-amounts { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: var(--space-3); }
.donate-amount { padding: 10px 22px; border: 2px solid var(--border-color); border-radius: var(--radius-full); font-size: .95rem; font-weight: 700; cursor: pointer; transition: var(--transition); color: var(--text-primary); background: var(--bg-card); font-family: var(--font-heading); }
.donate-amount:hover { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-light); }
.donate-amount.selected { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.donate-amount--custom { border-style: dashed; }

/* === DONATE PAYMENT INFO BOX === */
.donate-payment-info { background: var(--color-primary-light); border: 1px solid var(--color-primary); border-radius: var(--radius); padding: var(--space-2) var(--space-3); margin-top: var(--space-3); }
.donate-payment-info__title { font-weight: 700; font-size: .85rem; color: var(--text-primary); margin-bottom: 10px; text-transform: uppercase; letter-spacing: .06em; }
.donate-payment-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; border-bottom: 1px solid rgba(192,139,46,0.2); font-size: .88rem; }
.donate-payment-row:last-child { border-bottom: none; }
.donate-payment-row__label { font-weight: 600; color: var(--text-secondary); }
.donate-payment-row__val { font-weight: 700; color: var(--color-primary); }

/* === PLATFORM CHOICE POPUP === */
.platform-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 11000; display: flex; align-items: center; justify-content: center; padding: var(--space-3); opacity: 0; pointer-events: none; transition: opacity .3s ease; backdrop-filter: blur(8px); }
.platform-overlay.open { opacity: 1; pointer-events: all; }
.platform-popup { background: var(--bg-page); border-radius: var(--radius-lg); width: 100%; max-width: 480px; padding: var(--space-4); position: relative; box-shadow: var(--shadow-lg); animation: scaleIn .3s var(--ease); }
.platform-choices { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); margin-top: var(--space-2); }
.platform-choice { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: var(--space-3); border: 2px solid var(--border-color); border-radius: var(--radius-lg); background: var(--bg-card); cursor: pointer; transition: var(--transition); text-align: center; }
.platform-choice:hover { border-color: var(--color-primary); transform: translateY(-3px); box-shadow: var(--shadow); }
.platform-choice__name { font-weight: 700; font-size: .95rem; color: var(--text-primary); }
.platform-choice__desc { font-size: .78rem; color: var(--text-muted); line-height: 1.4; }
.donate-form { margin-top: var(--space-2); display: flex; flex-direction: column; gap: var(--space-2); }
@media(max-width:480px) { .platform-choices { grid-template-columns: 1fr; } }

/* === DONATE TABS === */
.donate-type-tabs { display: flex; gap: 0; margin-bottom: var(--space-3); border: 2px solid var(--color-primary); border-radius: var(--radius); overflow: hidden; }
.donate-tab { flex: 1; padding: 11px 16px; font-weight: 700; font-size: .9rem; cursor: pointer; background: transparent; color: var(--text-secondary); transition: var(--transition); border: none; font-family: var(--font-body); }
.donate-tab.active { background: var(--color-primary); color: #fff; }
.donate-tab:hover:not(.active) { background: var(--color-primary-light); color: var(--color-primary); }
.donate-tab-panel { display: none; }
.donate-tab-panel.active { display: block; animation: fadeIn .3s ease; }

/* === DONATE ITEMS CHECKLIST === */
.donate-items-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: var(--space-2); }
.donate-item-check { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border: 1.5px solid var(--border-color); border-radius: var(--radius); cursor: pointer; transition: var(--transition); background: var(--bg-card); }
.donate-item-check:hover { border-color: var(--color-primary); background: var(--color-primary-light); }
.donate-item-check input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; }
.donate-item-check__box { width: 20px; height: 20px; border: 2px solid var(--border-color); border-radius: 5px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: var(--transition); }
.donate-item-check input:checked ~ .donate-item-check__box { background: var(--color-primary); border-color: var(--color-primary); }
.donate-item-check input:checked ~ .donate-item-check__box::after { content: '\2713'; color: #fff; font-size: .85rem; font-weight: 700; }
.donate-item-check input:checked ~ .donate-item-check__label { color: var(--color-primary); font-weight: 600; }
.donate-item-check__label { font-size: .88rem; color: var(--text-secondary); }
.donate-payment-request { margin-top: var(--space-3); }
.donate-payment-request .donate-payment-info { margin-top: var(--space-2); animation: fadeIn .3s ease; }
html.dark-theme .donate-item-check { background: var(--bg-card); border-color: var(--border-color); }
html.dark-theme .donate-tab { color: var(--text-secondary); }
@media(max-width:480px) { .donate-items-grid { grid-template-columns: 1fr; } }
