/* ── WHITSUNDAY HOMES — SHARED STYLES ── */
:root {
  --ink:    #1C2B35;
  --navy:   #1C3A4A;
  --teal:   #4ECDC4;
  --teal-d: #1C8A85;
  --sand:   #E8DDD0;
  --cream:  #F6F2ED;
  --white:  #FAFAF8;
  --mid:    #7A9099;
  --rule:   #DDD6CC;
  --light:  #F0EBE4;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:'Outfit',sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  background:#FAFAF8;
  border-bottom:1px solid var(--rule);
  padding:0 40px;
  height:68px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.nav-wm{font-family:'Syne',sans-serif;font-weight:800;font-size:17px;line-height:1}
.nav-wm .d{color:rgba(28,43,53,0.28)}
.nav-wm .t{color:var(--teal-d)}
.nav-sub{font-family:'Josefin Sans',sans-serif;font-size:7.5px;letter-spacing:0.5em;color:var(--mid);text-transform:uppercase;margin-top:3px;display:block;font-weight:300}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-family:'Josefin Sans',sans-serif;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);text-decoration:none;font-weight:400;transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{background:var(--ink)!important;color:white!important;padding:10px 22px;border-radius:3px;font-size:10px!important;transition:background 0.2s!important}
.nav-cta:hover{background:var(--navy)!important}

/* ── HAMBURGER BUTTON ── */
.nav-mobile-toggle{
  display:none;           /* hidden desktop */
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:6px;
  cursor:pointer;
  background:none;
  border:none;
  padding:8px;
  min-width:44px;
  min-height:44px;
  flex-shrink:0;
}
.nav-mobile-toggle span{
  display:block;
  width:24px;
  height:2px;
  background:var(--ink);
  border-radius:2px;
  transition:transform 0.28s ease, opacity 0.2s ease, width 0.2s ease;
  transform-origin:center;
}
/* Animated X state */
.nav-mobile-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-mobile-toggle.open span:nth-child(2){opacity:0;width:0}
.nav-mobile-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ── PAGE HEADER ── */
.page-header{padding-top:68px;background:var(--cream);padding-bottom:0}
.page-header-inner{padding:64px 80px 56px}
.page-eyebrow{font-family:'Josefin Sans',sans-serif;font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--teal-d);font-weight:400;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.page-eyebrow::before{content:'';width:20px;height:1px;background:var(--teal)}
.page-title{font-family:'Syne',sans-serif;font-size:clamp(28px,5vw,52px);font-weight:800;color:var(--ink);line-height:1.08;letter-spacing:-0.02em;margin-bottom:14px}
.page-title em{color:var(--teal-d);font-style:normal}
.page-sub{font-size:16px;color:var(--mid);font-weight:300;max-width:520px;line-height:1.65}

/* ── BUTTONS ── */
.btn-primary{background:var(--ink);color:white;padding:14px 28px;border-radius:3px;font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;text-decoration:none;transition:background 0.2s,transform 0.15s;font-weight:600;display:inline-flex;align-items:center;min-height:44px}
.btn-primary:hover{background:var(--navy);transform:translateY(-1px)}
.btn-teal{background:var(--teal);color:var(--ink);padding:14px 28px;border-radius:3px;font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;min-height:44px;transition:background 0.2s}
.btn-teal:hover{background:#3dbdb5}
.btn-ghost{color:var(--ink);font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:10px;transition:gap 0.2s;font-weight:600;min-height:44px}
.btn-ghost::after{content:'→';font-size:14px;font-family:'Outfit',sans-serif}
.btn-ghost:hover{gap:16px}
.btn-outline{border:1.5px solid var(--ink);color:var(--ink);padding:13px 28px;border-radius:3px;font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;min-height:44px;transition:background 0.2s}
.btn-outline:hover{background:var(--ink);color:white}
.btn-outline-white{border:1px solid rgba(255,255,255,0.25);color:white;padding:13px 28px;border-radius:3px;font-family:'Josefin Sans',sans-serif;font-size:10px;letter-spacing:0.25em;text-transform:uppercase;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;min-height:44px;transition:border-color 0.2s,background 0.2s}
.btn-outline-white:hover{border-color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.06)}

/* ── SECTION COMMONS ── */
.section-eyebrow{font-family:'Josefin Sans',sans-serif;font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--teal-d);font-weight:400;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.section-eyebrow::before{content:'';width:20px;height:1px;background:var(--teal)}
.section-title{font-family:'Syne',sans-serif;font-size:clamp(24px,3vw,40px);font-weight:800;color:var(--ink);line-height:1.1;letter-spacing:-0.02em;margin-bottom:12px}

/* ── CTA STRIP ── */
.cta-strip{background:var(--navy);padding:80px;text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;border:1px solid rgba(78,205,196,0.06);pointer-events:none}
.cta-strip .section-eyebrow{justify-content:center;color:rgba(78,205,196,0.7)}
.cta-strip .section-eyebrow::before{background:var(--teal)}
.cta-strip .section-title{color:white;max-width:500px;margin:0 auto 14px}
.cta-strip-sub{font-size:15px;color:rgba(255,255,255,0.4);margin-bottom:40px;font-weight:300}
.cta-actions{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap}

/* ── FOOTER ── */
footer{background:var(--ink);padding:64px 80px 40px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer-brand-tagline{font-size:14px;color:rgba(255,255,255,0.35);margin-top:14px;font-weight:300;max-width:220px;line-height:1.6}
.footer-col h5{font-family:'Josefin Sans',sans-serif;font-size:8px;letter-spacing:0.4em;text-transform:uppercase;color:rgba(255,255,255,0.25);font-weight:400;margin-bottom:20px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,0.45);text-decoration:none;font-weight:300;transition:color 0.2s}
.footer-col ul a:hover{color:rgba(255,255,255,0.8)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:11px;color:rgba(255,255,255,0.2);font-family:'Josefin Sans',sans-serif;letter-spacing:0.1em}
.qbcc-badge{font-family:'Josefin Sans',sans-serif;font-size:9px;letter-spacing:0.2em;color:rgba(255,255,255,0.2);border:1px solid rgba(255,255,255,0.1);padding:5px 12px;border-radius:2px}

/* ── MOBILE STICKY QUOTE BAR ── */
.mobile-quote-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  z-index:998;
  background:var(--ink);
  border-top:2px solid rgba(78,205,196,0.3);
  padding:10px 20px;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow:0 -4px 20px rgba(0,0,0,0.15);
}
.mqb-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.mqb-label{
  font-family:'Josefin Sans',sans-serif;
  font-size:9px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.4);
  font-weight:300;
}
.mqb-name{
  font-family:'Syne',sans-serif;
  font-size:15px;
  font-weight:700;
  color:white;
  letter-spacing:-0.01em;
}
.mqb-btn{
  background:var(--teal);
  color:var(--ink);
  padding:12px 22px;
  border-radius:3px;
  font-family:'Josefin Sans',sans-serif;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  text-decoration:none;
  font-weight:700;
  white-space:nowrap;
  min-height:44px;
  display:inline-flex;
  align-items:center;
  flex-shrink:0;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp 0.6s cubic-bezier(0.16,1,0.3,1) both}
.anim-d1{animation-delay:0.05s}
.anim-d2{animation-delay:0.12s}
.anim-d3{animation-delay:0.2s}
.anim-d4{animation-delay:0.28s}

/* ── TABLET ≤1024px ── */
@media(max-width:1024px){
  nav{padding:0 24px}
  .page-header-inner{padding:52px 40px 44px}
  footer{padding:52px 40px 32px}
  .footer-top{grid-template-columns:1fr 1fr}
  .cta-strip{padding:60px 40px}
}

/* ── MOBILE ≤768px ── */
@media(max-width:768px){
  /* Show hamburger, hide desktop links */
  .nav-links{display:none}
  .nav-mobile-toggle{display:flex}
  nav{padding:0 20px}

  /* Page & footer */
  .page-header-inner{padding:44px 20px 36px}
  footer{padding:48px 20px 90px}
  .footer-top{grid-template-columns:1fr 1fr}
  .cta-strip{padding:52px 20px}

  /* Show sticky bar */
  .mobile-quote-bar{display:flex}

  /* Stack CTA actions */
  .cta-actions{flex-direction:column;gap:10px}
  .cta-actions .btn-teal,
  .cta-actions .btn-outline-white{width:100%;max-width:340px;justify-content:center}

  /* iOS: prevent auto-zoom on form fields */
  input,select,textarea{font-size:16px!important}
}

/* ── SMALL MOBILE ≤480px ── */
@media(max-width:480px){
  .footer-top{grid-template-columns:1fr}
  .page-title{font-size:clamp(26px,7vw,40px)}
  .page-header-inner{padding:32px 16px 28px}
  .cta-strip{padding:48px 16px}
  footer{padding:44px 16px 90px}
  nav{padding:0 16px}
}
