/* MDR Design-Build-Remodel — shared stylesheet */

  /* ============ TOKENS ============ */
  /* MDR brand palette: charcoal + warm tan/brass (matches the MDR logo).
     Variable names kept from the old blue theme so every var() reference
     across the CSS + inline HTML recolors from this single block. */
  :root{
    --ink:#222a33;          /* near-black charcoal */
    --ink-soft:#3b444e;
    --slate:#5c6671;
    --paper:#ffffff;
    --paper-2:#f6f4ef;      /* warm off-white */
    --line:#e7e3da;         /* warm hairline */
    --blue:#8a6a35;         /* accent bronze (links/kickers/icons on light) */
    --blue-deep:#6f5429;
    --blue-soft:#f2ebdf;    /* warm cream tint */
    --navy:#2b333d;         /* brand charcoal (dark sections/footer/headings) */
    --gold:#c2a06a;         /* warm tan (CTA buttons + accents on dark) */
    --gold-deep:#b08f57;
    --blue-light:#9c8049;   /* tan-brown subtitles */
    --maxw:1200px;
    --pad:clamp(20px,5vw,56px);
    --head:"Schibsted Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
    --body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
    --ease:cubic-bezier(.22,.61,.36,1);
    --shadow:0 24px 54px -30px rgba(30,26,20,.42);
    --shadow-sm:0 12px 30px -18px rgba(30,26,20,.32);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{font-family:var(--body);background:var(--paper);color:var(--slate);line-height:1.65;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
  img{display:block;max-width:100%}
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--blue);color:#fff}
  h1,h2,h3,h4{font-family:var(--head);color:var(--navy);line-height:1.08;letter-spacing:-.015em;font-weight:800;text-wrap:balance}
  .wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

  /* ---- polish ---- */
  body{text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale}
  p{text-wrap:pretty}
  :focus-visible{outline:2.5px solid var(--blue);outline-offset:3px;border-radius:4px}
  :focus:not(:focus-visible){outline:none}
  [id]{scroll-margin-top:104px}
  .btn:active{transform:translateY(0) scale(.99)}

  .kicker{font-family:var(--head);font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:16px}
  .kicker.on-dark{color:#cdb482}

  /* ============ BUTTONS ============ */
  .btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:700;font-size:15px;cursor:pointer;border:none;padding:15px 28px;border-radius:7px;transition:.3s var(--ease);letter-spacing:.01em}
  .btn-primary{background:var(--gold);color:var(--navy)}
  .btn-primary:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
  .btn-phone{background:transparent;color:var(--ink);border:1.5px solid var(--line);font-weight:700}
  .btn-phone:hover{border-color:var(--blue);color:var(--blue)}
  .btn-phone svg{color:var(--blue)}
  .on-dark .btn-phone,.btn-phone.on-dark{color:#fff;border-color:rgba(255,255,255,.35)}
  .on-dark .btn-phone:hover,.btn-phone.on-dark:hover{background:#fff;color:var(--blue);border-color:#fff}
  .on-dark .btn-phone svg,.btn-phone.on-dark svg{color:#fff}
  .on-dark .btn-phone:hover svg,.btn-phone.on-dark:hover svg{color:var(--blue)}
  .btnrow{display:flex;flex-wrap:wrap;gap:13px;align-items:center}
  .txtlink{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-weight:700;font-size:15px;color:var(--blue)}
  .txtlink .arr{transition:transform .3s var(--ease)}
  .txtlink:hover .arr{transform:translateX(5px)}

  /* ============ TOP STRIP ============ */
  .topstrip{background:var(--navy);color:#c2bdb0;font-size:12.5px}
  .topstrip .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;gap:14px}
  .topstrip .L{display:flex;gap:20px}
  .topstrip .L span{display:flex;align-items:center;gap:7px}
  .topstrip .dot{width:5px;height:5px;border-radius:50%;background:var(--gold)}
  .topstrip .R{font-weight:600;color:#fff}
  .topstrip .R .stars{color:#f2b950}
  @media(max-width:760px){.topstrip .L span:nth-child(n+2){display:none}.topstrip .R{display:none}}

  /* ============ HEADER ============ */
  header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:box-shadow .3s,border-color .3s}
  header.scrolled{box-shadow:0 8px 28px -22px rgba(30,26,20,.5)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:80px;gap:24px;transition:height .3s var(--ease)}
  header.scrolled .nav{height:66px}
  .logo img,.logo svg{height:46px;width:auto;transition:height .3s var(--ease)}
  header.scrolled .logo img,header.scrolled .logo svg{height:40px}
  /* current-page indicator (works with data-page; JS sets it on inner pages) */
  body[data-page="home"] .menu>a[href="index.html"]{color:var(--blue)}
  body[data-page="home"] .menu>a[href="index.html"]::after{width:100%}
  .menu{display:flex;align-items:center;gap:22px}
  .menu>a,.menu .drop>button,.menu .drop>a{font-family:var(--head);font-size:14.5px;font-weight:600;color:var(--ink);background:none;border:none;cursor:pointer;padding:8px 0;position:relative;display:inline-flex;align-items:center;gap:6px;transition:color .25s}
  .menu>a::after,.menu .drop>button::after,.menu .drop>a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--blue);transition:width .3s var(--ease)}
  .menu>a:hover,.menu .drop>button:hover,.menu .drop>a:hover{color:var(--blue)}
  .menu>a:hover::after,.menu .drop:hover>button::after,.menu .drop:hover>a::after{width:100%}
  .drop{position:relative}
  .drop>button .chev,.drop>a .chev{transition:transform .3s}
  .drop:hover>button .chev,.drop:hover>a .chev{transform:rotate(180deg)}
  .dropmenu{position:absolute;top:calc(100% + 12px);left:0;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;min-width:230px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.24s var(--ease);box-shadow:var(--shadow)}
  .dropmenu.wide{left:auto;right:0;transform:translateY(8px);width:540px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px 8px}
  .dropmenu.mega{left:0;right:auto;width:520px;display:grid;grid-template-columns:1fr 1fr;gap:4px 18px}
  .dropmenu.mega .dm-col{display:flex;flex-direction:column}
  .dropmenu.mega .dm-h{font-family:var(--head);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);padding:6px 12px 4px;margin-top:2px}
  .dropmenu.mega .dm-col:nth-child(2){border-left:1px solid var(--line);padding-left:6px}
  .drop:hover .dropmenu.mega{transform:translateY(0)}
  .drop:hover .dropmenu{opacity:1;visibility:visible;transform:translateY(0)}
  .drop:hover .dropmenu.wide{transform:translateY(0)}
  .dropmenu a{font-family:var(--body);font-size:13.5px;font-weight:500;color:var(--slate);padding:9px 12px;border-radius:8px;display:block;transition:.18s}
  .dropmenu a:hover{background:var(--blue-soft);color:var(--blue)}
  .nav-cta{display:flex;align-items:center;gap:14px}
  .nav-cta .btn{padding:10px 18px;font-size:14px;white-space:nowrap}
  .menu>a{white-space:nowrap}
  .nav-phone{font-family:var(--head);font-size:17px;font-weight:800;color:var(--ink);white-space:nowrap;display:flex;align-items:center;gap:8px}
  .nav-phone svg{color:var(--blue)}.nav-phone:hover{color:var(--blue)}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:11px;margin-right:-4px}
  .burger span{width:25px;height:2.5px;background:var(--ink);border-radius:2px}

  /* ============ MOBILE NAV ============ */
  .mnav{position:fixed;inset:0;background:var(--navy);z-index:100;transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:24px var(--pad) 40px;overflow-y:auto}
  .mnav.open{transform:translateX(0)}
  .mnav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
  .mnav-top .mwm{font-family:var(--head);font-weight:900;color:#fff;font-size:22px;letter-spacing:.03em}
  .mclose{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;width:44px;height:44px;border-radius:10px;font-size:22px;cursor:pointer}
  .mnav>a{color:#fff;font-family:var(--head);font-weight:700;font-size:24px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12)}
  .mnav .msub{font-family:var(--head);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:24px 0 4px;font-weight:700}
  .mloc{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
  .mloc a{font-size:15px;font-weight:500;color:#c2bdb0;padding:11px 0;border:none}
  .mnav .mcta{margin-top:26px;justify-content:center}

  /* ============ HERO ============ */
  .hero{position:relative;min-height:min(86vh,760px);display:flex;align-items:flex-end;color:#fff;overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:0}
  .hero-bg img{width:100%;height:100%;object-fit:cover}
  .hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(34,40,49,.93) 0%,rgba(34,40,49,.82) 55%,rgba(34,40,49,.62) 100%)}
  .hero .wrap{position:relative;z-index:2;width:100%;padding-top:clamp(50px,8vw,90px);padding-bottom:clamp(50px,7vw,84px)}
  .hero-inner{max-width:680px}
  .hero.compact{min-height:min(62vh,540px)}
  .hero h1{color:#fff;font-size:clamp(38px,5.8vw,68px);font-weight:900;letter-spacing:-.025em}
  .hero h1 em{font-style:normal;color:#d8bd86}
  .hero p{font-size:clamp(17px,1.6vw,20px);color:#d8d1c4;margin:22px 0 30px;max-width:33em;line-height:1.55}
  .hero .trustline{display:flex;align-items:center;gap:18px;margin-top:28px;flex-wrap:wrap;font-size:13.5px;color:#d6cfc0;font-weight:600}
  .hero .trustline .stars{color:#f2b950;letter-spacing:1px}
  .hero .trustline .sep{width:1px;height:16px;background:rgba(255,255,255,.25)}

  /* ============ SECTION ============ */
  .sec{padding:clamp(64px,8vw,116px) 0}
  .sec-tight{padding:clamp(50px,6vw,84px) 0}
  .sec-head{max-width:720px}
  .sec-head.center{margin:0 auto;text-align:center}
  .sec-head h2{font-size:clamp(30px,4.2vw,50px);font-weight:800;margin:0}
  .sec-head .sub{font-family:var(--head);font-size:clamp(17px,2vw,21px);font-weight:600;color:var(--blue-light);margin-top:14px}
  .sec-head p{margin-top:18px;font-size:17.5px;color:var(--slate)}
  .sec-head.center p{margin-left:auto;margin-right:auto}

  /* ============ ALTERNATING ROW ============ */
  .row{display:flex!important;flex-wrap:wrap;gap:clamp(34px,5vw,74px);align-items:center}
  .row>*{flex:1 1 calc(50% - clamp(34px,5vw,74px));min-width:0;width:auto!important;max-width:none!important;float:none!important;margin:0!important}
  .row .media{flex:1 1 calc(50% - clamp(34px,5vw,74px));border-radius:14px;overflow:hidden;aspect-ratio:11/9;box-shadow:var(--shadow);position:relative}
  .row .copy{flex:1 1 calc(50% - clamp(34px,5vw,74px))}
  .row + .row{margin-top:clamp(56px,7vw,100px)}
  .row .media::after{content:"";position:absolute;inset:0;border-radius:14px;box-shadow:inset 0 0 0 1px rgba(30,26,20,.08);pointer-events:none}
  .row .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
  .row .media:hover img{transform:scale(1.05)}
  .row .copy{text-align:left}
  .row .copy h2{font-size:clamp(28px,3.6vw,44px)!important;line-height:1.08!important;color:var(--navy)}
  .row .copy .sub{font-family:var(--head);font-size:19px;font-weight:600;color:var(--blue-light);margin-top:12px}
  .row .copy p{margin-top:18px}
  .row .copy .btnrow{margin-top:30px}
  .row.rev .media{order:2}
  @media(max-width:900px){.row>*,.row .media,.row .copy{flex:1 1 100%}.row.rev .media{order:0}.row .media{aspect-ratio:16/10}}

  /* ============ DIFFERENTIATORS ============ */
  .diff{background:var(--navy);color:#cabfae}
  .diff .kicker{text-align:center}
  .diff .sec-head{margin:0 auto;text-align:center}
  .diff .sec-head h2{color:#fff}
  .diff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:clamp(40px,5vw,60px)}
  .dcard{text-align:center;padding:8px}
  .dcard .ic{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:var(--gold)}
  .dcard h4{color:#fff;font-size:19px;font-weight:700;margin-bottom:10px}
  .dcard p{font-size:14.5px;color:#a7a194}
  @media(max-width:860px){.diff-grid{grid-template-columns:1fr 1fr;gap:30px}}
  @media(max-width:460px){.diff-grid{grid-template-columns:1fr}}

  /* ============ SERVICES ============ */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:clamp(38px,5vw,58px)}
  .svc{display:block;border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:.35s var(--ease)}
  .svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
  .svc .ph{aspect-ratio:3/2;overflow:hidden}
  .svc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
  .svc:hover .ph img{transform:scale(1.07)}
  .svc .bd{padding:24px 26px 26px}
  .svc h3{font-size:22px;font-weight:700}
  .svc p{font-size:14.5px;color:var(--slate);margin:10px 0 16px}
  .svc .more{display:inline-flex;align-items:center;gap:7px;font-family:var(--head);font-weight:700;font-size:14px;color:var(--blue)}
  .svc .more .arr{transition:transform .3s var(--ease)}
  .svc:hover .more .arr{transform:translateX(5px)}
  @media(max-width:880px){.svc-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:540px){.svc-grid{grid-template-columns:1fr}}

  /* ============ PROCESS ============ */
  .proc{background:var(--paper-2)}
  .proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:clamp(40px,5vw,58px);counter-reset:s}
  .pstep{padding:0 26px;position:relative}
  .pstep + .pstep{border-left:1px solid var(--line)}
  .pstep .pn{font-family:var(--head);font-weight:900;font-size:17px;color:#fff;background:var(--blue);width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin-bottom:20px}
  .pstep h4{font-size:21px;font-weight:700;margin-bottom:8px}
  .pstep p{font-size:14.5px}
  @media(max-width:860px){.proc-grid{grid-template-columns:1fr 1fr;gap:34px 0}.pstep:nth-child(odd){border-left:none}.pstep:nth-child(even){border-left:1px solid var(--line)}}
  @media(max-width:460px){.proc-grid{grid-template-columns:1fr;gap:30px}.pstep{border-left:none!important;padding:0}}

  /* ============ REVIEWS ============ */
  .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(38px,5vw,56px)}
  .rev{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px;display:flex;flex-direction:column}
  .rev .stars{color:#f2b950;letter-spacing:2px;font-size:16px}
  .rev p{font-size:16.5px;line-height:1.6;color:var(--ink);margin:16px 0 22px;flex:1;font-weight:500}
  .rev .who{display:flex;align-items:center;gap:12px}
  .rev .av{width:42px;height:42px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-family:var(--head);font-weight:800}
  .rev .who .nm{font-family:var(--head);font-weight:700;color:var(--ink);font-size:14.5px}
  .rev .who .ct{font-size:12.5px;color:var(--slate)}
  @media(max-width:880px){.rev-grid{grid-template-columns:1fr}}

  /* ============ FAQ ============ */
  .faq-wrap{max-width:840px;margin:0 auto}
  .faq-list{margin-top:clamp(34px,5vw,48px);border-top:1px solid var(--line)}
  .faq-list details{border-bottom:1px solid var(--line)}
  .faq-list summary{list-style:none;cursor:pointer;font-family:var(--head);font-weight:700;font-size:18px;color:var(--ink);padding:22px 44px 22px 0;position:relative;transition:color .25s}
  .faq-list summary::-webkit-details-marker{display:none}
  .faq-list summary:hover{color:var(--blue)}
  .faq-list summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:24px;font-weight:400;color:var(--blue);transition:transform .3s var(--ease)}
  .faq-list details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
  .faq-list .faq-a{padding:0 44px 24px 0;font-size:16px;color:var(--slate);line-height:1.65}
  .faq-list .faq-a a{color:var(--blue);font-weight:600}

  /* ============ LOCATIONS ============ */
  .loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:center}
  .loc-cities{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .loc-cities a{display:flex;align-items:center;gap:9px;font-family:var(--head);font-weight:600;font-size:14.5px;color:var(--ink);padding:11px 14px;border:1px solid var(--line);border-radius:8px;transition:.25s var(--ease)}
  .loc-cities a::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--blue);flex:none;transition:.25s}
  .loc-cities a:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}
  @media(max-width:900px){.loc-grid{grid-template-columns:1fr}.loc-cities{grid-template-columns:1fr 1fr}}
  .combolinks{display:flex;flex-direction:column;gap:10px}
  .combolinks a{display:flex;align-items:center;justify-content:space-between;font-family:var(--head);font-weight:700;font-size:15px;color:var(--ink);padding:14px 18px;border:1px solid var(--line);border-radius:10px;background:#fff;transition:.22s var(--ease)}
  .combolinks a::after{content:"\\2192";color:var(--blue);transition:.22s}
  .combolinks a:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);transform:translateX(3px)}

  /* ============ CTA ============ */
  .cta{position:relative;color:#fff;text-align:center;overflow:hidden}
  .cta-bg{position:absolute;inset:0;z-index:0}
  .cta-bg img{width:100%;height:100%;object-fit:cover}
  .cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,40,49,.9),rgba(34,40,49,.86))}
  .cta .wrap{position:relative;z-index:2}
  .cta h2{color:#fff;font-size:clamp(30px,4.6vw,54px);font-weight:900}
  .cta p{color:#d8d1c4;font-size:19px;margin:18px auto 32px;max-width:32em}
  .cta .btnrow{justify-content:center}

  /* ============ FOOTER ============ */
  footer{background:var(--navy);color:#a7a194;padding:clamp(44px,5.5vw,64px) 0 0}
  .fgrid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.05fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
  .fbrand .fwm{font-family:var(--head);font-weight:900;font-size:25px;color:#fff;letter-spacing:.01em}
  .fbrand .fsub{font-family:var(--head);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:#8f897c;margin-top:5px;font-weight:600}
  .fbrand p{font-size:14.5px;margin-top:18px;line-height:1.75}
  .fbrand a{color:#fff;font-weight:600}.fbrand a:hover{color:var(--gold)}
  .fcol h4{font-family:var(--head);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:700}
  .fcol a{display:block;font-size:14px;padding:4.5px 0;color:#a7a194;transition:.2s}
  .fcol a:hover{color:var(--gold);padding-left:4px}
  .fbadges{display:flex;flex-wrap:wrap;gap:13px;align-items:center}
  .fbadges img{height:38px;width:auto;opacity:.9;filter:brightness(0) invert(1);transition:.3s}
  .fbadges a:hover img{opacity:1}
  .fbot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:22px 0;font-size:13px;color:#8f897c;flex-wrap:wrap}
  @media(max-width:900px){.fgrid{grid-template-columns:1fr 1fr;gap:34px}}
  @media(max-width:520px){.fgrid{grid-template-columns:1fr}}

  /* ============ MOBILE STICKY BAR ============ */
  .mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:#fff;border-top:0;box-shadow:0 -10px 30px -14px rgba(34,40,49,.45);padding:10px 14px;gap:10px}
  .mobile-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--head);font-weight:700;font-size:15px;padding:13px;border-radius:8px}
  .mobile-bar .mb-call{background:var(--paper-2);color:var(--ink);border:1px solid var(--line)}
  .mobile-bar .mb-book{background:var(--blue);color:#fff}

  /* ============ REVEAL ============ */
  .rv{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .rv.in{opacity:1;transform:none}
  .rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}
  @media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}*{scroll-behavior:auto}}

  /* ============ RESPONSIVE ============ */
  @media(max-width:1180px){
    .menu,.nav-cta .nav-phone,.nav-cta .btn{display:none}
    .burger{display:flex}
    .hero-bg::after{background:linear-gradient(180deg,rgba(34,40,49,.55) 0%,rgba(34,40,49,.92) 100%)}
    .mobile-bar{display:flex}
    footer{padding-bottom:78px}
  }
  @media(max-width:560px){
    body{font-size:16px}
    .nav{height:68px}.logo img,.logo svg{height:38px}
  }

  /* ================= CASCADE HARDENING =================
     Scoped to .mdr-page so it overrides Avada/Fusion theme typography
     without touching the injected header/footer chrome. Mirrors the
     design colors exactly, with !important to win the cascade. */
  .mdr-page h1,.mdr-page h2,.mdr-page h3,.mdr-page h4,.mdr-page h5,.mdr-page h6{font-family:var(--head)!important;color:var(--navy)!important}
  .mdr-page p,.mdr-page li,.mdr-page td{font-family:var(--body)!important}
  .mdr-page p{color:var(--slate)!important}
  .mdr-page a{color:inherit}
  /* subtitles / kickers */
  .mdr-page .kicker{color:var(--blue)!important}
  .mdr-page .sec-head .sub,.mdr-page .row .copy .sub{color:var(--blue-light)!important}
  .mdr-page .sec-head p{color:var(--slate)!important}
  /* light text on dark backgrounds must re-win (higher specificity than the navy default above) */
  .mdr-page .hero,.mdr-page .hero p,.mdr-page .hero .trustline{color:#fff!important}
  .mdr-page .hero h1,.mdr-page .hero h2,.mdr-page .hero h3{color:#fff!important}
  .mdr-page .hero h1 em{color:#d8bd86!important}
  .mdr-page .hero p{color:#d8d1c4!important}
  .mdr-page .hero .trustline{color:#d6cfc0!important}
  .mdr-page .kicker.on-dark{color:#cdb482!important}
  .mdr-page .on-dark,.mdr-page .on-dark h1,.mdr-page .on-dark h2,.mdr-page .on-dark p{color:#fff!important}
  .mdr-page .cta,.mdr-page .cta h2{color:#fff!important}
  .mdr-page .cta p{color:#d8d1c4!important}
  .mdr-page .diff .sec-head h2{color:#fff!important}
  .mdr-page .dcard h3,.mdr-page .dcard h4{color:#fff!important}
  .mdr-page .dcard p{color:#a7a194!important}
  /* dark "Free Tool / budget" calc band — keep its text white over Fusion */
  .mdr-page .calc-band,.mdr-page .calc-band h3,.mdr-page .calc-band h2,.mdr-page .calc-band .cb-txt{color:#fff!important}
  .mdr-page .calc-band p{color:#cabfa9!important}
  .mdr-page .calc-band .btn-primary{color:var(--navy)!important}
  .mdr-page .calc-band .kicker,.mdr-page .calc-band .kicker.on-dark{color:#cdb482!important}
  /* dark navy CTA card in the services grid (inline background:var(--navy)) */
  .mdr-page .svc[style*="--navy"],.mdr-page .svc[style*="navy"]{color:#fff!important}
  .mdr-page .svc[style*="navy"] h3,.mdr-page .svc[style*="navy"] h4{color:#fff!important}
  .mdr-page .svc[style*="navy"] p{color:#cabfa9!important}
  /* any element explicitly given white/light text inline must keep it over Fusion */
  .mdr-page [style*="color:#fff"]{color:#fff!important}
  .mdr-page [style*="color:#cabfa9"]{color:#cabfa9!important}
  /* accent text colors */
  .mdr-page .stars{color:#f2b950!important}
  .mdr-page .txtlink,.mdr-page .svc .more,.mdr-page .combolinks a::after,.mdr-page .faq-list summary::after,.mdr-page .faq-list .faq-a a{color:var(--blue)!important}
  .mdr-page .rev p,.mdr-page .rev .who .nm,.mdr-page .faq-list summary,.mdr-page .loc-cities a{color:var(--ink)!important}
  .mdr-page .rev .who .ct,.mdr-page .svc p,.mdr-page .faq-list .faq-a{color:var(--slate)!important}
  /* neutralize Fusion's injected inline font-size scaling on our headings */
  .mdr-page .fusion-responsive-typography-calculated{font-size:revert!important;line-height:inherit!important}

  /* ============ INNER-PAGE COMPONENTS ============ */
  .hero.compact{min-height:min(60vh,520px)}
  .crumbs{font-size:13px;color:#a8a294;margin-bottom:16px}
  .crumbs a{color:#ddd4c2;font-weight:600}
  .crumbs a:hover{color:#fff}
  .crumbs span{opacity:.6;margin:0 6px}
  .lead{font-size:clamp(18px,2vw,21px);color:var(--ink-soft);font-weight:500;line-height:1.5}
  .prose{max-width:760px}
  .prose p{margin-top:18px}
  .prose p:first-child{margin-top:0}
  .checks{list-style:none;margin:28px 0 0;display:grid;gap:14px}
  .checks li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:var(--ink-soft)}
  .checks .ck{flex:none;width:24px;height:24px;border-radius:7px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;margin-top:1px}
  .checks li strong{color:var(--ink)}
  .sgal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:clamp(34px,5vw,52px)}
  .sgal a{border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 0 0 1px rgba(30,26,20,.08)}
  .sgal img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
  .sgal a:hover img{transform:scale(1.07)}
  .sgal a:nth-child(1){grid-column:span 2;grid-row:span 2}
  .sgal a:nth-child(6){grid-column:span 2}
  @media(max-width:860px){.sgal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.sgal a:nth-child(1){grid-column:span 2;grid-row:span 1}.sgal a:nth-child(6){grid-column:span 2}}
  /* contact */
  .cwrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:start}
  .cform{background:#fff;border:1px solid var(--line);border-radius:16px;padding:clamp(26px,3vw,40px);box-shadow:var(--shadow-sm)}
  .cform .fld{margin-bottom:18px}
  .cform label{display:block;font-family:var(--head);font-weight:600;font-size:13.5px;color:var(--ink);margin-bottom:7px}
  .cform input,.cform select,.cform textarea{width:100%;font-family:var(--body);font-size:16px;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:13px 15px;transition:.2s}
  .cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(138,106,53,.18)}
  .cform textarea{resize:vertical;min-height:120px}
  .cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .cform .btn{width:100%;justify-content:center;margin-top:6px}
  .infogrid{display:grid;gap:16px}
  .infocard{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px}
  .infocard .ic{flex:none;width:46px;height:46px;border-radius:11px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center}
  .infocard h4{font-size:16px;font-weight:700;margin-bottom:4px}
  .infocard p{font-size:14.5px;color:var(--slate);line-height:1.55}
  .infocard a{color:var(--blue);font-weight:600}
  @media(max-width:880px){.cwrap{grid-template-columns:1fr}.cform .row2{grid-template-columns:1fr}}
  /* richer form fields (quote + claim) */
  .cform .row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
  .cform .hint{font-size:12.5px;color:var(--slate);margin-top:6px;line-height:1.4}
  .req{color:#c0392b}
  .cform .pills{display:flex;flex-wrap:wrap;gap:10px}
  .cform .pills label{display:inline-flex;align-items:center;gap:8px;margin:0;font-family:var(--head);font-weight:600;font-size:14px;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:11px 15px;cursor:pointer;transition:.18s}
  .cform .pills label:hover{border-color:var(--blue-light)}
  .cform .pills input{width:auto;margin:0;accent-color:var(--blue)}
  .cform .pills input:checked + span{color:var(--blue)}
  .cform .pills label:has(input:checked){border-color:var(--blue);background:var(--blue-soft)}
  .filefield{border:1.5px dashed var(--line);border-radius:9px;padding:18px 16px;text-align:center;background:var(--paper);transition:.2s}
  .filefield:hover{border-color:var(--blue-light)}
  .filefield input{width:auto}
  .filefield .fileico{color:var(--blue);margin-bottom:8px}
  .formnote{display:flex;gap:14px;align-items:flex-start;background:var(--blue-soft);border:1px solid #ddd4c2;border-radius:12px;padding:18px 20px;margin-bottom:22px}
  .formnote svg{flex:none;color:var(--blue);margin-top:2px}
  .formnote p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0}
  .formnote strong{color:var(--navy)}
  @media(max-width:560px){.cform .row3{grid-template-columns:1fr}}
  /* projects gallery */
  .galcat{font-family:var(--head);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin:clamp(40px,5vw,60px) 0 18px}
  .galcat:first-of-type{margin-top:clamp(32px,4vw,44px)}
  .pgal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .pgal figure{margin:0;border-radius:12px;overflow:hidden;aspect-ratio:4/3;box-shadow:inset 0 0 0 1px rgba(30,26,20,.08);position:relative}
  .pgal img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
  .pgal figure:hover img{transform:scale(1.06)}
  .pgal figure.tall{aspect-ratio:auto;grid-row:span 2}
  @media(max-width:780px){.pgal{grid-template-columns:1fr 1fr}.pgal figure.tall{grid-row:span 1}}
  @media(max-width:460px){.pgal{grid-template-columns:1fr}}
  /* about stats + team */
  .statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:clamp(34px,5vw,48px)}
  .statrow .stat{background:#fff;padding:30px 24px;text-align:center}
  .statrow .stat .n{font-family:var(--head);font-weight:900;font-size:clamp(30px,3.4vw,42px);color:var(--blue);line-height:1}
  .statrow .stat .l{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);margin-top:8px;font-weight:600}
  @media(max-width:620px){.statrow{grid-template-columns:1fr}.statrow .stat{padding:22px}}
  .teamnote{background:var(--blue-soft);border:1px dashed var(--blue);border-radius:12px;padding:20px 24px;margin-top:28px;font-size:14.5px;color:var(--ink-soft)}
  .calc-band{display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;background:linear-gradient(150deg,var(--navy),#3b4350);border-radius:18px;padding:clamp(26px,4vw,40px);color:#fff;box-shadow:var(--shadow-sm)}
  .calc-band .cb-txt{max-width:60ch}
  .calc-band h3{font-family:var(--head);font-weight:800;font-size:clamp(19px,2.6vw,25px);color:#fff;letter-spacing:-.01em;margin-top:8px;line-height:1.2}
  .calc-band p{color:#cabfa9;margin-top:8px;font-size:15px}
  .calc-band .btn{flex:none}
  .calc-band .btn-primary{background:var(--gold);color:var(--navy)}
  .calc-band .btn-primary:hover{background:var(--gold-deep)}
  @media(max-width:640px){.calc-band{flex-direction:column;align-items:flex-start}.calc-band .btn{width:100%}}
  .calllink{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-weight:600;font-size:14.5px;color:var(--ink-soft);text-decoration:none;transition:color .2s var(--ease);padding:7px 2px}
  .calllink svg{color:var(--blue)}
  .calllink:hover{color:var(--blue)}
  .btnrow.on-dark .calllink{color:#ddd4c2}
  .btnrow.on-dark .calllink svg{color:var(--gold)}
  .btnrow.on-dark .calllink:hover{color:#fff}


  /* ============ FORM SUBMIT STATES (contact + quote) ============ */
  .form-success{background:var(--blue-soft);border:1px solid var(--gold);border-radius:16px;padding:clamp(28px,4vw,40px);text-align:center;box-shadow:var(--shadow-sm)}
  .form-success .fs-ic{width:62px;height:62px;border-radius:50%;background:var(--gold);color:var(--navy);display:grid;place-items:center;margin:0 auto 18px}
  .form-success h3{font-size:23px;color:var(--navy);margin-bottom:10px}
  .form-success p{color:var(--ink-soft);font-size:15.5px;max-width:42ch;margin:0 auto;line-height:1.6}
  .form-success a{color:var(--blue);font-weight:700}
  .form-err{background:#fbeceb;border:1px solid #e6b3ae;color:#a3271d;border-radius:10px;padding:13px 16px;font-size:14.5px;font-weight:600;margin-bottom:18px}

  /* ============ PROCESS TIMELINE (/process/) ============ */
  .ptime{max-width:880px;margin:clamp(36px,5vw,56px) auto 0;position:relative}
  .ptime .pstepx{position:relative;display:grid;grid-template-columns:60px 1fr;gap:24px;padding-bottom:36px}
  .ptime .pstepx:last-child{padding-bottom:0}
  .ptime .rail{position:relative;display:flex;justify-content:center}
  .ptime .num{width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--head);font-weight:900;font-size:18px;display:grid;place-items:center;flex:none;z-index:1;box-shadow:0 0 0 6px var(--paper)}
  .ptime .pstepx:first-child .num{background:var(--gold);color:var(--navy)}
  .ptime .line{position:absolute;top:56px;bottom:-36px;left:50%;transform:translateX(-50%);width:2px;background:var(--line)}
  .ptime .pstepx:last-child .line{display:none}
  .ptime .body{padding-top:3px}
  .ptime .chip{display:inline-block;font-family:var(--head);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);background:var(--blue-soft);padding:5px 11px;border-radius:20px;margin-bottom:11px}
  .ptime h3{font-size:21px;color:var(--navy);margin-bottom:9px;display:flex;align-items:center;gap:11px;line-height:1.15}
  .ptime h3 .ic{color:var(--gold);flex:none}
  .ptime .body p{font-size:15.5px;color:var(--slate);line-height:1.62}
  .ptime .body p + p{margin-top:10px}
  .ptime .tip{margin-top:12px;background:var(--blue-soft);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:8px;padding:12px 16px;font-size:14px;color:var(--ink-soft)}
  .ptime .tip strong{color:var(--navy)}
  @media(max-width:560px){.ptime .pstepx{grid-template-columns:46px 1fr;gap:16px}.ptime .num{width:44px;height:44px;font-size:15px}.ptime .line{top:44px}.ptime h3{font-size:19px}}
  /* promises strip */
  .promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(34px,5vw,50px)}
  .promise{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 24px;text-align:left}
  .promise .ic{width:48px;height:48px;border-radius:11px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;margin-bottom:16px}
  .promise h4{font-size:17px;color:var(--navy);margin-bottom:8px}
  .promise p{font-size:14.5px;color:var(--slate);line-height:1.6}
  @media(max-width:820px){.promise-grid{grid-template-columns:1fr;gap:16px}}
