
    :root {
      --navy: #213141;
      --navy-2: #162531;
      --cyan: #37edf9;
      --cyan-soft: #c9fbff;
      --teal: #007997;
      --teal-dark: #006278;
      --ink: #162631;
      --muted: #5d6c75;
      --paper: #f5f8f8;
      --white: #ffffff;
      --line: #d7e2e4;
      --shadow-sm: 0 10px 30px rgba(22, 37, 49, .08);
      --shadow-lg: 0 28px 70px rgba(16, 32, 43, .18);
      --radius-sm: .75rem;
      --radius-md: 1.15rem;
      --radius-lg: 1.75rem;
      --max: 1180px;
      --header-h: 78px;
    }

    *, *::before, *::after { box-sizing: border-box; }
    html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 1rem); }
    body {
      margin: 0;
      min-width: 320px;
      color: var(--ink);
      background: var(--white);
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      line-height: 1.6;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
    }
    body.menu-open { overflow: hidden; }
    img, svg { display: block; max-width: 100%; height: auto; }
    button, input, select, textarea { font: inherit; }
    a { color: inherit; }
    section { position: relative; }
    .container { width: min(calc(100% - 2rem), var(--max)); margin-inline: auto; }
    .skip-link {
      position: fixed; left: 1rem; top: .75rem; z-index: 9999;
      transform: translateY(-180%); padding: .75rem 1rem; border-radius: .5rem;
      color: var(--navy); background: var(--cyan); font-weight: 800;
    }
    .skip-link:focus { transform: none; }
    :focus-visible { outline: 3px solid var(--cyan); outline-offset: 3px; }

    .eyebrow {
      display: inline-flex; align-items: center; gap: .55rem;
      margin: 0 0 1rem; color: var(--teal-dark); font-size: .78rem;
      font-weight: 850; letter-spacing: .14em; text-transform: uppercase;
    }
    .eyebrow::before { content: ""; width: 1.9rem; height: 2px; background: currentColor; }
    .section-title {
      margin: 0; max-width: 820px; font-size: clamp(2rem, 5vw, 4.4rem);
      line-height: .98; letter-spacing: -.055em; font-weight: 900;
    }
    .section-copy { max-width: 710px; margin: 1.25rem 0 0; color: var(--muted); font-size: 1.05rem; }
    .section-head { margin-bottom: 2.5rem; }

    .button {
      display: inline-flex; align-items: center; justify-content: center; gap: .65rem;
      min-height: 3.15rem; padding: .78rem 1.15rem; border: 1px solid transparent;
      border-radius: 999px; text-decoration: none; font-weight: 850; line-height: 1;
      cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
    }
    .button:hover { transform: translateY(-2px); }
    .button-primary { color: var(--navy); background: var(--cyan); box-shadow: 0 10px 26px rgba(55, 237, 249, .22); }
    .button-primary:hover { box-shadow: 0 16px 34px rgba(55, 237, 249, .32); }
    .button-dark { color: var(--white); background: var(--navy); }
    .button-outline { color: var(--navy); border-color: rgba(33, 49, 65, .26); background: rgba(255,255,255,.82); }
    .button svg { width: 1.1rem; height: 1.1rem; flex: none; }

    .site-header {
      position: sticky; top: 0; z-index: 1000; height: var(--header-h);
      border-bottom: 1px solid rgba(33, 49, 65, .08); background: rgba(255,255,255,.93);
      backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    }
    .nav-wrap { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
    .brand { display: inline-flex; align-items: center; min-width: 0; text-decoration: none; }
    .brand img { width: clamp(190px, 24vw, 275px); height: auto; }
    .desktop-nav { display: flex; align-items: center; gap: 1.55rem; }
    .desktop-nav a:not(.button) { color: var(--navy); text-decoration: none; font-size: .93rem; font-weight: 760; }
    .desktop-nav a:not(.button):hover { color: var(--teal); }
    .nav-toggle {
      display: none; width: 3rem; height: 3rem; border: 1px solid var(--line); border-radius: .8rem;
      background: var(--white); color: var(--navy); cursor: pointer;
    }
    .nav-toggle svg { width: 1.45rem; margin: auto; }
    .mobile-panel {
      position: fixed; inset: var(--header-h) 0 auto 0; z-index: 999;
      max-height: calc(100vh - var(--header-h)); overflow-y: auto;
      border-bottom: 1px solid var(--line); background: var(--white); box-shadow: var(--shadow-lg);
      transform: translateY(-120%); opacity: 0; visibility: hidden;
      transition: transform .26s ease, opacity .2s ease, visibility .2s ease;
    }
    .mobile-panel[data-open="true"] { transform: none; opacity: 1; visibility: visible; }
    .mobile-links { display: grid; gap: .4rem; padding-block: 1rem 1.35rem; }
    .mobile-links > a:not(.button) { padding: .85rem .2rem; border-bottom: 1px solid var(--line); text-decoration: none; font-weight: 800; }
    .mobile-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: .6rem; }

    .hero {
      overflow: hidden; color: var(--white); background:
        radial-gradient(circle at 82% 18%, rgba(55,237,249,.18), transparent 29%),
        linear-gradient(135deg, var(--navy-2) 0%, var(--navy) 58%, #28495d 100%);
    }
    .hero::before {
      content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .13;
      background-image: linear-gradient(rgba(255,255,255,.4) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.4) 1px, transparent 1px);
      background-size: 52px 52px;
      mask-image: linear-gradient(to right, black, transparent 75%);
    }
    .hero-inner { min-height: calc(100svh - var(--header-h)); display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(310px, .8fr); align-items: center; gap: clamp(2rem, 7vw, 6rem); padding-block: 5.25rem; }
    .hero-copy { position: relative; z-index: 1; }
    .hero .eyebrow { color: var(--cyan); }
    .hero h1 { margin: 0; max-width: min(100%, 880px); font-size: clamp(3rem, 6.55vw, 6.35rem); line-height: 1; letter-spacing: -.055em; font-weight: 900; padding-top: .08em; padding-bottom: .08em; text-wrap: balance; overflow-wrap: normal; }
    .hero h1 span { display: block; color: var(--cyan); }
    .hero-lead { max-width: 680px; margin: 1.65rem 0 0; color: rgba(255,255,255,.79); font-size: clamp(1.05rem, 2vw, 1.25rem); }
    .hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
    .hero .button-outline { color: var(--white); border-color: rgba(255,255,255,.34); background: rgba(255,255,255,.07); }
    .hero-meta { display: flex; flex-wrap: wrap; gap: .65rem 1.35rem; margin-top: 2rem; padding: 0; list-style: none; color: rgba(255,255,255,.7); font-size: .9rem; }
    .hero-meta li { display: inline-flex; align-items: center; gap: .5rem; }
    .hero-meta svg { width: 1rem; color: var(--cyan); }

    .hero-board { position: relative; min-height: 480px; display: grid; place-items: center; }
    .blueprint-card {
      position: relative; width: min(100%, 430px); aspect-ratio: .86;
      padding: clamp(1.4rem, 4vw, 2.2rem); overflow: hidden; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-lg);
      background: rgba(255,255,255,.08); box-shadow: var(--shadow-lg); backdrop-filter: blur(8px);
      transform: rotate(2deg);
    }
    .blueprint-card::before, .blueprint-card::after { content: ""; position: absolute; pointer-events: none; }
    .blueprint-card::before {
      inset: 0; opacity: .24;
      background-image: linear-gradient(rgba(55,237,249,.45) 1px, transparent 1px), linear-gradient(90deg, rgba(55,237,249,.45) 1px, transparent 1px);
      background-size: 28px 28px;
    }
    .blueprint-card::after { width: 200px; height: 200px; right: -70px; bottom: -65px; border: 1px solid rgba(55,237,249,.5); border-radius: 50%; box-shadow: 0 0 0 25px rgba(55,237,249,.04), 0 0 0 50px rgba(55,237,249,.03); }
    .blueprint-content { position: relative; z-index: 1; height: 100%; display: flex; flex-direction: column; justify-content: space-between; }
    .blueprint-logo { width: 90%; filter: drop-shadow(0 8px 12px rgba(0,0,0,.2)); }
    .blueprint-label { display: inline-flex; width: fit-content; align-items: center; gap: .5rem; padding: .45rem .7rem; border: 1px solid rgba(255,255,255,.23); border-radius: 999px; background: rgba(0,0,0,.12); font-size: .72rem; font-weight: 850; letter-spacing: .11em; text-transform: uppercase; }
    .blueprint-note { max-width: 250px; margin: 0; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: rgba(255,255,255,.84); font-size: .8rem; line-height: 1.7; }
    .measure-line { width: 72%; height: 1px; margin-block: 1rem; background: var(--cyan); position: relative; }
    .measure-line::before, .measure-line::after { content: ""; position: absolute; top: -4px; width: 1px; height: 9px; background: var(--cyan); }
    .measure-line::before { left: 0; } .measure-line::after { right: 0; }
    .corner-tag {
      position: absolute; right: -1rem; top: 8%; z-index: 2; transform: rotate(6deg);
      padding: .75rem 1rem; border-radius: .85rem; color: var(--navy); background: var(--cyan);
      font-weight: 950; letter-spacing: .02em; box-shadow: var(--shadow-sm);
    }

    .proof-strip { border-bottom: 1px solid var(--line); background: var(--paper); }
    .proof-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
    .proof-item { display: flex; gap: .9rem; align-items: center; min-height: 105px; padding: 1.3rem 1.6rem; border-right: 1px solid var(--line); }
    .proof-item:first-child { padding-left: 0; } .proof-item:last-child { border-right: 0; }
    .proof-icon { display: grid; place-items: center; flex: 0 0 2.7rem; height: 2.7rem; border-radius: .8rem; color: var(--navy); background: var(--cyan-soft); }
    .proof-icon svg { width: 1.25rem; }
    .proof-item strong { display: block; color: var(--navy); font-size: .94rem; }
    .proof-item span { display: block; color: var(--muted); font-size: .82rem; line-height: 1.4; }

    .services { padding-block: clamp(5rem, 10vw, 8.5rem); background: var(--white); }
    .service-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1rem; }
    .service-card {
      position: relative; min-height: 270px; padding: 1.6rem; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }
    .service-card:hover { transform: translateY(-4px); border-color: rgba(0,121,151,.38); box-shadow: var(--shadow-sm); }
    .service-card:nth-child(1), .service-card:nth-child(4) { grid-column: span 7; }
    .service-card:nth-child(2), .service-card:nth-child(3) { grid-column: span 5; }
    .service-card:nth-child(5), .service-card:nth-child(6) { grid-column: span 6; }
    .service-number { color: var(--teal); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 850; font-size: .8rem; letter-spacing: .1em; }
    .service-card h3 { margin: 2.1rem 0 .8rem; color: var(--navy); font-size: clamp(1.45rem, 3vw, 2rem); line-height: 1.05; letter-spacing: -.035em; }
    .service-card p { max-width: 560px; margin: 0; color: var(--muted); }
    .service-list { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.2rem 0 0; padding: 0; list-style: none; }
    .service-list li { padding: .42rem .65rem; border: 1px solid var(--line); border-radius: 999px; color: var(--navy); background: var(--white); font-size: .78rem; font-weight: 730; }
    .service-mark { position: absolute; right: 1.2rem; top: 1.2rem; width: 3rem; height: 3rem; display: grid; place-items: center; border-radius: 50%; color: var(--teal); background: var(--white); }
    .service-mark svg { width: 1.3rem; }

    .do-it-right { overflow: hidden; padding-block: clamp(4.5rem, 9vw, 7.5rem); color: var(--white); background: var(--navy); }
    .do-it-right::after { content: "RIGHT"; position: absolute; right: -1vw; bottom: -9vw; color: rgba(255,255,255,.035); font-size: clamp(9rem, 27vw, 26rem); line-height: 1; font-weight: 950; letter-spacing: -.08em; pointer-events: none; }
    .right-grid { position: relative; z-index: 1; display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(2rem, 8vw, 7rem); align-items: center; }
    .right-logo-wrap { padding: 2rem; border: 1px solid rgba(255,255,255,.15); border-radius: var(--radius-lg); background: rgba(255,255,255,.05); }
    .right-logo-wrap img { width: min(100%, 490px); margin-inline: auto; }
    .do-it-right .eyebrow { color: var(--cyan); }
    .do-it-right .section-title { color: var(--white); }
    .do-it-right .section-copy { color: rgba(255,255,255,.7); }
    .commitments { display: grid; gap: .8rem; margin-top: 1.8rem; }
    .commitment { display: grid; grid-template-columns: auto 1fr; gap: .9rem; align-items: start; padding: 1rem 0; border-top: 1px solid rgba(255,255,255,.12); }
    .commitment:first-child { border-top: 0; }
    .commitment-badge { display: grid; place-items: center; width: 2.2rem; height: 2.2rem; border-radius: .65rem; color: var(--navy); background: var(--cyan); font-weight: 950; }
    .commitment strong { display: block; color: var(--white); }
    .commitment span { display: block; color: rgba(255,255,255,.65); font-size: .92rem; }

    .portfolio { padding-block: clamp(5rem, 10vw, 8.5rem); background: var(--paper); }
    .portfolio-groups { display: grid; gap: clamp(2.25rem, 5vw, 4rem); }
    .portfolio-group { padding-top: clamp(1.35rem, 3vw, 2rem); border-top: 1px solid var(--line); }
    .portfolio-group:first-child { border-top: 0; padding-top: 0; }
    .portfolio-group-head { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 1rem 2rem; align-items: end; margin-bottom: 1rem; }
    .portfolio-group-label { display: inline-flex; width: fit-content; align-items: center; gap: .5rem; color: var(--teal-dark); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .78rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
    .portfolio-group-label::before { content: ""; width: 1.7rem; height: 2px; background: currentColor; }
    .portfolio-group h3 { margin: .4rem 0 0; color: var(--navy); font-size: clamp(1.45rem, 3vw, 2.35rem); line-height: 1.02; letter-spacing: -.04em; }
    .portfolio-group-head p { margin: 0; color: var(--muted); font-size: .95rem; }
    .portfolio-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1rem; }
    .project-card { position: relative; grid-column: span 6; min-height: 360px; overflow: hidden; border-radius: var(--radius-md); background: var(--navy); box-shadow: var(--shadow-sm); isolation: isolate; }
    .project-card.span-7 { grid-column: span 7; }
    .project-card.span-5 { grid-column: span 5; }
    .project-card.featured { min-height: 455px; }
    .project-card.tall { min-height: 430px; }
    .project-photo { position: absolute; inset: 0; overflow: hidden; }
    .project-photo::before { content: ""; position: absolute; inset: 0; z-index: 2; background: linear-gradient(to top, rgba(16,31,42,.92), rgba(16,31,42,.18) 46%, rgba(16,31,42,.02) 73%); }
    .project-photo img { width: 100%; height: 100%; object-fit: cover; object-position: var(--pos, center); transition: transform .45s ease, filter .45s ease; }
    .project-card:hover .project-photo img { transform: scale(1.035); filter: saturate(1.05) contrast(1.02); }
    .project-content { position: absolute; inset: auto 0 0; z-index: 3; padding: clamp(1.15rem, 2.4vw, 1.6rem); color: var(--white); }
    .project-kicker { display: inline-flex; padding: .38rem .55rem; border-radius: .4rem; color: var(--navy); background: var(--cyan); font-size: .68rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
    .project-content h4 { margin: .75rem 0 .3rem; font-size: clamp(1.25rem, 2.5vw, 1.75rem); line-height: 1.05; letter-spacing: -.035em; }
    .project-content p { margin: 0; max-width: 40rem; color: rgba(255,255,255,.76); font-size: .9rem; }
    .portfolio-note { margin-top: 1.15rem; color: var(--muted); font-size: .86rem; }

    .process { padding-block: clamp(5rem, 10vw, 8.5rem); background: var(--white); }
    .process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; counter-reset: step; }
    .process-card { position: relative; padding: 1.4rem; border-top: 3px solid var(--navy); background: var(--paper); }
    .process-card::before { counter-increment: step; content: "0" counter(step); display: block; margin-bottom: 2.8rem; color: var(--teal); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 900; }
    .process-card h3 { margin: 0 0 .7rem; color: var(--navy); font-size: 1.2rem; }
    .process-card p { margin: 0; color: var(--muted); font-size: .9rem; }

    .service-area { padding-block: clamp(4.5rem, 9vw, 7rem); background: linear-gradient(145deg, #eefafb 0%, var(--paper) 65%); }
    .area-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 7vw, 5rem); align-items: center; }
    .area-map { position: relative; min-height: 390px; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--white); box-shadow: var(--shadow-sm); }
    .area-map::before { content: ""; position: absolute; inset: 0; opacity: .32; background-image: radial-gradient(circle at center, rgba(0,121,151,.32) 1.5px, transparent 1.8px); background-size: 20px 20px; }
    .area-map::after { content: ""; position: absolute; width: 260px; height: 260px; left: 50%; top: 50%; transform: translate(-50%,-50%); border-radius: 50%; background: radial-gradient(circle, rgba(55,237,249,.36), rgba(55,237,249,.09) 48%, transparent 70%); }
    .map-pin { position: absolute; z-index: 2; left: 50%; top: 46%; transform: translate(-50%,-50%); display: grid; place-items: center; width: 5rem; height: 5rem; border-radius: 50% 50% 50% 10%; rotate: -45deg; color: var(--navy); background: var(--cyan); box-shadow: 0 16px 40px rgba(0,121,151,.26); }
    .map-pin svg { width: 2rem; rotate: 45deg; }
    .map-label { position: absolute; z-index: 3; left: 50%; bottom: 2rem; transform: translateX(-50%); width: max-content; max-width: calc(100% - 2rem); padding: .8rem 1rem; border-radius: .75rem; color: var(--white); background: var(--navy); text-align: center; font-weight: 850; }
    .area-list { display: grid; gap: .7rem; margin: 1.8rem 0 0; padding: 0; list-style: none; }
    .area-list li { display: grid; grid-template-columns: auto 1fr; gap: .65rem; align-items: start; color: var(--navy); font-weight: 730; }
    .area-list svg { width: 1.15rem; margin-top: .2rem; color: var(--teal); }

    .contact { padding-block: clamp(5rem, 10vw, 8.5rem); color: var(--white); background: var(--navy-2); }
    .contact-grid { display: grid; grid-template-columns: .78fr 1.22fr; gap: clamp(2rem, 7vw, 5rem); align-items: start; }
    .contact .eyebrow { color: var(--cyan); }
    .contact .section-title { color: var(--white); }
    .contact .section-copy { color: rgba(255,255,255,.67); }
    .contact-card { margin-top: 2rem; padding: 1.25rem; border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); background: rgba(255,255,255,.05); }
    .contact-card a { display: inline-flex; align-items: center; gap: .8rem; color: var(--white); font-size: clamp(1.35rem, 3vw, 2rem); font-weight: 900; text-decoration: none; }
    .contact-card a:hover { color: var(--cyan); }
    .contact-card p { margin: .45rem 0 0; color: rgba(255,255,255,.59); font-size: .87rem; }

    .estimate-form { padding: clamp(1.2rem, 4vw, 2rem); border-radius: var(--radius-lg); color: var(--ink); background: var(--white); box-shadow: var(--shadow-lg); }
    .form-heading { margin: 0 0 .25rem; color: var(--navy); font-size: 1.65rem; line-height: 1.1; }
    .form-intro { margin: 0 0 1.4rem; color: var(--muted); font-size: .9rem; }
    .form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
    .field { display: grid; gap: .4rem; }
    .field.full { grid-column: 1 / -1; }
    .field label, fieldset legend { color: var(--navy); font-size: .82rem; font-weight: 820; }
    .visually-hidden-field { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
    .field input, .field select, .field textarea {
      width: 100%; min-height: 3.15rem; border: 1px solid #bfcdd1; border-radius: .72rem; padding: .75rem .85rem; color: var(--ink); background: var(--white);
    }
    .field textarea { min-height: 135px; resize: vertical; }
    .field input:focus, .field select:focus, .field textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(0,121,151,.14); outline: 0; }
    .field input[aria-invalid="true"], .field select[aria-invalid="true"], .field textarea[aria-invalid="true"] { border-color: #b42318; }
    .field-hint { color: var(--muted); font-size: .75rem; }
    fieldset { grid-column: 1 / -1; margin: 0; padding: 0; border: 0; }
    .radio-row { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: .55rem; }
    .radio-chip { position: relative; }
    .radio-chip input { position: absolute; opacity: 0; pointer-events: none; }
    .radio-chip label { display: inline-flex; min-height: 2.7rem; align-items: center; padding: .65rem .85rem; border: 1px solid #bfcdd1; border-radius: 999px; color: var(--navy); background: var(--white); cursor: pointer; font-size: .8rem; font-weight: 760; }
    .radio-chip input:checked + label { border-color: var(--teal); background: #e8fbfd; box-shadow: inset 0 0 0 1px var(--teal); }
    .radio-chip input:focus-visible + label { outline: 3px solid var(--cyan); outline-offset: 2px; }
    .form-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin-top: .3rem; }
    .form-note { flex: 1 1 260px; color: var(--muted); font-size: .75rem; }
    .form-status { display: none; grid-column: 1 / -1; padding: 1rem; border-radius: .8rem; }
    .form-status.success { display: block; border: 1px solid #66a77c; color: #164a2c; background: #edf9f0; }
    .form-status.error { display: block; border: 1px solid #d67c74; color: #7a2018; background: #fff0ef; }
    .other-project-field[hidden] { display: none; }

    .site-footer { padding-block: 3rem 1.2rem; color: rgba(255,255,255,.7); background: #101d26; }
    .footer-main { display: grid; grid-template-columns: 1.35fr .65fr .8fr; gap: 2rem; padding-bottom: 2rem; }
    .footer-logo { width: min(100%, 370px); }
    .footer-main h2 { margin: 0 0 .7rem; color: var(--white); font-size: .85rem; letter-spacing: .11em; text-transform: uppercase; }
    .footer-main p { max-width: 490px; margin: .9rem 0 0; font-size: .88rem; }
    .footer-links { display: grid; gap: .55rem; }
    .footer-links a { width: fit-content; color: rgba(255,255,255,.74); text-decoration: none; font-size: .88rem; }
    .footer-links a:hover { color: var(--cyan); }
    .footer-bottom { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding-top: 1.2rem; border-top: 1px solid rgba(255,255,255,.1); font-size: .76rem; }
    .footer-bottom a { color: var(--cyan); text-decoration: none; font-weight: 800; }

    .mobile-call-bar { display: none; }
    .back-to-top { position: fixed; z-index: 900; right: 1rem; bottom: 1rem; display: grid; place-items: center; width: 3rem; height: 3rem; border: 0; border-radius: 50%; color: var(--navy); background: var(--cyan); box-shadow: var(--shadow-sm); cursor: pointer; opacity: 0; visibility: hidden; transform: translateY(10px); transition: .2s ease; }
    .back-to-top.visible { opacity: 1; visibility: visible; transform: none; }
    .back-to-top svg { width: 1.2rem; }

    @media (max-width: 980px) {
      .desktop-nav { display: none; }
      .nav-toggle { display: grid; }
      .hero-inner { grid-template-columns: 1fr; min-height: auto; padding-block: 4rem 5rem; }
      .hero-board { min-height: auto; }
      .blueprint-card { aspect-ratio: 1.25; width: 100%; transform: none; }
      .right-grid, .area-grid, .contact-grid { grid-template-columns: 1fr; }
      .right-logo-wrap { order: 2; }
      .process-grid { grid-template-columns: repeat(2, 1fr); }
      .footer-main { grid-template-columns: 1fr 1fr; }
      .footer-brand { grid-column: 1 / -1; }
    }

    @media (max-width: 760px) {
      :root { --header-h: 68px; }
      .container { width: min(calc(100% - 1.25rem), var(--max)); }
      .brand img { width: 205px; }
      .hero-inner { padding-block: 3.4rem 4.25rem; gap: 2.8rem; }
      .hero h1 { max-width: 13.8ch; font-size: clamp(3rem, 14.2vw, 4.85rem); line-height: 1; }
      .hero-actions .button { flex: 1 1 100%; }
      .button { min-height: 2.85rem; padding: .65rem .95rem; font-size: .92rem; }
      .hero-meta { display: grid; }
      .blueprint-card { min-height: 370px; aspect-ratio: auto; }
      .corner-tag { right: .2rem; top: 4%; }
      .proof-grid { grid-template-columns: 1fr; }
      .proof-item { min-height: 84px; padding: 1rem 0; border-right: 0; border-bottom: 1px solid var(--line); }
      .proof-item:last-child { border-bottom: 0; }
      .service-card, .service-card:nth-child(n), .project-card, .project-card:nth-child(n), .project-card.span-7, .project-card.span-5 { grid-column: 1 / -1; }
      .portfolio-group-head { grid-template-columns: 1fr; align-items: start; }
      .service-card { min-height: auto; }
      .process-grid { grid-template-columns: 1fr; }
      .form-grid { grid-template-columns: 1fr; }
      .field.full, fieldset, .form-actions, .form-status { grid-column: 1; }
      .footer-main { grid-template-columns: 1fr; }
      .footer-brand { grid-column: 1; }
      .footer-bottom { flex-direction: column; align-items: flex-start; }
      .mobile-call-bar {
        position: fixed; inset: auto 0 0; z-index: 950; display: grid; grid-template-columns: 1fr 1fr; gap: .55rem;
        padding: .55rem .65rem calc(.55rem + env(safe-area-inset-bottom)); border-top: 1px solid var(--line); background: rgba(255,255,255,.96); backdrop-filter: blur(12px);
      }
      .mobile-call-bar .button { min-height: 2.5rem; padding-inline: .55rem; font-size: .8rem; font-weight: 800; white-space: nowrap; }
      .site-footer { padding-bottom: 6rem; }
      .back-to-top { bottom: 5.7rem; }
    }

    @media (max-width: 430px) {
      .brand img { width: 180px; }
      .button { min-height: 2.7rem; padding: .58rem .85rem; font-size: .88rem; }
      .nav-toggle { width: 2.75rem; height: 2.75rem; }
      .mobile-actions { grid-template-columns: 1fr; }
      .section-title { font-size: 2.35rem; }
      .hero h1 { max-width: 13.8ch; font-size: clamp(2.75rem, 13.8vw, 3.8rem); line-height: 1.02; letter-spacing: -.05em; }
      .blueprint-logo { width: 100%; }
      .right-logo-wrap { padding: 1.1rem; }
      .project-card, .project-card.featured, .project-card.tall { min-height: 330px; }
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
      .button:hover, .service-card:hover { transform: none; }
    }


    /* Patch: keep the hero headline from clipping in Android/app webviews and short landscape previews. */
    @media (max-width: 980px) {
      .hero-copy { min-width: 0; }
      .hero h1 { max-width: 13.8ch; }
    }
    @media (orientation: landscape) and (max-height: 540px) {
      .hero-inner { padding-block: 2.4rem 3rem; }
      .hero h1 { max-width: 13.8ch; font-size: clamp(3rem, 10.6vw, 5.45rem); line-height: 1; letter-spacing: -.052em; }
      .hero-lead { margin-top: 1.15rem; font-size: 1rem; }
      .hero-actions { margin-top: 1.35rem; }
      .hero-meta { margin-top: 1.25rem; }
    }
    .specialty { padding-block: clamp(4rem, 8vw, 6.5rem); background: linear-gradient(180deg, #ecf8fb, var(--paper)); border-top: 3px solid var(--cyan); }
    .specialty .eyebrow, .specialty .accent { color: var(--teal); }
    .specialty .section-title { max-width: 19ch; }
    .owner-note { margin-top: 1.9rem; padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.12); }
    .owner-note p { color: rgba(255,255,255,.82); max-width: 52ch; }
    .owner-note .sig-img { height: 74px; width: auto; max-width: 100%; display: block; margin-top: 1rem; }
    .owner-note .sig-name { font-weight: 700; color: #fff; font-size: 1rem; margin-top: .5rem; }
    .owner-note .sig-role { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: .3rem; }
  

/* ============================================================
   Service-page additions (shared) — MMAC Renovation
   ============================================================ */
.page-hero { position:relative; overflow:hidden; color:var(--white);
  background: radial-gradient(circle at 82% 18%, rgba(55,237,249,.18), transparent 29%),
              linear-gradient(135deg, var(--navy-2) 0%, var(--navy) 58%, #28495d 100%); }
.page-hero::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.13;
  background-image:linear-gradient(rgba(255,255,255,.4) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.4) 1px,transparent 1px);
  background-size:52px 52px; mask-image:linear-gradient(to right,black,transparent 75%); }
.page-hero-inner { position:relative; z-index:1; padding-block:clamp(2.6rem,6vw,4.6rem); }
.page-hero .eyebrow { color:var(--cyan); }
.page-hero h1 { margin:0; font-size:clamp(2.2rem,5.2vw,3.8rem); line-height:1.02; letter-spacing:-.045em; font-weight:900; max-width:20ch; }
.page-hero .lead { max-width:62ch; margin:1.15rem 0 0; color:rgba(255,255,255,.8); font-size:clamp(1.02rem,2vw,1.2rem); }
.page-hero .hero-actions { margin-top:1.7rem; }
.page-hero .button-outline { color:var(--white); border-color:rgba(255,255,255,.34); background:rgba(255,255,255,.07); }

.breadcrumb { display:flex; flex-wrap:wrap; gap:.45rem; align-items:center; margin:0 0 1.1rem; padding:0; list-style:none; font-size:.82rem; color:rgba(255,255,255,.72); }
.breadcrumb a { color:rgba(255,255,255,.86); text-decoration:none; }
.breadcrumb a:hover { color:var(--cyan); }
.breadcrumb li { display:inline-flex; align-items:center; gap:.45rem; }
.breadcrumb li:not(:last-child)::after { content:"/"; color:rgba(255,255,255,.4); }

.svc { padding-block:clamp(3.5rem,8vw,6rem); background:var(--white); }
.svc-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.svc-grid p { color:var(--muted); }
.svc-grid h2 { margin:0; color:var(--navy); font-size:clamp(1.7rem,3.4vw,2.5rem); line-height:1.05; letter-spacing:-.035em; }
.svc-points { display:grid; gap:.65rem; margin:0; padding:0; list-style:none; }
.svc-points li { display:grid; grid-template-columns:auto 1fr; gap:.7rem; align-items:start; color:var(--navy); font-weight:650; }
.svc-points svg { width:1.2rem; margin-top:.15rem; color:var(--teal); flex:none; }
.svc-aside { border:1px solid var(--line); border-radius:var(--radius-md); background:var(--paper); padding:1.5rem; }
.svc-aside h3 { margin:0 0 .3rem; color:var(--navy); font-size:1.15rem; }
.svc-aside p { margin:.2rem 0 1rem; color:var(--muted); font-size:.92rem; }

.gallery-section { padding-block:clamp(3rem,7vw,5.5rem); background:var(--paper); border-top:1px solid var(--line); }
.gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.gallery figure { margin:0; overflow:hidden; border-radius:var(--radius-md); background:var(--navy); box-shadow:var(--shadow-sm); aspect-ratio:4/3; }
.gallery img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .45s ease; }
.gallery figure:hover img { transform:scale(1.04); }

.ba-wrap { display:grid; gap:1.4rem; }
.ba-pair { display:grid; grid-template-columns:1fr 1fr; gap:1rem; align-items:stretch; }
.ba-pair figure { margin:0; position:relative; overflow:hidden; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); aspect-ratio:4/3; background:var(--navy); }
.ba-pair img { width:100%; height:100%; object-fit:cover; display:block; }
.ba-tag { position:absolute; left:.7rem; top:.7rem; z-index:2; padding:.3rem .62rem; border-radius:.4rem; font-size:.7rem; font-weight:850; letter-spacing:.06em; text-transform:uppercase; color:var(--navy); background:var(--cyan); }
.ba-tag.is-after { color:var(--white); background:var(--teal); }

.svc-cta { padding-block:clamp(3rem,6vw,4.5rem); color:var(--white); background:var(--navy-2); }
.svc-cta .container { display:flex; flex-wrap:wrap; gap:1.3rem 2rem; align-items:center; justify-content:space-between; }
.svc-cta h2 { margin:0; color:var(--white); font-size:clamp(1.6rem,3vw,2.4rem); letter-spacing:-.03em; max-width:22ch; }
.svc-cta .cta-actions { display:flex; flex-wrap:wrap; gap:.8rem; }
.desktop-nav a.is-active { color:var(--teal); }

@media (max-width:900px){ .svc-grid{grid-template-columns:1fr;} .gallery{grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .gallery{grid-template-columns:1fr 1fr; gap:.7rem;} .ba-pair{grid-template-columns:1fr;} }
