/* =====================================================================
   Barangaroo Water Taxis — rebuilt front-end (no Joomla)
   Plain HTML/CSS/JS. Mirrors the look of the previous Shape5 site
   with a modernised, mobile-first layout.
   ===================================================================== */

:root{
  --navy:        #0b2138;
  --navy-2:      #0f2c48;
  --ink:         #10151b;
  --gold:        #c8a45a;
  --gold-2:      #b8923f;
  --sea:         #1f7a8c;
  --paper:       #ffffff;
  --mist:        #f4f6f8;
  --line:        #e3e8ee;
  --muted:       #6a7683;
  --radius:      10px;
  --shadow:      0 10px 30px rgba(11,33,56,.12);
  --wrap:        1180px;
  --font:        'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--sea);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-weight:900;line-height:1.15;margin:0 0 .5em;color:var(--navy)}
h1{font-size:clamp(2rem,5vw,3.4rem);letter-spacing:.5px}
h2{font-size:clamp(1.5rem,3.4vw,2.3rem)}
h3{font-size:1.15rem}
p{margin:0 0 1rem}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  padding:14px 30px;
  border-radius:50px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
  font-size:.85rem;
  cursor:pointer;
  border:2px solid transparent;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  text-decoration:none;
}
.btn:hover{transform:translateY(-2px);text-decoration:none}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-2);color:#fff}
.btn-outline{border-color:#fff;color:#fff}
.btn-outline:hover{background:#fff;color:var(--navy)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);color:#fff}

/* ---------- top bar ---------- */
.topbar{background:var(--ink);color:#cdd7e0;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:16px}
.topbar a{color:#e7edf3}
.topbar .socials a{margin-left:14px;opacity:.85}
.topbar .socials a:hover{opacity:1}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(11,33,56,.96);
  backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:900;letter-spacing:.5px}
.brand:hover{text-decoration:none}
.brand .logo{height:44px;width:auto}
.brand .brand-txt{font-size:1.05rem;line-height:1.05}
.brand .brand-txt small{display:block;font-weight:600;font-size:.62rem;letter-spacing:3px;color:var(--gold)}
/* black + red wordmark logo on a clean white chip (legible on the navy header) */
.brand .wordmark{display:inline-flex;flex-direction:column;line-height:1;background:#fff;padding:7px 15px 8px;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.28)}
.brand .wm-b{font-weight:900;font-size:1.32rem;color:#111;letter-spacing:.3px}
.brand .wm-r{font-weight:800;font-size:.6rem;letter-spacing:4px;text-transform:uppercase;color:#cc0a1e;margin-top:3px}
@media (max-width:420px){.brand .wm-b{font-size:1.12rem}.brand .wm-r{font-size:.54rem;letter-spacing:3px}}
.menu{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.menu a{
  color:#dbe4ec;font-weight:600;font-size:.9rem;
  padding:10px 14px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px;
}
.menu a:hover,.menu a.active{color:#fff;background:rgba(255,255,255,.08);text-decoration:none}
.menu .call{color:var(--navy);background:var(--gold);}
.menu .call:hover{background:var(--gold-2);color:#fff}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer}

/* ---------- hero ---------- */
.hero{
  position:relative;color:#fff;text-align:center;
  display:flex;align-items:center;
  min-height:86vh;
  background:linear-gradient(rgba(6,14,26,.40),rgba(6,14,26,.55)),
             url('../img/hero.jpg') center/cover no-repeat;
  padding:90px 0;
}
.hero .wrap{width:100%}
.hero .eyebrow{color:var(--gold);letter-spacing:4px;text-transform:uppercase;font-weight:700;font-size:.8rem;margin-bottom:14px}
.hero h1{color:#fff;max-width:900px;margin-inline:auto}
.hero p.lead{font-size:1.15rem;max-width:720px;margin:18px auto 30px;color:#e4ebf1}
.hero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- section shell ---------- */
.section{padding:74px 0}
.section.mist{background:var(--mist)}
.section.navy{background:var(--navy);color:#e7edf3}
.section.navy h2,.section.navy h3{color:#fff}
.section-head{max-width:720px;margin:0 auto 46px;text-align:center}
.section-head .eyebrow{color:var(--gold);letter-spacing:3px;text-transform:uppercase;font-weight:700;font-size:.78rem;margin-bottom:10px}
.section.navy .section-head .eyebrow{color:var(--gold)}

/* ---------- feature grid ---------- */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.feature{
  background:var(--navy);border:1px solid rgba(200,164,90,.28);border-radius:var(--radius);
  padding:30px 26px;transition:transform .18s ease,box-shadow .18s ease;
}
.feature:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.35);border-color:rgba(200,164,90,.6)}
.feature .ico{display:none}
.feature h3{margin-bottom:.4rem;color:var(--gold)}
.feature p{margin:0;color:#e8edf2;font-size:.95rem}

/* ---------- image cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:3/4;box-shadow:var(--shadow);
}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover img{transform:scale(1.06)}
.card .cap{
  position:absolute;inset:auto 0 0 0;padding:18px 16px;
  background:linear-gradient(transparent,rgba(7,22,38,.9));color:#fff;
}
.card .cap h3{color:#fff;margin:0 0 2px;font-size:1.05rem}
.card .cap span{color:var(--gold);font-size:.78rem;letter-spacing:1px;text-transform:uppercase}

/* ---------- split feature ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}
.split .kicker{color:var(--sea);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:.78rem;margin-bottom:8px}

/* ---------- booking widget area ---------- */
.booking{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.booking .panel{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:26px;margin-top:10px;min-height:120px;
}
#widgetcontainer{min-height:80px;overflow:hidden}
.widget-fallback{
  border:1px dashed var(--line);border-radius:10px;padding:22px;text-align:center;color:var(--muted)
}
.widget-note{font-size:.82rem;color:var(--muted);margin-top:14px}

/* ---------- quote form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:.85rem;color:var(--navy)}
.field label .req{color:#c0392b}
.field input,.field select,.field textarea{
  padding:12px 14px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:.95rem;background:#fff;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px rgba(31,122,140,.12)}
/* honeypot — visually and functionally hidden from humans */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
/* form status banner */
.form-status{padding:14px 18px;border-radius:8px;margin-bottom:20px;font-weight:600;font-size:.95rem}
.form-status.ok{background:#e6f4ea;color:#1e6b34;border:1px solid #b7e0c2}
.form-status.err{background:#fdecea;color:#a32218;border:1px solid #f4c2bd}
.btn[disabled]{opacity:.6;cursor:progress}

/* ---------- trust strip ---------- */
.trust{display:flex;flex-wrap:wrap;gap:34px;align-items:center;justify-content:center}
.trust img{height:52px;width:auto;opacity:.9;filter:grayscale(.2)}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(rgba(11,33,56,.86),rgba(11,33,56,.9)),
             url('../img/newyears.jpg') center/cover no-repeat;
  color:#fff;text-align:center;padding:70px 0;
}
.cta-band h2{color:#fff}
.cta-band .phone{font-size:2rem;font-weight:900;color:var(--gold);letter-spacing:1px}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#aeb9c4;font-size:.9rem}
.footer-top{padding:56px 0;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.site-footer h4{color:#fff;font-size:1rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.site-footer a{color:#c3ced8}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer ul li{margin-bottom:9px}
.footer-logos{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.footer-logos img{height:42px;background:#fff;border-radius:6px;padding:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;text-align:center;font-size:.82rem;color:#8a97a4}

/* ---------- page hero (subpages) ---------- */
.page-hero{
  background:linear-gradient(rgba(7,22,38,.7),rgba(7,22,38,.78)),
             url('../img/boatrow4.jpg') center/cover no-repeat;
  color:#fff;text-align:center;padding:80px 0;
}
.page-hero h1{color:#fff}
.page-hero p{color:#dce4eb;max-width:640px;margin:0 auto}

/* ---------- misc ---------- */
.legal h2{margin-top:2rem}
.legal p,.legal li{color:#2c3742}
.floating-call{
  position:fixed;right:18px;bottom:18px;z-index:60;
  background:var(--gold);color:var(--navy);font-weight:800;
  padding:14px 20px;border-radius:50px;box-shadow:var(--shadow);
  display:none;
}
.floating-call:hover{background:var(--gold-2);color:#fff;text-decoration:none}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(1,1fr)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:26px}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .nav-toggle{display:block}
  .menu{
    position:absolute;top:74px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--navy);padding:8px 14px 16px;
    border-bottom:1px solid rgba(255,255,255,.1);
    display:none;
  }
  .menu.open{display:flex}
  .menu a{padding:13px 10px;border-radius:0;border-bottom:1px solid rgba(255,255,255,.06)}
  .menu .call{margin-top:8px;text-align:center;border-radius:6px}
  .form-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .floating-call{display:inline-block}
  .hero{min-height:78vh;padding:70px 0}
  /* let the fixed-width booking widget scroll inside its box instead of
     blowing out the page width (which broke the mobile nav) */
  #widgetcontainer{overflow-x:auto;-webkit-overflow-scrolling:touch}
}
