:root{
  /* Brand-matched to Theo's logo — deep navy + amber */
  --navy:#0B3D77;
  --navy-deep:#072A55;
  --gold:#F5A623;
  --gold-deep:#D88A0F;
  --cream:#f7f3e8;
  --ink:#073A6B;
  --text:#1c2a48;
  --muted:#5b6a85;
  --shell:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:'Inter','Helvetica Neue',Arial,sans-serif;color:var(--text);background:var(--shell);line-height:1.6;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Cinzel','Trajan Pro',Georgia,serif;font-weight:600;letter-spacing:.04em;color:var(--navy)}
h1{font-size:clamp(2.4rem,5vw,4.2rem);line-height:1.05}
h2{font-size:clamp(1.8rem,3.4vw,2.8rem);line-height:1.15;margin-bottom:1rem}
h3{font-size:1.25rem;letter-spacing:.08em}
p{margin-bottom:1rem}
.container{width:min(1200px,92%);margin:0 auto}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:14px 32px;background:linear-gradient(180deg,rgba(7,42,85,.78),rgba(7,42,85,0));transition:background .3s}
.site-header.scrolled{background:rgba(7,42,85,.96);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:78px;width:auto;display:block;border-radius:4px;box-shadow:0 4px 14px rgba(0,0,0,.35);object-fit:contain}
.nav{display:flex;gap:28px}
.nav a{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:#fff;padding:8px 2px;border-bottom:2px solid transparent;transition:all .25s}
.nav a:hover,.nav a.active{border-bottom-color:var(--gold);color:var(--gold)}
.cta-phone{background:var(--gold);color:var(--navy-deep);padding:10px 18px;border-radius:2px;font-weight:700;letter-spacing:.04em;font-size:.85rem;transition:all .25s}
.cta-phone:hover{background:#fff}

/* hamburger */
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{display:block;width:26px;height:2px;background:#fff;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff;text-align:center}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-slider{position:absolute;inset:0;z-index:1}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease-in-out;transform:scale(1.05)}
.hero-slide.active{opacity:1;animation:kenburns 8s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.12)}}
.hero-dots{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:10px}
.hero-dot{width:32px;height:3px;background:rgba(255,255,255,.35);border:none;cursor:pointer;padding:0;transition:.3s;border-radius:0}
.hero-dot.active{background:var(--gold);width:48px}
.hero-dot:hover{background:rgba(255,255,255,.65)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,58,107,.55) 0%,rgba(7,58,107,.45) 40%,rgba(7,42,85,.85) 100%);z-index:2}
.hero-content{position:relative;z-index:3;padding:0 20px;max-width:980px}
.hero-eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;margin-bottom:18px;font-weight:600}
.hero h1{color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.5);margin-bottom:24px}
.hero p.lead{font-size:1.2rem;color:rgba(255,255,255,.92);max-width:680px;margin:0 auto 36px}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;padding:16px 36px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.82rem;border-radius:2px;transition:all .3s;cursor:pointer;border:2px solid transparent}
.btn-gold{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.btn-gold:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--navy-deep)}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;opacity:.7;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;animation:bounce 2.4s infinite}
@keyframes bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ===== PAGE HEADER (non-home) ===== */
.page-hero{position:relative;height:50vh;min-height:380px;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center;background-size:cover;background-position:center;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,58,107,.85),rgba(11,61,119,.7))}
.page-hero-content{position:relative;z-index:2;padding-top:60px}
.page-hero h1{color:#fff}
.page-hero .crumb{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:block}

/* ===== SECTIONS ===== */
section{padding:90px 0;position:relative}
.section-bg{position:relative;color:#fff;background-size:cover;background-position:center;background-attachment:fixed}
.section-bg::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,58,107,.92),rgba(11,61,119,.88))}
.section-bg .container{position:relative;z-index:2}
.section-bg h2{color:#fff}
.eyebrow{display:block;font-size:.75rem;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;margin-bottom:14px;font-weight:600}
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media(max-width:840px){.split{grid-template-columns:1fr;gap:40px}}

/* ===== SERVICES GRID ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.svc-card{background:#fff;padding:36px 28px;border:1px solid rgba(11,61,119,.12);border-top:3px solid var(--gold);transition:all .3s;position:relative}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(11,61,119,.18)}
.svc-icon{width:54px;height:54px;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--gold);font-size:1.4rem}
.section-bg .svc-card{background:rgba(255,255,255,.08);border-color:rgba(245,166,35,.35);color:#fff;backdrop-filter:blur(4px)}
.section-bg .svc-card h3{color:#fff}
.svc-detail{max-height:0;opacity:0;overflow:hidden;transition:max-height .35s ease,opacity .25s ease,margin-top .35s ease;font-size:.92rem;line-height:1.55;color:var(--muted);margin-top:0}
.section-bg .svc-detail{color:rgba(255,255,255,.85)}
@media(hover:hover) and (pointer:fine){
  .svc-card:hover .svc-detail{max-height:240px;opacity:1;margin-top:12px}
}
@media(max-width:840px){.svc-grid{grid-template-columns:1fr}
  /* on touch devices show description inline always — Theo asked no hover for phone/iPad */
  .svc-detail{max-height:240px;opacity:1;margin-top:12px}
}

/* ===== STATS BAND ===== */
.stats{background:var(--navy);color:#fff;padding:50px 0;border-top:3px solid var(--gold);border-bottom:3px solid var(--gold)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats-grid h3{font-size:2.4rem;color:var(--gold);margin-bottom:6px}
.stats-grid p{font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.7);margin:0}
@media(max-width:840px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:36px}}

/* ===== GALLERY ===== */
.gal-filter{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.gal-filter button{background:transparent;border:1px solid rgba(11,61,119,.25);color:var(--navy);padding:9px 18px;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:.25s;font-family:inherit}
.gal-filter button.active,.gal-filter button:hover{background:var(--navy);color:var(--gold);border-color:var(--navy)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:900px){.gal-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.gal-grid{grid-template-columns:repeat(2,1fr)}}
.gal-item{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer;background:var(--navy)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s;filter:contrast(1.05) saturate(1.05)}
.gal-item:hover img{transform:scale(1.08)}
.gal-item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(7,58,107,.7));opacity:0;transition:.3s}
.gal-item:hover::after{opacity:1}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(7,58,107,.96);z-index:99;display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lightbox .close{position:absolute;top:20px;right:30px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer}

/* ===== TEAM ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:20px}
.team-card{background:#fff;padding:28px;text-align:center;border:1px solid rgba(11,61,119,.10);border-top:3px solid var(--gold);transition:transform .3s,box-shadow .3s}
.team-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(11,61,119,.18)}
.team-photo{width:160px;height:160px;border-radius:50%;overflow:hidden;margin:0 auto 22px;background:var(--cream);border:3px solid var(--gold);position:relative}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-placeholder{width:100%;height:100%;background:var(--navy);color:var(--gold);font-family:'Cinzel',serif;font-weight:600;font-size:3rem;letter-spacing:.06em;align-items:center;justify-content:center}
.team-card h3{margin-bottom:4px;color:var(--navy)}
.team-role{display:block;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:600}
.team-card p{color:var(--muted);font-size:.95rem;line-height:1.6;margin-bottom:0}
@media(max-width:840px){.team-grid{grid-template-columns:1fr;gap:24px}}

/* ===== REVIEWS ===== */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:20px}
.rev-card{background:#fff;padding:34px 30px;border-left:3px solid var(--gold);box-shadow:0 6px 24px rgba(11,61,119,.14);position:relative}
.rev-source{position:absolute;top:14px;right:18px;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
.section-bg .rev-card{background:rgba(255,255,255,.08);color:#fff;backdrop-filter:blur(4px)}
.rev-stars{color:var(--gold);font-size:1rem;letter-spacing:3px;margin-bottom:16px}
.rev-text{font-style:italic;color:var(--text);margin-bottom:18px;font-size:1rem;line-height:1.7}
.section-bg .rev-text{color:rgba(255,255,255,.92)}
.rev-author{font-weight:600;color:var(--navy);letter-spacing:.04em}
.section-bg .rev-author{color:var(--gold)}
@media(max-width:840px){.rev-grid{grid-template-columns:1fr}}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
@media(max-width:840px){.contact-grid{grid-template-columns:1fr}}
.contact-info h3{margin-bottom:24px}
.contact-row{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.18);display:flex;align-items:flex-start;gap:14px}
.contact-row .lbl{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.contact-row a{color:#fff;font-size:1.05rem;font-weight:500}
.contact-row a:hover{color:var(--gold)}
.socials{display:flex;gap:12px;margin-top:24px}
.socials a{width:44px;height:44px;border:1px solid rgba(245,166,35,.55);display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--gold);transition:.25s}
.socials a:hover{background:var(--gold);color:var(--navy-deep)}

/* ===== FOOTER ===== */
.footer{background:var(--navy-deep);color:#fff;padding:60px 0 24px;text-align:center}
.footer img{height:96px;width:auto;margin:0 auto 18px;border-radius:6px;display:block;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.footer p{font-size:.8rem;color:rgba(255,255,255,.55);letter-spacing:.04em}
.footer .links{display:flex;justify-content:center;gap:30px;margin:22px 0;flex-wrap:wrap}
.footer .links a{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.75)}
.footer .links a:hover{color:var(--gold)}
.copyright{padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:.72rem;letter-spacing:.06em;color:rgba(255,255,255,.4)}

/* mobile */
@media(max-width:840px){
  .nav,.cta-phone{display:none}
  .burger{display:flex}
  .nav.mobile-open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(7,42,85,.98);padding:24px;gap:18px}
  .nav.mobile-open a{font-size:1rem;border:none;padding:8px 0}
  .site-header{padding:12px 18px}
  .brand img{height:60px;border-radius:3px}
  section{padding:64px 0}
  .hero{min-height:540px}
}

/* ============ BOOKING SYSTEM ============ */
.cta-book{background:transparent;color:var(--gold);border:1px solid var(--gold);padding:9px 16px;border-radius:2px;font-weight:600;letter-spacing:.04em;font-size:.85rem;margin-right:8px;transition:all .25s;text-transform:uppercase}
.cta-book:hover{background:var(--gold);color:var(--navy-deep)}
@media(max-width:880px){.cta-book{display:none}}

.booking-wrap{background:var(--ink);padding:80px 0 100px;position:relative}
.booking-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(245,166,35,.10),transparent 50%);pointer-events:none}
.booking-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;align-items:start;position:relative}
@media(max-width:900px){.booking-grid{grid-template-columns:1fr;gap:32px}}

.booking-info h2{font-size:1.9rem;margin:14px 0 32px;font-family:'Cinzel',serif;line-height:1.2}
.booking-info .step-row{display:flex;gap:18px;align-items:flex-start;margin-bottom:24px}
.booking-info .step-num{flex-shrink:0;width:44px;height:44px;border:1.5px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:1.1rem}
.booking-info .step-row h3{color:#fff;font-size:1.05rem;margin-bottom:4px;font-family:'Cinzel',serif;font-weight:600}
.booking-info .step-row p{color:rgba(255,255,255,.7);font-size:.92rem;line-height:1.55}
.booking-trust{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:36px;padding-top:28px;border-top:1px solid rgba(245,166,35,.25)}
.booking-trust strong{color:var(--gold);display:block;font-size:.95rem;letter-spacing:.04em}
.booking-trust span{color:rgba(255,255,255,.6);font-size:.82rem}

.booking-form-card{background:#fff;padding:0;box-shadow:0 24px 60px rgba(0,0,0,.35);position:relative}

.booking-progress{display:grid;grid-template-columns:repeat(4,1fr);background:#073A6B;color:rgba(255,255,255,.55);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.bp-step{padding:16px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.08);transition:all .3s}
.bp-step:last-child{border-right:0}
.bp-step.active{background:var(--gold);color:var(--navy-deep)}

.bf-step{padding:40px 36px}
.bf-step h3{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--navy-deep);margin-bottom:6px}
.bf-step .sub{color:#5a6276;font-size:.94rem;margin-bottom:24px}

.service-pills,.radio-row,.radio-stack{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}
.radio-stack{flex-direction:column}
.pill{position:relative;display:inline-flex;align-items:center;cursor:pointer}
.pill input{position:absolute;opacity:0;pointer-events:none}
.pill span{display:inline-block;padding:11px 18px;border:1.5px solid #d8dce5;background:#fff;color:#0b1325;font-size:.92rem;font-weight:500;transition:all .2s;border-radius:2px;user-select:none}
.pill:hover span{border-color:var(--gold)}
.pill input:checked + span{background:var(--gold);border-color:var(--gold);color:var(--navy-deep);font-weight:600}
.pill.wide span{display:block;padding:14px 20px;text-align:center}
.pill.wide{display:block}

.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:#3a4258;margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid #d8dce5;background:#fafbfd;color:var(--navy-deep);font-family:inherit;font-size:.98rem;border-radius:2px;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold);background:#fff}
.field textarea{resize:vertical;min-height:80px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.field-row{grid-template-columns:1fr}}

.step-nav{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #ecedf2}
.btn-ghost{background:transparent;color:#3a4258;border:1.5px solid #d8dce5;padding:11px 22px;font-weight:600;cursor:pointer;font-family:inherit;border-radius:2px;transition:all .2s;font-size:.9rem}
.btn-ghost:hover{border-color:var(--navy-deep);color:var(--navy-deep)}
.form-note{font-size:.78rem;color:#7c8294;margin-top:14px;text-align:center;line-height:1.5}
.field-hint{font-size:.78rem;color:#7c8294;margin-top:6px;line-height:1.5;font-style:italic}
.cond[hidden]{display:none}

.booking-success,.booking-error{padding:60px 40px;text-align:center}
.booking-success .tick{width:72px;height:72px;background:var(--gold);color:var(--navy-deep);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.4rem;font-weight:700;margin:0 auto 24px}
.booking-success h3{font-family:'Cinzel',serif;font-size:1.7rem;color:var(--navy-deep);margin-bottom:10px}
.booking-success p{color:#5a6276;font-size:1rem;line-height:1.65;margin-bottom:6px}
.booking-success strong{color:var(--gold);font-family:'Cinzel',serif;letter-spacing:.06em;font-size:1.15rem}
.booking-error h3{font-family:'Cinzel',serif;font-size:1.3rem;color:#b03020;margin-bottom:10px}
.booking-error p{color:#5a6276;margin-bottom:18px}
.booking-error a{color:var(--gold);font-weight:600}

