/* =====================================================
   DUNWELL ROOFING & PAVING LLC — Main Stylesheet
   ===================================================== */

/* === RESET & BASE === */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;color:#111;background:#fff;font-size:15px;line-height:1.6}

/* === SMOOTH SCROLL === */
html{scroll-behavior:smooth}

/* === NAVIGATION === */
.nav{background:#E8920A;padding:0 2.5rem;display:flex;align-items:center;justify-content:space-between;height:68px;position:sticky;top:0;z-index:300}
.nav-left{display:flex;align-items:center}
.nav-logo{height:72px;width:auto;object-fit:contain;filter:drop-shadow(0 0 3px white) drop-shadow(0 0 6px white)}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-size:13px;color:#1a2744;text-decoration:none;font-weight:600;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-cta{background:#1a2744;color:#fff;padding:.55rem 1.25rem;font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap}

/* === HERO === */
.hero{position:relative;height:600px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.hi{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.4)}
.ho{position:absolute;inset:0;background:rgba(15,25,50,.55)}
.hc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;z-index:2}
.hc h1{font-size:3.4rem;font-weight:900;color:#fff;line-height:1.05;letter-spacing:-.02em;margin-bottom:.5rem}
.hc .hs{font-size:.85rem;color:rgba(255,255,255,.55);letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.75rem}
.hc .hp{font-size:.72rem;color:rgba(255,255,255,.3);font-style:italic;margin-top:1rem}
.ha{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.bw{background:#fff;color:#1a2744;padding:.85rem 2rem;font-size:13px;font-weight:800;text-decoration:none;border:none;cursor:pointer;letter-spacing:.05em;text-transform:uppercase}
.bo{background:#E8920A;color:#fff;padding:.85rem 2rem;font-size:13px;font-weight:800;text-decoration:none;border:none;cursor:pointer;letter-spacing:.05em;text-transform:uppercase}

/* === INTERIOR HERO (sub-pages) === */
.ih{position:relative;height:380px;overflow:hidden}
.ih img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 70%;filter:brightness(.4)}
.iho{position:absolute;inset:0;background:rgba(26,39,68,.6)}
.ihc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;z-index:2}
.ihc h1{font-size:2.2rem;font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:.35rem}
.ihc p{font-size:.8rem;color:rgba(255,255,255,.45);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.75rem}
.ihc a{color:#E8920A;font-weight:700;font-size:1rem;text-decoration:none}

/* === TRUST STRIP === */
.ts-strip{background:#fff;border-bottom:1px solid #f0ece4;padding:1.25rem 2.5rem;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:#333}
.ticon{width:36px;height:36px;background:#E8920A;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:900;flex-shrink:0}
.titext div:first-child{font-weight:800;color:#111;font-size:13px}
.titext div:last-child{font-size:11px;color:#999}
.tdiv{width:1px;height:36px;background:#eee}

/* === SECTIONS === */
.sec{padding:5rem 2.5rem}
.sec-w{background:#fff}
.sec-o{background:#f7f5f0}
.sec-n{background:#1a2744}
.sec h2{font-size:2rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.5rem;line-height:1.15}
.sec-n h2{color:#fff}
.sec-sub{font-size:.95rem;color:#888;line-height:1.75;max-width:520px;margin-bottom:3.5rem}
.sec-n .sec-sub{color:rgba(255,255,255,.45)}

/* === SERVICES GRID === */
.ng{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:#e0dbd0}
.nc{position:relative;overflow:hidden;cursor:pointer;height:340px;display:block;text-decoration:none}
.nc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .4s;filter:brightness(.5)}
.nc:hover img{transform:scale(1.06);filter:brightness(.35)}
.ncb{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem 1.75rem;z-index:2}
.nctag{font-size:9px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#E8920A;margin-bottom:6px}
.nctitle{font-size:1.2rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:.5rem}
.nclink{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);text-decoration:none;opacity:0;transition:opacity .2s}
.nc:hover .nclink{opacity:1;color:#E8920A}

/* === OUR STORY === */
.ss{display:grid;grid-template-columns:1fr 1fr;min-height:500px}
.si{display:block;background:#E8920A;padding:4px}
.si img{width:100%;height:100%;object-fit:cover;display:block;min-height:500px}
.sc{background:#1a2744;padding:4.5rem 3.5rem;display:flex;flex-direction:column;justify-content:center}
.sc h2{font-size:1.9rem;font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:2rem;line-height:1.15}
.sitem{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-start}
.ssq{width:8px;height:8px;background:#E8920A;flex-shrink:0;margin-top:7px}
.sitem h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#E8920A;margin-bottom:3px}
.sitem p{font-size:.87rem;color:rgba(255,255,255,.5);line-height:1.75}

/* === DUNWELL DIFFERENCE CARDS === */
.wg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.wc{background:#fff;padding:2rem;border-bottom:3px solid transparent;transition:border-color .2s,box-shadow .2s}
.wc:hover{border-bottom-color:#E8920A;box-shadow:0 8px 24px rgba(0,0,0,.07)}
.wnum{font-size:2.5rem;font-weight:900;color:#f0ece4;line-height:1;margin-bottom:.75rem}
.wc h4{font-size:.95rem;font-weight:800;color:#111;margin-bottom:.4rem}
.wc p{font-size:.82rem;color:#777;line-height:1.65}

/* === TESTIMONIALS === */
.tsec{background:#1a2744;padding:5rem 2.5rem}
.tsec h2{font-size:2rem;font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:.5rem}
.tsub{font-size:.95rem;color:rgba(255,255,255,.4);margin-bottom:1.5rem}
.pr{display:flex;gap:1rem;margin-bottom:2.5rem;flex-wrap:wrap}
.pb{font-size:12px;font-weight:700;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:6px;padding:.55rem 1rem;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
.pb .star{color:#E8920A}
.tcar{overflow:hidden}
.ttrack{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.ts{min-width:50%;padding:0 .75rem}
.tc{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:2rem;border-top:2px solid #E8920A;height:100%}
.tstars{color:#E8920A;font-size:.78rem;letter-spacing:3px;margin-bottom:1rem}
.tq{font-size:.92rem;color:rgba(255,255,255,.6);line-height:1.85;font-style:italic;margin-bottom:1.5rem}
.tn{font-size:.8rem;font-weight:800;color:#fff;letter-spacing:.06em;text-transform:uppercase}
.tp{font-size:.72rem;color:rgba(255,255,255,.25);letter-spacing:.06em;margin-top:3px}
.tnav{display:flex;align-items:center;gap:1.5rem;margin-top:2.5rem}
.tnbtn{background:none;border:none;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);cursor:pointer;padding:0}
.tnbtn:hover{color:#E8920A}
.tdots{display:flex;gap:7px;align-items:center}
.td{width:26px;height:2px;background:rgba(255,255,255,.15);border:none;cursor:pointer;padding:0;transition:background .2s,width .2s}
.td.active{background:#E8920A;width:42px}

/* === GALLERY === */
.gs{padding:4rem 2.5rem}
.gs h2{font-size:1.75rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.4rem}
.gs p{font-size:.9rem;color:#888;margin-bottom:2rem}
.gg{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:4px;grid-auto-flow:dense}
.gi{position:relative;overflow:hidden;cursor:pointer}
.gi.tall{grid-row:span 2}
.gi img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s,filter .4s;filter:brightness(.85)}
.gi:hover img{transform:scale(1.04);filter:brightness(.5)}
.gov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.25rem;opacity:0;transition:opacity .3s}
.gi:hover .gov{opacity:1}
.gtag{font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#E8920A;margin-bottom:4px}
.glabel{font-size:.88rem;font-weight:700;color:#fff;line-height:1.3}

/* === LOCATION STRIP === */
.loc{background:#C8870A;padding:.65rem 2.5rem;font-size:11px;font-weight:700;color:rgba(255,255,255,.9);letter-spacing:.1em;text-transform:uppercase}

/* === SERVICE PAGE DETAIL === */
.dw{display:grid;grid-template-columns:1fr 1fr;min-height:440px}
.dt{padding:4.5rem 3.5rem;display:flex;flex-direction:column;justify-content:center;background:#fff}
.dt .tag{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:#C8960A;padding:6px 16px;border-radius:4px;margin-bottom:1.25rem;display:inline-block;width:fit-content}
.dt h2{font-size:1.75rem;font-weight:900;color:#111;margin-bottom:1rem;line-height:1.15;letter-spacing:-.02em}
.dt p{font-size:.88rem;color:#666;line-height:1.8;margin-bottom:1rem}
.dt ul{margin:0 0 1.5rem 0;list-style:none}
.dt ul li{font-size:.88rem;color:#555;margin-bottom:8px;padding-left:1.25rem;position:relative;line-height:1.5}
.dt ul li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;background:#E8920A}
.di{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:#eae6de}
.di img{width:100%;height:340px;object-fit:cover;object-position:center bottom;display:block}
.bp{background:#2a2a2a;color:#fff;padding:.75rem 1.75rem;font-size:13px;font-weight:700;text-decoration:none;border:none;cursor:pointer;letter-spacing:.02em;border-radius:6px;margin-top:1.25rem;display:inline-block}
.bp:hover{background:#111}

/* === WHY CHOOSE US === */
.wi{padding:4.5rem 2.5rem;background:#f7f5f0}
.wi h2{font-size:1.75rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:2.5rem}

/* === PHOTO CTA BANNER === */
.pc{position:relative;height:420px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.pc>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.35)}
.pcc{position:relative;z-index:2;padding:2rem}
.pcc h2{font-size:3rem;font-weight:900;color:#fff;letter-spacing:-.03em;margin-bottom:.5rem;line-height:1.1}
.pcc h2 em{font-style:normal;color:#E8920A}
.pcc p{font-size:1rem;color:rgba(255,255,255,.6);margin-bottom:2rem}
.pca{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* === VIDEO SECTION === */
.vid-sec{padding:5rem 2.5rem;background:#f7f5f0}
.vid-sec h2{font-size:2rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.5rem}
.vid-sec .vid-sub{font-size:.95rem;color:#888;margin-bottom:2.5rem}
.vid-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;align-items:start}
.vid-main iframe,.vid-main .vid-placeholder{width:100%;aspect-ratio:16/9;display:block;border:none}
.vid-placeholder{background:#1a2744;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;aspect-ratio:16/9;cursor:pointer;position:relative;overflow:hidden}
.vid-placeholder::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.3)}
.vid-placeholder img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.vid-play{position:relative;z-index:2;width:70px;height:70px;background:#E8920A;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:transform .2s}
.vid-placeholder:hover .vid-play{transform:scale(1.1)}
.vid-play-icon{width:0;height:0;border-top:14px solid transparent;border-bottom:14px solid transparent;border-left:22px solid #fff;margin-left:5px}
.vid-placeholder span{position:relative;z-index:2;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.vid-sidebar{display:flex;flex-direction:column;gap:1rem}
.vid-thumb{display:flex;gap:.75rem;align-items:center;background:#fff;padding:.75rem;cursor:pointer;border-left:3px solid transparent;transition:border-color .2s}
.vid-thumb:hover,.vid-thumb.active{border-left-color:#E8920A}
.vid-thumb-img{width:80px;height:55px;object-fit:cover;flex-shrink:0;background:#e0dbd0}
.vid-thumb-info h5{font-size:.78rem;font-weight:800;color:#111;margin-bottom:3px}
.vid-thumb-info p{font-size:.7rem;color:#999}
.vid-cta-strip{background:#1a2744;padding:1.5rem 2.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.vid-cta-strip p{font-size:.9rem;color:rgba(255,255,255,.6)}
.vid-cta-strip strong{color:#fff}

/* === CONTACT === */
.cw{display:grid;grid-template-columns:1fr 1fr;min-height:600px}
.cl{background:#1a2744;padding:4.5rem 3.5rem;display:flex;flex-direction:column;justify-content:center}
.cl h2{font-size:1.85rem;font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:2rem;line-height:1.15}
.cdg{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2rem;margin-bottom:2.5rem}
.cd h4{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#E8920A;margin-bottom:4px}
.cd p{font-size:.9rem;color:rgba(255,255,255,.55)}
.cp{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:#E8920A;padding:3px}
.cp img{width:100%;height:145px;object-fit:cover;display:block}
.cr{background:#f7f5f0;padding:4.5rem 3.5rem;display:flex;flex-direction:column;justify-content:center}
.cr h2{font-size:1.5rem;font-weight:900;color:#111;margin-bottom:.25rem}
.fn{font-size:.8rem;color:#bbb;margin-bottom:2rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.5rem}
.ff{display:flex;flex-direction:column;margin-bottom:1rem}
.ff label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#aaa;margin-bottom:6px}
.ff input,.ff textarea{background:#fff;border:1.5px solid #e0dbd0;font-size:14px;padding:.65rem .9rem;outline:none;font-family:inherit;color:#111;transition:border-color .2s}
.ff input:focus,.ff textarea:focus{border-color:#E8920A}
.ff textarea{resize:none;height:75px}
.cbg p{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#aaa;margin-bottom:10px}
.cb{display:flex;align-items:center;gap:8px;font-size:13px;color:#555;margin-bottom:7px;cursor:pointer}
.cb input{accent-color:#E8920A}
.sbtn{width:100%;background:#E8920A;color:#fff;padding:.95rem;font-size:13px;font-weight:800;border:none;cursor:pointer;letter-spacing:.07em;text-transform:uppercase;margin-top:.75rem}

/* === FOOTER === */
.footer{background:#0d1a2e}
.footer-top{padding:4.5rem 2.5rem;display:grid;grid-template-columns:1.5fr 2fr;gap:4rem}
.footer-logo{height:60px;margin-bottom:1rem;display:block}
.footer-brand p{font-size:.82rem;color:rgba(255,255,255,.3);line-height:1.8;margin-bottom:1rem}
.footer-stars{display:flex;flex-direction:column;gap:4px}
.footer-stars span{font-size:11px;font-weight:700;color:#E8920A;letter-spacing:.05em}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer-cols h4{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:1.1rem}
.footer-cols a{display:block;font-size:13px;color:rgba(255,255,255,.38);text-decoration:none;margin-bottom:7px}
.footer-cols a:hover{color:#E8920A}
.footer-bar{background:#070f1c;padding:1.1rem 2.5rem;display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.15)}

/* === STICKY CTA === */
.sca{position:fixed;bottom:0;right:0;background:#1a2744;display:flex;align-items:center;gap:14px;padding:.75rem 1.5rem;z-index:500;border-top:2px solid #E8920A}
.sca span{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.sca a{font-size:14px;font-weight:800;color:#E8920A;text-decoration:none}

/* === THANK YOU PAGE === */
.ty{min-height:65vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5rem 2rem;background:#fff}
.tychk{width:70px;height:70px;background:#E8920A;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;font-size:2rem;color:#fff;font-weight:900}
.ty h2{font-size:2.5rem;font-weight:900;color:#111;margin-bottom:.75rem;letter-spacing:-.02em}
.ty p{font-size:.92rem;color:#777;max-width:440px;line-height:1.8;margin-bottom:.5rem}
.typh{font-size:1.5rem;font-weight:900;color:#E8920A;margin:1.5rem 0 .25rem}
.tya{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap;justify-content:center}
.tyg{background:transparent;color:#aaa;padding:.85rem 2rem;font-size:13px;font-weight:600;border:1.5px solid #e0dbd0;cursor:pointer;letter-spacing:.04em;text-transform:uppercase}

/* === VIDEO SECTION (Roofing page) === */
.vid-sec{padding:5rem 2.5rem;background:#f7f5f0}
.vid-sec h2{font-size:2rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.5rem}
.vid-sub{font-size:.95rem;color:#888;margin-bottom:2.5rem}

/* Two vertical (9:16) videos side by side */
.vid-pair{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:700px;margin:0 auto}
.vid-card{display:flex;flex-direction:column;gap:.75rem}
.vid-card video{width:100%;aspect-ratio:9/16;object-fit:cover;background:#111;display:block;border-radius:4px}
.vid-label{display:flex;flex-direction:column;gap:4px}
.vid-tag{font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:#E8920A;padding:4px 10px;border-radius:3px;display:inline-block;width:fit-content}
.vid-label p{font-size:.82rem;color:#777}
.vid-note{margin-top:2rem;font-size:.9rem;color:#777;text-align:center}
.vid-note a{color:#E8920A;font-weight:700;text-decoration:none}
.vid-note a:hover{text-decoration:underline}

/* === GALLERY — Before & After Layout === */
.gal-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.5rem}
.gal-intro{text-align:center;margin-bottom:3.5rem}
.gal-intro h1{font-size:2.2rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.5rem}
.gal-intro p{font-size:.95rem;color:#888;margin-bottom:2rem}

/* Filter buttons */
.gal-filters{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.gal-btn{background:#fff;border:1.5px solid #e0dbd0;color:#555;padding:.55rem 1.25rem;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.gal-btn:hover,.gal-btn.active{background:#E8920A;border-color:#E8920A;color:#fff}

/* Section */
.gal-section{margin-bottom:5rem}
.gal-section-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0ece4}
.gal-section-header h2{font-size:1.5rem;font-weight:900;color:#111;letter-spacing:-.02em;margin-bottom:.3rem}
.gal-section-header p{font-size:.88rem;color:#999}

/* Before/After grid */
.ba-grid{display:flex;flex-direction:column;gap:3rem}
.ba-pair{background:#fff;border:1px solid #f0ece4;border-radius:4px;overflow:hidden}
.ba-tag{background:#1a2744;color:#E8920A;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:.6rem 1.25rem}
.ba-images{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:0;background:#f7f5f0}

/* Individual image panels */
.ba-img{position:relative;overflow:hidden}
.ba-img img{width:100%;height:320px;object-fit:cover;display:block;transition:transform .4s}
.ba-img:hover img{transform:scale(1.03)}

/* Before/After labels */
.ba-label{position:absolute;bottom:0;left:0;right:0;padding:.6rem 1rem;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.ba-before{background:rgba(50,50,50,.75);color:rgba(255,255,255,.8)}
.ba-after{background:rgba(232,146,10,.85);color:#fff}

/* Arrow divider */
.ba-divider{display:flex;align-items:center;justify-content:center;width:48px;background:#1a2744;height:320px;flex-shrink:0}
.ba-divider span{color:#E8920A;font-size:1.5rem;font-weight:900}

/* Singles grid (no before available) */
.gal-singles{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gal-single{position:relative;overflow:hidden;border-radius:4px}
.gal-single img{width:100%;height:260px;object-fit:cover;display:block;transition:transform .4s,filter .3s}
.gal-single:hover img{transform:scale(1.04);filter:brightness(.75)}
.gal-single span{position:absolute;bottom:0;left:0;right:0;background:rgba(232,146,10,.9);color:#fff;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.6rem 1rem;transform:translateY(100%);transition:transform .3s}
.gal-single:hover span{transform:translateY(0)}

/* =====================================================
   MOBILE CSS — 768px and below
   ===================================================== */
@media (max-width: 768px) {

  /* Nav */
  .nav{padding:0 1.25rem;height:60px}
  .nav-logo{height:52px}
  .nav-links{display:none}
  .nav-cta{font-size:12px;padding:.45rem .9rem}

  /* Hero */
  .hero{height:480px;grid-template-columns:1fr}
  .hero .hi:last-of-type{display:none}
  .hc h1{font-size:2.2rem}
  .hc .hs{font-size:.75rem}
  .ha{flex-direction:column;align-items:center}
  .bw,.bo{width:220px;text-align:center}

  /* Interior hero */
  .ih{height:260px}
  .ihc h1{font-size:1.6rem}

  /* Trust strip */
  .ts-strip{gap:1.25rem;padding:1.25rem 1rem;justify-content:flex-start}
  .tdiv{display:none}

  /* Sections */
  .sec{padding:3rem 1.25rem}

  /* Services grid - stack to 2 columns on mobile */
  .ng{grid-template-columns:1fr 1fr}
  .nc{height:240px}

  /* Our Story */
  .ss{grid-template-columns:1fr}
  .si img{min-height:300px}
  .sc{padding:2.5rem 1.5rem}

  /* Dunwell Difference cards */
  .wg{grid-template-columns:1fr}
  .wi{padding:3rem 1.25rem}

  /* Photo CTA */
  .pcc h2{font-size:2rem}

  /* Testimonials */
  .tsec{padding:3rem 1.25rem}
  .ts{min-width:100%}
  .pr{gap:.5rem}

  /* Service detail pages */
  .dw{grid-template-columns:1fr}
  .di{grid-template-columns:1fr}
  .di img{height:260px}
  .dt{padding:2.5rem 1.5rem}

  /* Contact page */
  .cw{grid-template-columns:1fr}
  .cl{padding:2.5rem 1.5rem}
  .cr{padding:2.5rem 1.5rem}
  .cdg{grid-template-columns:1fr}
  .cp{grid-template-columns:1fr 1fr}
  .fr{grid-template-columns:1fr}

  /* Gallery */
  .gal-wrap{padding:2rem 1.25rem}
  .gal-filters{gap:.5rem}
  .gal-btn{font-size:11px;padding:.45rem .9rem}
  .ba-images{grid-template-columns:1fr}
  .ba-divider{display:none}
  .ba-img img{height:220px}
  .gal-singles{grid-template-columns:1fr 1fr}

  /* Footer */
  .footer-top{grid-template-columns:1fr;gap:2rem;padding:3rem 1.25rem}
  .footer-cols{grid-template-columns:1fr 1fr;gap:1.5rem}
  .footer-bar{flex-direction:column;gap:.5rem;font-size:10px;padding:1rem 1.25rem}

  /* Sticky CTA */
  .sca{padding:.6rem 1rem;gap:10px}
  .sca a{font-size:13px}

  /* Video section */
  .vid-pair{grid-template-columns:1fr;max-width:360px}

  /* Location strip */
  .loc{font-size:10px;padding:.65rem 1.25rem}
}

/* Small phones */
@media (max-width: 480px) {
  .ng{grid-template-columns:1fr}
  .nc{height:280px}
  .hc h1{font-size:1.8rem}
  .footer-cols{grid-template-columns:1fr}
  .gal-singles{grid-template-columns:1fr}
}

/* =====================================================
   HAMBURGER MENU
   ===================================================== */
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:26px;height:20px;background:none;border:none;cursor:pointer;padding:0;margin-left:auto}
.hamburger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* Mobile nav drawer */
.nav-links.mobile-open{display:flex}

@media (max-width: 768px) {
  .hamburger{display:flex}
  .nav-cta{display:none} /* hide call button in nav on mobile - sticky CTA handles it */
  .nav-links{
    display:none;
    position:fixed;
    top:60px;
    left:0;
    right:0;
    flex-direction:column;
    background:#1a2744;
    padding:1.5rem;
    gap:0;
    z-index:299;
    box-shadow:0 8px 24px rgba(0,0,0,.3);
  }
  .nav-links a{
    color:#fff;
    font-size:15px;
    font-weight:700;
    padding:1rem 0;
    border-bottom:1px solid rgba(255,255,255,.08);
    text-decoration:none;
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a.active{color:#E8920A}
  .nav-links a:hover{color:#E8920A}
}

/* === IMAGE LOADING — smooth placeholder === */
img{background:#e8e4dc}
.hi{background:#1a2744}
.nc img{background:#1a2744}
.ih img{background:#1a2744}