@layer reset, tokens, base, layout, components, responsive;

@layer reset {
  *, *::before, *::after { box-sizing: border-box; }
  html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
  body, h1, h2, h3, h4, p, ul, ol, figure, blockquote, dl, dd { margin: 0; }
  a { color: inherit; text-decoration: none; }
  img, svg { display: block; max-width: 100%; }
  button, input, select, textarea { font: inherit; color: inherit; }
  button { border: 0; background: none; cursor: pointer; }
}

@layer tokens {
  :root {
    /* palette */
    --jade: #135d55;
    --jade-700: #0f4a44;
    --jade-900: #0a322e;
    --graphite: #434a4f;
    --teal: #1aaba1;
    --ink: #16201f;
    --muted: #5e696c;
    --faint: #657174;
    --paper: #ffffff;
    --paper-2: #f4f6f6;
    --paper-3: #eaeeee;
    --sand: #d7c4a3;
    --sand-2: #f4efe6;
    --stone: #d8d0c1;
    --hair: #e2e7e7;
    --hair-2: #cfd6d6;
    --on-dark: #ffffff;

    /* type */
    --font-display: "Montserrat", system-ui, sans-serif;
    --font-body: "Inter", system-ui, sans-serif;

    /* spacing scale (8pt) */
    --s1: .5rem;
    --s2: 1rem;
    --s3: 1.5rem;
    --s4: 2rem;
    --s5: 3rem;
    --s6: 4rem;
    --s7: 6rem;
    --s8: 8rem;

    --maxw: 75rem;
    --pad: clamp(1.25rem, 5vw, 3rem);
    --section: clamp(4.5rem, 8vw, 6.5rem);
    --section-tight: clamp(3.5rem, 6vw, 5rem);
    --radius: .125rem;
    --shadow-soft: 0 28px 72px -64px rgba(10,50,46,.72);
    --rule: 1px solid rgba(19,93,85,.12);

    /* fluid display sizes */
    --fs-hero: clamp(2.55rem, 1.45rem + 2.55vw, 3.7rem);
    --fs-h2: clamp(1.875rem, 1.22rem + 2.35vw, 3.1rem);
    --fs-h3: clamp(1.1875rem, 1rem + .55vw, 1.35rem);
    --fs-lead: clamp(1.03125rem, .97rem + .34vw, 1.1875rem);
    --fs-body: 1rem;
    --fs-small: .8125rem;
    --fs-eyebrow: .75rem;
  }
}

@layer base {
  :target { scroll-margin-top: 8rem; }

  body {
    background:
      radial-gradient(circle at 15% 0%, rgba(26,171,161,.045), transparent 28rem),
      linear-gradient(180deg, #fbfcfc 0%, var(--paper) 28rem);
    color: var(--ink);
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: 1.62;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }

  h1, h2, h3, h4 {
    font-family: var(--font-display);
    line-height: 1.04;
    letter-spacing: -0.025em;
    color: var(--ink);
    text-wrap: balance;
  }

  h1 { font-size: var(--fs-hero); font-weight: 800; line-height: 1; letter-spacing: -0.052em; }
  h2 { font-size: var(--fs-h2); font-weight: 750; line-height: 1.03; letter-spacing: -0.038em; }
  h3 { font-size: var(--fs-h3); font-weight: 700; letter-spacing: -0.015em; }

  p { color: var(--muted); line-height: 1.62; text-wrap: pretty; }

  ::selection { background: var(--jade); color: #fff; }
  :focus-visible { outline: 2px solid var(--teal); outline-offset: 2px; border-radius: 1px; }
  :focus:not(:focus-visible) { outline: none; }

  .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--s2);
    font-family: var(--font-display);
    font-size: var(--fs-eyebrow);
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--jade);
  }
  .eyebrow::before {
    content: "";
    width: 1.75rem;
    height: .0625rem;
    background: var(--teal);
  }
  .eyebrow.on-dark { color: rgba(255,255,255,.72); }
  .eyebrow.on-dark::before { background: var(--teal); }
  .eyebrow--center { justify-content: center; }
}

@layer layout {
  .wrap {
    width: 100%;
    max-width: var(--maxw);
    margin-inline: auto;
    padding-inline: var(--pad);
  }

  .section { padding-block: var(--section); }
  .section + .section { padding-block-start: var(--section-tight); }
  .section--tint {
    background: var(--paper-2);
  }
  .section--ink { background: var(--jade); color: var(--on-dark); }

  .stack > * + * { margin-block-start: var(--s3); }
  .plain-list { padding: 0; list-style: none; }

  /* two-column split with even rhythm */
  .split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(var(--s5), 6vw, var(--s8));
    align-items: center;
  }
}

@layer components {
  /* ---------- Header ---------- */
  .skip-link {
    position: fixed;
    inset: var(--s2) auto auto var(--s2);
    z-index: 100;
    padding: .625rem .875rem;
    background: var(--jade);
    color: #fff;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transform: translateY(calc(-100% - var(--s3)));
    transition: transform .2s;
  }
  .skip-link:focus-visible { transform: translateY(0); }

  .site-header {
    position: sticky;
    top: 0;
    z-index: 90;
    background: rgba(255,255,255,.9);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--hair);
    transition: box-shadow .25s ease, background-color .25s ease;
  }
  .site-header.is-scrolled {
    background: rgba(255,255,255,.96);
    box-shadow: 0 10px 30px -22px rgba(10,50,46,.6);
  }
  .header-inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s3);
    min-height: 6rem;
  }
  .logo { display: inline-flex; align-items: center; }
  .logo img { height: 6.475rem; width: auto; }
  .site-menu {
    position: absolute;
    inset: calc(100% - .25rem) var(--pad) auto auto;
    z-index: 110;
    width: min(26rem, calc(100dvw - var(--pad) * 2));
    padding: var(--s4);
    border: 1px solid var(--hair);
    background: rgba(255,255,255,.97);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-.5rem);
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
  }
  .site-header.is-menu-open .site-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  .main-nav { display: flex; align-items: center; gap: clamp(var(--s3), 2.6vw, 2.5rem); }
  .site-menu .main-nav {
    display: grid;
    align-items: stretch;
    gap: 0;
  }
  .main-nav a {
    display: inline-flex;
    align-items: center;
    min-height: 2.75rem;
    font-family: var(--font-display);
    font-size: .875rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--graphite);
    transition: color .2s;
  }
  .site-menu .main-nav a {
    justify-content: space-between;
    min-height: 3.25rem;
    border-bottom: 1px solid var(--hair);
    color: var(--ink);
  }
  .site-menu .main-nav a:first-child { border-top: 1px solid var(--hair); }
  .main-nav a:hover { color: var(--jade); }
  .nav-cta {
    min-height: 2.75rem;
    padding: .625rem 1.125rem;
    background: var(--jade);
    color: #fff !important;
    border-radius: var(--radius);
    font-size: .8125rem !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase;
  }
  .nav-cta:hover { background: var(--jade-700); }
  .menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s2);
    min-height: 2.75rem;
    padding-inline: 1rem;
    border: 1px solid var(--hair);
    color: var(--jade-900);
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    transition: border-color .2s, color .2s, background-color .2s;
  }
  .menu-toggle:hover { border-color: var(--jade); color: var(--jade); }
  .menu-toggle i,
  .menu-toggle i::before,
  .menu-toggle i::after {
    display: block;
    width: 1.25rem;
    height: 1px;
    background: currentColor;
    transition: transform .18s ease, opacity .18s ease;
  }
  .menu-toggle i { position: relative; }
  .menu-toggle i::before,
  .menu-toggle i::after { content: ""; position: absolute; inset-inline-start: 0; }
  .menu-toggle i::before { transform: translateY(-.375rem); }
  .menu-toggle i::after { transform: translateY(.375rem); }
  .site-header.is-menu-open .menu-toggle i { background: transparent; }
  .site-header.is-menu-open .menu-toggle i::before { transform: rotate(45deg); }
  .site-header.is-menu-open .menu-toggle i::after { transform: rotate(-45deg); }
  .lang-switch {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .25rem;
    border: 1px solid var(--hair);
    background: rgba(255,255,255,.72);
  }
  .site-menu .lang-switch { margin-block-start: var(--s3); }
  .lang-switch a {
    display: inline-grid;
    place-items: center;
    min-width: 2.5rem;
    min-height: 2.25rem;
    padding-inline: .625rem;
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 800;
    letter-spacing: .12em;
    color: var(--jade-900);
    transition: background-color .2s, color .2s;
  }
  .lang-switch a:hover { color: var(--jade); }
  .lang-switch a[aria-current="page"] {
    background: var(--jade);
    color: #fff;
  }

  /* ---------- Buttons ---------- */
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .625rem;
    min-height: 3.25rem;
    padding-inline: var(--s4);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .8125rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.105em;
    text-align: center;
    text-transform: uppercase;
    white-space: nowrap;
    transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s;
  }
  .btn:active { transform: translateY(1px); }
  .btn--primary { background: var(--jade); color: #fff; }
  .btn--primary:hover { background: var(--jade-700); box-shadow: 0 14px 30px -18px rgba(10,50,46,.9); transform: translateY(-1px); }
  .btn--ghost { border-color: rgba(255,255,255,.4); color: #fff; }
  .btn--ghost:hover { background: #fff; color: var(--jade); border-color: #fff; }
  .btn--line { border-color: var(--hair-2); color: var(--jade); }
  .btn--line:hover { background: var(--jade); color: #fff; border-color: var(--jade); }

  /* ---------- Icons (recolored via mask) ---------- */
  .ico {
    display: inline-grid;
    place-items: center;
    width: 1em;
    height: 1em;
    flex: none;
    align-self: center;
    justify-self: center;
    vertical-align: middle;
    background-color: currentColor;
    -webkit-mask: var(--ico) center / contain no-repeat;
    mask: var(--ico) center / contain no-repeat;
  }
  :is(.svc__icon, .step__icon, .chips li, .verify li, .socials a, .quick a, .mobile-dock a, .mobile-dock button) .ico { margin: auto; }
  .btn .ico { width: 1rem; height: 1rem; margin: 0; transform: translateY(-.02em); }
  .ico--arrow { --ico: url("assets/icons/arrow.svg"); }
  .ico--building { --ico: url("assets/icons/building.svg"); }
  .ico--check { --ico: url("assets/icons/check.svg"); }
  .ico--facebook { --ico: url("assets/icons/facebook.svg"); }
  .ico--hammer { --ico: url("assets/icons/hammer.svg"); }
  .ico--home { --ico: url("assets/icons/home.svg"); }
  .ico--instagram { --ico: url("assets/icons/instagram.svg"); }
  .ico--key { --ico: url("assets/icons/key.svg"); }
  .ico--layers { --ico: url("assets/icons/layers.svg"); }
  .ico--map { --ico: url("assets/icons/map.svg"); }
  .ico--message { --ico: url("assets/icons/message.svg"); }
  .ico--paint { --ico: url("assets/icons/paint.svg"); }
  .ico--phone { --ico: url("assets/icons/phone.svg"); }
  .ico--ruler { --ico: url("assets/icons/ruler.svg"); }
  .ico--send { --ico: url("assets/icons/send.svg"); }
  .ico--shield { --ico: url("assets/icons/shield.svg"); }
  .ico--telegram { --ico: url("assets/icons/telegram.svg"); }
  .ico--trending { --ico: url("assets/icons/trending.svg"); }
  .ico--whatsapp { --ico: url("assets/icons/whatsapp.svg"); }
  .ico--wrench { --ico: url("assets/icons/wrench.svg"); }

  /* ---------- Hero ---------- */
  .hero {
    position: relative;
    min-height: min(48rem, calc(100svh - 6rem));
    display: flex;
    align-items: center;
    color: var(--ink);
    isolation: isolate;
    overflow: hidden;
    background:
      radial-gradient(circle at 78% 18%, rgba(215,196,163,.22), transparent 25rem),
      linear-gradient(180deg, #fbfaf7 0%, #fff 100%);
    border-bottom: 1px solid var(--hair);
  }
  .hero::before {
    content: "";
    position: absolute;
    inset: 8% auto auto 46%;
    width: min(34vw, 26rem);
    aspect-ratio: 1;
    z-index: -1;
    border: 1px solid rgba(19,93,85,.12);
    background: rgba(19,93,85,.035);
    transform: rotate(8deg);
    animation: heroFloat 9s ease-in-out infinite;
  }
  @keyframes heroFloat {
    0%, 100% { transform: translate3d(0,0,0) rotate(8deg); }
    50% { transform: translate3d(0,-.875rem,0) rotate(5deg); }
  }
  @keyframes heroImageDrift {
    0% { transform: scale(1.035) translate3d(0,0,0); }
    100% { transform: scale(1.09) translate3d(-1.2%, .8%, 0); }
  }
  @keyframes heroTextIn {
    from { opacity: 0; transform: translateY(1rem); }
    to { opacity: 1; transform: translateY(0); }
  }
  .hero__bg {
    position: relative;
    z-index: 0;
    overflow: hidden;
    width: 100%;
    max-width: min(31.5rem, 100%);
    justify-self: end;
    height: clamp(23rem, 44svh, 32rem);
    background: var(--paper-3);
    border: 1px solid var(--hair);
  }
  .hero__bg img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    filter: saturate(.9) contrast(1.02);
    transform: scale(1.035);
    animation: heroImageDrift 18s ease-in-out infinite alternate;
  }
  .hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(22,32,31,.18) 100%);
  }
  .hero .wrap { padding-block: clamp(3.25rem, 5vw, 4.75rem); width: 100%; }
  .hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(24rem, 31.5rem);
    gap: clamp(3.25rem, 5.2vw, 5.75rem);
    align-items: center;
    width: 100%;
    max-width: var(--maxw);
    margin-inline: auto;
  }
  .hero__inner { max-width: 41.5rem; animation: heroTextIn .75s cubic-bezier(.2,.6,.2,1) both; }
  .hero__inner > * { animation: heroTextIn .75s cubic-bezier(.2,.6,.2,1) both; }
  .hero__inner > *:nth-child(2) { animation-delay: .06s; }
  .hero__inner > *:nth-child(3) { animation-delay: .12s; }
  .hero__inner > *:nth-child(4) { animation-delay: .18s; }
  .hero__inner > *:nth-child(5) { animation-delay: .24s; }
  .hero__inner > *:nth-child(6) { animation-delay: .3s; }
  .hero .on-dark { color: var(--faint); }
  .hero .on-dark::before { background: var(--stone); }
  .hero__org {
    display: inline-flex;
    align-items: center;
    margin-block-start: .875rem;
    padding: .46rem .82rem;
    border: 1px solid rgba(19,93,85,.22);
    border-left: 3px solid var(--jade);
    background: linear-gradient(90deg, rgba(19,93,85,.08), rgba(255,255,255,.55));
    color: var(--jade-900);
    font-family: var(--font-display);
    font-size: clamp(.75rem, .68rem + .22vw, .875rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: .115em;
    text-transform: uppercase;
  }
  .hero h1 { color: var(--ink); font-weight: 800; }
  .hero__title { margin-block-start: 1.25rem; max-width: min(15.8ch, 100%); hyphens: none; overflow-wrap: normal; }
  .hero h1 em { font-style: normal; color: var(--ink); }
  .hero__lead {
    margin-block-start: 1.15rem;
    max-width: 40ch;
    color: var(--muted);
    font-size: var(--fs-lead);
    line-height: 1.55;
  }
  .hero__bullets {
    margin-block-start: 1.45rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: .55rem;
    max-width: 42rem;
    padding: 0;
    list-style: none;
  }
  .hero__bullets li {
    display: grid;
    grid-template-columns: .45rem minmax(0, 1fr);
    align-items: baseline;
    gap: .72rem;
    padding: .58rem 0;
    border-bottom: 1px solid var(--hair);
    color: var(--graphite);
    font-family: var(--font-display);
    font-size: .765rem;
    font-weight: 650;
    line-height: 1.34;
    letter-spacing: .025em;
  }
  .hero__bullets li::before {
    content: "";
    width: .34rem;
    height: .34rem;
    background: var(--stone);
  }
  .hero__actions { margin-block-start: 2rem; display: flex; flex-wrap: wrap; gap: .875rem; }
  .hero__actions .btn { box-shadow: 0 1.1rem 2.6rem -2rem rgba(10,50,46,.8); }
  .hero__actions .btn:hover { transform: translateY(-2px); }
  .hero__meta {
    margin-block-start: var(--s5);
    padding-block-start: var(--s4);
    border-top: 1px solid var(--hair);
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: clamp(var(--s4), 6vw, var(--s7));
    justify-content: start;
  }
  .hero__meta div strong {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(26px, 3vw, 36px);
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -0.02em;
  }
  .hero__meta div span {
    font-size: var(--fs-small);
    color: var(--muted);
    letter-spacing: 0.02em;
  }
  .hero__card {
    position: relative;
    align-self: end;
    padding: var(--s3) 0 0;
    border-top: 1px solid var(--hair);
    background: transparent;
    box-shadow: none;
  }
  .hero__card::before {
    content: "";
    position: absolute;
    inset-block-start: 0;
    inset-inline: 0;
    height: 0;
    background: none;
  }
  .hero__card span,
  .hero__card strong {
    display: block;
    font-family: var(--font-display);
  }
  .hero__card span {
    color: var(--faint);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
  }
  .hero__card strong {
    margin-block-start: var(--s3);
    color: var(--ink);
    font-size: clamp(1.5rem, 1rem + 2vw, 2.125rem);
    line-height: 1.05;
    letter-spacing: -.03em;
  }
  .hero__card p { margin-block-start: var(--s3); color: var(--muted); }
  .status-list {
    margin-block-start: var(--s4);
    padding: 0;
    list-style: none;
    display: grid;
    gap: var(--s2);
  }
  .status-list li {
    display: grid;
    grid-template-columns: 2.5rem 1fr;
    gap: var(--s2);
    align-items: center;
    padding-block-start: var(--s2);
    border-top: 1px solid var(--hair);
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--graphite);
  }
  .status-list span { color: var(--faint); }

  /* ---------- Company proof ---------- */
  .company-proof { padding-block: var(--s5); background: #fff; }
  .company-proof__card {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: clamp(var(--s4), 5vw, var(--s7));
    align-items: start;
    padding-block: var(--s5);
    border-block: 1px solid var(--hair);
    container-type: inline-size;
  }
  .company-proof h2 {
    margin-block-start: var(--s2);
    max-width: 15em;
    font-size: clamp(1.75rem, 1rem + 2.2vw, 2.75rem);
  }
  .company-proof__intro p {
    max-width: 38rem;
    margin-block-start: var(--s3);
    font-size: var(--fs-lead);
    color: var(--muted);
  }
  .company-proof__story {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s2);
    padding: var(--s2);
    border: 1px solid var(--hair);
    border-radius: var(--radius);
    background:
      radial-gradient(circle at 92% 8%, rgba(194, 151, 91, .18), transparent 28%),
      linear-gradient(145deg, rgba(255,255,255,.96), rgba(247,241,232,.72));
  }
  .company-proof__story article {
    min-height: 0;
    padding: var(--s3);
    border-bottom: 1px solid var(--hair);
    border-radius: calc(var(--radius) * .55);
    background: rgba(255,255,255,.48);
    display: grid;
    grid-template-columns: minmax(4.5rem, .28fr) minmax(0, 1fr);
    align-items: start;
    gap: var(--s3);
    transition: border-color .2s ease, transform .2s ease;
  }
  .company-proof__story article:last-of-type { border-bottom: 0; }
  .company-proof__story article:hover {
    border-color: rgba(24, 85, 65, .18);
    transform: translateY(-2px);
  }
  .company-proof__story span,
  .company-proof__link {
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--faint);
  }
  .company-proof__story h3 {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(1.15rem, .9rem + .8vw, 1.55rem);
    font-weight: 700;
    color: var(--jade-900);
    letter-spacing: -.02em;
  }
  .company-proof__story p { grid-column: 2; margin: -.4rem 0 0; color: var(--muted); }
  .company-proof__link {
    grid-column: 1 / -1;
    display: inline-flex;
    justify-self: end;
    align-items: center;
    gap: .55rem;
    min-height: 2.75rem;
    padding-inline: var(--s3);
    border: 1px solid var(--hair);
    border-radius: 999px;
    color: var(--jade-900);
    background: #fff;
  }
  .company-proof__link:hover { border-color: rgba(24, 85, 65, .35); background: var(--sand-2); }
  @container (max-width: 42rem) {
    .company-proof__story { gap: 0; padding: var(--s1); }
    .company-proof__story { grid-template-columns: 1fr; }
    .company-proof__story article { grid-template-columns: 1fr; gap: var(--s2); padding: var(--s3); }
    .company-proof__story p { grid-column: auto; margin-block-start: -.25rem; }
    .company-proof__link { justify-self: start; }
  }

  /* ---------- Section heading ---------- */
  .head { max-width: 60ch; }
  .head h2 { margin-block-start: var(--s2); }
  .head p { margin-block-start: var(--s3); font-size: var(--fs-lead); }
  .head--center { margin-inline: auto; text-align: center; }
  .head--center .eyebrow { justify-content: center; }

  .editorial { position: relative; }
  .media-frame {
    position: relative;
  }

  /* ---------- Intro split ---------- */
  .intro__media {
    aspect-ratio: 4/5;
    background: url("media/3/499051073_17987907041804187_3248527792756663469_n.jpg") center/cover no-repeat;
    border-radius: var(--radius);
  }
  .intro__body .btns { margin-block-start: var(--s4); display: flex; flex-wrap: wrap; gap: var(--s2); }
  .intro__copy { margin-block-start: var(--s3); }

  /* ---------- Services ---------- */
  .services__grid {
    margin-block-start: var(--s6);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border: var(--rule);
    border-radius: var(--radius);
    overflow: hidden;
  }
  .svc {
    position: relative;
    padding: clamp(var(--s4), 3vw, var(--s5));
    border-right: 1px solid var(--hair);
    background: var(--paper);
    transition: background .25s ease;
  }
  .svc::before {
    content: "";
    position: absolute;
    inset-block-start: 0;
    inset-inline: 0;
    height: 2px;
    background: var(--teal);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s ease;
  }
  .svc:last-child { border-right: 0; }
  .svc:hover { background: var(--paper-2); }
  .svc:hover::before { transform: scaleX(1); }
  .svc__no {
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: 600;
    letter-spacing: 0.16em;
    color: var(--teal);
  }
  .svc__icon {
    display: grid;
    place-items: center;
    width: 3.5rem;
    height: 3.5rem;
    margin-block-end: var(--s4);
    border: 1px solid var(--hair-2);
    border-radius: var(--radius);
    color: var(--jade);
    transition: background .25s, color .25s, border-color .25s;
  }
  .svc__icon > .ico { place-self: center; }
  .svc__icon .ico { width: 1.625rem; height: 1.625rem; }
  .svc:hover .svc__icon { color: #fff; background: var(--jade); border-color: var(--jade); }
  .svc h3 { margin-block-start: 0; }
  .svc p { margin-block-start: var(--s2); }
  .svc__link {
    display: inline-flex;
    align-items: center;
    gap: var(--s1);
    min-height: 2.75rem;
    margin-block-start: var(--s3);
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jade);
  }
  .svc__link span { display: inline-grid; place-items: center; transition: transform .2s; }
  .svc__link .ico { width: .9375rem; height: .9375rem; }
  .svc:hover .svc__link span { transform: translateX(.125rem); }

  .service-note {
    margin-block-start: var(--s4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s4);
    padding: var(--s3) clamp(var(--s3), 3vw, var(--s4));
    border: 1px solid var(--hair);
    background: #fff;
  }
  .service-note p { max-width: 76ch; color: var(--graphite); }
  .service-note a {
    display: inline-flex;
    align-items: center;
    gap: var(--s1);
    flex: none;
    min-height: 2.75rem;
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--jade);
    transition: color .2s, gap .2s;
  }
  .service-note a:hover { color: var(--jade-700); gap: var(--s2); }
  .service-note .ico { width: .9375rem; height: .9375rem; }

  /* ---------- Capability list ---------- */
  .cap__media {
    aspect-ratio: 5/6;
    background: url("assets/service-3.jpeg") center/cover no-repeat;
    border-radius: var(--radius);
  }
  .cap__list { margin-block-start: var(--s4); }
  .cap__list,
  .chips,
  .verify { padding: 0; list-style: none; }
  .cap__list li {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--s3);
    align-items: center;
    padding-block: var(--s3);
    border-bottom: 1px solid var(--hair);
    color: var(--ink);
    font-size: var(--fs-lead);
  }
  .cap__list li .ico { place-self: center; }
  .cap__list li:first-child { border-top: 1px solid var(--hair); }
  .cap__list li .ico {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--teal);
  }

  /* ---------- Approach steps ---------- */
  .steps {
    margin-block-start: var(--s6);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--s5) var(--s4);
  }
  .process {
    margin-block-start: var(--s6);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border: 1px solid var(--hair);
    background: var(--paper);
  }
  .process article {
    position: relative;
    min-height: 15.625rem;
    padding: clamp(var(--s3), 3vw, var(--s5));
    border-right: 1px solid var(--hair);
    display: grid;
    grid-template-rows: auto minmax(4.75rem, auto) 1fr;
    align-content: start;
    align-items: start;
    gap: var(--s3);
    overflow: hidden;
    transition: background .25s;
  }
  .process article::before {
    content: attr(data-step);
    position: absolute;
    inset: auto -.4em -.28em auto;
    font-family: var(--font-display);
    font-size: clamp(5rem, 9vw, 8rem);
    font-weight: 800;
    line-height: .8;
    letter-spacing: -.08em;
    color: rgba(19,93,85,.035);
    pointer-events: none;
  }
  .process article:hover { background: #fff; }
  .process article:last-child { border-right: 0; }
  .process span {
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .2em;
    color: var(--teal);
  }
  .process h3 {
    align-self: start;
    min-height: 2.12em;
    color: var(--jade-900);
    font-size: clamp(1.5rem, 1rem + 1.8vw, 2.125rem);
  }
  .process p {
    align-self: start;
  }
  .step__no {
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: 600;
    letter-spacing: 0.16em;
    color: var(--faint);
  }
  .step__icon {
    display: grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    margin-block-end: var(--s3);
    color: var(--jade);
    border: 1px solid var(--hair-2);
    border-radius: var(--radius);
  }
  .step__icon > .ico { place-self: center; }
  .step__icon .ico { width: 1.375rem; height: 1.375rem; }
  .step h3 { margin-block: var(--s3) var(--s2); color: var(--jade); }
  .step__head { display: flex; align-items: center; justify-content: space-between; }

  /* ---------- Trust band ---------- */
  .trust {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    align-items: stretch;
    background: #fff;
  }
  .trust__text { padding: clamp(var(--s5), 6vw, var(--s8)) clamp(var(--s4), 5vw, var(--s7)); }
  .trust__lead { margin-block-start: var(--s3); }
  .trust__badges { margin-block-start: var(--s4); display: flex; flex-wrap: wrap; gap: var(--s1); }
  .trust__badges span {
    padding: .625rem .875rem;
    border: 1px solid var(--hair-2);
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--graphite);
  }
  .trust__panel {
    background: url("assets/portfolio-2.jpg") center/cover no-repeat;
    min-height: 26.25rem;
  }

  /* ---------- Deliverables ---------- */
  .deliverables {
    position: relative;
    overflow: hidden;
    background: var(--jade-900);
    color: #fff;
  }
  .deliverables__grid {
    position: relative;
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: clamp(var(--s5), 6vw, var(--s8));
    align-items: start;
  }
  .deliverables h2,
  .deliverables h3 { color: #fff; }
  .deliverables p { color: rgba(255,255,255,.74); }
  .deliverables__intro > p { margin-block-start: var(--s3); font-size: var(--fs-lead); }
  .deliverables__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(255,255,255,.045);
  }
  .deliverables__cards article {
    min-height: 21.25rem;
    padding: clamp(var(--s3), 3vw, var(--s5));
    border-right: 1px solid rgba(255,255,255,.16);
    display: grid;
    align-content: space-between;
    gap: var(--s4);
  }
  .deliverables__cards article:last-child { border-right: 0; }
  .deliverables__cards span {
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .18em;
    color: var(--sand);
  }

  /* ---------- Portfolio ---------- */
  .gallery {
    margin-block-start: var(--s6);
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--s2);
  }
  .gallery figure { position: relative; margin: 0; overflow: hidden; border-radius: var(--radius); background: var(--jade-900); }
  .js img[loading="lazy"] {
    opacity: 0;
    transform: scale(1.012);
    transition: opacity .35s ease, transform .45s cubic-bezier(.2,.6,.2,1);
  }
  .js img[loading="lazy"].is-loaded,
  noscript img[loading="lazy"] {
    opacity: 1;
    transform: none;
  }
  .js img[loading="lazy"].has-load-error {
    opacity: 0;
    transform: none;
  }
  .gallery img { width: 100%; height: 100%; object-fit: cover; transition: opacity .35s ease, transform .6s cubic-bezier(.2,.6,.2,1); }
  .gallery figure:hover img { transform: scale(1.045); }
  .gallery figcaption {
    position: absolute;
    inset: auto 0 0 0;
    padding: var(--s4) var(--s3) var(--s2);
    background: linear-gradient(180deg, transparent, rgba(10,50,46,.86));
    color: #fff;
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .gallery .g1 { grid-column: span 7; aspect-ratio: 16/11; }
  .gallery .g2 { grid-column: span 5; aspect-ratio: 4/3; }
  .gallery .g3 { grid-column: span 5; aspect-ratio: 4/3; }
  .gallery .g4 { grid-column: span 7; aspect-ratio: 16/11; }

  /* ---------- Case studies ---------- */
  .case-studies {
    margin-block-start: var(--s7);
    display: grid;
    gap: clamp(var(--s6), 8vw, var(--s8));
  }
  .case-study {
    display: grid;
    grid-template-columns: minmax(18rem, .78fr) minmax(0, 1.22fr);
    gap: clamp(var(--s4), 5vw, var(--s7));
    align-items: center;
    padding-block: clamp(var(--s4), 5vw, var(--s6));
    border-top: 1px solid rgba(19,93,85,.16);
  }
  .case-study--reverse .case-study__copy { order: 2; }
  .case-study__copy {
    display: grid;
    gap: var(--s3);
    align-content: center;
  }
  .case-study__label {
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--teal);
  }
  .case-study h3 {
    color: var(--jade-900);
    font-size: clamp(1.75rem, 1.15rem + 2.6vw, 3.35rem);
  }
  .case-study__facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0;
    border-block: 1px solid var(--hair);
  }
  .case-study__facts div { padding: var(--s3) var(--s2); border-right: 1px solid var(--hair); }
  .case-study__facts div:last-child { border-right: 0; }
  .case-study__facts dt {
    font-family: var(--font-display);
    font-size: .625rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--faint);
  }
  .case-study__facts dd {
    margin-block-start: .35rem;
    font-family: var(--font-display);
    font-weight: 800;
    color: var(--jade-900);
    line-height: 1.2;
  }
  .case-study__notes {
    display: grid;
    gap: var(--s1);
    margin: 0;
    padding-inline-start: 1.1rem;
    color: var(--muted);
  }

  .case-gallery {
    position: relative;
    display: grid;
    gap: var(--s2);
    min-width: 0;
  }
  .case-gallery__rail {
    display: flex;
    align-items: center;
    gap: var(--s2);
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: thin;
    scrollbar-color: rgba(19,93,85,.35) transparent;
    padding: var(--s2) max(var(--s2), 2vw) var(--s3);
    background:
      radial-gradient(circle at 12% 8%, rgba(215,196,163,.28), transparent 30%),
      linear-gradient(135deg, rgba(255,255,255,.96), rgba(244,239,230,.62));
    border: 1px solid var(--hair);
  }
  .case-gallery__item {
    flex: 0 0 auto;
    position: relative;
    display: grid;
    place-items: center;
    margin: 0;
    overflow: hidden;
    scroll-snap-align: center;
    background:
      radial-gradient(circle at 22% 18%, rgba(26,171,161,.12), transparent 32%),
      linear-gradient(135deg, rgba(255,255,255,.98), rgba(244,239,230,.84));
    border: 1px solid rgba(19,93,85,.12);
    box-shadow: 0 1.4rem 3.4rem -2.5rem rgba(10,50,46,.55);
  }
  .case-gallery__item::before,
  .case-gallery__item::after {
    content: "";
    position: absolute;
    pointer-events: none;
  }
  .case-gallery__item::before {
    inset: 0;
    z-index: 0;
    background:
      linear-gradient(30deg, transparent 45%, rgba(19,93,85,.05) 45% 55%, transparent 55%),
      linear-gradient(150deg, transparent 45%, rgba(26,171,161,.06) 45% 55%, transparent 55%);
    background-size: 3.5rem 3.5rem;
    opacity: .72;
  }
  .case-gallery__item::after {
    z-index: 1;
    inline-size: 4.75rem;
    block-size: 4.75rem;
    border-radius: .5rem;
    background:
      linear-gradient(135deg, rgba(19,93,85,.95), rgba(26,171,161,.78)) top left / 52% 52% no-repeat,
      linear-gradient(225deg, rgba(215,196,163,.95), rgba(255,255,255,.66)) top right / 52% 52% no-repeat,
      linear-gradient(45deg, rgba(10,50,46,.82), rgba(19,93,85,.62)) bottom left / 52% 52% no-repeat,
      linear-gradient(315deg, rgba(244,239,230,.96), rgba(215,196,163,.86)) bottom right / 52% 52% no-repeat;
    box-shadow: 0 1.25rem 2.6rem -.95rem rgba(10,50,46,.42);
    transform: rotateX(58deg) rotateZ(45deg);
    animation: imageIsoLoader 1.45s ease-in-out infinite;
    transition: opacity .25s ease, transform .25s ease;
  }
  .case-gallery__item.is-image-loaded::after {
    opacity: 0;
    transform: rotateX(58deg) rotateZ(45deg) scale(.82);
  }
  .case-gallery__item.has-image-error::after {
    opacity: 1;
    animation: none;
    transform: rotateX(58deg) rotateZ(45deg);
  }
  .case-gallery__item.has-image-error::before {
    background:
      radial-gradient(circle at 50% 40%, rgba(255,255,255,.82), transparent 5.5rem),
      linear-gradient(30deg, transparent 45%, rgba(19,93,85,.06) 45% 55%, transparent 55%),
      linear-gradient(150deg, transparent 45%, rgba(26,171,161,.07) 45% 55%, transparent 55%);
    background-size: auto, 3.5rem 3.5rem, 3.5rem 3.5rem;
  }
  .case-gallery__item.has-image-error figcaption::before {
    content: attr(data-fallback-label);
    display: block;
    margin-block-end: .2rem;
    color: rgba(255,255,255,.78);
    font-size: .55rem;
    letter-spacing: .1em;
  }
  .case-gallery__item--hero { inline-size: clamp(20rem, 44vw, 38rem); block-size: clamp(20rem, 45vw, 34rem); }
  .case-gallery__item--landscape { inline-size: clamp(19rem, 38vw, 32rem); block-size: clamp(14rem, 27vw, 22rem); }
  .case-gallery__item--portrait { inline-size: clamp(14rem, 26vw, 21rem); block-size: clamp(19rem, 38vw, 30rem); }
  .case-gallery__item--square { inline-size: clamp(15rem, 28vw, 23rem); block-size: clamp(15rem, 28vw, 23rem); }
  .case-gallery__item:nth-child(2n) { transform: translateY(var(--s3)); }
  .case-gallery__item:nth-child(3n) { transform: translateY(calc(var(--s2) * -1)); }
  .case-gallery__item img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: clamp(.45rem, 1vw, .875rem);
    filter: saturate(.96) contrast(.98);
    background: linear-gradient(135deg, rgba(244,239,230,.94), rgba(255,255,255,.76));
  }
  .case-gallery__item figcaption {
    position: absolute;
    z-index: 3;
    inset: auto var(--s2) var(--s2) auto;
    padding: .4rem .65rem;
    background: rgba(10,50,46,.84);
    color: #fff;
    font-family: var(--font-display);
    font-size: .625rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
  }
  .case-gallery__controls {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--s1);
  }
  .case-gallery__controls span {
    margin-inline-end: auto;
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--faint);
  }
  .case-gallery__controls button {
    display: grid;
    place-items: center;
    inline-size: 2.75rem;
    block-size: 2.75rem;
    border: 1px solid var(--hair-2);
    background: #fff;
    color: var(--jade-900);
    font-family: var(--font-display);
    font-weight: 800;
    transition: background .2s ease, color .2s ease, transform .2s ease;
  }
  .case-gallery__controls button:hover { background: var(--jade); color: #fff; transform: translateY(-1px); }

  /* ---------- Before / After ---------- */
  .before-after {
    position: relative;
    overflow: hidden;
    background:
      linear-gradient(90deg, rgba(244,239,230,.68), transparent 42%),
      var(--paper);
  }
  .before-after::before {
    content: "";
    position: absolute;
    inset: 12% auto auto 0;
    inline-size: min(22vw, 16rem);
    block-size: 46%;
    background: var(--jade-900);
    opacity: .055;
    pointer-events: none;
  }
  .before-after__grid {
    position: relative;
    display: grid;
    grid-template-columns: minmax(17rem, .78fr) minmax(0, 1.22fr);
    gap: clamp(var(--s5), 7vw, var(--s8));
    align-items: center;
  }
  .before-after__copy {
    display: grid;
    gap: var(--s3);
    max-width: 34rem;
  }
  .before-after__copy h2 {
    color: var(--jade-900);
    font-size: clamp(2rem, 1.35rem + 2.7vw, 3.75rem);
  }
  .before-after__figure {
    position: relative;
    margin: 0;
    display: grid;
    padding: clamp(.75rem, 1.7vw, 1.25rem);
    overflow: visible;
    background:
      linear-gradient(135deg, rgba(19,93,85,.12), transparent 42%),
      #fff;
    border: 1px solid var(--hair);
    box-shadow: 0 1.4rem 4rem rgba(10,50,46,.14);
    transform: translateY(var(--s3));
  }
  .before-after__figure::before,
  .before-after__figure::after {
    content: "";
    position: absolute;
    z-index: -1;
    pointer-events: none;
  }
  .before-after__figure::before {
    inset: auto 7% -7% -6%;
    block-size: 44%;
    background: var(--sand-2);
    border: 1px solid rgba(215,196,163,.5);
  }
  .before-after__figure::after {
    inset: -8% -5% auto auto;
    inline-size: 42%;
    block-size: 52%;
    border: 1px solid rgba(19,93,85,.18);
    background: rgba(234,238,238,.72);
  }
  .before-after__figure img {
    width: 100%;
    height: 100%;
    max-height: min(68vh, 42rem);
    aspect-ratio: 1 / 1;
    object-fit: contain;
    display: block;
    background: var(--jade-900);
  }
  .before-after__figure figcaption {
    position: absolute;
    inset: auto clamp(var(--s2), 2vw, var(--s4)) clamp(var(--s2), 2vw, var(--s4));
    display: flex;
    justify-content: space-between;
    gap: var(--s2);
    pointer-events: none;
  }
  .before-after__figure figcaption span {
    padding: .55rem .8rem;
    background: rgba(10,50,46,.86);
    color: #fff;
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
  }
  .before-after__figure figcaption span:first-child { transform: translateY(-.875rem); }
  .before-after__figure figcaption span:last-child { transform: translateY(.875rem); }

  /* ---------- Cases ---------- */
  .case-grid {
    margin-block-start: var(--s6);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s2);
  }
  .case-card {
    position: relative;
    background: var(--paper);
    border: 1px solid var(--hair);
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 100%;
  }
  .case-card img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
  }
  .case-card > div { padding: clamp(var(--s3), 3vw, var(--s5)); }
  .case-card span {
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--teal);
  }
  .case-card h3 { margin-block-start: var(--s2); color: var(--jade-900); }
  .case-card p { margin-block-start: var(--s2); }
  .case-card dl {
    margin-block-start: var(--s4);
    display: grid;
    gap: var(--s2);
    border-top: 1px solid var(--hair);
    padding-block-start: var(--s3);
  }
  .case-card dl div { display: flex; justify-content: space-between; gap: var(--s3); }
  .case-card dt {
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--faint);
  }
  .case-card dd { font-weight: 600; color: var(--ink); text-align: right; }
  .case-card--dark { background: var(--jade-900); border-color: var(--jade-900); }
  .case-card--dark h3,
  .case-card--dark dd { color: #fff; }
  .case-card--dark p { color: rgba(255,255,255,.72); }
  .case-card--dark dl { border-color: rgba(255,255,255,.16); }

  /* ---------- Coverage ---------- */
  .chips {
    margin-block-start: var(--s5);
    display: flex;
    flex-wrap: wrap;
    gap: var(--s1);
    justify-content: center;
  }
  .chips li {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s1);
    padding: .75rem 1.125rem;
    border: 1px solid var(--hair);
    border-radius: 999px;
    background: #fff;
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: 500;
    color: var(--graphite);
    transition: border-color .2s, color .2s, background-color .2s;
  }
  .chips li .ico { align-self: center; }
  .chips li .ico { width: .875rem; height: .875rem; color: var(--teal); }
  .chips li:hover { border-color: var(--jade); color: var(--jade); background: var(--sand-2); }

  /* ---------- FAQ ---------- */
  .faq__grid {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    gap: clamp(var(--s5), 6vw, var(--s8));
    align-items: start;
  }
  .faq__grid > div:first-child > p { margin-block-start: var(--s3); font-size: var(--fs-lead); }
  .faq__list { border-top: 1px solid var(--hair); }
  .faq details {
    border-bottom: 1px solid var(--hair);
    background: #fff;
  }
  .faq summary {
    min-height: 4.875rem;
    padding: var(--s3) var(--s4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s3);
    font-family: var(--font-display);
    font-size: clamp(1.125rem, 1rem + .6vw, 1.375rem);
    font-weight: 600;
    line-height: 1.25;
    color: var(--ink);
    cursor: pointer;
    list-style: none;
  }
  .faq summary::-webkit-details-marker { display: none; }
  .faq summary::after {
    content: "+";
    display: grid;
    place-items: center;
    width: 2.125rem;
    height: 2.125rem;
    flex: none;
    border: 1px solid var(--hair-2);
    color: var(--jade);
  }
  .faq details[open] summary::after { content: "-"; background: var(--jade); color: #fff; border-color: var(--jade); }
  .faq details p {
    padding: 0 var(--s4) var(--s4);
    max-width: 76ch;
  }

  /* ---------- Company ---------- */
  .company { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(var(--s5), 6vw, var(--s8)); align-items: start; }
  .company__lead { margin-block-start: var(--s3); }
  .company__metrics { margin-block-start: var(--s4); display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s4); }
  .company__metrics strong {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(26px, 2.6vw, 34px);
    font-weight: 700;
    color: var(--jade);
    letter-spacing: -0.02em;
  }
  .company__metrics span { font-size: var(--fs-small); color: var(--muted); }
  .company__card { border: 1px solid var(--hair); border-radius: var(--radius); }
  .company__card .row {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr;
    gap: var(--s3);
    padding: var(--s3) clamp(var(--s3), 3vw, var(--s4));
    border-bottom: 1px solid var(--hair);
  }
  .company__card .row:last-child { border-bottom: 0; }
  .company__card dt {
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--faint);
  }
  .company__card dd { font-family: var(--font-display); font-weight: 500; color: var(--ink); }
  .company__card a { color: var(--jade); }
  .company__card dd a { display: inline-flex; align-items: center; min-height: 2rem; }
  .company__card a:hover { color: var(--teal); }
  .verify { grid-column: 1 / -1; margin-block-start: var(--s2); display: flex; flex-wrap: wrap; gap: var(--s1); }
  .verify li {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s1);
    padding: .625rem .875rem;
    background: var(--jade);
    color: #fff;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .verify li .ico { align-self: center; }
  .verify li .ico { width: .875rem; height: .875rem; }
  .socials { grid-column: 1 / -1; margin-block-start: var(--s2); display: flex; flex-wrap: wrap; gap: var(--s1); }
  .socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s1);
    min-height: 2.75rem;
    padding: .625rem 1rem;
    border: 1px solid var(--hair);
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jade);
    transition: border-color .2s, color .2s;
  }
  .socials a .ico { width: .9375rem; height: .9375rem; }
  .socials a:hover { border-color: var(--teal); color: var(--teal); }

  /* ---------- Feedback ---------- */
  .feedback { display: grid; grid-template-columns: 0.9fr 1.1fr; align-items: stretch; }
  .feedback__panel { background: url("assets/portfolio-3.jpg") center/cover no-repeat; min-height: 30rem; }
  .feedback__body { padding: clamp(var(--s5), 6vw, var(--s8)) clamp(var(--s4), 5vw, var(--s7)); }
  .feedback__quotes { margin-block-start: var(--s4); }
  .feedback blockquote { padding-block: var(--s4); border-top: 1px solid var(--hair-2); }
  .feedback blockquote:last-child { border-bottom: 1px solid var(--hair-2); }
  .feedback blockquote p { color: var(--ink); font-size: var(--fs-lead); line-height: 1.5; }
  .feedback blockquote footer {
    display: block;
    margin-block-start: var(--s2);
    font-family: var(--font-display);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--jade);
  }

  /* ---------- Investor ---------- */
  .investor__media {
    aspect-ratio: 4/3;
    background: url("assets/service-1.jpeg") center/cover no-repeat;
    border-radius: var(--radius);
  }
  .investor__lead { margin-block-start: var(--s3); }
  .investor__actions { margin-block-start: var(--s4); }

  /* ---------- Location ---------- */
  .location {
    position: relative;
    overflow: hidden;
    background:
      radial-gradient(circle at 12% 8%, rgba(26,171,161,.12), transparent 24rem),
      linear-gradient(180deg, #fff 0%, var(--paper-2) 100%);
  }
  .location::before {
    content: "";
    position: absolute;
    inset: 12% auto auto 6%;
    width: min(28vw, 18rem);
    aspect-ratio: 1;
    border: 1px solid rgba(19,93,85,.1);
    background: rgba(19,93,85,.035);
    transform: rotate(-8deg);
  }
  .location__card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, .86fr) minmax(22rem, 1.14fr);
    gap: clamp(var(--s4), 4vw, var(--s6));
    align-items: stretch;
    padding: clamp(var(--s3), 4vw, var(--s5));
    border: 1px solid var(--hair);
    background: rgba(255,255,255,.86);
    box-shadow: 0 34px 90px -58px rgba(10,50,46,.45);
    backdrop-filter: blur(10px);
  }
  .location__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
  }
  .location__body p {
    margin-block-start: var(--s3);
    color: var(--muted);
    font-size: var(--fs-lead);
  }
  .location__address {
    display: flex;
    align-items: flex-start;
    gap: var(--s2);
    margin-block-start: var(--s4);
    padding: var(--s3);
    border: 1px solid rgba(19,93,85,.16);
    border-left: 3px solid var(--jade);
    background: linear-gradient(90deg, rgba(19,93,85,.07), rgba(255,255,255,.62));
    color: var(--jade-900);
    font-family: var(--font-display);
    font-size: clamp(1rem, .92rem + .35vw, 1.125rem);
    font-style: normal;
    font-weight: 700;
    line-height: 1.45;
  }
  .location__address .ico {
    flex: 0 0 auto;
    width: 1.25rem;
    height: 1.25rem;
    margin-block-start: .125rem;
    background: var(--teal);
  }
  .location__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s2);
    margin-block-start: var(--s4);
  }
  .location__map {
    position: relative;
    overflow: hidden;
    min-height: clamp(22rem, 38vw, 30rem);
    border: 1px solid var(--hair-2);
    background: var(--paper-3);
  }
  .location__map::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.34), inset 0 -4rem 7rem -5rem rgba(10,50,46,.8);
  }
  .location__map iframe {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    border: 0;
    filter: saturate(.86) contrast(1.03);
  }

  /* ---------- Contact ---------- */
  .contact {
    text-align: center;
    background:
      radial-gradient(circle at 50% 0%, rgba(26,171,161,.18), transparent 60%),
      var(--jade-900);
  }
  .contact__panel {
    position: relative;
    padding-block: clamp(var(--s5), 7vw, var(--s7));
    border: 1px solid rgba(255,255,255,.14);
    background: transparent;
  }
  .contact__panel::before {
    content: "";
    position: absolute;
    inset-block-start: -1px;
    inset-inline: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--teal), var(--sand), transparent);
  }
  .contact__eyebrow { justify-content: center; }
  .contact h2 { margin-block-start: var(--s3); }
  .contact h2, .contact p { color: #fff; }
  .contact p { margin-block-start: var(--s3); margin-inline: auto; max-width: 56ch; color: rgba(255,255,255,.8); font-size: var(--fs-lead); }
  .contact__actions { margin-block-start: var(--s5); display: flex; flex-wrap: wrap; gap: var(--s2); justify-content: center; }

  /* ---------- Footer ---------- */
  .footer { position: relative; padding-block: var(--s5); border-top: 1px solid var(--hair); }
  .footer::before {
    content: "";
    position: absolute;
    inset-block-start: -1px;
    inset-inline: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--jade), var(--teal), var(--sand));
    opacity: .5;
  }
  .footer .wrap { display: flex; align-items: center; justify-content: space-between; gap: var(--s4); flex-wrap: wrap; }
  .footer img { height: 4.75rem; width: auto; }
  .footer p { font-size: var(--fs-small); color: var(--faint); }
  .footer__meta { display: grid; gap: .25rem; text-align: right; }
  .footer__meta a { color: var(--jade); font-weight: 600; }
  .footer__meta a:hover { color: var(--teal); }

  /* ---------- Legal ---------- */
  .legal {
    background: var(--paper);
  }
  .legal__wrap { max-width: 58rem; }
  .legal h1 { margin-block-start: var(--s3); }
  .legal__lead { margin-block-start: var(--s3); font-size: var(--fs-lead); }
  .legal__card {
    margin-block-start: var(--s4);
    padding: clamp(var(--s3), 4vw, var(--s5));
    border: var(--rule);
    background: #fff;
  }
  .legal__card h2 { font-size: clamp(1.5rem, 1rem + 1.6vw, 2rem); }
  .legal__card p { margin-block-start: var(--s2); }
  .legal__card a { color: var(--jade); font-weight: 600; overflow-wrap: anywhere; }

  /* ---------- Quick contact ---------- */
  .quick {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 45;
    display: grid;
    gap: var(--s1);
    justify-items: end;
  }
  .quick__main {
    padding: .8125rem 1.25rem;
    background: var(--jade);
    color: #fff;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    box-shadow: none;
    transition: background .2s;
  }
  .quick__main:hover { background: var(--jade-700); }
  .quick a {
    display: grid;
    place-items: center;
    width: 3.125rem;
    height: 3.125rem;
    background: #fff;
    border: 1px solid var(--hair);
    border-radius: var(--radius);
    color: var(--jade);
    box-shadow: none;
    transition: border-color .2s, color .2s, background .2s;
  }
  .quick a .ico { place-self: center; }
  .quick a .ico { width: 1.25rem; height: 1.25rem; }
  .quick a:hover { border-color: var(--teal); color: var(--teal); }

  .mobile-dock { display: none; }

  @keyframes imageIsoLoader {
    0%, 100% { transform: rotateX(58deg) rotateZ(45deg) translate3d(0,0,0); filter: saturate(.95); }
    50% { transform: rotateX(58deg) rotateZ(45deg) translate3d(0,-.45rem,0); filter: saturate(1.12); }
  }

  .js [data-reveal] {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .6s cubic-bezier(.2,.6,.2,1), transform .6s cubic-bezier(.2,.6,.2,1);
  }
  .js [data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
  }

  /* ---------- Dialog ---------- */
  .lead {
    position: fixed;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    width: min(94vw, 35rem);
    max-height: calc(100dvh - 32px);
    overflow: auto;
    margin: 0;
    padding: 0;
    border: 1px solid var(--hair);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 0 40px 120px -40px rgba(10,50,46,.55);
  }
  .lead::backdrop { background: rgba(10,50,46,.6); backdrop-filter: blur(4px); }
  .lead form { display: grid; gap: var(--s3); padding: clamp(var(--s4), 4vw, var(--s5)); }
  .lead form > * { min-width: 0; }
  .lead__head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--s3); padding-bottom: var(--s3); border-bottom: 1px solid var(--hair); }
  .lead__head h2 { margin-block-start: var(--s1); font-size: clamp(1.5rem, 1.2rem + 1vw, 1.875rem); }
  .lead__close { display: grid; place-items: center; width: 2.25rem; height: 2.25rem; background: var(--paper-2); border-radius: var(--radius); font-size: 1.375rem; color: var(--graphite); transition: background .2s, color .2s; }
  .lead__close:hover { background: var(--jade); color: #fff; }
  .lead__note { font-size: .875rem; color: var(--muted); }
  .lead .grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s2); }
  .lead label { display: grid; gap: .375rem; font-family: var(--font-display); font-size: .6875rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--faint); }
  .lead input, .lead select, .lead textarea {
    width: 100%;
    min-width: 0;
    min-height: 3rem;
    padding: .75rem .875rem;
    border: 1px solid var(--hair-2);
    border-radius: var(--radius);
    background: #fff;
    font-family: var(--font-body);
    font-size: .9375rem;
    letter-spacing: 0;
    text-transform: none;
    transition: border-color .2s;
  }
  .lead input:focus, .lead select:focus, .lead textarea:focus { border-color: var(--jade); box-shadow: 0 0 0 3px rgba(26,171,161,.16); }
  .lead input:focus-visible, .lead select:focus-visible, .lead textarea:focus-visible { outline: 2px solid var(--teal); outline-offset: 2px; }
  .lead textarea { resize: vertical; }
  .lead input:user-invalid, .lead select:user-invalid, .lead textarea:user-invalid { border-color: #b94a4a; }
  .lead__submit { width: 100%; margin-block-start: var(--s1); }
  .lead__status { min-height: 1.2em; font-size: .8125rem; color: var(--teal); }

  /* ---------- Cookie banner ---------- */
  .cookie {
    position: fixed;
    inset: auto var(--pad) var(--pad) var(--pad);
    z-index: 60;
    display: flex;
    justify-content: center;
    pointer-events: none;
  }
  .cookie[hidden] { display: none; }
  .cookie__inner {
    pointer-events: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--s4);
    align-items: center;
    width: min(58rem, 100%);
    padding: var(--s3) var(--s4);
    background: #fff;
    border: 1px solid var(--hair);
    box-shadow: 0 24px 60px -34px rgba(10,50,46,.45);
  }
  .cookie__text {
    margin: 0;
    font-size: .9375rem;
    line-height: 1.5;
    color: var(--ink);
  }
  .cookie__text a { color: var(--jade); font-weight: 600; }
  .cookie__text a:hover { color: var(--jade-700); }
  .cookie__actions {
    display: flex;
    gap: var(--s2);
    flex-wrap: wrap;
  }
  .cookie__actions .btn { min-height: 2.75rem; padding-inline: var(--s3); font-size: .75rem; }

  body:has(.lead[open]) .mobile-dock,
  body.is-dialog-open .mobile-dock { display: none; }
}

@layer responsive {
  @media (max-width: 980px) {
    .split, .company, .trust, .feedback, .hero__grid, .deliverables__grid, .faq__grid, .company-proof__card, .before-after__grid { grid-template-columns: 1fr; }
    .hero {
      min-height: auto;
      background:
        radial-gradient(circle at 88% 12%, rgba(215,196,163,.28), transparent 18rem),
        linear-gradient(180deg, #fbfaf7 0%, #fff 100%);
      color: var(--ink);
    }
    .hero::before {
      inset: 9% -18vw auto auto;
      width: 54vw;
      z-index: -1;
      border-color: rgba(19,93,85,.12);
      background: rgba(19,93,85,.04);
    }
    .hero::after { display: none; }
    .hero .wrap {
      min-height: auto;
      display: block;
      padding-block: clamp(2.5rem, 6vw, 4rem);
    }
    .hero__grid {
      position: relative;
      z-index: 2;
      width: 100%;
      grid-template-columns: minmax(0, 1fr);
      gap: clamp(var(--s4), 5vw, var(--s6));
    }
    .hero__inner {
      max-width: 48rem;
      padding: 0;
      border: 0;
      background: transparent;
      box-shadow: none;
      backdrop-filter: none;
    }
    .hero__bg {
      display: block !important;
      width: 100%;
      height: clamp(18rem, 52vw, 30rem);
      min-height: 0;
      border-color: rgba(19,93,85,.14);
      box-shadow: 0 2rem 5rem -3.5rem rgba(10,50,46,.45);
    }
    .hero__bg::before {
      content: "";
      position: absolute;
      inset: .75rem;
      z-index: 2;
      pointer-events: none;
      border: 1px solid rgba(255,255,255,.42);
    }
    .hero__bg::after { background: linear-gradient(180deg, transparent 52%, rgba(10,50,46,.22) 100%); }
    .hero .on-dark,
    .hero p,
    .hero h1,
    .hero h1 em { color: var(--ink); }
    .hero .on-dark { color: var(--faint); }
    .hero .on-dark::before { background: var(--stone); }
    .hero__lead { color: var(--muted); }
    .hero__bullets li { color: var(--graphite); border-color: var(--hair); }
    .hero__bullets li::before { background: var(--jade); box-shadow: 0 0 0 .25rem rgba(19,93,85,.1); }
    .hero__org {
      border-color: rgba(19,93,85,.22);
      border-left-color: var(--jade);
      background: linear-gradient(90deg, rgba(19,93,85,.08), rgba(255,255,255,.55));
      color: var(--jade-900);
      backdrop-filter: none;
    }
    .editorial .intro__media { display: none !important; }
    .editorial .split { gap: 0; }
    .before-after__grid { gap: var(--s5); }
    .before-after__copy { max-width: 48rem; }
    .before-after__figure { transform: none; }
    .trust__panel, .feedback__panel { min-height: 21.25rem; order: -1; }
    .services__grid { grid-template-columns: 1fr 1fr; }
    .svc:nth-child(2) { border-right: 0; }
    .svc { border-bottom: 1px solid var(--hair); }
    .steps { grid-template-columns: 1fr 1fr; }
    .process, .case-grid { grid-template-columns: 1fr 1fr; }
    .deliverables__cards { grid-template-columns: 1fr; }
    .deliverables__cards article { min-height: auto; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.16); }
    .deliverables__cards article:last-child { border-bottom: 0; }
    .process article:nth-child(2n) { border-right: 0; }
    .process article:nth-child(-n+2) { border-bottom: 1px solid var(--hair); }
    .gallery .g1, .gallery .g2, .gallery .g3, .gallery .g4 { grid-column: span 6; aspect-ratio: 4/3; }
    .case-study,
    .case-study--reverse { grid-template-columns: 1fr; }
    .case-study--reverse .case-study__copy { order: 0; }
  }

  @media (max-width: 640px) {
    :target { scroll-margin-top: 4.75rem; }
    body.is-menu-lock { overflow: hidden; touch-action: none; }
    .site-header { position: sticky; background: rgba(255,255,255,.96); }
    .header-inner { min-height: 5.875rem; gap: var(--s2); padding-block: .375rem; }
    .logo img { height: 4.55rem; }
    .menu-toggle { min-height: 2.625rem; padding-inline: .875rem; gap: .75rem; }
    .site-menu {
      position: fixed;
      inset: 0;
      z-index: 120;
      width: 100vw;
      max-width: none;
      min-height: 100dvh;
      padding: calc(5.875rem + var(--s4)) var(--pad) calc(5rem + var(--s4));
      display: grid;
      align-content: start;
      overflow-y: auto;
      border: 0;
      background:
        radial-gradient(circle at 10% 8%, rgba(26,171,161,.18), transparent 18rem),
        linear-gradient(180deg, rgba(255,255,255,.99), rgba(244,239,230,.98));
      box-shadow: none;
      transform: translateY(-.75rem);
    }
    .site-header.is-menu-open .header-inner { z-index: 130; }
    .site-header.is-menu-open .logo,
    .site-header.is-menu-open .menu-toggle { position: relative; z-index: 131; }
    .main-nav { width: 100%; }
    .main-nav a { display: inline-flex; align-items: center; min-height: 2.75rem; }
    .nav-cta { min-height: 2.75rem; justify-content: center; }
    .site-menu .lang-switch { width: 100%; justify-content: center; }
    .site-menu .lang-switch a { flex: 1; }
    
    .hero {
      min-height: auto;
      overflow: hidden;
      color: var(--ink);
      background:
        radial-gradient(circle at 82% 22%, rgba(215,196,163,.26), transparent 14rem),
        linear-gradient(180deg, #fbfaf7 0%, #fff 100%);
      border-bottom: 1px solid var(--hair);
    }
    .hero::before {
      display: block;
      inset: 7.2rem -13vw auto auto;
      width: min(58vw, 14.5rem);
      z-index: 1;
      border-color: rgba(19,93,85,.12);
      background: rgba(19,93,85,.032);
      opacity: 1;
    }
    .hero::after { display: none; }
    .hero .wrap {
      position: relative;
      z-index: 1;
      min-height: 0;
      display: flex;
      align-items: flex-start;
      padding-block: clamp(.7rem, 2.2svh, 1.1rem) calc(3.85rem + env(safe-area-inset-bottom));
    }
    .hero__grid {
      position: relative;
      z-index: 2;
      width: 100%;
      min-height: auto;
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--s3);
      align-items: center;
    }
    .hero__bg {
      position: absolute;
      inset: clamp(8.15rem, 18svh, 10.25rem) calc(var(--pad) * -1.35) auto auto;
      z-index: 1;
      display: block !important;
      width: min(39vw, 11.75rem);
      height: clamp(6.1rem, 14.2svh, 7.65rem);
      min-height: 0;
      margin: 0;
      border: 1px solid rgba(19,93,85,.14);
      box-shadow: 0 1.1rem 2.7rem -2.35rem rgba(10,50,46,.5);
      background: var(--paper-3);
      opacity: .9;
    }
    .hero__bg::before {
      content: "";
      position: absolute;
      inset: .5rem;
      z-index: 2;
      pointer-events: none;
      border: 1px solid rgba(255,255,255,.44);
    }
    .hero__bg::after {
      z-index: 1;
      background: linear-gradient(180deg, transparent 48%, rgba(10,50,46,.24) 100%);
    }
    .hero__bg img {
      object-position: 50% 50%;
      filter: saturate(.88) contrast(1.04) brightness(.96);
      transform: scale(1.03);
    }
    .hero__inner {
      position: relative;
      z-index: 3;
      width: min(100%, 31rem);
      margin-block-start: clamp(1.15rem, 3.6svh, 1.9rem);
      padding: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
      backdrop-filter: none;
    }
    .hero h1 {
      max-width: 12.05ch;
      font-size: clamp(1.66rem, 7.15vw, 2.12rem);
      line-height: .98;
      letter-spacing: -.065em;
    }
    .hero .on-dark,
    .hero p,
    .hero h1,
    .hero h1 em { color: var(--ink); }
    .hero .on-dark { color: var(--faint); }
    .hero .on-dark::before { background: var(--stone); }
    .hero__title { margin-block-start: var(--s2); }
    .hero__org {
      font-size: .68rem;
      letter-spacing: .105em;
      padding: .42rem .66rem;
      border-color: rgba(19,93,85,.22);
      border-left-color: var(--jade);
      background: linear-gradient(90deg, rgba(19,93,85,.08), rgba(255,255,255,.55));
      color: var(--jade-900);
      backdrop-filter: none;
    }
    .hero__lead { max-width: 33ch; font-size: .93rem; margin-block-start: var(--s2); line-height: 1.45; color: var(--muted); }
    .hero__bullets { display: grid; gap: .48rem; margin-block-start: var(--s3); }
    .hero__bullets li {
      padding: .58rem .66rem;
      background: rgba(255,255,255,.72);
      border: 1px solid rgba(19,93,85,.1);
      color: var(--graphite);
      font-size: .68rem;
      line-height: 1.34;
      backdrop-filter: none;
    }
    .hero__bullets li::before { background: var(--stone); box-shadow: 0 0 0 .25rem rgba(215,196,163,.16); }
    .hero__actions { margin-block-start: var(--s3); flex-direction: column; }
    .hero__actions .btn { width: 100%; min-height: 3.15rem; padding-inline: var(--s3); letter-spacing: .09em; }
    .hero__actions .btn--ghost {
      border-color: rgba(19,93,85,.16);
      color: var(--jade-900);
      background: rgba(255,255,255,.58);
    }
    .hero__meta { grid-template-columns: 1fr 1fr 1fr; gap: var(--s2); margin-block-start: var(--s4); }
    .hero__meta div strong { font-size: 1.25rem; }
    .hero__meta div span { font-size: .625rem; }
    .editorial .intro__media { display: none !important; }
    
    .services__grid { grid-template-columns: 1fr; }
    .svc { border-right: 0; }
    .service-note { display: grid; gap: var(--s2); }
    .process { grid-template-columns: 1fr; }
     .process article { min-height: 11.875rem; border-right: 0; border-bottom: 1px solid var(--hair); }
    .process article:last-child { border-bottom: 0; }
    .steps { grid-template-columns: 1fr; gap: var(--s5); }
    .gallery { grid-template-columns: 1fr; }
    .gallery .g1, .gallery .g2, .gallery .g3, .gallery .g4 { grid-column: 1 / -1; aspect-ratio: 4/3; }
    .before-after::before { display: none; }
    .before-after__figure { padding: .625rem; }
    .before-after__figure::before,
    .before-after__figure::after { display: none; }
    .before-after__figure img { max-height: none; }
    .before-after__figure figcaption {
      position: static;
      margin-block-start: var(--s2);
    }
    .before-after__figure figcaption span,
    .before-after__figure figcaption span:first-child,
    .before-after__figure figcaption span:last-child { transform: none; }
    
    .cases { overflow: hidden; }
    .case-studies { margin-block-start: var(--s5); gap: var(--s6); opacity: 1 !important; transform: none !important; }
    .case-study { display: grid; min-width: 0; padding-block: var(--s4); gap: var(--s3); }
    .case-study__facts { grid-template-columns: 1fr; }
    .case-study__facts div { border-right: 0; border-bottom: 1px solid var(--hair); }
    .case-study__facts div:last-child { border-bottom: 0; }
    .case-gallery { overflow: hidden; min-width: 0; width: 100%; }
    .case-gallery__rail {
      display: flex;
      align-items: stretch;
      gap: .75rem;
      width: 100%;
      max-width: 100%;
      min-height: min(64vw, 16.5rem);
      padding: .75rem;
      overflow-x: auto;
      overflow-y: hidden;
      background: transparent;
      contain: layout paint;
      -webkit-overflow-scrolling: touch;
    }
    .case-gallery__item--hero,
    .case-gallery__item--landscape,
    .case-gallery__item--portrait,
    .case-gallery__item--square {
      inline-size: min(78vw, 20rem);
      block-size: min(64vw, 16.5rem);
    }
    .case-gallery__item:nth-child(n) { transform: none; }
    .case-gallery__item img {
      object-fit: cover;
      padding: 0;
    }
    .case-gallery__controls { padding-inline: .75rem; }
    .case-gallery__controls button { min-width: 2.75rem; }
    
    .location__card { grid-template-columns: 1fr; }
    .location__map { min-height: 21rem; }
    .company__card .row { grid-template-columns: 1fr; gap: .25rem; }
    .company__metrics { grid-template-columns: 1fr; gap: var(--s2); }
    .faq summary { padding: var(--s3) 0; }
    .faq details p { padding-inline: 0; }
    .lead .grid2 { grid-template-columns: 1fr; }
    .location__card { padding: var(--s3); }
    .location__actions .btn { width: 100%; }
    .contact__panel { padding-inline: var(--s3); }
    .footer .wrap { flex-direction: column; align-items: flex-start; }
    .footer__meta { text-align: left; }
    .cookie__inner { grid-template-columns: 1fr; gap: var(--s2); padding: var(--s3); }
    .cookie__actions .btn { flex: 1; }
    .cookie { inset: auto .75rem calc(.75rem + 3.75rem + .75rem) .75rem; }
    .quick { display: none; }
    .mobile-dock {
      position: fixed;
      inset: auto .75rem .75rem .75rem;
      z-index: 45;
      display: grid;
      grid-template-columns: 1.1fr 1fr 1fr;
      gap: .375rem;
      padding: .375rem;
      background: rgba(255,255,255,.88);
      border: 1px solid var(--hair);
      backdrop-filter: blur(14px);
    }
    .mobile-dock a,
    .mobile-dock button {
      min-height: 2.875rem;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding-inline: .625rem;
      background: var(--paper-2);
      color: var(--jade-900);
      font-family: var(--font-display);
      font-size: .6875rem;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
    }
    .mobile-dock button { background: var(--jade); color: #fff; }
    body:has(.lead[open]) .mobile-dock,
    body.is-dialog-open .mobile-dock { display: none; }
    body { padding-bottom: 4.625rem; }
    .lead {
      inset: 1rem;
      transform: none;
      width: calc(100vw - 2rem);
    }
    .lead form { padding: 1.25rem; gap: var(--s2); }
    .lead__head { gap: var(--s2); padding-bottom: var(--s2); }
    .lead__note { font-size: .8125rem; }
  }

  @media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { animation: none !important; transition: none !important; }
    [data-reveal] { opacity: 1; transform: none; }
    .gallery figure:hover img { transform: none; }
  }
}
