/* =================================================================
   Bowtique Mobile Salon — mobile dog grooming, Macarthur NSW
   Palette + type built around the teal + hot-pink logo
   ================================================================= */
:root{
  --teal:#11b3ad;
  --teal-2:#0c9a95;
  --teal-deep:#0a7b77;
  --teal-dark:#093f3d;     /* dark sections */
  --pink:#ec1e8c;          /* BOWTIQUE magenta */
  --pink-2:#cc1374;
  --pink-soft:#fde4f1;
  --cream:#fff7ef;
  --sand:#fdf1e4;
  --ink:#26393a;
  --text:#374d4e;
  --muted:#6e8788;
  --line:rgba(12,80,77,.12);
  --line-d:rgba(255,255,255,.16);
  --shadow:0 20px 45px -20px rgba(10,70,70,.4);
  --shadow-sm:0 8px 22px -12px rgba(10,70,70,.35);
  --r:22px;
  --r-lg:30px;
  --maxw:1180px;
  --ff-head:"Fredoka",-apple-system,system-ui,sans-serif;
  --ff-body:"Nunito",-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--text);background:var(--cream);
  line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:600;line-height:1.1;margin:0;color:var(--ink)}
p{margin:0 0 1rem}
.wrap{width:min(var(--maxw),92%);margin-inline:auto}

/* eyebrow */
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-head);font-weight:600;
  font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;color:var(--pink)}
.eyebrow::before{content:"🐾";font-size:1rem;filter:saturate(.9)}
.on-dark .eyebrow{color:#7fe7e1}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;border:0;font-family:var(--ff-head);
  font-weight:600;font-size:1.05rem;padding:.85rem 1.7rem;border-radius:50px;transition:.22s ease;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-pink{background:var(--pink);color:#fff;box-shadow:0 12px 24px -10px rgba(236,30,140,.6)}
.btn-pink:hover{background:var(--pink-2);transform:translateY(-2px);box-shadow:0 18px 30px -12px rgba(236,30,140,.75)}
.btn-teal{background:var(--teal);color:#fff;box-shadow:0 12px 24px -10px rgba(10,123,119,.6)}
.btn-teal:hover{background:var(--teal-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-lg{padding:1rem 2.1rem;font-size:1.12rem}

/* =================== HEADER =================== */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);box-shadow:0 2px 18px -10px rgba(10,70,70,.35)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand .badge{width:50px;height:50px;border-radius:50%;overflow:hidden;background:var(--teal);flex:0 0 auto;
  box-shadow:0 4px 12px -4px rgba(10,123,119,.6)}
.brand .badge img{width:100%;height:100%;object-fit:cover;object-position:center}
.brand-txt{display:flex;flex-direction:column;line-height:1;font-family:var(--ff-head)}
.brand-txt b{color:var(--pink);font-size:1.32rem;font-weight:700;letter-spacing:.01em}
.brand-txt span{color:var(--teal-deep);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.2rem}
.nav-links a{font-family:var(--ff-head);font-weight:500;font-size:1.02rem;color:var(--ink);
  padding:.5rem .9rem;border-radius:50px;transition:.18s}
.nav-links a:hover{color:var(--pink);background:var(--pink-soft)}
.nav-links a.active{color:var(--pink)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-phone{display:flex;align-items:center;gap:.45rem;color:var(--ink);font-family:var(--ff-head);font-weight:600;font-size:1.05rem}
.nav-phone svg{width:18px;height:18px;color:var(--teal)}
/* landing page only — pink header text */
.site-header.lp .nav-links a{color:var(--pink)}
.site-header.lp .nav-links a:hover{color:var(--pink-2)}
.site-header.lp .nav-phone{color:var(--pink)}
.burger{display:none;background:transparent;border:0;cursor:pointer;padding:.4rem}
.burger span{display:block;width:26px;height:3px;background:var(--teal-deep);margin:5px 0;border-radius:3px;transition:.25s}

/* =================== HERO SLIDESHOW =================== */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--teal-dark)}
.hero-slides{position:absolute;inset:0;z-index:0}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  transform:scale(1.06);transition:opacity 1.4s ease, transform 6s ease}
.slide.on{opacity:1;transform:scale(1)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg,rgba(8,50,48,.9) 0%,rgba(8,50,48,.7) 42%,rgba(8,50,48,.28) 100%)}
.hero .wrap{position:relative;z-index:2;padding:5.5rem 0}
.hero-inner{max-width:680px}
.hero h1{font-size:clamp(2.6rem,6vw,4.7rem);font-weight:700;line-height:1.02;color:#fff}
.hero h1 .pink{color:#ff8dcb}
.hero .lead{font-size:1.2rem;color:#eafaf8;max-width:540px;margin:1.1rem 0 1.8rem;font-weight:500}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-trust{display:flex;gap:1.6rem;flex-wrap:wrap;margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.2)}
.htr{display:flex;align-items:center;gap:.5rem;font-family:var(--ff-head);font-weight:500;color:#eafaf8;font-size:.98rem}
.htr svg{width:20px;height:20px;color:#ffd23f;flex:0 0 auto}
.htr b{color:#fff;font-weight:600}
.hero-dots{position:absolute;bottom:22px;left:0;right:0;z-index:3;display:flex;gap:.5rem;justify-content:center}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.4);transition:.25s;padding:0}
.hero-dots button.on{background:#fff;width:30px;border-radius:6px}

/* =================== SECTIONS =================== */
.pad{padding:5.5rem 0}
.pad-sm{padding:3.6rem 0}
.teal{background:var(--teal)}
.teal-dark{background:var(--teal-dark);color:#fff}
.teal-dark h2,.teal-dark h3{color:#fff}
.cream{background:var(--cream)}
.sand{background:var(--sand)}
.white{background:#fff}
.sec-head{max-width:640px;margin-bottom:2.6rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.1rem);margin:.5rem 0 .7rem}
.sec-head p{color:var(--muted);font-size:1.08rem;margin:0}
.teal-dark .sec-head p{color:#bfe8e5}

/* trust strip */
.strip{background:var(--pink);color:#fff}
.strip .wrap{display:flex;flex-wrap:wrap;gap:.8rem 2.2rem;justify-content:center;align-items:center;padding:1rem 0}
.strip span{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-head);font-weight:500;font-size:1.02rem}
.strip svg{width:20px;height:20px}

/* =================== SERVICE CARDS =================== */
.grid{display:grid;gap:1.5rem}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border-radius:var(--r);padding:1.8rem;box-shadow:var(--shadow-sm);transition:.25s;text-align:center}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ico{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;margin:0 auto 1rem;
  background:var(--pink-soft)}
.card .ico svg{width:36px;height:36px;color:var(--pink)}
.card:nth-child(3n+2) .ico{background:#d9f5f3}
.card:nth-child(3n+2) .ico svg{color:var(--teal-deep)}
.card:nth-child(3n) .ico{background:#fff0d6}
.card:nth-child(3n) .ico svg{color:#e09000}
.card h3{font-size:1.35rem;margin-bottom:.3rem}
.card p{color:var(--muted);font-size:.98rem;margin:0}

/* photo service card */
.pcard{position:relative;border-radius:var(--r);overflow:hidden;min-height:300px;display:flex;flex-direction:column;
  justify-content:flex-end;color:#fff;box-shadow:var(--shadow-sm);background:var(--teal-deep)}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .5s}
.pcard::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,50,48,0) 40%,rgba(8,50,48,.82))}
.pcard .t{position:relative;z-index:2;padding:1.4rem}
.pcard h3{color:#fff;font-size:1.4rem}
.pcard:hover img{transform:scale(1.06)}

/* feature list */
.flist{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}
.flist li{display:flex;gap:.6rem;align-items:flex-start;color:var(--text);font-weight:600}
.flist li::before{content:"🐾";flex:0 0 auto;font-size:1rem}
.teal-dark .flist li{color:#dcf2f0}

/* split */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:3.2rem;align-items:center}
.split.rev{grid-template-columns:1fr 1.05fr}
.split-img{width:100%;height:460px;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow);display:block}
.split h2{font-size:clamp(1.9rem,3.8vw,2.8rem);margin-bottom:1rem}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.step{background:#fff;border-radius:var(--r);padding:1.8rem 1.4rem;text-align:center;box-shadow:var(--shadow-sm);position:relative}
.step .n{width:46px;height:46px;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--ff-head);
  font-weight:700;font-size:1.2rem;display:grid;place-items:center;margin:0 auto .9rem}
.step:nth-child(2) .n{background:var(--pink)}
.step:nth-child(3) .n{background:#f3a712;color:#3a2a00}
.step:nth-child(4) .n{background:var(--teal-deep)}
.step h3{font-size:1.2rem;margin-bottom:.2rem}
.step p{color:var(--muted);font-size:.95rem;margin:0}

/* gallery */
.gal{columns:3;column-gap:1.1rem}
.gal figure{margin:0 0 1.1rem;break-inside:avoid;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--shadow-sm)}
.gal img{width:100%;transition:.5s}
.gal figure:hover img{transform:scale(1.06)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .8rem;color:#fff;font-family:var(--ff-head);
  font-weight:600;background:linear-gradient(180deg,transparent,rgba(8,50,48,.85));opacity:0;transition:.3s}
.gal figure:hover figcaption{opacity:1}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(6,40,38,.95);z-index:200;display:none;align-items:center;justify-content:center;padding:4vh 4vw}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:14px}
.lb-close{position:absolute;top:18px;right:26px;background:transparent;border:0;color:#fff;font-size:2.4rem;cursor:pointer}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.16);border:0;color:#fff;
  width:54px;height:54px;border-radius:50%;font-size:1.6rem;cursor:pointer}
.lb-nav:hover{background:var(--pink)}
.lb-prev{left:3vw}.lb-next{right:3vw}

/* reviews */
.rev{background:#fff;border-radius:var(--r);padding:1.7rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.7rem}
.rev .stars{color:#ffc01e;letter-spacing:1px}
.rev p{color:#46595a;margin:0;font-weight:500}
.rev .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.rev .av{width:42px;height:42px;border-radius:50%;background:var(--teal);display:grid;place-items:center;color:#fff;font-family:var(--ff-head);font-weight:700}
.rev:nth-child(3n+2) .av{background:var(--pink)}
.rev .who b{font-family:var(--ff-head);font-size:1rem;color:var(--ink)}
.rev .who span{display:block;font-size:.8rem;color:var(--muted)}
.gbadge{display:inline-flex;align-items:center;gap:.55rem;background:#fff;border-radius:50px;padding:.5rem 1.2rem;
  font-family:var(--ff-head);font-weight:600;box-shadow:var(--shadow-sm)}
.gbadge .g{color:#4285F4;font-weight:700}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:.55rem}
.chip{background:#fff;border:1.5px solid var(--line);color:var(--teal-deep);font-family:var(--ff-head);font-weight:500;
  font-size:.92rem;padding:.4rem 1rem;border-radius:50px}
.teal-dark .chip{background:rgba(255,255,255,.1);color:#dcf2f0;border-color:rgba(255,255,255,.2)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--teal),var(--teal-deep));color:#fff;text-align:center;
  border-radius:var(--r-lg);padding:3.4rem 2rem;position:relative;overflow:hidden}
.cta-band::before{content:"🐾";position:absolute;font-size:9rem;opacity:.12;top:-1rem;right:1.5rem}
.cta-band h2{font-size:clamp(1.9rem,4vw,2.9rem);color:#fff;position:relative}
.cta-band p{color:#dcf2f0;max-width:540px;margin:.6rem auto 1.5rem;position:relative;font-weight:500}
.cta-band .hero-actions{justify-content:center;position:relative}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2.6rem}
.info-card{background:#fff;border-radius:var(--r);padding:1.3rem 1.4rem;display:flex;gap:1rem;align-items:flex-start;
  margin-bottom:1rem;box-shadow:var(--shadow-sm)}
.info-card .ico{width:46px;height:46px;border-radius:50%;background:var(--pink-soft);display:grid;place-items:center;flex:0 0 auto}
.info-card .ico svg{width:22px;height:22px;color:var(--pink)}
.info-card h4{font-size:1.12rem;margin-bottom:.1rem}
.info-card p,.info-card a{color:var(--muted);margin:0;font-size:.98rem}
.info-card a:hover{color:var(--pink)}
.form{background:#fff;border-radius:var(--r);padding:2rem;box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.35rem}
.field label{font-family:var(--ff-head);font-weight:600;font-size:.92rem;color:var(--ink)}
.field input,.field select,.field textarea{padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:14px;
  font-family:inherit;font-size:.98rem;background:#fafdfd;transition:.18s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(17,179,173,.15)}
.field textarea{resize:vertical;min-height:120px}
.hours-tbl{width:100%;border-collapse:collapse}
.hours-tbl td{padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--text);font-size:.98rem}
.hours-tbl td:last-child{text-align:right;font-family:var(--ff-head);font-weight:600}
.hours-tbl tr.closed td:last-child{color:var(--pink)}

/* FAQ */
.faq{max-width:820px;margin-inline:auto}
.qa{background:#fff;border-radius:16px;margin-bottom:.8rem;overflow:hidden;box-shadow:var(--shadow-sm)}
.qa summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;font-family:var(--ff-head);font-weight:600;font-size:1.08rem;
  color:var(--ink);display:flex;justify-content:space-between;gap:1rem;align-items:center}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";font-size:1.5rem;color:var(--pink);transition:.2s}
.qa[open] summary::after{transform:rotate(45deg)}
.qa p{padding:0 1.3rem 1.2rem;color:var(--muted);margin:0}

/* page hero */
.page-hero{position:relative;background:var(--teal-dark);color:#fff;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:url('../img/van.webp');background-size:cover;background-position:center;opacity:.22}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,50,48,.55),rgba(8,50,48,.92))}
.page-hero .wrap{position:relative;z-index:2;padding:4.4rem 0 3.8rem}
.page-hero h1{font-size:clamp(2.2rem,5.2vw,3.8rem);color:#fff}
.page-hero p{color:#cdeeeb;max-width:600px;font-size:1.12rem;margin:.7rem 0 0;font-weight:500}
.crumbs{font-family:var(--ff-head);font-size:.86rem;letter-spacing:.04em;color:#8fd6d1;margin-bottom:.4rem}
.crumbs a:hover{color:#fff}

/* footer */
.site-footer{background:var(--teal-dark);color:#a9d4d1;padding:4rem 0 1.6rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.2rem;margin-bottom:2.6rem}
.foot-grid .fbrand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.foot-grid .fbrand .badge{width:54px;height:54px;border-radius:50%;overflow:hidden;background:var(--teal);flex:0 0 auto}
.foot-grid .fbrand .badge img{width:100%;height:100%;object-fit:cover}
.foot-grid .fbrand b{font-family:var(--ff-head);color:#fff;font-size:1.3rem}
.foot-grid h4{color:#fff;font-size:1.05rem;margin-bottom:1rem;font-family:var(--ff-head)}
.foot-grid a,.foot-grid p{color:#a9d4d1;font-size:.96rem;display:block;margin-bottom:.5rem}
.foot-grid a:hover{color:#ff8dcb}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);padding-top:1.4rem;display:flex;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#7fb8b4}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* mobile call bar */
.callbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--pink);color:#fff;text-align:center;
  padding:.85rem;font-family:var(--ff-head);font-weight:600;font-size:1.05rem}

/* =================== RESPONSIVE =================== */
@media(max-width:960px){
  .g-3,.g-4,.steps{grid-template-columns:repeat(2,1fr)}
  .split,.split.rev,.contact-grid{grid-template-columns:1fr;gap:2rem}
  .split-img{order:-1;height:320px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gal{columns:2}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;align-items:stretch;background:#fff;
    padding:1rem;gap:.2rem;transform:translateY(-135%);transition:.3s;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-links a{padding:.9rem 1rem;font-size:1.1rem}
  .burger{display:block}
  .nav-phone span{display:none}
  .callbar{display:block}
  body{padding-bottom:54px}
  .hero .wrap{padding:4rem 0}
  .hero{min-height:88vh}
}
@media(max-width:540px){
  .g-2,.g-3,.g-4,.steps,.form .row{grid-template-columns:1fr}
  .gal{columns:1}
  .pad{padding:3.6rem 0}
  .foot-grid{grid-template-columns:1fr}
  .hero-trust{gap:1rem}
}
