/* MJN Carpentry — Propeller demo build. Editorial tradie reference (tradie/tradie1). */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#6C300C; --brand-d:#4A1F08; --brand-l:#8A4A22;
  --ink:#1d1813; --bg:#ffffff; --paper:#f6f1ea; --paper-d:#efe7dc;
  --line:#e7ded2; --muted:#726a60; --char:#0a0a0a;
  --max:1180px; --r:14px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:#fff;line-height:1.62;
  font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.07;letter-spacing:-0.03em;font-weight:800}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.sect{padding:96px 0}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);
  display:flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--brand);display:inline-block}
.eyebrow.c{justify-content:center}
.muted{color:var(--muted)}

/* ---------- NAV ---------- */
.navhost{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;justify-content:center;
  padding:18px 16px;pointer-events:none}
.nav-pill{pointer-events:auto;display:inline-flex;align-items:center;gap:28px;width:fit-content;
  margin:0 auto;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:999px;padding:9px 9px 9px 20px;
  box-shadow:0 8px 30px rgba(40,20,5,.10)}
.nav-brand{display:flex;align-items:center;gap:9px;font-weight:800;letter-spacing:-.02em;font-size:15.5px}
.nav-brand img{height:30px;width:auto}
.nav-links{display:flex;gap:24px;margin:0;list-style:none}
.nav-links a{font-size:14.5px;font-weight:600;color:#473d33;padding:6px 2px;transition:color .15s}
.nav-links a:hover{color:var(--brand)}
.nav-cta{background:var(--brand);color:#fff;font-weight:700;font-size:14px;padding:11px 20px;
  border-radius:999px;display:inline-flex;align-items:center;gap:7px;transition:background .15s}
.nav-cta:hover{background:var(--brand-d)}
.nav-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;
  border:none;background:var(--brand);border-radius:999px;cursor:pointer}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:17px;
  height:2px;background:#fff;border-radius:2px;position:relative;transition:.2s}
.nav-toggle span::before{position:absolute;top:-5.5px}
.nav-toggle span::after{position:absolute;top:5.5px}
.mobile-menu{position:fixed;inset:0;z-index:95;background:rgba(20,12,4,.55);
  opacity:0;pointer-events:none;transition:opacity .22s}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-panel{position:absolute;top:0;right:0;width:min(86vw,360px);height:100%;background:#fff;
  padding:30px 26px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .26s}
.mobile-menu.open .mobile-panel{transform:translateX(0)}
.mobile-panel .mp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.mobile-panel .mp-head img{height:38px}
.mp-close{border:none;background:var(--paper);width:40px;height:40px;border-radius:999px;font-size:20px;cursor:pointer;color:var(--ink)}
.mobile-panel a.ml{padding:15px 4px;font-weight:700;font-size:18px;border-bottom:1px solid var(--line)}
.mobile-panel .mp-call{margin-top:18px;background:var(--brand);color:#fff;text-align:center;
  padding:15px;border-radius:12px;font-weight:700}
.mobile-panel .mp-phone{margin-top:10px;text-align:center;font-weight:800;font-size:20px;color:var(--brand)}
.nav-links,.nav-pill .nav-cta.desk{display:flex}

/* ---------- HERO ---------- */
.hero{padding:150px 0 0;text-align:center;background:#fff}
.hero h1{font-size:clamp(2.7rem,7vw,5.3rem);max-width:14ch;margin:18px auto 0}
.hero h1 .lt{color:var(--muted);font-weight:800}
.hero p.sub{max-width:48ch;margin:22px auto 0;font-size:1.12rem;color:var(--muted)}
.hero-cta{display:flex;gap:14px;justify-content:center;margin:30px auto 0;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;
  padding:15px 28px;border-radius:999px;transition:.16s;cursor:pointer;border:1.6px solid transparent}
.btn-dark{background:var(--char);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-brand{background:var(--brand);color:#fff}
.btn-brand:hover{background:var(--brand-d);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:#fff}
.btn-ghost:hover{background:var(--ink);color:#fff}
.hero-figure{position:relative;max-width:var(--max);margin:54px auto 0;padding:0 24px}
.hero-figure .hf-img{border-radius:20px 20px 0 0;overflow:hidden;aspect-ratio:16/8.4}
.hero-figure .hf-img img{width:100%;height:100%;object-fit:cover}
.hero-pill{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  background:rgba(10,10,10,.86);backdrop-filter:blur(8px);color:#fff;border-radius:999px;
  padding:11px 22px;display:flex;gap:16px;align-items:center;font-size:13.5px;font-weight:600;white-space:nowrap}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:#7ED957}
.hero-pill b{font-weight:800}
.hero-pill .sep{width:1px;height:16px;background:rgba(255,255,255,.25)}

/* ---------- TRUST RAIL ---------- */
.trust{background:var(--char);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust .ti{padding:34px 26px;border-right:1px solid rgba(255,255,255,.12);text-align:center}
.trust .ti:last-child{border-right:none}
.trust .ti .big{font-size:2.5rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.trust .ti .lbl{margin-top:9px;font-size:13px;color:#b9b0a4;font-weight:500;line-height:1.45}

/* ---------- SECTION HEADING ---------- */
.shead{max-width:var(--max);margin:0 auto}
.shead h2{font-size:clamp(2rem,4.4vw,3.3rem);margin-top:14px}
.shead h2 .lt{color:var(--muted)}
.shead .lead{margin-top:16px;max-width:46ch;color:var(--muted);font-size:1.06rem}
.shead.split{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:end}
.shead.split .lead{margin-top:0}

/* ---------- SERVICES GRID ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.svc-card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;
  display:flex;flex-direction:column;transition:.18s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(40,20,5,.13);border-color:#d8cab6}
.svc-card .ph{aspect-ratio:3/2;overflow:hidden}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.svc-card:hover .ph img{transform:scale(1.05)}
.svc-card .bd{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.svc-card .num{font-size:12px;font-weight:700;color:var(--brand);letter-spacing:.12em}
.svc-card h3{font-size:1.32rem;margin:8px 0 8px}
.svc-card p{font-size:.96rem;color:var(--muted);flex:1}
.svc-card .more{margin-top:16px;font-weight:700;font-size:14px;color:var(--brand);display:inline-flex;gap:6px}

/* ---------- SPLIT FEATURE ---------- */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.feat.rev .fx-media{order:2}
.fx-media{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3.4}
.fx-media img{width:100%;height:100%;object-fit:cover}
.fx-body h2{font-size:clamp(1.9rem,3.8vw,2.9rem);margin-top:14px}
.fx-body h2 .lt{color:var(--muted)}
.fx-body p{margin-top:16px;color:var(--muted)}
.vp-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:26px}
.vp-grid .vp{background:#fff;padding:22px}
.vp-grid .vp h4{font-size:1.05rem}
.vp-grid .vp p{margin-top:6px;font-size:.9rem;color:var(--muted)}

/* ---------- PROCESS ---------- */
.proc{background:var(--paper)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:46px}
.proc-grid .ps{padding:30px 26px 30px 0;border-top:2px solid var(--ink)}
.proc-grid .ps:not(:last-child){padding-right:30px}
.proc-grid .ps .st{font-size:11.5px;font-weight:700;letter-spacing:.14em;color:var(--brand);text-transform:uppercase}
.proc-grid .ps h4{font-size:1.18rem;margin:12px 0 9px}
.proc-grid .ps p{font-size:.92rem;color:var(--muted)}

/* ---------- CLIENT VOICE ---------- */
.voice{background:#fff}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.voice-card{background:var(--paper);border-radius:var(--r);padding:30px 26px;display:flex;flex-direction:column}
.voice-card .qm{font-size:3rem;line-height:.6;color:var(--brand);font-weight:800;font-family:Georgia,serif;height:26px}
.voice-card p{font-size:1rem;color:#3a332b;flex:1;margin-top:6px}
.voice-card .who{margin-top:18px;display:flex;align-items:center;gap:12px}
.voice-card .av{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.voice-card .who b{font-size:.96rem}
.voice-card .who span{display:block;font-size:12.5px;color:var(--muted);font-weight:500}

/* ---------- COVERAGE ---------- */
.cover{background:var(--char);color:#fff}
.cover-top{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:end}
.cover-top h2{font-size:clamp(2rem,4.2vw,3.1rem)}
.cover-top h2 .lt{color:#8c8478}
.cover-top .lead{color:#b7aea2}
.cover-main{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;margin-top:46px;align-items:center}
.cover-map{border:1px solid rgba(255,255,255,.16);border-radius:var(--r);padding:20px;background:#121110}
.cover-areas h3{font-size:1.4rem}
.cover-areas h3 .lt{color:#8c8478}
.area-cols{margin-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:0 30px}
.area-cols .ac{display:flex;justify-content:space-between;padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.1);font-size:14.5px}
.area-cols .ac span{color:#8c8478;font-size:12px}
.cover-note{margin-top:18px;font-size:13.5px;color:#8c8478}

/* ---------- GALLERY ---------- */
.gal{background:var(--paper)}
.gal-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:42px}
.gal-mosaic .gi{overflow:hidden;border-radius:10px}
.gal-mosaic .gi img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal-mosaic .gi:hover img{transform:scale(1.06)}
.gal-mosaic .w2{grid-column:span 2}
.gal-mosaic .h2{grid-row:span 2}

/* ---------- CTA BAND ---------- */
.ctaband{background:var(--brand);color:#fff;text-align:center}
.ctaband h2{font-size:clamp(2rem,4.4vw,3.2rem)}
.ctaband h2 .lt{color:rgba(255,255,255,.55)}
.ctaband p{margin:16px auto 0;max-width:44ch;color:rgba(255,255,255,.84)}
.ctaband .hero-cta{margin-top:28px}
.ctaband .btn-ghost{border-color:#fff;color:#fff;background:transparent}
.ctaband .btn-ghost:hover{background:#fff;color:var(--brand)}
.ctaband .btn-light{background:#fff;color:var(--brand)}
.ctaband .btn-light:hover{background:var(--char);color:#fff}

/* ---------- CONTACT ---------- */
.contact{background:#fff}
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:48px}
.cx-rows{margin-top:26px;border-top:1px solid var(--line)}
.cx-row{display:flex;align-items:center;gap:16px;padding:20px 4px;border-bottom:1px solid var(--line)}
.cx-row .ix{font-size:11px;font-weight:700;color:var(--brand);width:24px}
.cx-row .ck{display:block;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cx-row .cv{display:block;font-size:1.12rem;font-weight:700;margin-top:3px}
.form-card{background:var(--char);border-radius:18px;padding:34px}
.form-card .fc-tag{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:#9a9189;font-weight:700}
.form-card label{display:block;font-size:13px;color:#b9b0a4;font-weight:600;margin:18px 0 7px}
.form-card input,.form-card textarea{width:100%;background:#1c1a18;border:1px solid #34302b;
  border-radius:10px;padding:13px 14px;color:#fff;font-family:inherit;font-size:15px}
.form-card input:focus,.form-card textarea:focus{outline:2px solid var(--brand-l);border-color:transparent}
.form-card textarea{min-height:104px;resize:vertical}
.form-card button{width:100%;margin-top:22px;background:var(--brand);color:#fff;border:none;
  padding:16px;border-radius:10px;font-weight:700;font-size:15px;cursor:pointer;transition:.16s}
.form-card button:hover{background:#fff;color:var(--brand)}
.form-note{margin-top:14px;font-size:12px;color:#8a8278;text-align:center}
.form-ok{display:none;background:#1c1a18;border:1px solid var(--brand-l);border-radius:10px;
  padding:16px;color:#fff;font-size:14px;margin-top:18px}

/* ---------- PAGE HERO (inner pages) ---------- */
.phero{padding:160px 0 70px;background:var(--paper)}
.phero .crumb{font-size:12.5px;color:var(--muted);font-weight:600}
.phero .crumb a:hover{color:var(--brand)}
.phero h1{font-size:clamp(2.3rem,5vw,4rem);margin-top:16px;max-width:18ch}
.phero h1 .lt{color:var(--muted)}
.phero p{margin-top:16px;max-width:52ch;color:var(--muted);font-size:1.08rem}

/* ---------- SERVICE PAGE ---------- */
.svc-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.svc-intro .si-media{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3.2}
.svc-intro .si-media img{width:100%;height:100%;object-fit:cover}
.svc-intro h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.svc-intro p{margin-top:14px;color:var(--muted)}
.chk{margin-top:20px;list-style:none;display:grid;gap:10px}
.chk li{display:flex;gap:11px;align-items:flex-start;font-size:.98rem}
.chk li::before{content:"";flex:none;width:20px;height:20px;border-radius:50%;background:var(--brand);
  margin-top:2px;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.4"><path d="M20 6L9 17l-5-5"/></svg>');
  background-repeat:no-repeat;background-position:center}
.svc-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:42px}
.svc-strip .gi{aspect-ratio:4/3;border-radius:10px;overflow:hidden}
.svc-strip .gi img{width:100%;height:100%;object-fit:cover}

/* ---------- FAQ / QA ---------- */
.qa{max-width:780px;margin:0 auto}
.qa details{border-bottom:1px solid var(--line);padding:4px 0}
.qa summary{cursor:pointer;list-style:none;padding:20px 40px 20px 0;font-weight:700;font-size:1.08rem;
  position:relative}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";position:absolute;right:6px;top:18px;font-size:1.5rem;color:var(--brand);font-weight:400}
.qa details[open] summary::after{content:"\2013"}
.qa details p{padding:0 40px 22px 0;color:var(--muted);font-size:.99rem}
.faq-cat{margin-top:54px}
.faq-cat:first-child{margin-top:0}
.faq-cat h2{font-size:1.5rem;padding-bottom:8px}

/* ---------- FOOTER ---------- */
.foot{background:var(--char);color:#cabfb2;padding:70px 0 0}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
.foot-brand img{height:46px;margin-bottom:14px}
.foot-brand p{font-size:13.5px;line-height:1.65;max-width:34ch}
.foot-nap{margin-top:16px;font-size:12.5px;color:#8c8478;line-height:1.7}
.foot-soc{display:flex;gap:10px;margin-top:16px}
.foot-soc a{width:38px;height:38px;border-radius:50%;border:1px solid #3a352f;display:flex;
  align-items:center;justify-content:center;transition:.16s}
.foot-soc a:hover{background:var(--brand);border-color:var(--brand)}
.foot-soc svg{width:17px;height:17px;fill:#cabfb2}
.foot-soc a:hover svg{fill:#fff}
.foot-col h5{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.foot-col a,.foot-col p{display:block;font-size:14px;padding:5px 0;color:#cabfb2}
.foot-col a:hover{color:#fff}
.foot-band{margin-top:54px;overflow:hidden;line-height:.8}
.foot-band span{font-size:clamp(3.5rem,15vw,12rem);font-weight:800;letter-spacing:-.05em;
  color:#211e1b;white-space:nowrap;display:block;padding:0 24px}
.foot-band span .lt{color:#2e2a25}
.foot-bot{border-top:1px solid #2a2620;margin-top:10px;padding:22px 0;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:#8c8478}
.footer-credit a{color:#cabfb2}
.footer-credit a:hover{color:#fff}

/* ---------- STICKY MOBILE CTA ---------- */
.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:80}
.sticky-cta a{flex:1;text-align:center;padding:15px 8px;font-weight:700;font-size:15px;color:#fff}
.sticky-cta .sc-call{background:var(--brand)}
.sticky-cta .sc-msg{background:#0a0a0a}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1023px){
  .nav-links{display:none}
  .nav-pill .nav-cta.desk{display:none}
  .shead.split,.cover-top{grid-template-columns:1fr;gap:18px}
  .feat{grid-template-columns:1fr;gap:30px}
  .feat.rev .fx-media{order:0}
  .cover-main{grid-template-columns:1fr;gap:28px}
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .svc-intro{grid-template-columns:1fr;gap:28px}
  .trust .wrap{grid-template-columns:1fr 1fr}
  .trust .ti:nth-child(2){border-right:none}
  .trust .ti:nth-child(1),.trust .ti:nth-child(2){border-bottom:1px solid rgba(255,255,255,.12)}
  .svc-grid,.voice-grid{grid-template-columns:1fr 1fr}
  .proc-grid{grid-template-columns:1fr 1fr}
  .proc-grid .ps{padding-right:24px!important}
}
@media(min-width:1024px){
  .nav-toggle{display:none!important}
}
@media(max-width:680px){
  .sect{padding:64px 0}
  .hero{padding:128px 0 0}
  .wrap{padding:0 20px}
  .hero-figure{padding:0 16px}
  .hero-figure .hf-img{border-radius:14px 14px 0 0;aspect-ratio:16/13}
  .hero-pill{font-size:11.5px;padding:9px 14px;gap:9px;flex-wrap:nowrap;max-width:92%}
  .hero-pill .sep:last-of-type,.hero-pill .x-hide{display:none}
  .svc-grid,.voice-grid,.proc-grid,.vp-grid,.area-cols,.svc-strip,.gal-mosaic{grid-template-columns:1fr}
  .gal-mosaic{grid-auto-rows:auto}
  .gal-mosaic .gi{aspect-ratio:3/2}
  .gal-mosaic .w2,.gal-mosaic .h2{grid-column:auto;grid-row:auto}
  .trust .wrap{grid-template-columns:1fr 1fr}
  .proc-grid .ps{border-top:2px solid var(--ink);padding:24px 0!important}
  .btn{padding:14px 22px}
  .hero-cta{gap:10px}
  .hero-cta .btn{flex:1;justify-content:center;min-width:140px}
  .foot-top{grid-template-columns:1fr 1fr;gap:28px}
  .foot-brand{grid-column:1/-1}
  .sticky-cta{display:flex}
  body{padding-bottom:54px}
  .form-card{padding:26px 22px}
  .phero{padding:120px 0 50px}
}
