/* Trygt Overvann AS — delt stilark for multi-page nettside */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
:root{
  --paper:#f4f1ec;--white:#ffffff;--ink:#1c1b18;--ink2:#3e3c37;--ink3:#82807a;
  --rule:#d8d3ca;--petro:#1b4d5e;--petro2:#26697d;--amber:#c07a2f;
  --serif:'EB Garamond',Georgia,serif;--sans:'Outfit',system-ui,sans-serif;
  --mono:'DM Mono',monospace;--max:1240px;--pad:clamp(1.25rem,5vw,4rem);
}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);transition:box-shadow .3s}
.nav.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.07)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);height:68px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;cursor:pointer;color:inherit}
.nav-logo{height:38px;width:38px;object-fit:contain}
.nav-name{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);letter-spacing:.01em;line-height:1.15}
.nav-name small{display:block;font-family:var(--mono);font-size:.58rem;color:var(--ink3);letter-spacing:.14em;text-transform:uppercase;font-weight:300;margin-top:1px}
.nav-links{display:flex;align-items:center;list-style:none;gap:2rem}
.nav-links a{font-size:.88rem;font-weight:400;color:var(--ink2);text-decoration:none;cursor:pointer;transition:color .2s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--petro)}
.nav-cta{background:var(--petro);color:var(--white);border:none;padding:.6rem 1.5rem;font-family:var(--sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s;text-decoration:none;display:inline-block}
.nav-cta:hover{background:var(--ink)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink)}

/* BREADCRUMBS */
.breadcrumb{max-width:var(--max);margin:0 auto;padding:1rem var(--pad) 0;font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.breadcrumb li{display:flex;align-items:center;gap:.5rem}
.breadcrumb li+li::before{content:"/";color:var(--rule)}
.breadcrumb a{color:var(--ink3);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--petro)}
.breadcrumb [aria-current="page"]{color:var(--ink2)}

/* HERO */
.hero{position:relative;height:92vh;min-height:600px;max-height:900px;overflow:hidden;display:flex;align-items:flex-end;padding-top:68px}
.hero-img{position:absolute;inset:0;background-image:url('../assets/Vann Bryggen.webp');background-size:cover;background-position:center 40%;filter:brightness(.72) saturate(.9);transition:transform 8s ease}
.hero:hover .hero-img{transform:scale(1.03)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(27,77,94,.88) 0%,rgba(27,77,94,.35) 45%,rgba(0,0,0,.08) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--max);width:100%;margin:0 auto;padding:0 var(--pad) clamp(3rem,6vw,5rem);display:grid;grid-template-columns:1fr 1fr;align-items:end;gap:3rem}
.hero-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:1.25rem}
.hero-title{font-family:var(--serif);font-size:clamp(2.2rem,5vw,4rem);font-weight:400;color:#fff;line-height:1.15;letter-spacing:-.01em;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:rgba(255,255,255,.75)}
.hero-desc{font-size:clamp(.9rem,1.5vw,1.05rem);color:rgba(255,255,255,.78);line-height:1.75;max-width:480px}
.hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:1rem}
.hero-stat-row{display:flex;gap:2rem}
.hero-stat{text-align:right;border-top:1px solid rgba(255,255,255,.2);padding-top:.75rem}
.hero-stat-val{font-family:var(--serif);font-size:2rem;font-weight:400;color:#fff;line-height:1}
.hero-stat-lbl{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:.3rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end}
.btn-hero-primary{background:#fff;color:var(--petro);border:none;padding:.85rem 2rem;font-family:var(--sans);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.btn-hero-primary:hover{background:var(--amber);color:#fff}
.btn-hero-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.45);padding:.85rem 2rem;font-family:var(--sans);font-size:.9rem;font-weight:400;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.btn-hero-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* SERVICES BAND */
.services-band{background:var(--white);padding:clamp(4rem,8vw,7rem) 0}
.services-band .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:clamp(2rem,4vw,3.5rem);padding-bottom:1rem;border-bottom:1px solid var(--rule)}
.section-eyebrow{font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.section-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--ink);margin-top:.4rem}
.section-link{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--petro);text-decoration:none;cursor:pointer;transition:color .2s;border-bottom:1px solid var(--rule);padding-bottom:2px}
.section-link:hover{color:var(--ink);border-color:var(--ink)}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:1px;background:var(--rule)}
.svc-card{background:var(--white);padding:2rem;cursor:pointer;transition:background .2s;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.svc-card:hover{background:var(--paper)}
.svc-card.featured{grid-row:1/3;display:flex;flex-direction:column;justify-content:flex-end;padding:0;min-height:440px}
.svc-card.featured .svc-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.62) saturate(.85);transition:transform .6s ease,filter .6s ease}
.svc-card.featured:hover .svc-img{transform:scale(1.04);filter:brightness(.72) saturate(.9)}
.svc-card.featured .svc-card-inner{position:relative;z-index:2;padding:2rem;background:linear-gradient(to top,rgba(27,77,94,.9) 0%,transparent 100%)}
.svc-card.featured .svc-num{color:rgba(255,255,255,.5)}
.svc-card.featured .svc-name{color:#fff;font-size:1.5rem}
.svc-card.featured .svc-desc{color:rgba(255,255,255,.7)}
.svc-card.featured .svc-arr{color:rgba(255,255,255,.6)}
.svc-num{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;color:var(--ink3);margin-bottom:.75rem;display:block}
.svc-name{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);line-height:1.3;margin-bottom:.5rem;transition:color .2s}
.svc-card:hover .svc-name{color:var(--petro)}
.svc-desc{font-size:.85rem;color:var(--ink3);line-height:1.65;margin-bottom:1rem}
.svc-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}
.svc-tag{font-family:var(--mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);border:1px solid var(--rule);padding:.18rem .45rem;transition:border-color .2s}
.svc-card:hover .svc-tag{border-color:var(--petro2);color:var(--petro2)}
.svc-arr{display:inline-block;font-size:.8rem;color:var(--rule);transition:transform .2s,color .2s}
.svc-card:hover .svc-arr{transform:translateX(5px);color:var(--petro)}

/* SPLIT-ABOUT */
.split-about{display:grid;grid-template-columns:1fr 1fr;min-height:540px}
.split-img{background-size:cover;background-position:center;min-height:420px}
.split-content{background:var(--ink);padding:clamp(3rem,7vw,6rem) clamp(2rem,5vw,4.5rem);display:flex;flex-direction:column;justify-content:center}
.split-eyebrow{font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:1.5rem}
.split-heading{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:#fff;line-height:1.3;margin-bottom:1.25rem}
.split-text{font-size:.95rem;color:rgba(255,255,255,.65);line-height:1.85;margin-bottom:1.75rem;max-width:400px}
.split-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.1);border-top:1px solid rgba(255,255,255,.1);padding-top:1px;margin-top:.5rem}
.split-stat{background:var(--ink);padding:1.25rem 0 1rem}
.split-stat-val{font-family:var(--serif);font-size:2rem;font-weight:400;color:#fff;line-height:1}
.split-stat-lbl{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:.35rem}

/* EXPERTISE */
.expertise-band{background:var(--paper);padding:clamp(4rem,8vw,7rem) 0;border-top:1px solid var(--rule)}
.expertise-band .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);margin-top:clamp(2rem,4vw,3.5rem)}
.exp-item{background:var(--paper);padding:2rem 1.75rem;border-left:2px solid transparent;transition:border-color .2s,background .2s}
.exp-item:hover{border-left-color:var(--amber);background:var(--white)}
.exp-item-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:.65rem}
.exp-item-name{font-family:var(--serif);font-size:1.05rem;color:var(--ink);line-height:1.4}

/* SPLIT-CLIMATE */
.split-climate{display:grid;grid-template-columns:1fr 1fr;min-height:500px}
.split-climate .split-content{background:var(--petro);order:1}
.split-climate .split-img{background-image:url('../assets/Flom under bro.webp');order:2}

/* CTA */
.cta-band{background:var(--white);padding:clamp(4rem,8vw,7rem) 0;border-top:1px solid var(--rule)}
.cta-band .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}
.cta-heading{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.6rem);font-weight:400;color:var(--ink);line-height:1.3}
.cta-heading em{font-style:italic;color:var(--petro)}
.cta-sub{font-size:.92rem;color:var(--ink3);margin-top:.75rem;line-height:1.7}
.cta-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* PRODUCT TEASER */
.product-teaser{background:var(--ink);padding:clamp(2.5rem,5vw,3.5rem) 0;border-top:1px solid rgba(255,255,255,.08)}
.product-teaser .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
.product-teaser-text{max-width:680px}
.product-teaser-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:.5rem}
.product-teaser-title{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.4rem);font-weight:400;color:#fff;line-height:1.4;margin-bottom:.4rem}
.product-teaser-desc{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.7}
.btn-teaser{background:var(--amber);color:#fff;border:none;padding:.7rem 1.8rem;font-family:var(--sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s;text-decoration:none;white-space:nowrap;display:inline-block}
.btn-teaser:hover{background:#a8691f}

/* BUTTONS */
.btn-primary{background:var(--petro);color:#fff;border:none;padding:.9rem 2rem;font-family:var(--sans);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;text-decoration:none;display:inline-block}
.btn-primary:hover{background:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink2);border:1px solid var(--rule);padding:.9rem 2rem;font-family:var(--sans);font-size:.9rem;font-weight:400;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none;display:inline-block}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}

/* FOOTER */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7)}
.footer-body{max-width:var(--max);margin:0 auto;padding:clamp(3rem,6vw,5rem) var(--pad);display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem}
.footer-brand-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem;text-decoration:none;color:inherit}
.footer-logo{height:30px;width:30px;object-fit:contain}
.footer-brand-name{font-family:var(--serif);font-size:.95rem;color:rgba(255,255,255,.9)}
.footer-desc{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.7;max-width:240px}
.footer-col-title{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.45rem}
.footer-links a{font-size:.85rem;color:rgba(255,255,255,.55);text-decoration:none;cursor:pointer;transition:color .18s}
.footer-links a:hover{color:rgba(255,255,255,.9)}
.footer-bottom{max-width:var(--max);margin:0 auto;padding:1.25rem var(--pad);border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;color:rgba(255,255,255,.25)}

/* SERVICE PAGE */
.svc-page{padding-top:68px}
.svc-hero{position:relative;height:clamp(260px,35vw,440px);overflow:hidden}
.svc-hero-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.6) saturate(.8)}
.svc-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(27,77,94,.85) 0%,rgba(0,0,0,.2) 100%)}
.svc-hero-content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:0 var(--pad);height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(2rem,4vw,3.5rem)}
.svc-hero-num{font-family:var(--mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.75rem}
.svc-hero-title{font-family:var(--serif);font-size:clamp(1.8rem,4vw,3rem);font-weight:400;color:#fff;line-height:1.18;margin-bottom:.75rem}
.svc-hero-lead{font-size:clamp(.9rem,1.5vw,1.05rem);color:rgba(255,255,255,.7);max-width:600px;line-height:1.7}
.svc-body{max-width:var(--max);margin:0 auto;padding:clamp(2.5rem,5vw,4rem) var(--pad);display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.svc-content h2{font-family:var(--serif);font-size:1.35rem;font-weight:400;color:var(--ink);margin:2rem 0 .75rem}
.svc-content h2:first-child{margin-top:0}
.svc-content h3{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);margin:1.5rem 0 .5rem}
.svc-content p{font-size:.94rem;color:var(--ink2);line-height:1.85;margin-bottom:1rem}
.svc-content ul{list-style:none;margin:1rem 0 1.5rem}
.svc-content ul li{font-size:.92rem;color:var(--ink2);line-height:1.7;padding:.5rem 0 .5rem 1.25rem;border-bottom:1px solid var(--rule);position:relative}
.svc-content ul li::before{content:'\2014';position:absolute;left:0;color:var(--amber);font-family:var(--mono)}
.svc-content a{color:var(--petro);text-decoration:underline;text-decoration-color:var(--rule);transition:text-decoration-color .2s}
.svc-content a:hover{text-decoration-color:var(--petro)}
.svc-content blockquote{border-left:3px solid var(--amber);padding:.5rem 0 .5rem 1.25rem;margin:1.5rem 0;font-family:var(--serif);font-size:1.05rem;font-style:italic;color:var(--ink2);line-height:1.7}
.svc-content blockquote cite{display:block;margin-top:.5rem;font-family:var(--mono);font-size:.65rem;font-style:normal;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}
.svc-content strong{color:var(--ink);font-weight:600}
.svc-card-contact{background:var(--white);border:1px solid var(--rule);padding:1.75rem;position:sticky;top:84px}
.svc-card-contact h3{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--ink);margin-bottom:.5rem}
.svc-card-contact p{font-size:.82rem;color:var(--ink3);line-height:1.7;margin-bottom:1.25rem}
.svc-card-contact .btn-primary{display:block;width:100%;text-align:center;padding:.85rem}
.contact-detail{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;color:var(--ink3);text-align:center;margin-top:.6rem}
.svc-related-title{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-top:1.75rem;margin-bottom:.75rem}
.svc-related{list-style:none}
.svc-related li{border-bottom:1px solid var(--rule)}
.svc-related a{display:flex;justify-content:space-between;align-items:center;padding:.65rem 0;font-size:.85rem;color:var(--ink2);text-decoration:none;cursor:pointer;transition:color .18s}
.svc-related a:hover{color:var(--petro)}
.svc-content .svc-inline-img{width:100%;margin:1.5rem 0 2rem;border:1px solid var(--rule)}
.svc-content .svc-inline-img img{width:100%;height:auto;display:block}
.svc-content .svc-img-caption{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);padding:.6rem 0;border-bottom:1px solid var(--rule)}

/* FAQ */
.faq-block{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--rule)}
.faq-block h2{font-family:var(--serif);font-size:1.35rem;font-weight:400;color:var(--ink);margin-bottom:1rem}
.faq-item{border-bottom:1px solid var(--rule);padding:1.1rem 0}
.faq-item h3{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--ink);margin-bottom:.4rem}
.faq-item p{font-size:.92rem;color:var(--ink2);line-height:1.75;margin:0}

/* "WHEN DO YOU NEED THIS" */
.when-block{margin-top:2rem;background:var(--paper);padding:1.75rem;border-left:3px solid var(--amber)}
.when-block h2{margin-top:0 !important}
.when-block p{margin-bottom:.75rem}

/* INNER PAGE */
.inner-page{padding-top:68px}
.inner-header{background:var(--ink);padding:clamp(3rem,6vw,5rem) var(--pad)}
.inner-header-inner{max-width:var(--max);margin:0 auto}
.inner-header h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:400;color:#fff;margin-bottom:.65rem;line-height:1.2}
.inner-header p{font-size:1rem;color:rgba(255,255,255,.6);max-width:500px}
.inner-body{max-width:var(--max);margin:0 auto;padding:clamp(2.5rem,5vw,4rem) var(--pad)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2rem,5vw,5rem)}
.contact-block{margin-bottom:2rem}
.c-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:.4rem}
.c-value{font-family:var(--serif);font-size:1.1rem;color:var(--ink);line-height:1.6}
.c-value a{color:var(--ink);text-decoration:none;transition:color .2s}
.c-value a:hover{color:var(--petro)}
.form-title{font-family:var(--serif);font-size:1.4rem;font-weight:400;color:var(--ink);margin-bottom:1.5rem}
.fg{margin-bottom:1.15rem}
.fg label{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:.4rem}
.fg input,.fg select,.fg textarea{width:100%;background:var(--white);border:1px solid var(--rule);padding:.75rem;font-family:var(--sans);font-size:.9rem;color:var(--ink);outline:none;transition:border-color .18s;appearance:none;border-radius:0}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--petro)}
.fg textarea{resize:vertical;min-height:120px}

/* OM */
.om-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem)}
.om-text p{font-size:.95rem;color:var(--ink2);line-height:1.85;margin-bottom:1rem}
.om-values{border-top:1px solid var(--rule)}
.om-val{padding:1.25rem 0;border-bottom:1px solid var(--rule)}
.om-val-num{font-family:var(--mono);font-size:.6rem;color:var(--ink3);letter-spacing:.08em;margin-bottom:.3rem}
.om-val-title{font-family:var(--serif);font-size:1.05rem;color:var(--ink);margin-bottom:.3rem}
.om-val-desc{font-size:.85rem;color:var(--ink2);line-height:1.7}

/* MEDIA */
@media(max-width:1024px){
  .hero-content{gap:2rem}
  .footer-body{grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
  .svc-body{grid-template-columns:1fr 280px;gap:2rem}
}
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}.nav-toggle{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--rule);padding:1rem 2rem;gap:1.25rem;z-index:99}
  .hero{min-height:auto;height:auto;padding-bottom:clamp(3rem,8vw,5rem)}
  .hero-content{grid-template-columns:1fr;gap:2rem}
  .hero-right{align-items:flex-start}.hero-btns{justify-content:flex-start}
  .hero-desc,.split-text{max-width:100%}
  .hero-stat-val{font-size:1.6rem}
  .svc-grid{grid-template-columns:1fr}.svc-card.featured{min-height:300px}
  .split-about,.split-climate{grid-template-columns:1fr}
  .split-img{min-height:260px;order:0!important}
  .split-climate .split-content{order:0!important}
  .exp-grid{grid-template-columns:1fr 1fr}
  .cta-band .inner{grid-template-columns:1fr;text-align:center}
  .cta-btns{justify-content:center}
  .footer-body{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-desc{max-width:100%}
  .svc-body{grid-template-columns:1fr}.svc-card-contact{position:static}
  .contact-grid,.om-grid{grid-template-columns:1fr}
  .svc-hero{height:clamp(220px,30vw,360px)}
  .nav-links a,.footer-links a{padding:.5rem 0;display:inline-block;min-height:44px;line-height:44px}
  .btn-primary,.btn-ghost,.btn-hero-primary,.btn-hero-ghost,.nav-cta{min-height:48px;padding:.85rem 2rem}
}
@media(max-width:600px){
  .exp-grid{grid-template-columns:1fr}
  .footer-body{grid-template-columns:1fr}
  .hero-stat-row{gap:1rem;flex-wrap:wrap}
  .hero-stat-val{font-size:1.35rem}
  .hero-stat-lbl{font-size:.55rem}
  .hero-title{font-size:clamp(1.8rem,7vw,2.8rem)}
  .split-heading{font-size:clamp(1.4rem,5vw,2rem)}
  .section-title{font-size:clamp(1.3rem,5vw,2rem)}
  .svc-hero-title{font-size:clamp(1.5rem,6vw,2.4rem)}
  .inner-header h1{font-size:clamp(1.6rem,6vw,2.6rem)}
  .cta-heading{font-size:clamp(1.3rem,5vw,2rem)}
  .split-stats{grid-template-columns:1fr 1fr}
  .svc-card{padding:1.25rem}
  .hero-btns{flex-direction:column;width:100%}
  .btn-hero-primary,.btn-hero-ghost{width:100%;text-align:center}
  .svc-inline-img img{border-radius:0}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.au{opacity:0;animation:fadeUp .65s ease forwards}
.d1{animation-delay:.08s}.d2{animation-delay:.18s}.d3{animation-delay:.28s}.d4{animation-delay:.38s}
