:root{
  --navy:#12222e; --navy2:#1b3040; --steel:#5b7183; --orange:#e0651a; --orange-d:#c4551260;
  --ink:#1c2733; --muted:#5a6b78; --line:#e2e7eb; --bg:#f6f8f9; --card:#fff;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}
img{max-width:100%;display:block}
a{color:var(--orange)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.2rem}
.skip{position:absolute;left:8px;top:-48px;background:var(--navy);color:#fff;padding:.6rem 1rem;border-radius:8px;z-index:100;transition:top .2s}
.skip:focus{top:8px}
:focus-visible{outline:3px solid var(--orange);outline-offset:2px}

/* header */
.site-head{background:var(--navy);color:#fff;position:sticky;top:0;z-index:50}
.head-row{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;gap:1rem}
.brand{display:flex;align-items:center}
.brand-logo{height:54px;width:auto;display:block}
.nav{display:flex;gap:.3rem;flex-wrap:wrap}
.nav a{color:#d7e2ea;text-decoration:none;font-weight:600;padding:.5rem .8rem;border-radius:6px}
.nav a:hover{background:#ffffff18;color:#fff}
.nav a.active{color:#fff;box-shadow:inset 0 -3px 0 var(--orange)}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer}
@media(max-width:800px){
  .nav-toggle{display:block}
  .nav{display:none;width:100%;flex-direction:column}
  body.nav-open .nav{display:flex}
  .head-row{flex-wrap:wrap}
}

/* page hero */
.page-hero{background:linear-gradient(rgba(13,26,36,.68),rgba(13,26,36,.8)),url('/assets/img/band.webp') center/cover;color:#fff;padding:3.6rem 0 3.2rem;text-align:center}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 .5rem}
.page-hero p{color:#c7d6e0;max-width:680px;margin:0 auto}

/* listings */
.listings{padding:2.5rem 0 3rem;display:grid;gap:1.6rem}
.listing{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 8px 24px rgba(18,34,46,.06);display:grid;grid-template-columns:minmax(0,420px) 1fr}
@media(max-width:760px){.listing{grid-template-columns:1fr}}
.listing.past{opacity:.85}
.listing-media{background:#0d1a24;position:relative;min-height:260px}
.listing-media .noimg{display:flex;align-items:center;justify-content:center;height:100%;color:#4a6070;min-height:260px}
.carousel{position:absolute;inset:0}
.slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;pointer-events:none}
.slide.active{opacity:1;pointer-events:auto}
.cprev,.cnext{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:0;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;font-size:1.05rem;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center}
.cprev{left:8px}.cnext{right:8px}
.cprev:hover,.cnext:hover{background:rgba(0,0,0,.72)}
.cdots{position:absolute;bottom:10px;left:0;right:0;display:flex;gap:7px;justify-content:center;z-index:3}
.cdot{width:9px;height:9px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer}
.cdot.active{background:#fff}
.listing-body{padding:1.4rem 1.6rem}
.listing-body h2{margin:.1rem 0 .3rem;font-size:1.25rem;color:var(--navy)}
.reg{color:var(--orange);font-weight:800}
.badge{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:700;margin-bottom:.6rem}
.badge.live{background:#e4f4ea;color:#1c7a43}
.badge.past{background:#eceff1;color:#5a6b78}
.year{color:var(--muted)}
.price{font-weight:700;color:var(--navy);margin:.4rem 0}
.desc ul{margin:.6rem 0;padding-left:1.2rem}
.desc li{margin:.25rem 0}
.enquire{display:inline-block;margin-top:.8rem;background:var(--orange);color:#fff;text-decoration:none;font-weight:700;padding:.6rem 1.3rem;border-radius:8px}
.enquire:hover{filter:brightness(.95)}
.intro{max-width:760px;margin:0 auto 1rem;color:var(--muted);text-align:center}

/* footer */
.site-foot{background:var(--navy);color:#c7d6e0;margin-top:2rem}
.foot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:2.4rem 1.2rem;text-align:center}
@media(max-width:700px){.foot-grid{grid-template-columns:1fr}}
.site-foot strong{color:#fff;display:block;margin-bottom:.3rem}
.site-foot a{color:#ffb44d}
.foot-base{border-top:1px solid #ffffff18;text-align:center;padding:1rem;font-size:.85rem;color:#8fa6b5}

/* ---- content components ---- */
.hero{position:relative;color:#fff;text-align:center;padding:5.5rem 0 5rem;
  background:linear-gradient(rgba(13,26,36,.55),rgba(13,26,36,.7)),url('/assets/img/hero.webp') center/cover}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 .6rem;letter-spacing:.01em}
.hero .tag{font-size:clamp(1.05rem,2.5vw,1.35rem);color:#e6eef3;max-width:640px;margin:0 auto}
.section{padding:3.4rem 0}
.section.alt{background:#fff}
.section h2{font-size:clamp(1.5rem,3vw,2.05rem);color:var(--navy);text-align:center;margin:0 0 .4rem}
.section .lead{max-width:780px;margin:0 auto 2rem;text-align:center;color:var(--muted);font-size:1.08rem}
.prose{max-width:820px;margin:0 auto}
.prose h3{color:var(--navy);margin:1.7rem 0 .3rem}
.prose p{margin:.6rem 0}
.prose ul{margin:.6rem 0 .6rem 1.2rem}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.svc{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 8px 24px rgba(18,34,46,.06);display:flex;flex-direction:column}
.svc img{height:180px;width:100%;object-fit:cover}
.svc-b{padding:1.1rem 1.25rem;display:flex;flex-direction:column;flex:1}
.svc h3{margin:.1rem 0 .4rem;color:var(--navy)}
.svc p{color:var(--muted);flex:1;margin:.2rem 0}
.svc .more{color:var(--orange);font-weight:700;margin-top:.7rem;text-decoration:none}
.split{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem;align-items:center;max-width:1000px;margin:0 auto}
@media(max-width:800px){.split{grid-template-columns:1fr}}
.split img{border-radius:14px;box-shadow:0 10px 26px rgba(18,34,46,.12);width:100%}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1rem 0 0}
.chip{background:#eef2f5;border:1px solid var(--line);border-radius:999px;padding:.4rem 1rem;font-weight:600;color:var(--navy)}
.cta{background:linear-gradient(150deg,var(--navy),var(--navy2));color:#fff;text-align:center;padding:2.8rem 1.2rem;border-radius:16px}
.cta h2{color:#fff}.cta p{color:#c7d6e0;max-width:640px;margin:.4rem auto 0}
.btn{display:inline-block;background:var(--orange);color:#fff;text-decoration:none;font-weight:700;padding:.75rem 1.5rem;border-radius:8px;border:0;cursor:pointer;font:inherit;font-weight:700}
.btn:hover{filter:brightness(.95)}
.btn-light{background:#fff;color:var(--navy)}
.btns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.3rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr}}
.info-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.3rem;margin-bottom:1rem}
.info-card strong{color:var(--navy);display:block;margin-bottom:.2rem}
.form label{display:block;font-weight:600;margin:.8rem 0 .3rem;color:var(--navy)}
.form input,.form textarea{width:100%;padding:.65rem .75rem;border:1px solid var(--line);border-radius:8px;font:inherit;background:#fff}
.form textarea{min-height:140px;resize:vertical}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.flash{padding:.85rem 1.1rem;border-radius:8px;margin-bottom:1rem;font-weight:600}
.flash.ok{background:#e4f4ea;color:#1c7a43;border:1px solid #b6e0c4}
.flash.err{background:#fdecea;color:#a5281b;border:1px solid #f5c6c0}
.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.9rem}
.gal img{width:100%;height:170px;object-fit:cover;border-radius:10px}
.desc .spec-h{font-weight:700;color:var(--navy);margin:.7rem 0 .15rem}
.desc ul{margin:.2rem 0 .4rem 1.15rem}
.desc li{margin:.2rem 0}
/* lightbox */
img.zoomable{cursor:zoom-in}
.lightbox{position:fixed;inset:0;background:rgba(6,14,20,.92);display:none;align-items:center;justify-content:center;z-index:200;padding:2rem;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:95vw;max-height:92vh;width:auto;height:auto;border-radius:8px;box-shadow:0 12px 48px rgba(0,0,0,.6)}
/* about page richer components */
.round-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:1.5rem}
@media(max-width:800px){.round-cards{grid-template-columns:1fr}}
.round-card{text-align:center}
.round-card img{width:160px;height:160px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;box-shadow:0 8px 22px rgba(18,34,46,.18);filter:grayscale(1);transition:filter .3s ease}
.round-card:hover img{filter:grayscale(0)}
.round-card h3{color:var(--navy);margin:.2rem 0 .4rem}
.round-card p{color:var(--muted);margin:0}
.imgband{background:linear-gradient(rgba(13,26,36,.5),rgba(13,26,36,.62)),url('/assets/img/about-banner.webp') center/cover;color:#fff;text-align:center;padding:4.2rem 1.2rem}
.imgband h2{color:#fff;margin:0 0 .4rem}
.imgband p{max-width:760px;margin:0 auto;color:#eaf1f6;font-size:1.08rem}
.checklist{list-style:none;padding:0;max-width:760px;margin:1rem auto 0;display:grid;gap:.55rem}
.checklist li{position:relative;padding-left:1.9rem;color:var(--ink)}
.checklist li::before{content:"\2713";position:absolute;left:0;top:0;color:#5a9216;font-weight:800;font-size:1.1rem}
/* contact page */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:2.4rem}
@media(max-width:760px){.contact-cards{grid-template-columns:1fr}}
.cc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.7rem 1.2rem;text-align:center;box-shadow:0 8px 24px rgba(18,34,46,.06)}
.cc .ico{width:56px;height:56px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;margin:0 auto .9rem}
.cc .ico svg{width:26px;height:26px;fill:#fff}
.cc h3{margin:.1rem 0 .35rem;color:var(--navy);font-size:1.05rem}
.cc a{color:var(--orange);font-weight:600;text-decoration:none}
.cc a:hover{text-decoration:underline}
.cc p{color:var(--muted);margin:0}
.socials{display:flex;gap:.7rem;justify-content:center;margin-top:.6rem}
.socials a{width:44px;height:44px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;transition:background .2s}
.socials a:hover{background:var(--orange)}
.socials svg{width:22px;height:22px;fill:#fff}
/* enquiry modal */
.modal{position:fixed;inset:0;background:rgba(6,14,20,.62);display:none;align-items:flex-start;justify-content:center;z-index:300;padding:2rem 1rem;overflow:auto}
.modal.open{display:flex}
.modal-box{background:#fff;border-radius:14px;max-width:520px;width:100%;padding:1.6rem 1.6rem 1.9rem;position:relative;box-shadow:0 22px 60px rgba(0,0,0,.4)}
.modal-box h2{color:var(--navy);margin:.1rem 0 1rem}
.modal-x{position:absolute;top:.5rem;right:.7rem;background:none;border:0;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal-x:hover{color:var(--navy)}
.enq-re{background:#eef2f5;border-radius:8px;padding:.55rem .85rem;font-weight:600;color:var(--navy);margin:0 0 1rem}
