:root{
  --blue:#005bac;
  --blue-dark:#083b66;
  --sky:#00a7e1;
  --pink:#ff2f7d;
  --yellow:#fff25c;
  --cream:#fff9df;
  --light:#eefaff;
  --text:#173d59;
  --white:#fff;
  --shadow:0 18px 45px rgba(0,69,125,.14);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:#fff;
  font-family:"Noto Sans",Arial,sans-serif;
  line-height:1.7;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit}
button,input,select,textarea{font:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;left:12px;top:-80px;z-index:999;background:#fff;color:var(--blue);padding:10px 16px;border-radius:10px;font-weight:800;transition:.2s}
.skip-link:focus{top:12px}
.container{width:min(1120px,calc(100% - 40px));margin-inline:auto}
.container.narrow{width:min(860px,calc(100% - 40px))}
.section{padding:96px 0;text-align:center}
.section-kicker{margin:0 0 10px;color:var(--pink);font-family:"Montserrat",sans-serif;font-size:14px;font-weight:900;letter-spacing:.16em}
.section-kicker.light{color:var(--yellow)}
h1,h2,h3,.button,.hero-badge,.price-card strong{font-family:"Montserrat","Noto Sans",sans-serif}
h2{margin:0;color:var(--blue);font-size:clamp(34px,5vw,58px);line-height:1.18;font-weight:900;letter-spacing:-.03em}
h3{line-height:1.3}
.section-lead{max-width:820px;margin:22px auto 0;font-size:19px}

.site-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:100;
  padding:12px 20px;
  transition:.3s;
}
.site-header.is-scrolled{background:rgba(255,255,255,.96);box-shadow:0 8px 30px rgba(0,48,90,.12);backdrop-filter:blur(12px)}
.header-inner{max-width:1260px;margin:auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.header-logo{width:190px;transition:.3s}
.site-header:not(.is-scrolled) .header-logo{filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.global-nav{display:flex;align-items:center;gap:22px}
.global-nav a{text-decoration:none;font-weight:800;font-size:14px;color:#fff}
.site-header.is-scrolled .global-nav a{color:var(--blue-dark)}
.global-nav .lang-link{border:2px solid currentColor;border-radius:999px;padding:7px 13px}
.global-nav .nav-book{padding:11px 19px;border-radius:999px;background:var(--pink);color:#fff!important;box-shadow:0 5px 0 #c90050}
.nav-toggle{display:none;width:46px;height:46px;border:0;border-radius:50%;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.14);padding:11px;cursor:pointer}
.nav-toggle span:not(.sr-only){display:block;height:3px;background:var(--blue);margin:4px 0;border-radius:10px;transition:.25s}

.hero{position:relative;min-height:100svh;display:grid;place-items:center;color:#fff;background:url("../images/main.jpg") center/cover no-repeat;overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(0,55,105,.82),rgba(0,135,195,.42),rgba(0,35,70,.72))}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:90px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 1440 120' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,72 C180,30 360,120 540,76 C720,32 900,32 1080,76 C1260,120 1350,42 1440,72 L1440,120 L0,120 Z' fill='%23ffffff'/%3E%3C/svg%3E") center bottom/100% 100% no-repeat;z-index:2}
.hero-content{position:relative;z-index:3;width:min(1180px,calc(100% - 40px));padding:130px 0 150px;text-align:center}
.hero-logo{width:min(310px,65vw);margin:0 auto 24px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.28))}
.hero-badges{display:flex;justify-content:center;align-items:stretch;gap:14px;flex-wrap:wrap;margin:0 auto 28px}
.hero-badge{display:flex;align-items:center;justify-content:center;min-height:70px;padding:12px 26px;border-radius:999px;font-size:18px;font-weight:900;box-shadow:0 7px 0 rgba(0,35,70,.25),0 15px 30px rgba(0,0,0,.16)}
.hero-badge-yellow{background:var(--yellow);color:var(--blue)}
.hero-badge-white{gap:10px;background:rgba(255,255,255,.97);border:3px solid var(--yellow);color:var(--blue);text-align:left}
.hero-badge-white span:last-child{display:flex;flex-direction:column}
.hero-badge small{color:var(--pink);font-family:"Noto Sans",sans-serif;font-size:12px;font-weight:800}
.badge-icon{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--yellow)}
.eyebrow{margin:0 0 10px;color:var(--yellow);font-family:"Montserrat",sans-serif;font-weight:900;letter-spacing:.2em}
.hero h1{margin:0;font-size:clamp(48px,8.4vw,104px);line-height:.98;letter-spacing:-.045em;text-shadow:0 8px 26px rgba(0,0,0,.38)}
.hero-lead{max-width:850px;margin:24px auto 28px;font-size:clamp(19px,2.5vw,30px);font-weight:800}
.season-box{display:inline-flex;flex-direction:column;gap:2px;padding:15px 28px;border-radius:22px;background:#fff;color:var(--blue);box-shadow:0 14px 34px rgba(0,0,0,.24)}
.season-box span{font-family:"Montserrat",sans-serif;font-size:12px;font-weight:900;letter-spacing:.18em}
.season-box strong{font-family:"Montserrat",sans-serif;font-size:clamp(22px,3vw,38px)}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:26px}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:14px 28px;border-radius:999px;text-decoration:none;font-weight:900;transition:.25s}
.button:hover{transform:translateY(-4px)}
.button-primary{background:linear-gradient(135deg,#ff4b91,var(--pink));color:#fff;box-shadow:0 8px 0 #c90050}
.button-secondary{background:#fff;color:var(--blue);box-shadow:0 8px 0 rgba(0,35,70,.22)}
.button-outline{border:3px solid var(--blue);color:var(--blue);background:#fff}
.button-large{font-size:20px;padding:17px 38px}
.booking-note{margin:18px auto 0;font-size:13px;opacity:.9}
.scroll-cue{position:absolute;z-index:4;bottom:78px;left:50%;transform:translateX(-50%);color:#fff;text-decoration:none;font-family:"Montserrat",sans-serif;font-size:11px;font-weight:800;letter-spacing:.18em}
.scroll-cue::after{content:"";display:block;width:1px;height:34px;background:#fff;margin:7px auto 0;animation:scrollLine 1.7s infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

.intro{background:linear-gradient(180deg,#fff,#effbff)}
.quick-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:40px}
.quick-facts div{padding:22px 14px;border-radius:20px;background:#fff;border:3px solid #d9f1fb;box-shadow:var(--shadow)}
.quick-facts strong{display:block;color:var(--pink);font-family:"Montserrat",sans-serif;font-size:25px}
.quick-facts span{font-size:13px;font-weight:700}
.photo-strip{height:min(56vw,620px);background:url("../images/gallery06.jpg") center/cover no-repeat;background-attachment:fixed}
.card-grid{display:grid;gap:22px;margin-top:42px}
.card-grid-3{grid-template-columns:repeat(3,1fr)}
.feature-card,.campaign-card{padding:34px 24px;border-radius:28px;background:#fff;border:4px solid var(--sky);box-shadow:var(--shadow);transition:.3s}
.feature-card:hover,.campaign-card:hover{transform:translateY(-9px)}
.feature-icon,.campaign-icon{display:block;font-size:48px}
.feature-card h3,.campaign-card h3{margin:12px 0;color:var(--pink);font-size:24px}
.feature-card p,.campaign-card p{margin-bottom:0}
.blue-section{background:linear-gradient(135deg,#e7f8ff,#fff)}
.split-panel{display:grid;grid-template-columns:260px 1fr;gap:42px;align-items:center;padding:42px;border:4px solid var(--sky);border-radius:34px;background:#fff;box-shadow:var(--shadow);text-align:left}
.split-image{padding:24px;border-radius:24px;background:#f1fbff}
.split-copy h2{font-size:clamp(32px,4.5vw,52px)}
.split-copy p:last-child{font-size:19px}

.price-section{background:#eefaff}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.price-card{position:relative;overflow:hidden;border:4px solid #d9ecfa;border-radius:28px;background:#fff;box-shadow:var(--shadow)}
.price-card h3{margin:0;padding:20px;background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;font-size:23px}
.price-card-featured{border-color:var(--pink);transform:scale(1.035)}
.popular-tag{position:absolute;top:15px;right:-40px;width:155px;padding:7px 0;background:var(--pink);color:#fff;font-size:12px;font-weight:900;transform:rotate(45deg)}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:25px 22px;border-bottom:1px solid #edf1f4;text-align:left}
.price-row:last-child{border-bottom:0}
.price-row span{font-weight:800}
.price-row small{color:#61798a;font-size:11px}
.price-row strong{color:var(--pink);font-size:32px;white-space:nowrap}
.family-box{max-width:780px;margin:38px auto 0;padding:26px;border:4px solid var(--yellow);border-radius:26px;background:#fff;box-shadow:var(--shadow)}
.family-box>span{display:inline-block;padding:6px 18px;border-radius:999px;background:var(--yellow);color:var(--blue);font-weight:900}
.family-box p{font-weight:800}
.family-box div{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;color:var(--pink);font-family:"Montserrat",sans-serif;font-size:22px}
.check-list{list-style:none;padding:0;margin:0;text-align:left}
.check-list li{position:relative;padding-left:28px;margin:10px 0}
.check-list li::before{content:"✓";position:absolute;left:0;color:#00a85a;font-weight:900}
.price-notes{max-width:820px;margin:34px auto 0;padding:22px 26px;border-radius:20px;background:#fff}

.campaign-section{background:linear-gradient(135deg,#fff8d7,#edfaff)}
.campaign-label{display:inline-block!important;margin:10px 0!important;padding:5px 15px;border-radius:999px;background:var(--yellow);color:var(--blue);font-size:13px;font-weight:900}
.schedule-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:40px}
.schedule-card{padding:22px 12px;border:3px solid #dcefff;border-radius:22px;background:#fff;box-shadow:0 12px 26px rgba(0,91,172,.1)}
.schedule-card strong{display:block;color:var(--blue);font-family:"Montserrat",sans-serif;font-size:18px}
.schedule-card span{display:block;margin-top:7px;color:var(--pink);font-size:13px;font-weight:800}
.flow-box{margin-top:38px;padding:30px;border:4px solid var(--sky);border-radius:28px;background:#f8fdff}
.flow-box h3{margin:0 0 20px;color:var(--blue);font-size:25px}
.flow-box ol{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:0;margin:0}
.flow-box li{padding:18px 10px;border-radius:17px;background:#fff;font-weight:800}
.flow-box li span{display:grid;place-items:center;width:32px;height:32px;margin:0 auto 8px;border-radius:50%;background:var(--yellow);color:var(--blue)}

.gallery-section{background:linear-gradient(180deg,#fff,#eefaff)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:16px;margin-top:38px}
.gallery-grid figure{position:relative;overflow:hidden;margin:0;border-radius:24px;background:#dff7ff;box-shadow:var(--shadow)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.45s}
.gallery-grid figure:hover img{transform:scale(1.07)}
.gallery-grid figure::after{content:"";position:absolute;inset:45% 0 0;background:linear-gradient(transparent,rgba(0,35,70,.78))}
.gallery-grid figcaption{position:absolute;z-index:2;left:16px;right:16px;bottom:13px;color:#fff;font-weight:900;text-align:left}
.gallery-large{grid-column:span 2;grid-row:span 2}
.gallery-wide{grid-column:span 2}

.rules-section{background:linear-gradient(135deg,#fffef4,#f1fbff)}
.rule-pills{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:34px 0}
.rule-pills span{padding:10px 17px;border-radius:999px;background:var(--blue);color:#fff;font-weight:900}
.rules-panel{padding:34px;border:4px solid #ffd54f;border-radius:28px;background:#fff;box-shadow:var(--shadow);text-align:left}
.rules-panel h3{margin-top:0;color:var(--blue);font-size:25px}
.notice{margin:24px 0 0;padding:14px 18px;border-radius:14px;background:#f1f8fc;font-size:14px}
.notice a{color:var(--blue);font-weight:800}
.faq-section details{margin:13px 0;padding:19px 22px;border-radius:17px;background:#f4fbff;text-align:left}
.faq-section summary{cursor:pointer;color:var(--blue);font-weight:900}
.faq-section details[open]{box-shadow:0 10px 26px rgba(0,91,172,.1)}

.access-section{background:#f8fdff}
.access-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:stretch;margin-top:42px;text-align:left}
.access-info,.map-wrap{border-radius:28px;background:#fff;box-shadow:var(--shadow)}
.access-info{padding:34px}
.access-info h3{margin-top:0;color:var(--blue);font-size:25px}
.access-info ul{padding-left:20px}
.map-wrap{overflow:hidden;min-height:430px}
.map-wrap iframe{width:100%;height:100%;min-height:430px;border:0}
.final-cta{position:relative;padding:100px 0 120px;background:linear-gradient(135deg,var(--sky),var(--blue));color:#fff;text-align:center;overflow:hidden}
.final-cta h2{color:#fff;font-size:clamp(38px,6vw,68px)}
.final-cta p{font-size:22px;font-weight:800}
.site-footer{padding:44px 20px 110px;background:var(--blue-dark);color:#fff;text-align:center}
.footer-inner{max-width:1000px;margin:auto}
.footer-inner>img{width:210px;margin:0 auto 22px}
.footer-contact{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 22px}
.footer-contact span{font-weight:800}
.footer-contact a{color:var(--yellow);font-family:"Montserrat",sans-serif;font-size:24px;font-weight:900;text-decoration:none}
.site-footer nav{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.site-footer nav a{text-decoration:none;font-size:14px;font-weight:800}
.site-footer p{margin:0;opacity:.8;font-size:13px}
.floating-book{position:fixed;z-index:90;right:18px;bottom:18px;padding:16px 25px;border-radius:999px;background:linear-gradient(135deg,#ff4b91,var(--pink));color:#fff;text-decoration:none;font-family:"Montserrat",sans-serif;font-weight:900;box-shadow:0 8px 0 #c90050,0 18px 36px rgba(0,0,0,.24)}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .75s ease,transform .75s ease}
.reveal.is-visible{opacity:1;transform:none}

@media(max-width:980px){
  .global-nav{position:fixed;top:0;right:-100%;width:min(360px,86vw);height:100vh;padding:90px 28px 34px;background:#fff;box-shadow:-16px 0 40px rgba(0,40,80,.18);flex-direction:column;align-items:stretch;gap:8px;transition:.3s}
  .global-nav.is-open{right:0}
  .global-nav a,.site-header:not(.is-scrolled) .global-nav a{color:var(--blue-dark);padding:12px 8px}
  .global-nav .nav-book{text-align:center;color:#fff!important}
  .nav-toggle{display:block;position:relative;z-index:2}
  .nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.is-open span:nth-child(2){opacity:0}
  .nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .card-grid-3,.price-grid{grid-template-columns:1fr}
  .price-card-featured{transform:none}
  .schedule-grid{grid-template-columns:repeat(2,1fr)}
  .flow-box ol{grid-template-columns:1fr 1fr}
  .quick-facts{grid-template-columns:1fr 1fr}
  .split-panel,.access-grid{grid-template-columns:1fr}
  .split-image{max-width:260px;margin:auto}
  .split-copy{text-align:center}
}

@media(max-width:680px){
  .section{padding:70px 0}
  .container,.container.narrow{width:min(100% - 28px,1120px)}
  .site-header{padding:9px 13px}
  .header-logo{width:145px}
  .hero-content{width:calc(100% - 28px);padding:105px 0 130px}
  .hero-logo{width:min(260px,72vw);margin-bottom:18px}
  .hero-badges{display:grid;grid-template-columns:1fr;width:min(100%,430px);gap:9px;margin-bottom:22px}
  .hero-badge{min-height:58px;padding:9px 16px;font-size:15px}
  .hero-badge-white{justify-content:center}
  .hero-badge-white strong{font-size:14px}
  .hero h1{font-size:clamp(43px,13vw,68px)}
  .hero-lead{font-size:18px;line-height:1.55}
  .season-box{padding:13px 17px}
  .season-box strong{font-size:20px}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-actions .button{width:min(100%,340px)}
  .photo-strip{height:78vw;background-attachment:scroll}
  .quick-facts{grid-template-columns:1fr 1fr;gap:10px}
  .quick-facts div{padding:17px 8px}
  .quick-facts strong{font-size:20px}
  .split-panel{padding:26px 18px}
  .price-row{align-items:flex-start;flex-direction:column}
  .price-row strong{font-size:30px}
  .family-box div{flex-direction:column;gap:8px}
  .schedule-grid,.flow-box ol{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:165px;gap:10px}
  .gallery-large,.gallery-wide{grid-column:span 2}
  .gallery-grid figure{border-radius:17px}
  .rules-panel,.access-info{padding:25px 18px}
  .map-wrap,.map-wrap iframe{min-height:380px}
  .floating-book{left:14px;right:14px;bottom:14px;text-align:center}
  .site-footer{padding-bottom:100px}
}

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

/* =========================================
   Hero access information
========================================= */

.hero-access-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 10px auto 14px;
  padding: 14px 26px;
  background: rgba(255, 255, 255, 0.96);
  border: 3px solid #fff25c;
  border-radius: 999px;
  box-shadow:
    0 7px 0 rgba(0, 56, 105, 0.24),
    0 14px 30px rgba(0, 0, 0, 0.18);
  color: #005bac;
}

.hero-access-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  background: #fff25c;
  border-radius: 50%;
  font-size: 22px;
  line-height: 1;
}

.hero-access-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  line-height: 1.3;
}

.hero-access-text strong {
  display: block;
  margin: 0;
  color: #005bac;
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  font-weight: 800;
  white-space: nowrap;
}

.hero-access-text strong + strong {
  margin-top: 2px;
  font-size: 15px;
}

.hero-access-text small {
  display: block;
  margin-top: 4px;
  color: #ff2f7d;
  font-family: "Montserrat", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

/* Tablet */
@media (max-width: 900px) {
  .hero-access-badge {
    max-width: 90%;
    padding: 12px 20px;
  }

  .hero-access-text strong {
    font-size: 14px;
    white-space: normal;
  }

  .hero-access-text strong + strong {
    font-size: 13px;
  }
}

/* Smartphone */
@media (max-width: 600px) {
  .hero-access-badge {
    width: 100%;
    max-width: 430px;
    gap: 10px;
    padding: 11px 14px;
    border-width: 2px;
    border-radius: 24px;
  }

  .hero-access-icon {
    flex-basis: 36px;
    width: 36px;
    height: 36px;
    font-size: 18px;
  }

  .hero-access-text strong {
    font-size: 12px;
    line-height: 1.35;
  }

  .hero-access-text strong + strong {
    font-size: 11px;
  }

  .hero-access-text small {
    font-size: 10px;
  }
}