/* ===== Responsive-900.css Master Order =====
   Media range: max-width 900px, with narrower late fixes for 700/500/400.
  
*/
@media (max-width: 900px) {
  /* ===== Mobile Shared Variables ===== */
  :root {
    --r-content: calc(100vw - 28px);
    --r-who-center: 98px;
    --r-who-gap: 18px;
    --r-who-word: 22px;
    --r-copy: 10px;
    --r-small-btn: 12px;
    --r-service-card-w: 150px;
    --r-service-card-h: 196px;
    --r-service-gap: 18px;
  }

  /* ===== Mobile Splash Page ===== */
  body.splash-body .headline-top {
    top: 21vh;
    left: 8vw;
  }

  body.splash-body .headline-bottom {
    top: 63vh;
    right: 8vw;
  }

  body.splash-body .splash-logo {
    top: 34vh;
    left: 50%;
    width: min(38vw, 240px);
    transform: translateX(-50%);
  }

  body.splash-body .enter-btn {
    top: 77vh;
    width: 220px;
    min-width: 220px;
    padding: 14px 34px;
  }

  body.splash-body .tool-screwdriver {
    width: 50vw;
  }

  body.splash-body .tool-roller {
    width: 46vw;
    margin-top: -26px;
  }

  body.splash-body .tool-drill {
    width: 44vw;
    margin-top: 160px;
	margin-right: -20px;  
  }

  body.splash-body .tool-wrench {
    width: 40vw;
    margin-bottom: 200px;
    margin-left: -34px;
  }

  body.splash-body .tool-pliers {
    width: 42vw;
	  margin-bottom: 100px;
  }

  body.splash-body .tool-hammer {
    width: 60vw;
    margin-bottom: -78px;
	  margin-right: -50px;
  }

  /* ===== Mobile Global Shared ===== */
  .who-grid,
  .who-text,
  .services-text,
  .services-media {
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }

  .stat-item span,
  .footer p,
  .footer-links li,
  .copyright {
    font-size: 10px;
  }

  .nav .menu {
    padding-top: 118px;
    gap: 28px;
  }

  .nav .menu a,
  .nav .menu .active,
  .nav.is-sticky .menu a,
  .nav.is-sticky .menu .active {
    font-size: clamp(22px, 7vw, 34px);
  }

  .nav.menu-open .menu a.active::after,
  .nav.menu-open .menu .active::after,
  .nav.menu-open.is-sticky .menu a.active::after,
  .nav.menu-open.is-sticky .menu .active::after {
    background: #ffffff !important;
  }

  /* ===== Mobile Homepage + Inner Pages Hero Shared ===== */
  .hero {
    min-height: 395px;
    padding-top: 72px;
    background-position: 36% 20%;
  }

  body.about-page .about-hero,
  body.service-page .service-hero,
  body.contact-page .contact-hero,
  body.portfolio-exterior-page .portfolio-exterior-hero,
  body.portfolio-interior-page .portfolio-interior-hero {
    min-height: 360px;
  }

  .logo {
    margin-top: 5px;
    width: 138px;
  }

  .hero-content.page {
    position: absolute;
    top: 126px;
    left: 50%;
    right: auto;
    width: min(calc(100% - 48px), 470px);
    max-width: calc(100% - 48px);
    margin: 0;
    padding-top: 0;
    text-align: center;
    z-index: 4;
    transform: translateX(-50%);
  }

  /* ===== Mobile Inner Pages Hero Shared ===== */
  body.about-page .about-hero-content,
  body.service-page .service-hero-content,
  body.contact-page .contact-hero-content,
  body.portfolio-exterior-page .portfolio-exterior-hero-content,
  body.portfolio-interior-page .portfolio-interior-hero-content,
  body.about-page .about-hero-content.page,
  body.service-page .service-hero-content.page,
  body.contact-page .contact-hero-content.page,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page,
  body.portfolio-interior-page .portfolio-interior-hero-content.page {
    min-height: clamp(500px, 50vw, 840px);
    box-sizing: border-box;
  }

  /* ===== Mobile About Page ===== */
  body.about-page .about-intro {
    width: min(100%, 540px);
    margin: 70px auto 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 42px;
  }

  body.about-page .about-intro-frame {
    width: min(100%, 540px);
    min-height: auto;
    margin: 0 auto;
    padding: 0 34px 42px;
    display: block;
    text-align: left;
  }

 

  body.about-page .about-intro-frame::after {
    content: "";
    position: absolute;
    left: 34px;
    bottom: 0;
    width: min(280px, calc(100% - 68px));
    height: 3px;
    margin: 0;
    background: var(--olive);
  }

  body.about-page .about-intro-frame h2 {
    margin: 0 0 24px;
    width: 100%;
    max-width: 100%;
    font-size: clamp(42px, 7vw, 56px);
    line-height: 1.02;
  }

  body.about-page .about-intro-frame p {
    width: 100%;
    max-width: 100%;
    font-size: 14px;
    line-height: 1.78;
    text-align: justify;
    margin: 0;
  }

  body.about-page .about-intro-images {
    width: min(100%, 460px);
    max-width: 460px;
    height: auto;
    aspect-ratio: 42 / 33;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
  }

  body.about-page .about-photo-large {
    left: 0;
    bottom: 0;
    width: 64%;
    height: auto;
    aspect-ratio: 27 / 20;
  }

  body.about-page .about-photo-tall {
    left: 46%;
    top: 0;
    width: 54%;
    height: auto;
    aspect-ratio: 23 / 28;
  }

  body.about-page .about-hero-content h1,
  body.about-page .about-hero-content.page h1 {
    margin-top: -250px;
  }

  body.contact-page .contact-hero-content h1,
  body.contact-page .contact-hero-content.page h1 {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    margin-top: -250px;
    font-size: 80px;
    line-height: 1;
  }

  body.service-page .service-hero-content h1,
  body.service-page .service-hero-content.page h1 {
    margin-top: 30px;
  }

  body.service-page .service-hero-content,
  body.service-page .service-hero-content.page {
    place-items: start center;
    padding-top: 56px;
  }


  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1 {
    margin-top: -300px;
    font-size: 80px;
    line-height: 1;
  }

  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    margin-top: -300px;
    font-size: 80px;
    line-height: 1;
  }

  body.portfolio-exterior-page .portfolio-exterior-copy-frame h2 {
    font-size: clamp(38px, 6vw, 60px);
    line-height: 0.92;
  }

  body.portfolio-exterior-page .portfolio-exterior-gallery-head h2,
  body.portfolio-interior-page .portfolio-interior-gallery-head h2 {
    font-size: clamp(24px, 7vw, 38px);
    line-height: 0.94;
  }

  body.portfolio-exterior-page .portfolio-exterior-gallery-head h2 {
    font-size: clamp(22px, 6.2vw, 34px);
    margin-bottom: 12px;
  }

  body.portfolio-interior-page .portfolio-interior-gallery-head h2 {
    font-size: clamp(22px, 6.2vw, 34px);
    margin-bottom: 12px;
  }

  /* ===== Mobile Portfolio Exterior Page: Intro ===== */
  body.portfolio-exterior-page .portfolio-exterior-intro {
    width: calc(100% - 100px);
  }

  body.portfolio-exterior-page .portfolio-exterior-feature {
    width: 100%;
  }

  body.portfolio-exterior-page .portfolio-exterior-copy-frame p {
    max-width: 100%;
    font-size: 14px;
    line-height: 1.34;
  }

  body.portfolio-exterior-page .portfolio-exterior-points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 20px;
  }

  body.portfolio-exterior-page .portfolio-exterior-points ul {
    margin: 0;
    padding: 0;
  }

  body.portfolio-exterior-page .portfolio-exterior-points li {
    padding-left: 14px;
    font-size: 12px;
    line-height: 1.45;
  }

  body.portfolio-exterior-page .portfolio-exterior-points li::before {
    width: 6px;
    height: 6px;
    top: 10px;
  }

  /* ===== Mobile Portfolio Exterior Page: Actions ===== */
  body.portfolio-exterior-page .portfolio-exterior-actions {
    margin-top: 18px;
    margin-bottom: 25px;
    gap: 22px;
  }

  body.portfolio-exterior-page .portfolio-exterior-action,
  body.portfolio-exterior-page .portfolio-exterior-dropdown,
  body.portfolio-exterior-page .portfolio-exterior-dropdown-toggle,
  body.portfolio-exterior-page .portfolio-exterior-dropdown-menu {
    width: min(100%, 340px);
    min-width: min(100%, 340px);
  }

  body.portfolio-exterior-page .portfolio-exterior-action,
  body.portfolio-exterior-page .portfolio-exterior-dropdown-toggle {
    padding: 17px 26px;
  }

  /* ===== Mobile Portfolio Interior Page: Actions ===== */
  body.portfolio-interior-page .portfolio-interior-actions {
    margin-top: 18px;
    margin-bottom: 25px;
    gap: 22px;
  }

  body.portfolio-interior-page .portfolio-interior-action,
  body.portfolio-interior-page .portfolio-interior-dropdown,
  body.portfolio-interior-page .portfolio-interior-dropdown-toggle,
  body.portfolio-interior-page .portfolio-interior-dropdown-menu {
    width: min(100%, 340px);
    min-width: min(100%, 340px);
  }

  body.portfolio-interior-page .portfolio-interior-action,
  body.portfolio-interior-page .portfolio-interior-dropdown-toggle {
    padding: 17px 26px;
  }

  body.portfolio-exterior-page .portfolio-exterior-cta {
    margin-top: -200px;
    transform: translateY(28px);
  }

  body.portfolio-exterior-page .portfolio-exterior-gallery {
    width: calc(100% - 66px) !important;
    margin-bottom: 220px;
    display: block !important;
    column-count: 3 !important;
    column-gap: 28px !important;
    gap: 0 !important;
    grid-template-columns: none !important;
    grid-auto-rows: auto !important;
    min-height: 0 !important;
    padding-top: 0 !important;
  }

  body.portfolio-interior-page .portfolio-interior-cta {
    margin-top: -200px;
    transform: translateY(28px);
  }

  body.portfolio-interior-page .portfolio-interior-gallery {
    width: calc(100% - 16px) !important;
    margin-bottom: 220px;
    display: block !important;
    column-count: 3 !important;
    column-gap: -18px !important;
    min-height: 0 !important;
    padding-top: 0 !important;
  }

  body.portfolio-exterior-page .portfolio-card,
  body.portfolio-interior-page .portfolio-card {
    display: inline-block !important;
    width: 95% !important;
    box-sizing: border-box !important;
    margin: 0 0 14px !important;
    break-inside: avoid !important;
    page-break-inside: avoid !important;
    vertical-align: top !important;
  }

  body.portfolio-exterior-page .portfolio-card,
  body.portfolio-exterior-page .portfolio-card.wide {
    grid-column: auto !important;
  }

  body.portfolio-exterior-page .portfolio-card.is-visible,
  body.portfolio-interior-page .portfolio-card.is-visible,
  body.portfolio-exterior-page .portfolio-card.is-visible img,
  body.portfolio-interior-page .portfolio-card.is-visible img {
    animation-fill-mode: both !important;
  }

  body.portfolio-exterior-page .portfolio-card:not(.is-visible),
  body.portfolio-interior-page .portfolio-card:not(.is-visible) {
    opacity: 0 !important;
    transform: scale(0.06) !important;
  }

  body.portfolio-exterior-page .portfolio-card:not(.is-visible)::before,
  body.portfolio-interior-page .portfolio-card:not(.is-visible)::before {
    opacity: 1 !important;
  }

  body.portfolio-exterior-page .portfolio-card:not(.is-visible) img,
  body.portfolio-interior-page .portfolio-card:not(.is-visible) img {
    opacity: 0 !important;
  }

  body.portfolio-interior-page .portfolio-interior-points {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 20px;
  }

  /* ===== Mobile Portfolio Interior Page: Intro ===== */
  body.portfolio-interior-page .portfolio-interior-intro {
    width: calc(100% - 100px);
  }

  body.portfolio-interior-page .portfolio-interior-copy-frame h2 {
    font-size: clamp(38px, 6vw, 60px);
    line-height: 0.92;
  }

  body.portfolio-interior-page .portfolio-interior-copy-frame p {
    max-width: 100%;
    font-size: 14px;
    line-height: 1.34;
  }

  body.portfolio-interior-page .portfolio-interior-points ul {
    margin: 0;
    padding: 0;
  }

  body.portfolio-interior-page .portfolio-interior-points li {
    padding-left: 14px;
    font-size: 12px;
    line-height: 1.45;
  }

  body.portfolio-interior-page .portfolio-interior-points li::before {
    width: 6px;
    height: 6px;
    top: 10px;
  }

  body.contact-page .contact-hero-content h1 .contact-hero-line,
  body.contact-page .contact-hero-content.page h1 .contact-hero-line {
    display: block;
  }

  @media (max-width: 400px) {
    body.about-page .about-intro-images {
      width: calc(100% - 32px);
      max-width: calc(100% - 32px);
      overflow: hidden;
    }

    body.about-page .about-photo-large {
     
      bottom: 20%;
      width: 83%;
    }

    body.about-page .about-photo-tall {
      left: 34%;
      width: 60%;
    }

    body.about-page .about-intro {
      width: calc(100% - 28px);
      gap: 26px;
    }

    body.about-page .about-intro-frame {
      width: calc(100% - 8px);
      max-width: calc(100% - 8px);
      padding: 0 12px 28px;
      margin-inline: auto;
      box-sizing: border-box;
    }

    body.about-page .about-intro-frame::after {
      left: 12px;
      width: min(220px, calc(100% - 24px));
    }

    body.about-page .about-intro-frame h2 {
      font-size: 28px;
      line-height: 0.98;
      margin-bottom: 14px;
    }

    body.about-page .about-intro-frame p {
      font-size: 12px;
      line-height: 1.58;
      max-width: 100%;
    }

    .who-text {
      padding-bottom: 118px;
	margin-bottom: 2opx;
    }

    .who-grid {
      grid-template-columns: 126px 126px 126px;
      width: min(100%, calc((126px * 3) + (var(--r-who-gap) * 2)));
      margin-bottom: 28px;
    }

    .who .img-1,
    .who .img-2,
    .who .img-3 {
      width: 126px;
      height: 186px;
    }

    .who .word {
      font-size: 38px;
    }

    .about-hammer {
      width: 320px;
      right: -178px;
      top: 344px;
    }

    .hero-content {
      width: min(calc(100% - 24px), 320px);
      margin-inline: auto;
      text-align: center;
      
    }

    .hero-content h1 {
      width: 100%;
      max-width: 100%;
      margin-inline: auto;
      font-size: 76px !important;
      line-height: 0.95 !important;
      display: flex;
      justify-content: center;
      text-align: center;
      left: auto;
		
    }

    body.service-page .service-hero-content h1,
    body.service-page .service-hero-content.page h1 {
      font-size: 76px;
      line-height: 0.9;
      text-align: center;
		margin-top: 15%;
    }

    .hero-title-text {
      display: inline-block;
      width: auto;
    }

    .services-media {
      width: 320px;
      max-width: 320px;
      min-height: 360px;
      margin-left: auto;
      margin-right: auto;
    }

    .interior {
      left: 72px;
      top: 8px;
      font-size: 28px !important;
    }

    .exterior {
      left: 214px;
      bottom: 64px;
      font-size: 28px !important;
    }

    .svc-a,
    .svc-b {
      width: 176px;
      height: 232px;
    }

    .svc-a {
      left: -12px;
      top: 58px;
    }

    .svc-b {
      left: 212px;
      top: 40px;
    }

    body.contact-page .contact-hero-content,
    body.contact-page .contact-hero-content.page {
      width: min(calc(100% - 24px), 320px);
      max-width: calc(100% - 24px);
      left: 45%;
      right: auto;
      transform: translateX(-50%);
      text-align: center;
    }

    body.contact-page .contact-hero-content h1,
    body.contact-page .contact-hero-content.page h1 {
      width: 100%;
      max-width: 100%;
      margin-inline: auto;
      font-size: 76px;
      line-height: 0.94;
      text-align: center;
    }

    body.contact-page .contact-hero-content h1 .contact-hero-line,
    body.contact-page .contact-hero-content.page h1 .contact-hero-line {
      width: 100%;
      text-align: center;
    }

    body.portfolio-exterior-page .portfolio-exterior-hero-content,
    body.portfolio-exterior-page .portfolio-exterior-hero-content.page,
    body.portfolio-interior-page .portfolio-interior-hero-content,
    body.portfolio-interior-page .portfolio-interior-hero-content.page {
      width: min(calc(100% - 18px), 374px);
      max-width: calc(100% - 18px);
      left: 50%;
      right: auto;
      transform: translateX(-50%);
      text-align: center;
    }

    body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
    body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
    body.portfolio-interior-page .portfolio-interior-hero-content h1,
    body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
      width: 100%;
      max-width: 100%;
      margin-inline: auto;
      font-size: 60px;
      line-height: 0.94;
      text-align: center;
    }

    body.portfolio-exterior-page .portfolio-exterior-hero-line,
    body.portfolio-interior-page .portfolio-interior-hero-line {
      display: block;
      width: 100%;
      text-align: center;
    }

    body.portfolio-exterior-page .portfolio-exterior-intro {
      width: calc(100% - 28px);
    }

    body.portfolio-interior-page .portfolio-interior-intro {
      width: calc(100% - 30px);
    }

    body.portfolio-exterior-page .portfolio-exterior-copy-frame h2 {
      font-size: 30px;
      line-height: 0.94;
    }

    body.portfolio-interior-page .portfolio-interior-copy-frame h2 {
      font-size: 30px;
      line-height: 0.94;
    }

    body.portfolio-interior-page .portfolio-interior-copy-frame::after {
      width: 3px;
    }

    .float-up,
    .float-wa {
      width: 60px;
      height: 60px;
      right: 14px;
    }

    .float-up {
      bottom: 96px;
      background-size: 60%;
    }

    .float-wa {
      bottom: 25px;
    }

    .float-wa img {
      width: 34px;
      height: 34px;
    }

    body.about-page .core-card:first-child .core-card-title-lower {
      margin-top: 25px !important;
    }
  }

  /* ===== Mobile About Page: Values ===== */
  body.about-page .about-values {
    width: min(100%, 540px);
    margin: 200px auto 0;
  }

  body.about-page .vision-row,
  body.about-page .mission-row {
    width: 100%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 18px;
  }

  body.about-page .mission-row {
    margin-top: 34px;
  }

  body.about-page .about-values h2 {
    font-size: clamp(28px, 6vw, 42px);
    margin: 0;
  }

  body.about-page .vision-row h2,
  body.about-page .mission-row h2 {
    width: auto;
    justify-self: start;
  }

  body.about-page .vision-box,
  body.about-page .mission-box {
    width: min(100%, 700px);
    min-height: 140px;
    margin: 0;
    justify-self: start;
  }

  body.about-page .vision-box {
    margin-left: 20%;
    padding: 38px 18px 28px 46px;
    clip-path: polygon(20% 0, 100% 0, 100% 100%, 0 100%, 0 50%);
  }

  body.about-page .vision-box p {
    max-width: 88%;
    margin: 0;
    font-size: 14px;
    line-height: 1.75;
    text-align: justify;
	  padding-left: 20px;
  }

  body.about-page .mission-box {
	   margin-left: -60px;
    width: min(100%, 700px);
    justify-self: start;
    clip-path: var(--mission-shape);
  }

  body.about-page .mission-box p {
    margin-left: 0;
    padding: 10px 18px 26px 46px;
    max-width: 88%;
    font-size: 14px;
    line-height: 1.75;
    text-align: justify;
  }

  body.about-page .mission-row h2 {
    justify-self: end;
  }

  /* ===== Mobile About Page: Why Choose Muhibah ===== */
  body.about-page .why-about {
    margin-top: 42px;
  }

  body.about-page .why-about-grid {
    width: min(100%, 540px);
    min-height: auto;
    margin: 0 auto;
    padding: 30px 34px 34px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(7, auto);
    grid-template-areas:
      "copy copy"
      "sofa sofa"
      "exp exp"
      "tool sparks"
      "solutions solutions"
      "handshake handshake"
      "customer customer";
    row-gap: 18px;
    column-gap: 12px;
    align-items: start;
    justify-items: stretch;
  }

  body.about-page .why-about-grid::before {
    margin-left: 0;
    background-position: center bottom;
    background-size: auto 58%;
    opacity: 0.18;
  }

  body.about-page .why-copy {
    grid-area: copy;
    align-self: start;
    padding-left: 0;
  }

  body.about-page .why-copy h2 {
    margin-bottom: 0;
    font-size: clamp(40px, 8vw, 54px);
    line-height: 0.98;
  }

  body.about-page .why-card-handshake,
  body.about-page .why-card-sparks,
  body.about-page .why-card-sofa,
  body.about-page .why-card-tool,
  body.about-page .why-stat-left,
  body.about-page .why-stat-center,
  body.about-page .why-stat-right {
    margin: 0;
    justify-self: stretch;
    align-self: start;
  }

  body.about-page .why-card {
    --why-border: 8px;
  }

  body.about-page .why-card-sofa {
    grid-area: sofa;
    --why-cut: polygon(0 0, 86% 0, 100% 50%, 100% 100%, 0 100%);
    width: 100%;
    height: auto;
    aspect-ratio: 28 / 9;
  }

  body.about-page .why-card-sofa img {
    object-position: center 75%;
  }

  body.about-page .why-stat-right {
    grid-area: exp;
    margin-bottom: 0;
  }

  body.about-page .why-card-tool {
    grid-area: tool;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 0.78;
  }

  body.about-page .why-card-sparks {
    grid-area: sparks;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 0.78;
  }

  body.about-page .why-stat-center {
    grid-area: solutions;
  }

  body.about-page .why-card-handshake {
    grid-area: handshake;
    --why-cut: polygon(0 0, 100% 0, 100% 100%, 14% 100%, 0 50%);
    width: 100%;
    height: auto;
    aspect-ratio: 28 / 9;
	  object-position: center 60%;
  }

  body.about-page .why-stat-left {
    grid-area: customer;
  }

  body.about-page .why-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    text-align: center;
    transform: none;
    transform-origin: center top;
  }

  body.about-page .why-stat strong {
    font-size: clamp(38px, 7vw, 52px);
    line-height: 1;
  }

  body.about-page .why-stat span {
    margin-top: 0;
    font-size: clamp(18px, 3.8vw, 28px);
    line-height: 1.18;
  }

  /* ===== Mobile About Page: Core Values ===== */
  body.about-page .core-values {
    width: calc(100% - 24px);
    max-width: 800px;
    margin: 0 auto;
    padding-top: 18px;
    padding-bottom: 74px;
  }

  body.about-page .core-values h2 {
    font-size: clamp(32px, 9vw, 64px);
    margin-bottom: 20px;
	  text-align: center;
  }

  body.about-page .core-grid {
    grid-template-columns: repeat(2, minmax(0, 300px));
    gap: 24px;
    justify-content: center;
    justify-items: center;
  }

  body.about-page .core-card {
    width: 100%;
    min-height: 192px;
    height: 420px;
    padding: 30px 12px 12px;
    left: auto;
    box-sizing: border-box;
  }

  body.about-page .core-card::after {
    inset: 3px;
  }

  body.about-page .core-card img:not(.core-card-icon-large) {
    width: 58px !important;
    height: 58px !important;
    margin-bottom: 14px;
	   margin-top: 14px;
  }

  body.about-page .core-card-icon-large {
    width: 72px !important;
    margin-bottom: 14px;
	 
  }

  body.about-page .core-card h3 {
    font-size: 20px;
    margin-bottom: 10px;
    min-height: 44px;
	  text-align: left;
  }

  body.about-page .core-card p {
    font-size: 14px;
    line-height: 1.5;
  }

  @media (min-width: 501px) and (max-width: 700px) {
    body.about-page .core-values {
      width: calc(100% - 8px);
    }

    body.about-page .core-grid {
      gap: 16px;
    }

    body.about-page .core-card {
      height: 340px;
    }
  }

  @media (max-width: 500px) {
    body.about-page .core-values {
      width: calc(100% - 8px);
    }

    body.about-page .core-values h2 {
      font-size: clamp(30px, 10vw, 46px);
    }

    body.about-page .core-grid {
      width: 100%;
      gap: 14px;
      margin-inline: auto;
      transform: translateX(-44px);
    }

    body.about-page .core-card {
      height: 280px;
      min-height: 180px;
    }

    body.about-page .core-card h3 {
      font-size: 17px;
      line-height: 1.08;
      overflow-wrap: break-word;
    }

    body.about-page .core-card p {
      font-size: 12px;
      line-height: 1.45;
      overflow-wrap: break-word;
    }
  }

  body.about-page .core-card-title-lower,
  body.about-page .core-card-title-tight {
    min-height: 44px;
    margin-top: 0 !important;
  }

  body.about-page .core-card:first-child .core-card-icon-large {
    margin-top: 18px;
    margin-bottom: 14px;
  }

  body.about-page .core-card:first-child h3 {
    margin-top: 25px;
  }
	 body.about-page .core-card:first-child p {
    margin-top: -2px;
  }
	
	

  @media (max-width: 400px) {
    body.about-page .core-values {
      width: calc(100% - 8px);
    }

    body.about-page .core-values h2 {
      font-size: clamp(32px, 10vw, 40px);
    }

    body.about-page .core-grid {
      width: 100%;
      gap: clamp(10px, 3vw, 12px);
      transform: translateX(clamp(-32px, -12vw, -20px));
    }

    body.about-page .core-card {
      height: clamp(236px, 80vw, 300px);
      min-height: clamp(154px, 48vw, 192px);
      padding: clamp(24px, 7.5vw, 30px) clamp(10px, 3vw, 12px) clamp(10px, 3vw, 12px);
		margin-left:40opx；
    }

    body.about-page .core-card img:not(.core-card-icon-large) {
      width: clamp(46px, 14.5vw, 58px) !important;
      height: clamp(46px, 14.5vw, 58px) !important;
      margin-top: clamp(11px, 3.5vw, 14px);
      margin-bottom: clamp(11px, 3.5vw, 14px);
    }

    body.about-page .core-card-icon-large {
      width: clamp(58px, 18vw, 72px) !important;
      margin-bottom: clamp(11px, 3.5vw, 14px);
    }

    body.about-page .core-card h3 {
      font-size: clamp(14px, 4.25vw, 17px);
      line-height: 1.08;
      min-height: clamp(35px, 11vw, 44px);
      margin-bottom: clamp(8px, 2.5vw, 10px);
    }

    body.about-page .core-card p {
      font-size: clamp(10px, 3vw, 12px);
      line-height: 1.45;
    }

    body.about-page .core-card-title-lower,
    body.about-page .core-card-title-tight {
      min-height: clamp(35px, 11vw, 44px);
    }

    body.about-page .core-card:first-child .core-card-icon-large {
      margin-top: clamp(14px, 4.5vw, 18px);
      margin-bottom: clamp(11px, 3.5vw, 14px);
    }

    body.about-page .core-card:first-child h3 {
      margin-top: clamp(20px, 6.25vw, 25px) !important;
    }
  }

  /* ===== Mobile Homepage ===== */
  .hero-content h1 {
    margin-top: 18px;
    font-size: 96px;
    line-height: 1;
  }

  .hero-content p {
    max-width: min(100%, 440px);
    margin-top: 0;
    margin-inline: auto;
    font-size: 24px;
    line-height: 1.2;
  }

  .who-grid {
    grid-template-columns: repeat(3, clamp(110px, 28vw, 138px));
    width: min(100%, calc((clamp(110px, 28vw, 138px) * 3) + (var(--r-who-gap) * 2)));
    margin-bottom: 30px;
  }

  .who .img-1,
  .who .img-2,
  .who .img-3 {
    width: clamp(110px, 28vw, 138px);
    height: clamp(163px, 41vw, 204px);
  }

  .who .word {
    font-size: clamp(34px, 8.8vw, 41px);
  }

  .who-text {
    width: 360px;
    max-width: 360px;
    min-width: 360px;
    padding: 34px 26px 118px;
    box-sizing: border-box;
    border-right: 2px solid var(--olive);
  }

  .who-text::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 36%;
    height: 2px;
    background: var(--olive);
  }

  .who-text::after {
    content: "";
    position: absolute;
    left: 26%;
    right: 0;
    bottom: 0;
    height: 2px;
    background: var(--olive);
  }

  .who-text p {
    width: 100%;
    max-width: 100%;
    margin-bottom: 14px;
    font-size: 14px;
    line-height: 1.65;
    text-align: justify;
  }

  .who-text .btn-dark,
  .who-text .btn-learn,
  .who-text .btn-dark.btn-learn {
    width: 240px;
    min-width: 240px;
    max-width: 240px;
    min-height: 50px;
    margin-top: 12px;
    margin-left: auto;
    margin-right: auto;
    padding: 14px 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    line-height: 1;
  }

  .about-hammer {
    width: clamp(320px, 81vw, 400px);
    right: clamp(-220px, -44vw, -180px);
    top: clamp(220px, 56vw, 260px);
    transform: rotate(-24deg);
    transform-origin: center center;
  }

  .who.hammer-active .about-hammer {
    animation: hammerEnterPhone 1.4s cubic-bezier(0.22, 0.84, 0.24, 1) forwards;
  }

  .who.hammer-idle .about-hammer {
    animation: hammerSwayPhone 2.9s cubic-bezier(0.12, 0, 0.2, 1) infinite alternate;
    animation-fill-mode: both;
  }

  .stats-roller {
    left: -170px;
    top: -240px;
    width: 300px;
  }

  .stats {
    margin-top: 22px;
  }

  .stats::before {
    left: -56px;
    right: 0;
    width: calc(150% + 56px);
    background-position: left -72px;
    background-size: auto 200%;
  }

  .stats-grid {
    gap: 14px 8px;
  }

  .stat-item strong {
    font-size: 48px;
  }

  .services {
    display: block;
    padding: 36px 0 18px;
  }

  .services::after {
    bottom: -18px;
    height: 42px;
  }

  .services-text {
    width: min(100%, 560px);
    max-width: 560px;
    margin: 0 auto;
  }

  .services h2 {
    margin-left: 0;
    margin-bottom: 14px;
  }

  .services-text p {
    width: 100%;
    max-width: 100%;
    margin: 0 0 22px;
    font-size: 14px;
    line-height: 1.8;
    text-align: justify;
  }

  .services-text .btn-dark {
    width: 240px;
    min-width: 240px;
    max-width: 240px;
    margin-left: 0;
    margin-right: auto;
    padding: 14px 28px;
    font-size: 16px;
  }

  .services-media {
    --services-card-width: clamp(132px, 35vw, 220px);
    --services-card-height: clamp(174px, 46vw, 290px);
    --services-media-gap: clamp(16px, 5vw, 56px);
    --services-media-left: max(0px, calc((100% - var(--services-card-width) - var(--services-card-width) - var(--services-media-gap)) / 2));
    --services-label-size: clamp(21px, 5vw, 34px);
    --services-card-a-top: clamp(58px, 12vw, 84px);
    --services-card-b-top: clamp(22px, 6vw, 42px);
    width: min(100%, 590px);
    max-width: min(560px, calc(100vw - 32px));
    min-height: clamp(460px, 73vw, 460px);
    margin-top: 48px;
	  margin-bottom: 48px;
	  margin-left: clamp(0px, calc(20vw - 100px), 20%);
	
    position: relative;
    display: block;
  }

  .services-media h3 {
    margin: 0;
    font-size: var(--services-label-size);
    line-height: 1;
    white-space: nowrap;
  }


  .interior {
    left: calc(var(--services-media-left) + clamp(40px, 10vw, 60px));
    top: clamp(25px, 5vw, 40px);
    font-size: var(--services-label-size) !important;
  }

  .exterior {
    left: calc(var(--services-media-left) + var(--services-card-width) + var(--services-media-gap) + clamp(14px, 4vw, 16px));
    top: calc(var(--services-card-b-top) + var(--services-card-height) + clamp(10px, 2.5vw, 18px));
    bottom: auto;
    font-size: var(--services-label-size) !important;
  }

  .svc-a {
    left: var(--services-media-left);
    top: var(--services-card-a-top);
    width: var(--services-card-width);
    height: var(--services-card-height);
  }

  .svc-b {
    left: calc(var(--services-media-left) + var(--services-card-width) + var(--services-media-gap));
    top: var(--services-card-b-top);
    width: var(--services-card-width);
    height: var(--services-card-height);
  }

  .services-wrench-wrap {
    position: absolute;
    left: auto;
    right: clamp(106px, 22vw, 130px);
    top: clamp(228px, 36vw, 250px);
    width: 76px;
    height: 96px;
    overflow: visible;
    z-index: 6;
    pointer-events: none;
  }

  .services-wrench-wrap::before {
    content: none !important;
  }

  .services-wrench {
    display: block !important;
    width: clamp(270px, 30vw, 290px) !important;
    height: auto !important;
    max-width: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: scaleX(-1) rotate(122deg);
    transform-origin: 72% 88%;
  }

  .services.wrench-active .services-wrench {
    opacity: 1 !important;
    animation: wrenchEnterPhone 1.08s cubic-bezier(0.22, 0.84, 0.24, 1) forwards !important;
    transform-origin: 72% 88% !important;
  }

  .services.wrench-idle .services-wrench {
    opacity: 1 !important;
    animation: wrenchSwayPhone 2.6s ease-in-out infinite alternate !important;
    transform-origin: 72% 88% !important;
  }

  @media (max-width: 500px) {
    .services-wrench {
      width: clamp(238px, 34vw, 238px) !important;
    }

    .previous-head h2 {
      width: calc(120vw - 112px) !important;
      min-width: 0 !important;
      max-width: calc(120vw - 112px) !important;
      margin-left: -250px !important;
      padding-left: 24px !important;
      padding-right: 18px !important;
      font-size: clamp(24px, 6vw, 30px) !important;
    }
  }

  @media (max-width: 400px) {
    .services-media {
      min-height: clamp(300px, 86vw, 340px);
      margin-bottom: 18px;
    }

    .services-wrench-wrap {
      right: clamp(68px, 34vw, 60px);
    }

    .services-wrench {
      width: clamp(200px, 32vw, 210px) !important;
		right: clamp(36px, 32vw, 40px);
    }
  }

  .previous-head {
    display: flex;
    flex-direction: column-reverse;
    align-items: flex-start;
    margin-bottom: 18px;
  }

  .previous-head h2 {
    width: fit-content;
    max-width: 430px;
    min-width: 430px;
    margin-bottom: 16px;
    margin-left: -300px;
    padding: 8px 18px 10px 26px;
	  font-size: 28px;
  }

  .previous-head p {
    max-width: 360px;
    margin: 0;
    font-size: 14px;
    line-height: 1.8;
	  margin-left: -330px;
  }

  .previous-screwdriver {
    width: 320px;
    top: 400px;
    right: -150px;
  }

  .previous-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    margin-top: 18px;
  }

  .previous-explore-btn {
    width: 328px;
    min-width: 328px;
    padding: 13px 20px;
    font-size: 14px;
    line-height: 1.1;
  }

  .cta {
    margin-top: 2px;
    margin-bottom: -120px;
    transform: translateY(42px);
  }

  .cta-card {
    width: min(100% - 34px, 420px);
    min-height: 266px;
    margin-top: 18px;
    padding: 22px 18px;
  }

  .cta-card::after {
    inset: 20px 20px 20px 20px;
  }

  .cta-card h2 {
    font-size: 26px;
    line-height: 1.18;
    margin-bottom: 14px;
  }

  .cta-card .btn,
  .cta-card .btn-dark,
  .cta-card a.btn,
  .cta-card a.btn-dark {
    width: 220px;
    min-width: 220px;
    max-width: 220px;
    padding: 12px 22px;
    font-size: 15px;
    justify-content: center;
  }

  body.service-page .service-cta-wrap .cta-card,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card {
    width: min(100% - 34px, 420px);
    min-height: 266px;
    margin-top: 18px;
    padding: 22px 18px;
  }

  body.service-page .service-cta-wrap .cta-card h2,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card h2,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card h2 {
    font-size: 26px;
    line-height: 1.18;
    margin-bottom: 14px;
  }

  body.service-page .service-cta-wrap .cta-card .btn,
  body.service-page .service-cta-wrap .cta-card .btn-dark,
  body.service-page .service-cta-wrap .cta-card a.btn,
  body.service-page .service-cta-wrap .cta-card a.btn-dark,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card .btn,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card .btn-dark,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card a.btn,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card a.btn-dark,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card .btn,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card .btn-dark,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card a.btn,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card a.btn-dark {
    width: 220px;
    min-width: 220px;
    max-width: 220px;
    padding: 12px 22px;
    font-size: 15px;
    justify-content: center;
  }

  .footer-grid {
    width: min(100% - 44px, 320px);
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 54px;
  }

  .footer-logo {
    width: 132px;
    margin-bottom: 14px;
  }

  .footer p {
    font-size: 14px;
    line-height: 1.55;
  }

  .socials {
    margin-top: 16px;
    gap: 16px;
  }

  .socials a {
    width: 30px;
    height: 30px;
  }

  .footer-links {
    margin-left: 0;
  }

  .footer-links h3 {
    font-size: 28px;
    margin-bottom: 16px;
  }

  .footer-links li {
    margin-top: 18px;
  }

  .footer-links a {
    font-size: 12px;
    line-height: 1.4;
  }

  .copyright {
    width: 100%;
    margin-inline: auto;
    text-align: center;
    padding-top: 12px;
  }

  body.contact-page .footer-grid {
    width: min(100% - 44px, 390px);
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 54px;
  }

  body.contact-page .copyright {
    width: 100%;
  }

  body.contact-page .footer {
    margin-top: 0;
  }

  body.contact-page .footer-top-curve {
    top: -72px;
    height: 118px;
    left: -4%;
    right: -4%;
  }

  body.contact-page .footer-logo {
    width: 132px;
    margin-bottom: 14px;
  }

  body.contact-page .footer p {
    font-size: 14px;
    line-height: 1.55;
  }

  body.contact-page .socials {
    margin-top: 16px;
    gap: 16px;
  }

  body.contact-page .socials a {
    width: 30px;
    height: 30px;
  }

  body.contact-page .footer-links {
    margin-left: 0;
  }

  body.contact-page .footer-links h3 {
    font-size: 28px;
    margin-bottom: 2px;
  }

  body.contact-page .footer-links li {
    margin-top: 18px;
  }

  body.contact-page .footer-links a {
    font-size: 12px;
    line-height: 1.4;
  }

  body.contact-page .copyright {
    width: calc(100% - 28px);
    margin-inline: auto;
    text-align: center;
    padding-top: 12px;
  }

  /* ===== Mobile Contact Page: Contact Section ===== */
  body.contact-page .contact-section {
    padding: 44px 0 24px;
  }

  body.contact-page .contact-success-panel {
    width: min(86vw, 560px);
    min-height: 340px;
    padding: 34px 34px 30px;
  }

  body.contact-page .contact-success-logo {
    width: min(44vw, 240px);
    height: min(36vw, 200px);
    left: 0;
    bottom: 0;
  }

  body.contact-page .contact-success-panel h2 {
    max-width: 100%;
    margin: 0 auto 18px;
    font-size: clamp(30px, 6.2vw, 46px);
  }

  body.contact-page .contact-success-panel p {
    max-width: min(100%, 360px);
    font-size: 17px;
    line-height: 1.45;
  }

  body.contact-page .contact-shell {
    width: min(calc(100% - 48px), 540px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 36px;
  }

  body.contact-page .contact-copy {
    padding-top: 0;
  }

  body.contact-page .contact-eyebrow {
    display: none;
  }

  body.contact-page .contact-copy h2 {
    position: relative;
    margin: 50px 0 30px;
    color: transparent;
    font-size: 0;
    line-height: 0;
    width: auto;
	  
  }

  body.contact-page .contact-copy h2 br {
    display: none;
  }

  body.contact-page .contact-copy h2::before {
    display: block;
    color: var(--purple);
    content: "GET IN TOUCH";
    font-size: clamp(42px, 8.5vw, 62px);
    line-height: 0.96;
  }

  body.contact-page .contact-intro {
    max-width: 100%;
    margin: 0 0 28px;
    font-size: 14px;
    line-height: 1.5;
  }

  body.contact-page .contact-info-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px 28px;
  }

  body.contact-page .contact-info-item {
    display: block;
  }

  body.contact-page .contact-info-icon {
    width: 68px;
    height: 68px;
    margin: 0 0 10px;
    border-radius: 10px;
  }

  body.contact-page .contact-info-item h3 {
    margin: 0 0 6px;
    font-size: 16px;
    line-height: 1.15;
  }

  body.contact-page .contact-info-item p,
  body.contact-page .contact-info-item a {
    font-size: 14px;
    line-height: 1.45;
    width: 100%;
  }

  body.contact-page .contact-inline-socials {
    gap: 18px;
    margin-top: 40px;
	  margin-bottom: 50px;
  }

  body.contact-page .contact-inline-socials a {
    width: 32px;
    height: 32px;
  }

  /* ===== Mobile Contact Page: Form + Map ===== */
  body.contact-page .contact-form-wrap {
    padding-top: 0;
  }

  body.contact-page .contact-form {
    width: 100%;
    padding: 24px 18px 18px;
  }

  body.contact-page .contact-form label {
    margin-bottom: 6px;
    font-size: 12px;
  }

  body.contact-page .contact-form input {
    height: 38px;
    padding: 0 12px;
    margin-bottom: 12px;
    font-size: 14px;
  }

  body.contact-page .contact-form textarea {
    height: 120px;
    padding: 10px 12px;
    margin-bottom: 12px;
    font-size: 14px;
  }

  body.contact-page .contact-submit {
    padding: 12px 16px;
  }

  body.contact-page .contact-map-shell {
    width: 100%;
    margin: 0 auto;
    padding-inline: 18px;
    box-sizing: border-box;
  }

  body.contact-page .contact-map-card {
    width: 100%;
  }

  /* ===== Mobile Service Page ===== */
  /* ===== Mobile Service Page: Shared Exterior + Interior ===== */
  body.service-page .service-copy-exterior .btn-dark,
  body.service-page .service-copy-interior .btn-dark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 268px;
    min-width: 268px;
    padding: 15px 30px;
    font-size: 16px;
  }

  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 26px !important;
  }

  body.service-page .service-feature-exterior .service-copy,
  body.service-page .service-feature-interior .service-copy {
    order: 1 !important;
    justify-self: start !important;
    margin: 0 !important;
    text-align: left !important;
    opacity: 0;
    transform: translateX(96px);
  }

  body.service-page .service-feature-exterior .service-collage,
  body.service-page .service-feature-interior .service-collage {
    order: 2 !important;
    justify-self: start !important;
    margin: 0 !important;
  }

  /* ===== Mobile Service Page: Intro ===== */
  body.service-page .service-intro {
    margin-bottom: 28px;
  }

  body.service-page .service-intro h2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    font-size: 48px;
    text-align: center;
    line-height: 1.02;
  }

  body.service-page .service-intro h2 span {
    display: block;
  }

  body.service-page .service-intro p {
    width: 100%;
    max-width: 100%;
    margin: 0 0 22px;
    font-size: 14px;
    line-height: 1.8;
    text-align: center;
  }

  /* ===== Mobile Service Page: Exterior ===== */
  body.service-page .service-feature-exterior {
    width: min(100%, 420px);
    gap: 30px !important;
    justify-items: center;
    position: relative;
    left: 24px;
  }

  body.service-page .service-feature-exterior .service-copy-exterior {
    order: 1 !important;
    width: min(100%, 1250px);
    text-align: left;
    padding-left: 50px;
  margin-bottom: 50px;

  }

  body.service-page .service-feature-exterior .exterior-collage {
    order: 2 !important;
  }

  body.service-page .service-copy-exterior h3 {
    font-size: 42px;
   
  }

  body.service-page .service-copy-exterior p {
    mmargin-bottom: 40px;
    font-size: 14px;
    line-height: 1.7;
	  width: 150%;
    max-width: 150%;
  }

  body.service-page .service-feature-exterior .service-collage {
    width: min(100%, 450px);
    gap: 12px !important;
    justify-self: center !important;
  }

  body.service-page .service-feature-exterior .service-card::before {
    inset: 0;
  }

  body.service-page .service-feature-exterior .service-card img,
  body.service-page .service-feature-exterior .service-card-overlay-text {
    inset: 4px;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
  }

  body.service-page .service-copy-exterior .btn-dark {
    width: 240px;
    min-width: 240px;
    max-width: 240px;
    height: auto;
    min-height: 0;
    padding: 17px 16px;
    font-size: 12px;
    justify-content: center;
	  margin-bottom: 50px;
  }

  body.service-page .service-feature-exterior .service-card-overlay-text {
    font-size: 25px;
  }

  /* ===== Mobile Service Page: Interior ===== */
  body.service-page .service-feature-interior .service-copy-interior {
    order: 1 !important;
    width: min(100%, 1250px);
    text-align: right;
    padding-left: 92px;
    margin-bottom: 50px;
	  margin-right: -900px;
    position: relative;
    left: 150px;
  }

  body.service-page .service-feature-interior {
    position: relative;
    left: 14px;
  }

  body.service-page .service-feature-interior.is-visible .service-copy {
    animation: serviceCopySlideInRightPhone 1.02s cubic-bezier(0.22, 1, 0.36, 1) 0.04s forwards;
  }

  body.service-page .service-feature-interior .interior-collage {
    order: 2 !important;
  }

  body.service-page .service-copy-interior h3 {
    font-size: 42px;
    position: relative;
    right: auto;
    left: 30px;
    opacity: 0;
    transform: translateX(72px);
  }

  body.service-page .service-copy-interior p {
    margin: 0 0 30px;
    position: relative;
    right: auto;
    left: -80px;
    font-size: 14px;
    line-height: 1.7;
    width: 150%;
    max-width: 150%;
    margin-left: auto;
    opacity: 0;
    transform: translateX(72px);
	  text-align: right;
  }

  body.service-page .service-feature-interior .service-collage {
    width: min(100%, 450px);
    gap: 12px !important;
    justify-self: center !important;
  }

  body.service-page .service-feature-interior .service-card::before {
    inset: 0;
  }

  body.service-page .service-feature-interior .service-card img,
  body.service-page .service-feature-interior .service-card-overlay-text {
    inset: 4px;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
  }

  body.service-page .service-copy-interior .btn-dark {
    width: 240px;
    min-width: 240px;
    max-width: 240px;
    height: auto;
    min-height: 0;
    padding: 17px 16px;
    font-size: 12px;
    justify-content: center;
    margin-bottom: 50px;
    position: relative;
    margin-right: 0;
    left: -5px;
    opacity: 0;
    transform: translateX(72px);
  }

  body.service-page .service-feature-interior .service-card-overlay-text {
    font-size: 25px;
  }

  body.service-page .service-feature-interior.is-visible .service-copy-interior h3 {
    animation: serviceCopySlideInRightPhoneText 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.04s forwards;
  }

  body.service-page .service-feature-interior.is-visible .service-copy-interior p {
    animation: serviceCopySlideInRightPhoneText 0.96s cubic-bezier(0.22, 1, 0.36, 1) 0.16s forwards;
  }

  body.service-page .service-feature-interior.is-visible .service-copy-interior .btn-dark {
    animation: serviceCopySlideInRightPhoneText 1s cubic-bezier(0.22, 1, 0.36, 1) 0.28s forwards;
  }

  /* ===== Mobile Service Page: How We Work ===== */
  body.service-page .service-work-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "icon-a"
      "step-1"
      "icon-b"
      "step-2"
      "icon-c"
      "step-3"
      "icon-d"
      "step-4";
    justify-items: center;
    row-gap: 32px;
    margin-top: 68px;
  }

  body.service-page .service-work-step-1,
  body.service-page .service-work-step-2,
  body.service-page .service-work-step-3,
  body.service-page .service-work-step-4 {
    transform: none;
  }

  body.service-page .service-work-icon {
    width: 120px;
    height: 120px;
    justify-self: center;
    align-self: center;
    place-self: center;
  }

  body.service-page .service-work-icon img {
    width: 60px;
    height: 60px;
    display: block;
    margin-inline: auto;
  }

  body.service-page .service-work-step {
    width: 216px;
    height: 232px;
    padding: 20px 18px;
  }

  body.service-page .service-work-step h3,
  body.service-page .service-work-step p,
  body.service-page .service-work-step-1 h3,
  body.service-page .service-work-step-1 p,
  body.service-page .service-work-step-2 h3,
  body.service-page .service-work-step-2 p,
  body.service-page .service-work-step-3 h3,
  body.service-page .service-work-step-3 p,
  body.service-page .service-work-step-4 h3,
  body.service-page .service-work-step-4 p {
    top: 0;
  }

  body.service-page .service-work-step-detail {
    font-size: 14px;
	  padding-left: 25px;
    padding-right: 25px;
  }

  body.service-page .service-work-step-1 .service-work-step-detail,
  body.service-page .service-work-step-3 .service-work-step-detail,
  body.service-page .service-work-step-2 .service-work-step-detail,
  body.service-page .service-work-step-4 .service-work-step-detail {
    padding-left: 25px;
    padding-right: 25px;
  }

  body.service-page .service-work-icon-c img {
    position: static;
  }

  /* ===== Mobile Service Page: Assurance Statements ===== */
  body.service-page .service-assurance-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.service-page .service-assurance-copy {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    align-items: start;
    column-gap: 16px;
    min-height: auto;
    padding: 0;
  }

  body.service-page .service-assurance-people {
    position: static;
    width: 260px;
    margin-left: -28px;
    grid-column: 1;
    grid-row: 1;
  }

  body.service-page .service-assurance-copy-text {
    grid-column: 2;
    grid-row: 1;
    max-width: none;
    padding-left: 0;
    align-self: start;
  }

  body.service-page .service-assurance-copy-text h2 {
    margin-bottom: 12px;
	  margin-left: -60px;
    font-size: 54px;
    line-height: 0.95;
    text-align: left;
  }

  body.service-page .service-assurance-copy-text p {
    margin: 0;
    max-width: none;
    width: 100%;
    padding-left: 0;
    font-size: 14px;
    line-height: 1.7;
    text-align: justify;
  }

  body.service-page .service-assurance-bars {
    display: grid;
    gap: 14px;
    padding-top: 0;
  }

	body.service-page .service-assurance-bar {
		  min-height: auto;
    width: 100%;
    padding: 28px 26px;
	}
	body.service-page .service-assurance-bar-top{
	  margin-left: 50px;	
	}
	body.service-page .service-assurance-bar-middle{
		  margin-left: 100px;	
	}
  body.service-page .service-assurance-bar-bottom {
    margin-left: 150px;
	}
  body.service-page .service-assurance-bar h3 {
    font-size: 28px;
    line-height: 1.02;
	  margin-left: 20px;
  }

  body.service-page .service-assurance-bar p {
    padding-top: 6px;
	  margin-left: 20px;
    font-size: 14px;
    line-height: 1.2;
  }

  /* ===== Mobile Service Page: We Serve At ===== */
  body.service-page .service-area-grid {
    grid-template-columns: 170px minmax(0, 1fr);
    grid-template-areas:
      "map copy"
      "map truck";
    align-items: start;
    gap: 12px 18px;
	  margin-bottom: -120px;
  }

  body.service-page .service-area-map {
    grid-area: map;
    align-self: start;
  }

  body.service-page .service-area-map img {
    width: 100%;
    margin-left: 0;
  }

  body.service-page .service-area-copy {
    grid-area: copy;
    align-self: start;
    padding-left: 0;
  }

  body.service-page .service-area-copy h2 {
    margin: 0 0 10px;
    font-size: 42px;
    text-align: left;
  }

  body.service-page .service-area-copy ul {
    padding-left: 24px;
    font-size: 14px;
    line-height: 1.7;
    text-align: left;
  }

  body.service-page .service-area-truck {
    grid-area: truck;
    align-self: end;
    margin-top: 0;
    margin-left: 0;
   
  }

  body.service-page .service-area-truck img {
    width: 130%;
    margin-left: 0;
  }

  /* ===== Mobile Service Page: Footer ===== */
  body.service-page .footer p {
    font-size: 14px;
    line-height: 1.55;
  }

  body.service-page .footer-links h3 {
    font-size: 28px;
    margin-bottom: 16px;
  }

  body.service-page .footer-links a {
    font-size: 12px;
    line-height: 1.4;
  }
}

@keyframes hammerSwayPhone {
  0% {
    transform: translateY(0) scaleX(-1) rotate(14deg);
  }

  100% {
    transform: translateY(10px) scaleX(-1) rotate(24deg);
  }
}

@keyframes serviceCopySlideInRightPhone {
  from {
    opacity: 0;
    transform: translateX(96px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes serviceCopySlideInRightPhoneText {
  from {
    opacity: 0;
    transform: translateX(72px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes hammerEnterPhone {
  0% {
    opacity: 0;
    transform: translateX(30px) translateY(-180px) scaleX(-1) rotate(-62deg);
  }

  72% {
    opacity: 1;
    transform: translateX(0) translateY(10px) scaleX(-1) rotate(24deg);
  }

  100% {
    opacity: 1;
    transform: translateX(0) translateY(0) scaleX(-1) rotate(14deg);
  }
}

@keyframes wrenchEnterPhone {
  0% {
    opacity: 0;
    transform: translateX(46px) translateY(112px) scaleX(-1) rotate(74deg);
  }

  100% {
    opacity: 1;
    transform: translateX(0) translateY(0) scaleX(-1) rotate(22deg);
  }
}

@keyframes wrenchSwayPhone {
  0% {
    transform: translateX(0) translateY(0) scaleX(-1) rotate(22deg);
  }

  100% {
    transform: translateX(6px) translateY(-6px) scaleX(-1) rotate(28deg);
  }
}

@media (max-width: 560px) {
  body.service-page,
  body.service-page .service-main,
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    overflow-x: hidden;
  }

  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    left: 0;
    width: 100%;
    max-width: 100%;
    padding-inline: 16px;
    box-sizing: border-box;
  }

  body.service-page .service-feature-exterior .service-copy-exterior,
  body.service-page .service-feature-interior .service-copy-interior {
    width: 100%;
    max-width: 100%;
    left: 0;
    margin-right: 0;
    padding-left: 0;
    box-sizing: border-box;
  }

  body.service-page .service-feature-interior .service-copy-interior {
    width: min(100%, 340px);
    max-width: min(100%, 340px);
    margin-left: auto;
    margin-right: 0;
    text-align: center;
  }

  body.service-page .service-copy-exterior p,
  body.service-page .service-copy-interior p {
    width: 100%;
    max-width: 100%;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p,
  body.service-page .service-copy-interior .btn-dark {
    left: 0;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p {
    text-align: center;
  }

  body.service-page .service-copy-interior p {
    margin-left: 0;
  }

  body.service-page .service-copy-interior .btn-dark {
    margin-inline: auto;
  }
}

@media (max-width: 400px) {
  body.service-page .service-feature-interior .service-copy-interior {
    width: calc(100% - 32px) !important;
    max-width: calc(100% - 32px) !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    text-align: right !important;
    box-sizing: border-box;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: 0 !important;
    right: auto !important;
    text-align: right !important;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
  }

  body.service-page .service-copy-interior p {
    margin-bottom: 30px;
  }

  body.service-page .service-copy-interior .btn-dark {
    margin-left: auto !important;
    margin-right: 0 !important;
    max-width: 100%;
  }
}

@media (min-width: 401px) and (max-width: 500px) {
  body.service-page .service-feature-interior .service-copy-interior {
    width: calc(100% - 40px) !important;
    max-width: 420px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    text-align: right !important;
    box-sizing: border-box;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: 0 !important;
    right: auto !important;
    text-align: right !important;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
  }

  body.service-page .service-copy-exterior h3,
  body.service-page .service-copy-interior h3 {
    font-size: 46px;
  }

  body.service-page .service-copy-interior p {
    margin-bottom: 34px;
    font-size: 15px;
    line-height: 1.72;
  }

  body.service-page .service-copy-interior .btn-dark {
    width: 260px;
    min-width: 260px;
    max-width: 100%;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}

@media (min-width: 501px) and (max-width: 700px) {
  body.service-page .service-feature-interior .service-copy-interior {
    width: calc(100% - 56px) !important;
    max-width: 540px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    text-align: right !important;
    box-sizing: border-box;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: 0 !important;
    right: auto !important;
    text-align: right !important;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
  }

  body.service-page .service-copy-exterior h3,
  body.service-page .service-copy-interior h3 {
    font-size: 54px;
  }

  body.service-page .service-copy-interior p {
    margin-bottom: 40px;
    font-size: 16px;
    line-height: 1.76;
  }

  body.service-page .service-copy-interior .btn-dark {
    width: 286px;
    min-width: 286px;
    max-width: 100%;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}

@media (min-width: 701px) and (max-width: 900px) {
  body.service-page .service-feature-interior .service-copy-interior {
    width: calc(100% - 72px) !important;
    max-width: 680px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    text-align: right !important;
    box-sizing: border-box;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: 0 !important;
    right: auto !important;
    text-align: right !important;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
  }

  body.service-page .service-copy-exterior h3,
  body.service-page .service-copy-interior h3 {
    font-size: 64px;
  }

  body.service-page .service-copy-interior p {
    margin-bottom: 46px;
    font-size: 17px;
    line-height: 1.78;
  }

  body.service-page .service-copy-interior .btn-dark {
    width: 320px;
    min-width: 320px;
    max-width: 100%;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 900px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    width: var(--service-mobile-column, min(100%, 520px)) !important;
    max-width: var(--service-mobile-column, min(100%, 520px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    justify-items: center !important;
    box-sizing: border-box;
  }

  body.service-page .service-feature-exterior .service-copy-exterior,
  body.service-page .service-feature-interior .service-copy-interior,
  body.service-page .service-feature-exterior .service-collage,
  body.service-page .service-feature-interior .service-collage {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    left: 0 !important;
    justify-self: center !important;
    box-sizing: border-box;
  }

  body.service-page .service-copy-exterior p,
  body.service-page .service-copy-interior p {
    width: 70% !important;
    max-width: 70% !important;
  }

  body.service-page .service-copy-interior p {
    margin-left: auto !important;
    margin-right: 0 !important;
  }

  body.service-page .service-work h2,
  body.service-page .service-work-grid,
  body.service-page .service-work-icon,
  body.service-page .service-work-step {
    opacity: 1;
    visibility: visible;
  }
}

@media (min-width: 701px) and (max-width: 900px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    --service-mobile-column: min(100% - 72px, 880px);
  }

  body.service-page .service-feature-exterior {
    left: 0 !important;
    width: min(100% - 72px, 760px) !important;
    max-width: 760px !important;
    margin-left: 20% !important;
    margin-right: auto !important;
  }

  body.service-page .service-feature-exterior .service-copy-exterior {
    width: min(100%, 760px) !important;
    max-width: 760px !important;
    padding-left: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-self: center !important;
  }

  body.service-page .service-copy-exterior p {
    width:70% !important;
    max-width: 100% !important;
  }

  body.service-page .service-feature-interior .service-collage {
    margin-left: auto !important;
    margin-right: auto !important;
    justify-self: center !important;
    transform: translateX(35%) !important;
  }
	body.service-page .service-feature-exterior .service-collage {
    margin-left: auto !important;
    margin-right: auto !important;
    justify-self: center !important;
  }

  body.service-page .service-feature-exterior .service-copy-exterior,
  body.service-page .service-feature-interior .service-copy-interior {
    margin-left: auto !important;
    margin-right: auto !important;
    justify-self: center !important;
  }

  body.service-page .service-feature-interior {
    left: 0 !important;
    width: min(100% - 72px, 760px) !important;
    max-width: 760px !important;
    margin-left: -10%  !important;
    margin-right: auto !important;
  }

  body.service-page .service-feature-interior .service-copy-interior {
    width: min(100%, 760px) !important;
    max-width: 760px !important;
    padding-left: 0 !important;
    margin-right:  !important;
    margin-left: auto !important;
    position: relative;
    left: 0 !important;
    text-align: right !important;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p,
  body.service-page .service-copy-interior .btn-dark {
    position: relative;
    left: 0 !important;
    right: auto !important;
    margin-left: auto !important;
    margin-right: 0 !important;
  }

  body.service-page .service-copy-interior p {
    width: 70% !important;
    max-width: 100% !important;
    text-align: right !important;
    margin-left: auto !important;
    margin-right: 0 !important;
  }

  body.service-page .service-copy-interior .btn-dark {
    display: inline-flex !important;
    width: 240px !important;
    min-width: 240px !important;
    max-width: 240px !important;
    padding: 17px 16px !important;
    font-size: 12px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}

@media (min-width: 701px) and (max-width: 900px) {
  body.about-page .why-about {
    position: relative;
  }

  body.about-page .why-about::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("Images/about page/background_logo.png");
    background-repeat: no-repeat;
    background-position: -370px center;
    background-size: cover;
    opacity: 0.6;
    pointer-events: none;
    z-index: 0;
  }

  body.about-page .why-about-grid {
    position: relative;
    z-index: 1;
  }

  body.about-page .why-about-grid::before {
    display: none;
  }
}

@media (min-width: 701px) and (max-width: 768px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    width: min(calc(100% - 72px), 560px) !important;
    max-width: 560px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    left: 0 !important;
    transform: none !important;
    justify-items: stretch !important;
  }

  body.service-page .service-feature-exterior .service-copy-exterior,
  body.service-page .service-feature-interior .service-copy-interior,
  body.service-page .service-feature-exterior .service-collage,
  body.service-page .service-feature-interior .service-collage {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    left: 0 !important;
    right: auto !important;
    transform: none !important;
    justify-self: center !important;
    box-sizing: border-box !important;
  }

  body.service-page .service-copy-exterior h3,
  body.service-page .service-copy-exterior p,
  body.service-page .service-copy-exterior .btn-dark {
    left: 0 !important;
    right: auto !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    text-align: left !important;
  }

  body.service-page .service-copy-interior h3,
  body.service-page .service-copy-interior p,
  body.service-page .service-copy-interior .btn-dark {
    left: 0 !important;
    right: auto !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    text-align: right !important;
  }

  body.service-page .service-copy-exterior p,
  body.service-page .service-copy-interior p {
    width: 70% !important;
    max-width: 70% !important;
  }
}

@media (max-width: 400px) {
  body.service-page .service-assurance-copy-text h2 {
    font-size: 36px !important;
  }

  body.service-page .service-assurance-copy-text p {
    font-size: 11px !important;
	  margin-left: -20px;
  }

  body.service-page .service-assurance-bar-top {
    margin-left: 0 !important;
	  width: 200%;
  }

  body.service-page .service-assurance-bar-middle {
    margin-left: 42px !important;
	  width: 200%;
  }

  body.service-page .service-assurance-bar-bottom {
    margin-left: 84px !important;
	  width: 200%;
  }
}

@media (min-width: 501px) and (max-width: 700px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    --service-mobile-column: min(100% - 56px, 540px);
  }

  body.contact-page .contact-map-shell {
    width: min(calc(100% - 48px), 540px) !important;
    max-width: 540px !important;
    margin: 0 auto !important;
    padding-inline: 0 !important;
    box-sizing: border-box !important;
  }

  body.contact-page .contact-map-card {
    width: 100% !important;
    max-width: none !important;
    margin: 0 auto !important;
  }

  .previous-head h2 {
    width: clamp(590px, 84vw, 740px) !important;
    max-width: clamp(590px, 84vw, 740px) !important;
    min-width: 0 !important;
    margin-left: clamp(-130px, 5vw, -174px) !important;
  }
}

@media (min-width: 401px) and (max-width: 500px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    --service-mobile-column: min(100% - 40px, 420px);
  }

  body.service-page .service-hero {
    height: clamp(360px, 78vw, 390px) !important;
    min-height: clamp(360px, 78vw, 390px) !important;
    margin-bottom: clamp(72px, 16vw, 92px) !important;
    overflow: hidden !important;
  }

  body.service-page .service-hero-content,
  body.service-page .service-hero-content.page {
    height: clamp(360px, 78vw, 390px) !important;
    min-height: clamp(360px, 78vw, 390px) !important;
  }

  body.service-page .service-intro {
    margin-top: 0 !important;
    padding-top: clamp(10px, 3vw, 18px) !important;
  }

  body.service-page .service-area-copy h2 {
    font-size: 34px !important;
  }

  body.service-page .service-area-map img {
    width: 78% !important;
  }

  body.service-page .service-area-truck img {
    width: 185% !important;
  }
}

@media (max-width: 400px) {
  body.service-page .service-feature-exterior,
  body.service-page .service-feature-interior {
    --service-mobile-column: calc(100% - 32px);
  }

  body.service-page .service-hero {
    height: 360px !important;
    min-height: 360px !important;
    margin-bottom: 84px !important;
    overflow: hidden !important;
  }

  body.service-page .service-hero .nav.page,
  body.service-page .service-hero .nav.is-sticky {
    position: absolute !important;
  }

  body.service-page .service-hero-content,
  body.service-page .service-hero-content.page {
    height: 360px !important;
    min-height: 360px !important;
  }

  body.service-page .service-intro {
    margin-top: 0 !important;
    min-height: auto !important;
    padding-top: 0 !important;
    padding-bottom: 56px !important;
  }

  body.service-page .service-area-grid {
    margin-bottom: 28px !important;
  }

  body.service-page .service-cta-wrap {
    padding-top: 36px !important;
    padding-bottom: 96px !important;
    position: relative !important;
    z-index: 4 !important;
  }

  body.service-page .service-cta-wrap .cta {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    transform: none !important;
    position: relative !important;
    z-index: 4 !important;
  }

  body.service-page .service-cta-wrap .cta-card {
    min-height: 300px !important;
    overflow: visible !important;
  }

  body.service-page .footer {
    position: relative !important;
    z-index: 1 !important;
    margin-top: 0 !important;
  }

  body.service-page .float-up {
    bottom: 112px !important;
  }

  body.service-page .float-wa {
    bottom: 34px !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-gallery {
    width: calc(100% - 40px) !important;
    display: block !important;
    column-count: 2 !important;
    column-gap: 16px !important;
    min-height: 0 !important;
    padding-top: 0 !important;
  }

  body.portfolio-exterior-page .portfolio-card {
    display: inline-block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 0 12px !important;
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  body.portfolio-exterior-page .portfolio-card.is-visible {
    animation-fill-mode: both !important;
  }

  body.portfolio-exterior-page .portfolio-card.is-visible img {
    animation-fill-mode: both !important;
  }

  body.portfolio-interior-page .portfolio-interior-gallery {
    width: calc(100% - 40px) !important;
    display: block !important;
    column-count: 2 !important;
    column-gap: 16px !important;
    min-height: 0 !important;
    padding-top: 0 !important;
  }

  body.portfolio-interior-page .portfolio-card {
    display: inline-block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 0 12px !important;
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  body.portfolio-interior-page .portfolio-card.is-visible {
    animation-fill-mode: both !important;
  }

  body.portfolio-interior-page .portfolio-card.is-visible img {
    animation-fill-mode: both !important;
  }
}

@media (max-width: 500px) {
  body.service-page .service-area-copy h2 {
    font-size: 34px !important;
  }

  body.service-page .service-area-map img,
  body.service-page .service-area-map .service-map {
    width: 88% !important;
    max-width: 88% !important;
  }

  body.service-page .service-area-truck img,
  body.service-page .service-area-truck .service-truck {
    width: 155% !important;
    max-width: none !important;
  }
}

@media (min-width: 701px) and (max-width: 900px) {
  body.service-page .service-area-map img,
  body.service-page .service-area-map .service-map {
    width: 140% !important;
    max-width: 140% !important;
	  margin-left: 20%;
  }

  body.service-page .service-area-copy {
    padding-left: 140px !important;
  }

  body.service-page .service-area-truck img,
  body.service-page .service-area-truck .service-truck {
    width: 80% !important;
    max-width: none !important;
	  margin-left: 20%;
	  margin-bottom: 50px;
  }

  body.service-page .service-assurance-copy-text p {
    width: 70% !important;
    max-width: 82% !important;
	  
  }

  body.service-page .service-assurance-bars {
    gap: 20px !important;
	     min-height: 150px !important;
    padding: 36px 34px !important;
	  margin-top: -50px;
  }


  body.service-page .service-assurance-bar-top {
    width: min(120% - 80px, 1620px) !important;
  }

  body.service-page .service-assurance-bar-middle {
    width: min(120% - 140px, 1360px) !important;
  }

  body.service-page .service-assurance-bar-bottom {
    width: min(120% - 200px, 1300px) !important;
  }

  body.service-page .service-assurance-bar h3 {
    font-size: 36px !important;
    line-height: 1.04 !important;
	  margin-left: 50px;
  }

  body.service-page .service-assurance-bar p {
    font-size: 18px !important;
    line-height: 1.3 !important;
    padding-top: 10px !important;
	  margin-left: 50px;
  }

  body.contact-page .contact-map-shell {
    width: min(calc(100% - 48px), 540px) !important;
    max-width: 540px !important;
    margin: 0 auto !important;
    padding-inline: 0 !important;
    box-sizing: border-box !important;
  }

  body.contact-page .contact-map-card {
    width: 100% !important;
    max-width: none !important;
    margin: 0 auto !important;
  }

  body.about-page .about-hero-content h1,
  body.about-page .about-hero-content.page h1,
  body.contact-page .contact-hero-content h1,
  body.contact-page .contact-hero-content.page h1,
  body.service-page .service-hero-content h1,
  body.service-page .service-hero-content.page h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    font-size: 80px !important;
    line-height: 1 !important;
    max-width: 640px !important;
    white-space: normal !important;
    text-wrap: balance !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: -25% !important;
    margin-right: auto !important;
    font-size: clamp(58px, 15vw, 72px) !important;
    text-align: center !important;
  }

  @media (min-width: 401px) and (max-width: 500px) {
    body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
    body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
    body.portfolio-interior-page .portfolio-interior-hero-content h1,
    body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
      width: calc(100% - 18px) !important;
      max-width: calc(100% - 18px) !important;
      margin-left: auto !important;
      margin-right: auto !important;
      font-size: clamp(52px, 13vw, 62px) !important;
    }

    body.portfolio-exterior-page .portfolio-exterior-hero-line,
    body.portfolio-interior-page .portfolio-interior-hero-line {
      display: block !important;
      width: 100% !important;
      text-align: center !important;
    }
  }

  .stat-item span {
    font-size: 16px !important;
    line-height: 1.45 !important;
    margin-top: -10px !important;
  }

  .footer,
  body.contact-page .footer,
  body.service-page .footer,
  body.portfolio-exterior-page .footer,
  body.portfolio-interior-page .footer {
    margin-top: 140px !important;
    padding: 180px 0 0 !important;
    background: var(--olive) !important;
    position: relative !important;
    overflow: visible !important;
  }

  .footer-top-curve,
  body.contact-page .footer-top-curve {
    display: block !important;
    position: absolute !important;
    left: -4% !important;
    right: -4% !important;
    top: -100px !important;
    height: 230px !important;
    background: #ffffff !important;
    border-radius: 0 0 50% 50% / 0 0 50% 50% !important;
    z-index: 0 !important;
  }

  .footer-grid,
  body.contact-page .footer-grid {
    width: min(72%, 1000px) !important;
    max-width: 1000px !important;
    margin-inline: auto !important;
    position: relative !important;
    z-index: 1 !important;
    display: grid !important;
    grid-template-columns: minmax(240px, 1fr) minmax(190px, auto) !important;
    align-items: start !important;
    justify-content: space-between !important;
    gap: 200px !important;
  }

  .footer-logo,
  body.contact-page .footer-logo {
    width: 142px !important;
    margin-bottom: 14px !important;
  }

  .footer p,
  body.contact-page .footer p,
  body.service-page .footer p {
    font-size: 18px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
  }

  .socials,
  body.contact-page .socials {
    display: flex !important;
    gap: 12px !important;
    margin-top: 16px !important;
  }

  .socials a,
  body.contact-page .socials a {
    width: 24px !important;
    height: 24px !important;
  }

  .footer-links,
  body.contact-page .footer-links {
    justify-self: end !important;
    margin-left: 0 !important;
    min-width: 190px !important;
  }

  .footer-links h3,
  body.contact-page .footer-links h3,
  body.service-page .footer-links h3 {
    font-size: 40px !important;
    line-height: 1 !important;
    margin: 0 0 24px !important;
  }

  .footer-links ul,
  body.contact-page .footer-links ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .footer-links li,
  body.contact-page .footer-links li {
    margin: 0 0 16px !important;
  }

  .footer-links a,
  body.contact-page .footer-links a,
  body.service-page .footer-links a {
    font-size: 16px !important;
    line-height: 1.1 !important;
    color: #ffffff !important;
  }

  .copyright,
  body.contact-page .copyright {
    width: 100% !important;
    margin: 22px 0 0 !important;
    padding: 12px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.45) !important;
    text-align: center !important;
    font-size: 11px !important;
    line-height: 1.1 !important;
    color: #ffffff !important;
    position: relative !important;
    z-index: 1 !important;
  }

  .copyright-text {
    transform: none !important;
  }

  .who {
    width: min(100% - 80px, 820px) !important;
    gap: 18px !important;
    margin-top: 42px !important;
  }

  .who-grid {
    grid-template-columns: repeat(3, 190px) !important;
    width: 650px !important;
    max-width: 650px !important;
    min-height: 560px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: 22px !important;
  }

  .who .img-1,
  .who .img-2,
  .who .img-3 {
    width: 190px !important;
    height: 280px !important;
  }

  .who .word {
    font-size: 54px !important;
  }

  .who-text {
    width: min(100% - 120px, 520px) !important;
    max-width: 520px !important;
    min-width: 520px !important;
    padding: 54px 44px 80px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .who-text p {
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin-bottom: 26px !important;
  }

  .who-text .btn-dark,
  .who-text .btn-learn,
  .who-text .btn-dark.btn-learn {
    width: 240px !important;
    min-width: 240px !important;
    max-width: 240px !important;
    min-height: 50px !important;
    padding: 14px 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    line-height: 1 !important;
  }

  .about-hammer {
    width: 480px !important;
    right: -250px !important;
    top: 380px !important;
  }

  .previous-head {
    margin-bottom: 8px !important;
  }

  .previous-head h2 {
    width: 780px !important;
    min-width: 620px !important;
    max-width: 780px !important;
    height: auto !important;
    margin-bottom: 6px !important;
    margin-left: -10% !important;
    padding: 14px 34px 16px 46px !important;
    font-size: 42px !important;
    line-height: 1 !important;
  }

  .previous-head p {
    margin-top: -30px !important;
  }

  .previous .cta-card,
  body.service-page .service-cta-wrap .cta-card,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card {
    width: min(100% - 80px, 760px) !important;
    min-height: 300px !important;
  }

  .previous .cta-card::after,
  body.service-page .service-cta-wrap .cta-card::after,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card::after,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card::after {
    inset: 28px 42px 28px 42px !important;
  }

  .previous .cta-card h2,
  body.service-page .service-cta-wrap .cta-card h2,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card h2,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card h2 {
    font-size: 38px !important;
    line-height: 1.14 !important;
  }

  .previous .cta-card .btn,
  .previous .cta-card .btn-dark,
  .previous .cta-card a.btn,
  .previous .cta-card a.btn-dark,
  body.service-page .service-cta-wrap .cta-card .btn,
  body.service-page .service-cta-wrap .cta-card .btn-dark,
  body.service-page .service-cta-wrap .cta-card a.btn,
  body.service-page .service-cta-wrap .cta-card a.btn-dark,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card .btn,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card .btn-dark,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card a.btn,
  body.portfolio-exterior-page .portfolio-exterior-cta .cta-card a.btn-dark,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card .btn,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card .btn-dark,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card a.btn,
  body.portfolio-interior-page .portfolio-interior-cta .cta-card a.btn-dark {
    font-size: 18px !important;
  }
}

@media (min-width: 701px) and (max-width: 900px) {
  body.home-page .stats::before,
  body:not(.about-page):not(.service-page):not(.contact-page):not(.portfolio-exterior-page):not(.portfolio-interior-page) .stats::before {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    background-position: left center !important;
    background-size: auto 220% !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    position: relative !important;
    left: clamp(190px, 19vw, 270px) !important;
    font-size: 80px !important;
  }
}

@media (min-width: 700px) and (max-width: 752px) {
  .previous-head h2 {
    width: clamp(570px, 68vw, 620px) !important;
    min-width: 0 !important;

    margin-left: clamp(-40px, 23vw,-42px) !important;
    padding: 12px 28px 14px 40px !important;
    font-size: clamp(32px, 4.7vw, 36px) !important;
    white-space: nowrap !important;
  }
}

@media (min-width: 401px) and (max-width: 500px) {
  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    width: calc(100% - 28px) !important;
    max-width: calc(100% - 28px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    transform: none !important;
    font-size: clamp(76px, 12vw, 76px) !important;
    line-height: 0.6 !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line,
  body.portfolio-interior-page .portfolio-interior-hero-line {
    position: relative !important;
    display: block !important;
    width: 100% !important;

    max-width: 100% !important;
    color: #443850 !important;
    animation: aboutHeroTitleFadeUp 0.9s ease forwards, portfolioHeroLineToWhite 0.01s linear 2.03s forwards !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::before,
  body.portfolio-interior-page .portfolio-interior-hero-line::before {
    opacity: 0 !important;
    animation: none !important;
	  
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::after,
  body.portfolio-interior-page .portfolio-interior-hero-line::after {
    content: attr(data-text) !important;
    position: absolute !important;
    display: block !important;
    inset: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    font: inherit !important;
    line-height: inherit !important;
    letter-spacing: inherit !important;
    white-space: nowrap !important;
    text-align: center !important;
    color: #ffffff !important;
    opacity: 1 !important;
    -webkit-clip-path: inset(-0.26em 100% -0.18em 0);
    clip-path: inset(-0.26em 100% -0.18em 0);
    animation-name: portfolioHeroSweepTight !important;
    animation-duration: 1.05s !important;
    animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1) !important;
    animation-delay: 0.98s !important;
    animation-fill-mode: forwards !important;
    animation-iteration-count: 1 !important;
    height: 100% !important;
    margin-bottom: 0 !important;
    z-index: 10 !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1 {
    width: calc(100% - 28px) !important;
    max-width: calc(100% - 28px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    transform: none !important;
    font-size: clamp(76px, 12vw, 76px) !important;
    line-height: 0.6 !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    color: #443850 !important;
    animation: aboutHeroTitleFadeUp 0.9s ease forwards, portfolioHeroLineToWhite 0.01s linear 2.03s forwards !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::before {
    opacity: 0 !important;
    animation: none !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::after {
    content: attr(data-text) !important;
    position: absolute !important;
    display: block !important;
    inset: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    font: inherit !important;
    line-height: inherit !important;
    letter-spacing: inherit !important;
    white-space: nowrap !important;
    text-align: center !important;
    color: #ffffff !important;
    opacity: 1 !important;
    -webkit-clip-path: inset(-0.26em 100% -0.18em 0);
    clip-path: inset(-0.26em 100% -0.18em 0);
    animation-name: portfolioHeroSweepTight !important;
    animation-duration: 1.05s !important;
    animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1) !important;
    animation-delay: 0.98s !important;
    animation-fill-mode: forwards !important;
    animation-iteration-count: 1 !important;
    height: 300% !important;
    margin-bottom: 2250px !important;
    z-index: 10 !important;
  }
}

@media (max-width: 400px) {
  body.portfolio-exterior-page .portfolio-exterior-hero-content h1,
  body.portfolio-exterior-page .portfolio-exterior-hero-content.page h1,
  body.portfolio-interior-page .portfolio-interior-hero-content h1,
  body.portfolio-interior-page .portfolio-interior-hero-content.page h1 {
    line-height: 0.5 !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line,
  body.portfolio-interior-page .portfolio-interior-hero-line {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    color: #443850 !important;
    animation: aboutHeroTitleFadeUp 0.9s ease forwards, portfolioHeroLineToWhite 0.01s linear 2.03s forwards !important;
    text-align: center !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::before,
  body.portfolio-interior-page .portfolio-interior-hero-line::before {
    opacity: 0 !important;
    animation: none !important;
  }

  body.portfolio-exterior-page .portfolio-exterior-hero-line::after,
  body.portfolio-interior-page .portfolio-interior-hero-line::after {
    content: attr(data-text) !important;
    position: absolute !important;
    display: block !important;
    inset: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 100% !important;
    font: inherit !important;
    line-height: inherit !important;
    letter-spacing: inherit !important;
    white-space: nowrap !important;
    text-align: center !important;
    color: #ffffff !important;
    opacity: 1 !important;
    -webkit-clip-path: inset(-0.24em 100% -0.2em 0);
    clip-path: inset(-0.24em 100% -0.2em 0);
    animation-name: portfolioHeroSweepTight !important;
    animation-duration: 1.05s !important;
    animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1) !important;
    animation-delay: 0.98s !important;
    animation-fill-mode: forwards !important;
    animation-iteration-count: 1 !important;
    z-index: 10 !important;
  }
}

@media (min-width: 401px) and (max-width: 500px) {
  body.service-page .service-area-grid {
    margin-bottom: clamp(48px, 12vw, 68px) !important;
  }

  body.service-page .service-cta-wrap {
    padding-top: clamp(36px, 9vw, 52px) !important;
    padding-bottom: clamp(38px, 10vw, 54px) !important;
    position: relative !important;
    z-index: 4 !important;
  }

  body.service-page .service-cta-wrap .cta {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    transform: none !important;
    position: relative !important;
    z-index: 4 !important;
  }

  body.service-page .service-cta-wrap .cta-card {
    min-height: clamp(280px, 62vw, 320px) !important;
    overflow: visible !important;
  }

  body.service-page .footer {
    margin-top: clamp(58px, 14vw, 78px) !important;
    padding-top: clamp(142px, 32vw, 168px) !important;
    position: relative !important;
    z-index: 1 !important;
    overflow: visible !important;
  }

  body.service-page .footer-top-curve {
    top: clamp(-106px, -22vw, -88px) !important;
    height: clamp(200px, 46vw, 230px) !important;
  }

  body.service-page .footer-grid {
    width: min(calc(100% - 44px), 390px) !important;
    max-width: 390px !important;
    margin-inline: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: clamp(24px, 6vw, 34px) !important;
  }

  body.service-page .footer-links {
    justify-self: start !important;
    min-width: 0 !important;
    margin-left: 0 !important;
  }
}

@keyframes portfolioHeroSweepTight {
  0% {
    -webkit-clip-path: inset(-0.26em 100% -0.18em 0);
    clip-path: inset(-0.26em 100% -0.18em 0);
  }

  100% {
    -webkit-clip-path: inset(-0.26em -0.08em -0.18em 0);
    clip-path: inset(-0.26em -0.36em -0.18em 0);
  }
}

@keyframes portfolioHeroLineToWhite {
  0% {
    color: #443850;
    opacity: 1;
  }

  to {
    color: #ffffff;
    opacity: 1;
  }
}
