/* ============================================================
   SEASIDE PAINTING — Gold Coast & Northern NSW
   Palette: deep ocean navy + marine teal + warm sand
   Display: Anton (brand font) · Body: Inter
   ============================================================ */

:root{
  --navy:#0C2D3F;
  --navy-deep:#071F2B;
  --teal:#15808E;
  --teal-btn:#0B6675;
  --teal-dark:#094E5A;
  --sand:#F4F0E7;
  --sand-2:#ECE5D6;
  --ink:#15323D;
  --muted:#5A6B72;
  --white:#FFFFFF;
  --line:rgba(12,45,63,.14);
  --shadow:0 18px 40px -22px rgba(7,31,43,.45);
  --shadow-sm:0 8px 22px -14px rgba(7,31,43,.4);
  --radius:14px;
  --maxw:1180px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--sand);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--teal-dark);text-decoration:none}

h1,h2,h3{margin:0;line-height:1.04}
.display{
  font-family:"Anton",Impact,sans-serif;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.01em;
}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}

.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--teal);margin:0 0 14px;
}
.section{padding:clamp(56px,8vw,108px) 0}
.section-head{max-width:680px;margin-bottom:clamp(30px,4vw,52px)}
.section-title{
  font-family:"Anton",Impact,sans-serif;text-transform:uppercase;
  font-size:clamp(1.9rem,4.2vw,3.1rem);color:var(--navy);letter-spacing:.01em;
}
.section-title.light{color:var(--white)}
.lead{font-size:1.075rem;color:var(--muted);margin:16px 0 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:600;font-size:1rem;line-height:1;
  padding:15px 26px;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--teal-btn);color:#fff}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;transform:translateY(-2px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-deep);transform:translateY(-2px)}
.btn svg{width:18px;height:18px;flex:none}

:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:4px}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(244,240,231,.86);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s,background .25s}
.header.scrolled{box-shadow:0 10px 30px -20px rgba(7,31,43,.5);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;flex:none}
.brand .word{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:1.18rem;letter-spacing:.04em;color:var(--navy);line-height:1}
.brand .word small{display:block;font-family:"Inter",sans-serif;font-weight:600;font-size:.54rem;letter-spacing:.26em;color:var(--teal);margin-top:3px}
.nav-panel{display:flex;align-items:center;gap:26px}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--navy);font-weight:500;font-size:.96rem;position:relative}
.nav-links a:hover{color:var(--teal-dark)}
.nav-actions{display:flex;align-items:center;gap:16px}
.nav-phone{display:inline-flex;align-items:center;gap:8px;color:var(--navy);font-weight:700;font-size:.98rem}
.nav-phone svg{width:17px;height:17px;color:var(--teal)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--navy)}
.nav-toggle svg{width:28px;height:28px}
.panel-cta{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;isolation:isolate;background:var(--navy)}
.hero-img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(7,31,43,.92) 0%,rgba(7,31,43,.78) 38%,rgba(7,31,43,.32) 70%,rgba(7,31,43,.12) 100%);}
.hero-inner{padding:clamp(70px,12vw,140px) 0 clamp(56px,8vw,96px);max-width:720px}
.hero h1{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;
  font-size:clamp(2.6rem,7vw,5rem);letter-spacing:.005em;margin:18px 0 0;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{font-style:normal;color:#7FD3DC}
.hero .eyebrow{color:#8FDBE3}
.hero-sub{font-size:clamp(1.05rem,2.2vw,1.28rem);color:rgba(255,255,255,.9);margin:22px 0 0;max-width:600px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}

/* trust bar */
.trust{background:var(--navy-deep);color:#cfe6ea}
.trust-row{display:flex;flex-wrap:wrap;gap:10px 34px;justify-content:center;align-items:center;
  padding:18px 0;font-size:.93rem;font-weight:500}
.trust-row span{display:inline-flex;align-items:center;gap:9px}
.trust-row svg{width:17px;height:17px;color:var(--teal);flex:none}

/* ---------- Intro strip ---------- */
.intro{background:var(--white)}
.intro-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.intro p{font-size:1.12rem;color:var(--ink)}
.intro p.big{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.1rem);color:var(--navy);line-height:1.08;margin:0 0 18px}
.intro-stats{display:grid;gap:18px}
.stat{border-left:3px solid var(--teal);padding-left:16px}
.stat b{font-family:"Anton",Impact,sans-serif;font-size:1.7rem;color:var(--navy);display:block;line-height:1}
.stat span{font-size:.92rem;color:var(--muted)}

/* ---------- Services ---------- */
.services{background:var(--sand)}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card-media{aspect-ratio:16/10;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-media img{transform:scale(1.05)}
.card-body{padding:24px 24px 28px}
.card-body h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:1.35rem;color:var(--navy);margin-bottom:10px;letter-spacing:.01em}
.card-body p{color:var(--muted);font-size:.99rem;margin:0}

/* ---------- Why us ---------- */
.why{background:var(--navy);color:#fff}
.why-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,64px);align-items:center}
.why-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.why-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:5/4}
.why .section-title{color:#fff}
.why .eyebrow{color:#8FDBE3}
.feat-list{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:22px}
.feat{display:flex;gap:16px}
.feat .ic{flex:none;width:44px;height:44px;border-radius:11px;background:rgba(127,211,220,.14);
  display:grid;place-items:center;color:#8FDBE3}
.feat .ic svg{width:22px;height:22px}
.feat h4{margin:0 0 4px;font-size:1.08rem;color:#fff;font-weight:700}
.feat p{margin:0;color:rgba(255,255,255,.74);font-size:.96rem}

/* ---------- Before / after ---------- */
.ba{background:var(--white)}
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px}
.ba-card{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.ba-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.ba-tag{position:absolute;top:14px;left:14px;background:var(--navy);color:#fff;font-weight:700;
  font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:7px 13px;border-radius:999px}
.ba-tag.after{background:var(--teal-btn)}
.ba-note{margin:22px 0 0;color:var(--muted);max-width:640px}

/* ---------- Gallery ---------- */
.work{background:var(--sand-2)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tile{position:relative;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);background:var(--navy)}
.tile img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;transition:transform .5s ease,opacity .3s}
.tile:hover img{transform:scale(1.07)}
.tile figcaption{position:absolute;inset:auto 0 0 0;
  background:linear-gradient(0deg,rgba(7,31,43,.86),rgba(7,31,43,0));
  color:#fff;padding:30px 14px 13px;font-size:.86rem;font-weight:600;letter-spacing:.01em}
.tile.tall{grid-row:span 2}
.tile.tall img{aspect-ratio:auto;height:100%}

/* ---------- Process ---------- */
.process{background:var(--white)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:10px;counter-reset:step}
.step{position:relative;padding:30px 26px;border:1px solid var(--line);border-radius:var(--radius);background:var(--sand)}
.step .num{font-family:"Anton",Impact,sans-serif;font-size:2.6rem;color:var(--teal);line-height:1;display:block;margin-bottom:10px}
.step h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:1.2rem;color:var(--navy);margin-bottom:8px}
.step p{margin:0;color:var(--muted);font-size:.98rem}

/* ---------- Areas ---------- */
.areas{background:var(--navy-deep);color:#fff}
.areas .section-title{color:#fff}
.areas .eyebrow{color:#8FDBE3}
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin-top:8px}
.area-col h4{font-size:1.06rem;color:#8FDBE3;margin:0 0 14px;letter-spacing:.02em}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#dff0f2;
  padding:7px 14px;border-radius:999px;font-size:.9rem}

/* ---------- Contact ---------- */
.contact{background:var(--sand)}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,60px);align-items:start}
.contact-info .lead{color:var(--muted)}
.contact-lines{display:grid;gap:18px;margin:28px 0}
.cline{display:flex;gap:14px;align-items:flex-start}
.cline .ic{flex:none;width:42px;height:42px;border-radius:11px;background:#fff;display:grid;place-items:center;color:var(--teal-btn);box-shadow:var(--shadow-sm)}
.cline .ic svg{width:20px;height:20px}
.cline b{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.cline a,.cline span{font-size:1.12rem;color:var(--navy);font-weight:600}
.cred{margin-top:8px;font-size:.9rem;color:var(--muted)}
.cred strong{color:var(--navy)}

.form{background:var(--white);border-radius:var(--radius);padding:clamp(24px,4vw,38px);box-shadow:var(--shadow)}
.form h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:1.5rem;margin-bottom:6px}
.form p.note{color:var(--muted);font-size:.95rem;margin:0 0 22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;color:var(--navy);margin-bottom:7px}
.field input,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(21,128,142,.15)}
.field textarea{min-height:120px;resize:vertical}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hp{position:absolute;left:-9999px}

/* ---------- Wave divider ---------- */
.wave{display:block;width:100%;height:54px;margin-bottom:-1px}
.wave path{fill:var(--navy)}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#bcd2d8;padding:clamp(48px,6vw,72px) 0 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:34px}
.footer .brand .word{color:#fff}
.footer .fbrand p{margin:16px 0 0;color:#90aeb6;font-size:.95rem;max-width:280px}
.footer h5{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer ul a,.footer ul span{color:#bcd2d8;font-size:.96rem}
.footer ul a:hover{color:#fff}
.footer-bottom{margin-top:40px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:space-between;font-size:.85rem;color:#7f9aa2}

/* ---------- Reveal animation (no-JS safe: only hides once JS adds .js-anim) ---------- */
html.js-anim .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
html.js-anim .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.js-anim .reveal,html.js-anim .reveal.in{opacity:1;transform:none;transition:none}
  .card,.btn,.tile img,.card-media img{transition:none}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .intro-grid,.why-grid,.contact-grid{grid-template-columns:1fr}
  .why-media{order:-1}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .tile.tall{grid-row:span 1}
  .tile.tall img{aspect-ratio:1/1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-actions .nav-phone,.nav-actions .btn-primary{display:none}
  .nav-toggle{display:inline-flex}
  .nav-panel{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--sand);border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);transform:translateY(-120%);transition:transform .3s ease;z-index:40}
  .nav-panel.open{transform:none}
  .nav-links{flex-direction:column;align-items:stretch;gap:0;padding:8px 22px 18px}
  .nav-links li{border-top:1px solid var(--line)}
  .nav-links a{display:block;padding:15px 0;font-size:1.05rem}
  .panel-cta{display:grid;gap:10px;padding:0 22px 22px}
  .panel-cta .btn{justify-content:center}
  .cards,.steps,.ba-wrap,.areas-grid,.row2{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .trust-row{gap:8px 20px;font-size:.85rem}
  body{font-size:16px}
}

/* ============================================================
   MULTI-PAGE COMPONENTS
   ============================================================ */

/* ---- Logo image in brand ---- */
.brand .logo-img{height:38px;width:auto;display:block;flex:none}
.footer .brand .logo-img{height:40px}

/* ---- Dropdown nav (desktop) ---- */
.nav-links li.has-dd{position:relative}
.dd-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:0;font:inherit;
  color:var(--navy);font-weight:500;font-size:.96rem;cursor:pointer;padding:0;line-height:1}
.dd-toggle svg{width:12px;height:12px;transition:transform .25s}
.dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);
  background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  min-width:236px;padding:8px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;margin-top:12px}
.dropdown::before{content:"";position:absolute;top:-14px;left:0;right:0;height:16px}
.nav-links li.has-dd:hover .dropdown,.nav-links li.has-dd:focus-within .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-links li.has-dd:hover .dd-toggle svg{transform:rotate(180deg)}
.dropdown a{display:block;padding:11px 14px;border-radius:8px;color:var(--navy);font-size:.95rem;font-weight:500;border:0}
.dropdown a:hover{background:var(--sand);color:var(--teal-dark)}
.nav-links a[aria-current="page"],.dd-toggle[aria-current="page"]{color:var(--teal-dark)}
.nav-links a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--teal);margin-top:3px;border-radius:2px}

/* ---- Page hero (inner pages) ---- */
.page-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;isolation:isolate}
.page-hero .ph-bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;opacity:.30}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(7,31,43,.92),rgba(7,31,43,.66))}
.page-hero .container{padding:clamp(46px,7vw,88px) 0}
.page-hero h1{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:clamp(2.1rem,5.2vw,3.7rem);letter-spacing:.01em;margin:0;max-width:880px}
.page-hero .ph-sub{font-size:clamp(1.02rem,2vw,1.22rem);color:rgba(255,255,255,.86);margin:16px 0 0;max-width:620px}
.crumbs{font-size:.84rem;margin:0 0 16px;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.crumbs a{color:#8FDBE3}.crumbs a:hover{color:#fff}
.crumbs span{color:rgba(255,255,255,.45)}
.crumbs em{color:rgba(255,255,255,.7);font-style:normal}

/* ---- Generic split (light bg) ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.split-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.split.rev .split-media{order:-1}

/* ---- Prose ---- */
.prose{max-width:730px}
.prose p{margin:0 0 16px;color:var(--ink)}
.prose p:last-child{margin-bottom:0}
.prose h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:1.4rem;margin:30px 0 12px;letter-spacing:.01em}

/* ---- Checklist ---- */
.checklist{list-style:none;margin:20px 0 0;padding:0;display:grid;gap:13px}
.checklist.two{grid-template-columns:1fr 1fr;gap:13px 30px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-size:1rem}
.checklist li svg{flex:none;width:22px;height:22px;color:var(--teal);margin-top:1px}

/* ---- Values grid (about) ---- */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.value{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px}
.value .ic{width:46px;height:46px;border-radius:12px;background:rgba(21,128,142,.1);display:grid;place-items:center;color:var(--teal-btn);margin-bottom:14px}
.value .ic svg{width:23px;height:23px}
.value h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:1.18rem;color:var(--navy);margin:0 0 8px}
.value p{margin:0;color:var(--muted);font-size:.97rem}

/* ---- CTA band ---- */
.cta-band{background:var(--teal-btn);color:#fff;text-align:center}
.cta-band .container{padding:clamp(42px,6vw,74px) 0}
.cta-band h2{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:clamp(1.8rem,4vw,2.9rem);margin:0 0 12px;letter-spacing:.01em}
.cta-band p{max-width:580px;margin:0 auto 26px;color:rgba(255,255,255,.92);font-size:1.05rem}
.cta-band .btn{background:#fff;color:var(--navy)}
.cta-band .btn:hover{background:var(--navy-deep);color:#fff;transform:translateY(-2px)}
.cta-band .btn.alt{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);margin-left:10px}
.cta-band .btn.alt:hover{background:rgba(255,255,255,.14);border-color:#fff}

/* ---- Section bg helpers ---- */
.bg-white{background:var(--white)}
.bg-sand{background:var(--sand)}
.bg-sand2{background:var(--sand-2)}

/* ---- Work category gallery heading ---- */
.cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:8px 0 18px;flex-wrap:wrap}
.cat-head h2{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:clamp(1.5rem,3vw,2.1rem)}
.cat-head span{color:var(--muted);font-size:.95rem}
.work-block + .work-block{margin-top:clamp(40px,6vw,72px)}

/* ---- Inline list (areas page) ---- */
.area-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px 24px 26px}
.area-card h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:1.25rem;margin:0 0 6px}
.area-card .reg{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);margin:0 0 14px}
.area-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* ---- FAQ ---- */
.faq{display:grid;gap:0;max-width:820px}
.faq details{border-bottom:1px solid var(--line);padding:18px 0}
.faq summary{font-weight:600;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--teal);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"\2212"}
.faq p{margin:12px 0 0;color:var(--muted)}

/* ---- Responsive for new components ---- */
@media (max-width:980px){
  .split{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .values,.area-cards{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  /* mobile dropdown becomes inline expandable */
  .dd-toggle{width:100%;justify-content:space-between;padding:15px 0;font-size:1.05rem;border-top:1px solid var(--line)}
  .nav-links li.has-dd .dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;
    border:0;border-radius:0;padding:0 0 8px 14px;min-width:0;margin:0;display:none}
  .nav-links li.has-dd .dropdown::before{display:none}
  .nav-links li.has-dd.open .dropdown{display:block}
  .nav-links li.has-dd.open .dd-toggle svg{transform:rotate(180deg)}
  .dropdown a{padding:10px 0;font-size:1rem}
  .values,.area-cards,.checklist.two{grid-template-columns:1fr}
  .cta-band .btn.alt{margin-left:0;margin-top:10px}
}

/* ============================================================
   MULTI-PAGE COMPONENTS
   ============================================================ */

/* ---- Logo image in header/footer ---- */
.brand .logo-img{height:38px;width:auto;display:block}
.footer .brand .logo-img{height:40px}

/* ---- Services dropdown ---- */
.has-sub{position:relative}
.sub-toggle{display:inline-flex;align-items:center;gap:5px}
.sub-toggle svg{width:13px;height:13px;transition:transform .2s}
.subnav{list-style:none;margin:0;padding:0}
@media (min-width:761px){
  .subnav{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
    min-width:230px;background:#fff;border:1px solid var(--line);border-radius:12px;
    box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transition:opacity .18s,transform .18s;z-index:60}
  .subnav::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
  .has-sub:hover .subnav,.has-sub:focus-within .subnav{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .has-sub:hover .sub-toggle svg{transform:rotate(180deg)}
  .subnav a{display:block;padding:11px 14px;border-radius:8px;color:var(--navy);font-size:.94rem;font-weight:500}
  .subnav a:hover{background:var(--sand);color:var(--teal-dark)}
}
.nav-links a.active{color:var(--teal-dark)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--teal)}

/* ---- Inner page hero / banner ---- */
.page-hero{position:relative;color:#fff;background:var(--navy);isolation:isolate;overflow:hidden}
.page-hero.has-img::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(7,31,43,.93),rgba(7,31,43,.74) 55%,rgba(7,31,43,.55))}
.page-hero-img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover}
.page-hero-inner{padding:clamp(48px,8vw,92px) 0 clamp(40px,6vw,72px);max-width:760px}
.page-hero h1{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(2.1rem,5vw,3.6rem);margin:14px 0 0;line-height:1.04}
.page-hero p{font-size:clamp(1.02rem,2vw,1.2rem);color:rgba(255,255,255,.88);margin:18px 0 0;max-width:620px}
.page-hero .eyebrow{color:#8FDBE3}
.page-hero .hero-cta{margin-top:28px}

/* ---- Breadcrumb ---- */
.crumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.85rem;color:rgba(255,255,255,.7);margin:0}
.crumb a{color:rgba(255,255,255,.7)}
.crumb a:hover{color:#fff}
.crumb span{opacity:.5}

/* ---- Media + text split (reusable) ---- */
.media-text{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center}
.media-text.flip .mt-media{order:2}
.mt-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.mt-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.mt-body h2{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);
  font-size:clamp(1.7rem,3.5vw,2.5rem);letter-spacing:.01em;margin-bottom:14px}
.mt-body p{color:var(--muted);margin:0 0 14px}
.mt-body p:last-child{margin-bottom:0}

/* ---- Checklist (what's included) ---- */
.checklist{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:13px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink)}
.checklist li svg{flex:none;width:21px;height:21px;color:var(--teal-btn);margin-top:2px}
.included{background:var(--white)}
.included .inner{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,5vw,56px);align-items:start}
.prodbox{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.prodbox h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:1.2rem;margin-bottom:14px}
.prodbox ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.prodbox li{display:flex;justify-content:space-between;gap:14px;font-size:.95rem;border-bottom:1px dashed var(--line);padding-bottom:11px}
.prodbox li:last-child{border-bottom:0;padding-bottom:0}
.prodbox li b{color:var(--navy);font-weight:600}
.prodbox li span{color:var(--muted);text-align:right}

/* ---- Strip gallery (service pages) ---- */
.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.strip figure{margin:0;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);position:relative}
.strip img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.strip figcaption{position:absolute;inset:auto 0 0 0;background:linear-gradient(0deg,rgba(7,31,43,.82),transparent);
  color:#fff;padding:26px 13px 11px;font-size:.84rem;font-weight:600}

/* ---- FAQ (details/summary) ---- */
.faq{display:grid;gap:12px;max-width:820px}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:600;color:var(--navy);
  font-size:1.04rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:"Anton",sans-serif;font-size:1.5rem;color:var(--teal);line-height:1;transition:transform .2s}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{color:var(--teal-dark)}
.faq .ans{padding:0 22px 20px;color:var(--muted);margin:0}

/* ---- CTA band ---- */
.cta-band{background:var(--teal-btn);color:#fff}
.cta-band .inner{display:flex;flex-wrap:wrap;gap:22px;align-items:center;justify-content:space-between;
  padding:clamp(34px,5vw,52px) 0}
.cta-band h2{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;font-size:clamp(1.6rem,3.5vw,2.4rem);
  letter-spacing:.01em;margin:0;max-width:560px;line-height:1.06}
.cta-band p{margin:8px 0 0;color:rgba(255,255,255,.85)}
.cta-band .btn-white{background:#fff;color:var(--teal-dark)}
.cta-band .btn-white:hover{background:var(--sand);transform:translateY(-2px)}
.cta-actions{display:flex;flex-wrap:wrap;gap:13px;align-items:center}
.cta-phone{color:#fff;font-weight:700;font-size:1.1rem;display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.cta-phone svg{width:19px;height:19px}

/* ---- Areas page ---- */
.area-block{display:grid;gap:14px;margin-bottom:40px}
.area-block:last-child{margin-bottom:0}
.area-block h3{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);font-size:1.5rem}
.area-feature{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-top:8px}
.area-card{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:20px 22px}
.area-card h4{margin:0 0 7px;color:var(--navy);font-size:1.05rem}
.area-card p{margin:0;color:var(--muted);font-size:.93rem}

/* ---- Generic prose block ---- */
.prose{max-width:760px}
.prose p{color:var(--muted);margin:0 0 16px}
.prose p:last-child{margin-bottom:0}
.prose h2{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;color:var(--navy);
  font-size:clamp(1.6rem,3.2vw,2.2rem);margin:34px 0 14px}

/* ---- Responsive (multi-page) ---- */
@media (max-width:980px){
  .media-text,.included .inner{grid-template-columns:1fr}
  .media-text.flip .mt-media{order:-1}
  .strip{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .subnav{display:block;padding:0 0 6px 14px}
  .subnav a{display:block;padding:12px 0;font-size:.98rem;color:var(--muted);border-top:1px solid var(--line)}
  .sub-toggle svg{display:none}
  .nav-links a.active::after{display:none}
  .strip{grid-template-columns:1fr 1fr}
  .cta-band .inner{flex-direction:column;align-items:flex-start}
}

/* ---------- multi-page utility additions ---------- */
.card{text-decoration:none;color:inherit}
.cardlink{display:inline-block;margin-top:14px;color:var(--teal-dark);font-weight:600;font-size:.92rem}
.card:hover .cardlink{color:var(--teal-btn)}
.textlink{color:var(--teal-dark);font-weight:600;border-bottom:2px solid rgba(21,128,142,.32);padding-bottom:2px}
.textlink:hover{border-color:var(--teal-dark)}
.section.areas-line{background:var(--sand-2);padding:clamp(34px,5vw,56px) 0}
.section.areas-line .prose p{margin:0;color:var(--muted);font-size:1.02rem}

/* ---------- Mobile sticky call/quote bar ---------- */
.callbar{display:none}
@media (max-width:760px){
  .callbar{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:80;
    box-shadow:0 -6px 22px rgba(7,31,43,.22)}
  .callbar a{display:flex;align-items:center;justify-content:center;gap:9px;padding:15px 10px;
    font-weight:700;font-size:1.02rem;text-decoration:none;letter-spacing:.01em}
  .callbar-call{background:var(--navy);color:#fff}
  .callbar-call svg{width:19px;height:19px}
  .callbar-quote{background:var(--teal-btn);color:#fff}
  .callbar-quote:active,.callbar-call:active{filter:brightness(1.1)}
  body{padding-bottom:56px}
}

/* ===================== Trust badges ===================== */
.section.trust{padding:40px 0}
.trust-eyebrow{display:flex;justify-content:center;text-align:center;margin-bottom:22px}
.trust-badges{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px}
.tb-logo{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e7e1d6;
  border-radius:12px;padding:14px 24px;box-shadow:var(--shadow-sm);height:80px}
.tb-logo img{max-height:48px;width:auto;object-fit:contain;display:block}

/* ===================== Lightbox ===================== */
.gallery .tile img,.strip figure img,.ba-card img{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  background:rgba(7,20,28,.93);padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:94vw;max-height:86vh;width:auto;height:auto;border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.lightbox-cap{position:absolute;left:0;right:0;bottom:22px;text-align:center;color:#fff;font-weight:600;
  font-size:.95rem;padding:0 24px;text-shadow:0 1px 6px rgba(0,0,0,.7)}
.lightbox-close{position:absolute;top:16px;right:20px;width:46px;height:46px;border:none;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox-close:hover{background:rgba(255,255,255,.28)}

/* ===================== Mobile gallery / strip polish ===================== */
@media (max-width:760px){
  .tb-logo{height:66px;padding:11px 16px;flex:1 1 40%}
  .tb-logo img{max-height:38px}
  .gallery{gap:10px}
  .tile img{aspect-ratio:1/1}
  .tile figcaption{font-size:.7rem;line-height:1.18;padding:24px 10px 9px;letter-spacing:0;
    background:linear-gradient(0deg,rgba(7,31,43,.9),rgba(7,31,43,.5) 42%,rgba(7,31,43,0))}
  .strip{gap:10px}
  .strip figcaption{font-size:.72rem;line-height:1.18;padding:18px 10px 9px}
}

/* ===================== Google reviews ===================== */
.section.reviews{background:var(--navy);color:#fff;text-align:center}
.reviews-inner{max-width:740px;margin:0 auto}
.g-google{font-weight:700;font-size:1.15rem;letter-spacing:.3px;margin:0 0 8px;color:#fff}
.g-google .b{color:#4285F4}.g-google .r{color:#EA4335}.g-google .y{color:#FBBC05}.g-google .g{color:#34A853}
.reviews .stars{color:#FBBC05;font-size:2.1rem;letter-spacing:4px;line-height:1;margin:4px 0 10px}
.reviews-score{font-size:1.25rem;margin:0 0 4px;color:rgba(255,255,255,.92)}
.reviews-score strong{color:#fff;font-weight:800}
.reviews-sub{color:rgba(255,255,255,.74);margin:10px auto 22px;max-width:600px}
.reviews-cta{display:flex;justify-content:center}
.reviews-leave{margin:16px 0 0;color:rgba(255,255,255,.62);font-size:.9rem}
.reviews-leave a{color:#86d0da;text-decoration:underline}
@media (max-width:760px){.reviews .stars{font-size:1.8rem;letter-spacing:3px}.reviews-score{font-size:1.1rem}}

/* ===================== Form status message ===================== */
.form-status{margin:14px 0 0;padding:11px 14px;border-radius:8px;font-weight:600;font-size:.92rem}
.form-status.ok{background:#e7f4ea;color:#1d7a3c;border:1px solid #bfe3cb}
.form-status.err{background:#fdeaea;color:#b42318;border:1px solid #f3c4c2}
