*{box-sizing:border-box}
:root{
  --navy:#003366;--navy-2:#0a457f;--mint:#1ABC9C;--mint-2:#16a085;
  --light:#f5fbff;--white:#ffffff;--text:#193046;--muted:#5b6f84;
  --border:rgba(0,51,102,.12);--shadow:0 18px 40px rgba(0,51,102,.10);--radius:20px;
}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:linear-gradient(180deg,#f7fcff,#eef8fb 45%,#f8ffff)}
a{text-decoration:none;color:inherit} img{max-width:100%;display:block}
.container{width:min(1180px,92%);margin:0 auto}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand a{font-size:1.22rem;font-weight:900;color:var(--navy);letter-spacing:.3px}
.brand span{display:block;font-size:.8rem;color:var(--muted);margin-top:2px}
.nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.nav a{padding:10px 14px;border-radius:999px;font-weight:700;color:var(--navy)}
.nav a:hover,.nav a.active{background:rgba(26,188,156,.12);color:var(--mint-2)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;font-weight:800;background:linear-gradient(90deg,var(--navy),var(--mint));color:#fff;border:none;box-shadow:var(--shadow)}
.btn.secondary{background:#fff;color:var(--navy);border:1px solid var(--border);box-shadow:none}
.hero{padding:34px 0 18px;display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:center;min-height:86vh}
.hero-copy .eyebrow{display:inline-block;padding:8px 12px;border-radius:999px;background:rgba(26,188,156,.12);color:var(--mint-2);font-weight:800;font-size:.84rem}
.hero-copy h1{margin:12px 0 10px;font-size:3.3rem;line-height:1.03;color:var(--navy)}
.hero-copy p{margin:0;color:#35516e;line-height:1.8;font-size:1.04rem;max-width:60ch}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.hero-card,.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-slider{position:relative;min-height:470px;overflow:hidden}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.03);transition:opacity .8s ease,transform 1s ease}
.slide.active{opacity:1;transform:scale(1)}
.slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,51,102,.08),rgba(0,51,102,.24))}
.slider-dots{position:absolute;left:18px;bottom:18px;display:flex;gap:8px;z-index:3}
.slider-dots button{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.7);background:rgba(255,255,255,.4);cursor:pointer}
.slider-dots button.active{background:var(--mint);border-color:var(--mint)}
.section{padding:22px 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.section-head h2{margin:0;color:var(--navy);font-size:2rem}
.section-head p{margin:6px 0 0;color:var(--muted);line-height:1.75;max-width:68ch}
.badge{display:inline-block;padding:8px 12px;border-radius:999px;background:rgba(0,51,102,.08);color:var(--navy);font-size:.82rem;font-weight:800}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.panel,.feature{padding:22px}
.feature h3,.panel h3{margin:0 0 8px;color:var(--navy)}
.feature p,.panel p{margin:0;color:#3f5b78;line-height:1.75}
.service-card,.gallery-card,.ticket-card{overflow:hidden;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}
.service-card img,.gallery-card img,.ticket-card img,.banner-media img{width:100%;height:100%;object-fit:cover}
.service-card .body,.ticket-card .body{padding:18px}
.service-card h3,.ticket-card h3{margin:0 0 8px;color:var(--navy)}
.service-card p,.ticket-card p{margin:0;color:#446079;line-height:1.7}
.gallery-card{height:220px}
.page-hero{padding:28px 0 18px}
.banner{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.banner .copy{padding:24px}
.banner h1{margin:0 0 10px;color:var(--navy);font-size:2.5rem}
.banner p{margin:0;color:#406079;line-height:1.8}
.banner-media{min-height:320px;overflow:hidden;border-radius:18px}
.tickets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.price{display:inline-block;margin-top:12px;padding:9px 12px;border-radius:999px;background:rgba(26,188,156,.12);color:var(--mint-2);font-weight:900}
form{padding:22px}
.row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
label{display:block;margin-bottom:6px;color:var(--navy);font-weight:800}
input,select,textarea{width:100%;padding:13px 14px;border-radius:14px;border:1px solid rgba(0,51,102,.16);outline:none;background:#fbfeff;color:var(--text)}
textarea{min-height:130px;resize:vertical}
.notice{margin:14px 0;padding:14px 16px;border-radius:14px;background:rgba(26,188,156,.12);border:1px solid rgba(26,188,156,.22);color:#12614f}
.notice.error{background:rgba(220,80,80,.10);border-color:rgba(220,80,80,.22);color:#8d2f2f}
.contact-list{list-style:none;padding:0;margin:14px 0 0}
.contact-list li{padding:10px 0;border-bottom:1px dashed rgba(0,51,102,.12);color:#3e5b77}
.map{overflow:hidden;border-radius:18px;border:1px solid var(--border)}
.map iframe{width:100%;height:360px;border:0}
.footer{margin-top:30px;padding:20px 0;border-top:1px solid var(--border);background:#fff}
.footer-inner{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted)}
@media (max-width: 980px){
  .hero,.banner,.grid-2,.grid-3,.grid-4,.row,.tickets-grid{grid-template-columns:1fr}
  .hero-copy h1{font-size:2.4rem}
  .hero-slider{min-height:320px}
}
