/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/c02d0e2d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/aae6f7cd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/a4702efd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/c02d0e2d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/aae6f7cd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/a4702efd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/c02d0e2d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/aae6f7cd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/a4702efd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/c02d0e2d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/aae6f7cd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/a4702efd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/c02d0e2d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/aae6f7cd.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/a4702efd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/53259075.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/e1c6ab3b.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/a7c0dee4.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/11eb440c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/71c3907d.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/651d686f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/53259075.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/e1c6ab3b.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/a7c0dee4.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/11eb440c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/71c3907d.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/651d686f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/53259075.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/e1c6ab3b.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/a7c0dee4.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/11eb440c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/71c3907d.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/651d686f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


  :root {
    --bg: #07090b;
    --ink: #07090b;
    --light: #f0ebe1;
    --light-2: #e4dccb;
    --cyan: #3dd9d6;
    --cyan-deep: #11a6a3;
    --line-d: rgba(240,235,225,0.10);
    --line-d-strong: rgba(240,235,225,0.22);
    --line-l: rgba(7,9,11,0.10);
    --line-l-strong: rgba(7,9,11,0.22);
    --muted-d: rgba(240,235,225,0.62);
    --muted-l: rgba(7,9,11,0.62);
    --display: "Archivo", system-ui, sans-serif;
    --mono: "JetBrains Mono", ui-monospace, monospace;
  }
  *,*::before,*::after { box-sizing: border-box; }
  html,body { margin: 0; padding: 0; overflow-x: clip; max-width: 100%; }
  body {
    background: var(--bg);
    color: var(--light);
    font-family: var(--display);
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }
  .footer { overflow: hidden; }
  ::selection { background: var(--cyan); color: var(--ink); }
  a { color: inherit; text-decoration: none; }
  button { font: inherit; cursor: pointer; }

  .mono { font-family: var(--mono); }
  .tick { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; }

  /* ---------- Layout ---------- */
  .wrap { width: min(1360px, 100% - 80px); margin: 0 auto; }
  @media (max-width: 720px) { .wrap { width: 100% - 32px; width: calc(100% - 32px); } }
  .full-wrap { width: 100%; padding: 0 40px; }
  .section { position: relative; padding: 0; }
  .pad { padding: 140px 0; }
  .light { background: var(--light); color: var(--ink); }
  .dark { background: var(--bg); color: var(--light); }
  .cyan-bg { background: var(--cyan); color: var(--ink); }

  /* ---------- HEADER / NAV ---------- */
  .site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    background: rgba(7, 9, 11, 0.78);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid var(--line-d);
  }
  .nav {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 32px;
    padding: 14px 40px;
    max-width: 1600px;
    margin: 0 auto;
  }
  .nav .brand {
    display: inline-flex; align-items: center;
    color: inherit; text-decoration: none;
  }
  .nav .brand .logo {
    display: block;
    height: 46px;
    width: auto;
    object-fit: contain;
  }
  .nav .links {
    list-style: none;
    margin: 0; padding: 0;
    display: flex; gap: 4px;
    justify-self: center;
  }
  .nav .links a {
    display: inline-block;
    padding: 10px 14px;
    font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--light); text-decoration: none;
    border: 1px solid transparent;
    transition: border-color .15s, color .15s;
  }
  .nav .links a:hover { border-color: var(--line-d-strong); color: var(--cyan); }
  .nav-cta {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 12px 20px;
    background: var(--light); color: var(--ink);
    font-family: var(--mono); font-weight: 700; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
    text-decoration: none;
    border: none;
    transition: background .15s, color .15s;
  }
  .nav-cta:hover { background: var(--cyan); color: var(--ink); }
  .nav-cta .sq { width: 8px; height: 8px; background: var(--cyan); }

  /* ---------- HERO ---------- */
  .hero { position: relative; padding: 130px 0 0; overflow: hidden; }
  .hero-grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 60px;
    align-items: end;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .hero-head {
    padding-bottom: 32px;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .hero-meta {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: 80px;
    align-items: start;
    padding: 36px 0 44px;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .hero-lead {
    margin: 0;
    font-size: clamp(18px, 1.4vw, 22px);
    line-height: 1.45;
    color: var(--light);
    max-width: 560px;
    letter-spacing: -0.01em;
  }
  .hero-meta-right {
    display: flex;
    flex-direction: column;
    gap: 28px;
    align-items: stretch;
  }
  .hero-eyebrow {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 8px 14px;
    border: 1px solid var(--line-d-strong);
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--cyan);
    margin-bottom: 40px;
  }
  .hero-eyebrow .led { width: 8px; height: 8px; background: var(--cyan); animation: blink 1.6s steps(2) infinite; }
  @keyframes blink { 50% { opacity: 0.3; } }

  .hero-title {
    margin: 0 0 24px;
    font-family: var(--display); font-weight: 900;
    font-size: clamp(96px, 13vw, 220px);
    line-height: 0.82;
    letter-spacing: -0.05em;
  }
  .hero-title .row { display: flex; align-items: baseline; flex-wrap: nowrap; gap: 0.12em; }
  .hero-title .row.r2 { padding-left: 0; }
  .hero-title .pill {
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--cyan); color: var(--ink);
    padding: 0 0.16em;
    font-weight: 900;
    font-size: inherit;
    letter-spacing: inherit;
  }
  .hero-title .light-fill { color: var(--light); }
  .hero-title .small {
    font-family: var(--mono); font-weight: 500; font-size: 0.1em; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--muted-d); align-self: end; padding-bottom: 0.4em; margin-left: 0.2em;
  }

  .hero-meta-right .stat-block {
    display: grid; grid-template-columns: 1fr 1fr;
    border-top: 1px solid var(--line-d-strong);
    border-bottom: 1px solid var(--line-d-strong);
  }
  .hero-meta-right .stat { padding: 22px 0; }
  .hero-meta-right .stat:first-child { border-right: 1px solid var(--line-d-strong); padding-right: 20px; }
  .hero-meta-right .stat:last-child { padding-left: 20px; }
  .hero-meta-right .stat .n { font-family: var(--display); font-weight: 900; font-size: 52px; line-height: 1; color: var(--cyan); letter-spacing: -0.03em; }
  .hero-meta-right .stat .l { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-d); margin-top: 10px; }

  .hero-actions { display: flex; gap: 12px; }
  .btn {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 16px 22px;
    font-family: var(--mono); font-weight: 700; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
    border: 1px solid var(--light); background: transparent; color: var(--light);
    transition: background .15s, color .15s;
  }
  .btn.primary { background: var(--cyan); color: var(--ink); border-color: var(--cyan); }
  .btn.primary:hover { background: var(--light); border-color: var(--light); }
  .btn.ghost:hover { background: var(--light); color: var(--ink); }
  .btn .arr { display: inline-block; }

  .hero-stripe {
    margin-top: 0; padding: 14px 0;
    display: flex; justify-content: space-between;
    border-bottom: 1px solid var(--line-d-strong);
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--muted-d);
  }
  .hero-stripe .led { display: inline-block; width: 8px; height: 8px; background: var(--cyan); margin-right: 8px; vertical-align: middle; }

  /* Hero composition block: huge cyan rectangle with type punch-out feel */
  .hero-block {
    margin-top: 0;
    display: grid; grid-template-columns: 7fr 5fr;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .hero-block .left {
    background: var(--cyan); color: var(--ink);
    padding: 60px 48px 56px;
    position: relative; overflow: hidden;
  }
  .hero-block .left h3 { margin: 0 0 18px; font-family: var(--display); font-weight: 900; font-size: 56px; letter-spacing: -0.03em; line-height: 0.9; }
  .hero-block .left p { margin: 0; font-size: 17px; line-height: 1.5; max-width: 540px; color: rgba(7,9,11,0.78); }
  .hero-block .left .tag { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 24px; }
  .hero-block .left .tag .dt { width: 8px; height: 8px; background: var(--ink); }
  .hero-block .left .shape {
    position: absolute; right: -40px; bottom: -40px; width: 280px; height: 280px;
    pointer-events: none;
  }

  .hero-block .right {
    padding: 60px 48px; background: var(--bg);
    border-left: 1px solid var(--line-d-strong);
  }
  .hero-block .right h4 { margin: 0 0 24px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cyan); }
  .hero-block .right ol { margin: 0; padding: 0; list-style: none; counter-reset: c; display: flex; flex-direction: column; gap: 0; }
  .hero-block .right li {
    counter-increment: c;
    padding: 14px 0;
    border-top: 1px solid var(--line-d);
    display: flex; align-items: center; gap: 16px;
    font-family: var(--display); font-size: 20px; font-weight: 500; letter-spacing: -0.01em;
  }
  .hero-block .right li:last-child { border-bottom: 1px solid var(--line-d); }
  .hero-block .right li::before {
    content: "0" counter(c);
    font-family: var(--mono); font-weight: 500; font-size: 12px; letter-spacing: 0.16em;
    color: var(--cyan); min-width: 28px;
  }

  /* ---------- SERVICES ---------- */
  .services { background: var(--light); color: var(--ink); }
  .services .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-l-strong);
  }
  .services .sec-head h2 {
    margin: 0;
    font-family: var(--display); font-weight: 900;
    font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em;
  }
  .services .sec-head h2 em { font-style: normal; background: var(--cyan); padding: 0 0.08em; }
  .services .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-l); margin-bottom: 12px; }
  .services .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 460px; }

  .svc-rows { }
  .svc-row {
    display: grid; grid-template-columns: 100px 220px 1fr 220px 80px;
    align-items: center; gap: 32px;
    padding: 40px 0;
    border-bottom: 1px solid var(--line-l-strong);
    cursor: pointer;
    transition: padding-left .25s, padding-right .25s, background .25s, color .25s;
  }
  .svc-row:hover { background: var(--ink); color: var(--light); padding-left: 24px; padding-right: 24px; }
  .svc-row:hover .svc-n { color: var(--cyan); }
  .svc-row:hover .svc-desc { color: rgba(240,235,225,0.75); }
  .svc-row:hover .svc-tags span { border-color: var(--line-d-strong); color: var(--cyan); }
  .svc-row:hover .svc-go { background: var(--cyan); color: var(--ink); border-color: var(--cyan); }
  .svc-n { font-family: var(--mono); font-size: 14px; letter-spacing: 0.16em; color: rgba(7,9,11,0.55); transition: color .2s; }
  .svc-title {
    font-family: var(--display); font-weight: 800; font-size: 36px;
    letter-spacing: -0.025em; line-height: 0.95;
  }
  .svc-glyph { position: relative; width: 64px; height: 64px; color: currentColor; }
  .svc-glyph svg { width: 100%; height: 100%; }
  .svc-desc { font-size: 16px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 540px; }
  .svc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
  .svc-tags span {
    display: inline-block; padding: 6px 10px;
    border: 1px solid var(--line-l-strong);
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
    transition: border-color .2s, color .2s;
  }
  .svc-go {
    width: 56px; height: 56px;
    display: grid; place-items: center;
    background: transparent; color: currentColor; border: 1px solid var(--line-l-strong);
    transition: background .2s, color .2s, border-color .2s;
  }

  /* ---------- PROCESS ---------- */
  .process { background: var(--bg); color: var(--light); }
  .process .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .process .sec-head h2 {
    margin: 0;
    font-family: var(--display); font-weight: 900;
    font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em;
  }
  .process .sec-head h2 em { font-style: normal; background: var(--cyan); color: var(--ink); padding: 0 0.08em; }
  .process .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cyan); margin-bottom: 12px; }
  .process .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: var(--muted-d); max-width: 460px; }

  .proc-grid {
    display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin-top: 0;
    border-top: 1px solid var(--line-d);
  }
  .proc-step {
    position: relative;
    padding: 36px 28px 36px;
    border-right: 1px solid var(--line-d);
    border-bottom: 1px solid var(--line-d-strong);
    min-height: 360px;
    display: flex; flex-direction: column;
  }
  .proc-step:last-child { border-right: 1px solid var(--line-d-strong); }
  .proc-step.active { background: var(--cyan); color: var(--ink); }
  .proc-step.active .proc-tick { color: var(--ink); }
  .proc-step.active .proc-num { color: var(--ink); }
  .proc-num {
    font-family: var(--display); font-weight: 900; font-size: 96px;
    line-height: 0.85; letter-spacing: -0.05em; color: var(--cyan);
    margin-bottom: 24px;
  }
  .proc-tick { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cyan); margin-bottom: 8px; }
  .proc-step h4 { margin: 0 0 12px; font-family: var(--display); font-weight: 800; font-size: 22px; letter-spacing: -0.015em; }
  .proc-step p { margin: 0; font-size: 14px; line-height: 1.55; color: var(--muted-d); }
  .proc-step.active p { color: rgba(7,9,11,0.72); }
  .proc-step .squiggle { margin-top: auto; padding-top: 24px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(240,235,225,0.35); }
  .proc-step.active .squiggle { color: rgba(7,9,11,0.55); }

  /* ---------- CASES ---------- */
  .cases { background: var(--light); color: var(--ink); }
  .cases .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-l-strong);
  }
  .cases .sec-head h2 {
    margin: 0; font-family: var(--display); font-weight: 900;
    font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em;
  }
  .cases .sec-head h2 em { font-style: normal; background: var(--cyan); padding: 0 0.08em; }
  .cases .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-l); margin-bottom: 12px; }
  .cases .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 460px; }

  .case-grid {
    display: grid; grid-template-columns: repeat(12, 1fr); gap: 0;
    margin-top: 0; border-top: 1px solid var(--line-l-strong);
  }
  .case-card {
    border-right: 1px solid var(--line-l-strong);
    border-bottom: 1px solid var(--line-l-strong);
    display: flex; flex-direction: column; min-height: 480px;
    background: var(--light);
  }
  .case-card.c1 { grid-column: span 7; }
  .case-card.c2 { grid-column: span 5; }
  .case-card.c3 { grid-column: span 5; }
  .case-card.c4 { grid-column: span 7; }
  .case-cover {
    flex: 1; position: relative; overflow: hidden;
    background: var(--ink);
    border-bottom: 1px solid var(--line-l-strong);
    display: grid; place-items: center;
    color: var(--cyan);
  }
  .case-cover.cyan { background: var(--cyan); color: var(--ink); }
  .case-cover.light { background: var(--light-2); color: var(--ink); }
  .case-cover-tag {
    position: absolute; top: 18px; left: 18px;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  }
  .case-cover-shape {
    width: 70%; height: 70%; position: relative;
  }
  .case-meta {
    padding: 24px 28px 28px;
    display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: end;
  }
  .case-meta h3 { margin: 0; font-family: var(--display); font-weight: 800; font-size: 30px; letter-spacing: -0.025em; line-height: 1; }
  .case-meta .desc { font-size: 14px; line-height: 1.5; color: rgba(7,9,11,0.65); margin-top: 10px; max-width: 480px; }
  .case-meta .stat {
    text-align: right;
    font-family: var(--display); font-weight: 900; font-size: 48px; color: var(--cyan-deep); letter-spacing: -0.03em; line-height: 1;
  }
  .case-meta .stat-lbl { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-l); margin-top: 6px; }

  /* ---------- LOGOS / CTA BAND ---------- */
  .band {
    background: var(--cyan); color: var(--ink);
    padding: 60px 0; overflow: hidden;
    border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
  }
  .band-track {
    display: flex; gap: 80px; white-space: nowrap;
    animation: marq 32s linear infinite;
    font-family: var(--display); font-weight: 900; font-size: 56px; letter-spacing: -0.03em;
  }
  .band-track span { display: inline-flex; align-items: center; gap: 80px; }
  .band-track .sq { display: inline-block; width: 18px; height: 18px; background: var(--ink); }
  @keyframes marq { to { transform: translateX(-50%); } }

  .clients { background: var(--bg); padding: 80px 0; border-bottom: 1px solid var(--line-d); }
  .clients-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 32px; }
  .clients-head .l { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-d); }
  .clients-head .r { font-family: var(--display); font-weight: 800; font-size: 28px; letter-spacing: -0.02em; }
  .clients-head .r em { font-style: normal; color: var(--cyan); }
  .clients-grid {
    display: grid; grid-template-columns: repeat(6, 1fr); border-left: 1px solid var(--line-d);
  }
  .clients-grid .cell {
    aspect-ratio: 2 / 1;
    border-right: 1px solid var(--line-d);
    border-top: 1px solid var(--line-d);
    display: grid; place-items: center;
    font-family: var(--display); font-weight: 700; font-size: 20px; letter-spacing: -0.02em;
    color: rgba(240,235,225,0.55);
    transition: background .15s, color .15s;
  }
  .clients-grid .cell:hover { background: var(--cyan); color: var(--ink); }

  /* ---------- TESTIMONIALS ---------- */
  .testi { background: var(--light); color: var(--ink); }
  .testi .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-l-strong);
  }
  .testi .sec-head h2 {
    margin: 0; font-family: var(--display); font-weight: 900;
    font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em;
  }
  .testi .sec-head h2 em { font-style: normal; background: var(--cyan); padding: 0 0.08em; }
  .testi .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 460px; }
  .testi .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-l); margin-bottom: 12px; }

  .testi-feature {
    margin-top: 60px;
    display: grid; grid-template-columns: 1.5fr 1fr; align-items: stretch;
    border: 1px solid var(--line-l-strong);
  }
  .testi-feature .quote { padding: 56px 48px; border-right: 1px solid var(--line-l-strong); }
  .testi-feature .marks { font-family: var(--display); font-weight: 900; font-size: 120px; line-height: 0.6; height: 60px; color: var(--cyan); }
  .testi-feature blockquote {
    margin: 24px 0 0;
    font-family: var(--display); font-weight: 500;
    font-size: 32px; line-height: 1.25; letter-spacing: -0.015em;
  }
  .testi-feature blockquote em { font-style: normal; background: var(--cyan); padding: 0 6px; }
  .testi-feature .author { padding: 56px 48px; background: var(--ink); color: var(--light); display: flex; flex-direction: column; justify-content: space-between; }
  .testi-feature .author .ava { width: 64px; height: 64px; background: var(--cyan); color: var(--ink); display: grid; place-items: center; font-family: var(--display); font-weight: 900; font-size: 26px; }
  .testi-feature .author b { display: block; font-family: var(--display); font-weight: 700; font-size: 22px; margin-top: 24px; letter-spacing: -0.01em; }
  .testi-feature .author span { display: block; font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted-d); margin-top: 6px; }
  .testi-feature .author .meta-row {
    margin-top: auto; padding-top: 32px; border-top: 1px solid var(--line-d);
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--muted-d);
  }
  .testi-feature .author .meta-row .v { display: block; color: var(--cyan); font-size: 18px; letter-spacing: -0.01em; text-transform: none; font-family: var(--display); font-weight: 700; margin-top: 6px; }

  .testi-row { display: grid; grid-template-columns: 1fr 1fr; border-left: 1px solid var(--line-l-strong); border-bottom: 1px solid var(--line-l-strong); }
  .testi-row .card { padding: 36px 40px; border-right: 1px solid var(--line-l-strong); }
  .testi-row .card .m { font-family: var(--display); font-weight: 900; font-size: 64px; line-height: 0.6; height: 24px; color: var(--cyan); }
  .testi-row .card blockquote { margin: 20px 0 28px; font-family: var(--display); font-size: 21px; line-height: 1.35; letter-spacing: -0.005em; }
  .testi-row .card .who { display: flex; gap: 14px; align-items: center; }
  .testi-row .card .ava { width: 40px; height: 40px; background: var(--ink); color: var(--cyan); display: grid; place-items: center; font-family: var(--mono); font-weight: 700; font-size: 14px; }
  .testi-row .card b { display: block; font-family: var(--display); font-weight: 700; font-size: 15px; letter-spacing: -0.005em; }
  .testi-row .card .sub { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(7,9,11,0.55); margin-top: 4px; }

  /* ---------- CONTACT ---------- */
  .contact { background: var(--ink); color: var(--light); }
  .contact .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-d-strong);
  }
  .contact .sec-head h2 { margin: 0; font-family: var(--display); font-weight: 900; font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em; }
  .contact .sec-head h2 em { font-style: normal; background: var(--cyan); color: var(--ink); padding: 0 0.08em; }
  .contact .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: var(--muted-d); max-width: 460px; }
  .contact .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cyan); margin-bottom: 12px; }

  .contact-shell {
    margin-top: 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    border: 1px solid var(--line-d-strong);
  }
  .contact-form { padding: 48px; border-right: 1px solid var(--line-d-strong); }
  .field-row { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--line-d-strong); }
  .field { padding: 18px 0; }
  .field + .field { border-left: 1px solid var(--line-d-strong); padding-left: 20px; }
  .field label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cyan); margin-bottom: 8px; }
  .field input, .field select, .field textarea {
    width: 100%; background: transparent; border: 0; outline: none;
    color: var(--light); font-family: var(--display); font-weight: 500; font-size: 18px; padding: 0;
  }
  .field textarea { min-height: 110px; line-height: 1.5; resize: vertical; }
  .field input::placeholder, .field textarea::placeholder { color: rgba(240,235,225,0.25); }
  .field-full { padding: 18px 0; border-bottom: 1px solid var(--line-d-strong); }
  .pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
  .pill { padding: 8px 12px; border: 1px solid var(--line-d-strong); background: transparent; color: var(--light); font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }
  .pill.on { background: var(--cyan); color: var(--ink); border-color: var(--cyan); }
  .form-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 28px; }
  .form-actions .note { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted-d); }
  .form-submit { display: inline-flex; align-items: center; gap: 14px; padding: 18px 28px; background: var(--cyan); color: var(--ink); border: none; font-family: var(--mono); font-weight: 700; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
  .form-submit .arr { width: 22px; height: 1px; background: currentColor; position: relative; }
  .form-submit .arr::after { content: ""; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-right: 1px solid currentColor; border-top: 1px solid currentColor; transform: rotate(45deg); }
  .form-submit:hover { background: var(--light); }

  .contact-side { padding: 48px; display: flex; flex-direction: column; gap: 32px; background: var(--bg); }
  .info-block { padding-bottom: 20px; border-bottom: 1px solid var(--line-d); }
  .info-block:last-child { border-bottom: 0; padding-bottom: 0; }
  .info-block .l { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cyan); margin-bottom: 10px; }
  .info-block .v { font-family: var(--display); font-weight: 700; font-size: 22px; letter-spacing: -0.01em; }
  .info-block .v small { display: block; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; color: var(--muted-d); margin-top: 6px; font-weight: 400; }
  .availability { background: var(--cyan); color: var(--ink); padding: 24px; }
  .availability .h { display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 12px; }
  .availability .h .sq { width: 8px; height: 8px; background: var(--ink); }
  .availability p { margin: 0; font-size: 15px; line-height: 1.5; color: rgba(7,9,11,0.78); }

  /* ---------- FAQ ---------- */
  .faq { background: var(--light); color: var(--ink); }
  .faq .sec-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end;
    padding: 0 0 60px;
    border-bottom: 1px solid var(--line-l-strong);
  }
  .faq .sec-head h2 { margin: 0; font-family: var(--display); font-weight: 900; font-size: clamp(64px, 7vw, 120px); line-height: 0.88; letter-spacing: -0.04em; }
  .faq .sec-head h2 em { font-style: normal; background: var(--cyan); padding: 0 0.08em; }
  .faq .sec-head .meta { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-l); margin-bottom: 12px; }
  .faq .sec-head p { margin: 0; font-size: 17px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 460px; }

  .faq-list { margin-top: 0; }
  .faq-item { border-bottom: 1px solid var(--line-l-strong); }
  .faq-q {
    padding: 28px 0; cursor: pointer;
    display: grid; grid-template-columns: 80px 1fr 60px; align-items: center; gap: 24px;
    font-family: var(--display); font-weight: 700; font-size: 26px; letter-spacing: -0.02em;
  }
  .faq-q:hover { color: var(--cyan-deep); }
  .faq-num { font-family: var(--mono); font-size: 13px; letter-spacing: 0.16em; color: rgba(7,9,11,0.5); }
  .faq-toggle { width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid var(--line-l-strong); justify-self: end; font-family: var(--mono); font-size: 18px; font-weight: 500; }
  .faq-item.open .faq-toggle { background: var(--ink); color: var(--cyan); border-color: var(--ink); }
  .faq-a {
    max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .25s ease;
    display: grid; grid-template-columns: 80px 1fr 60px; gap: 24px;
  }
  .faq-item.open .faq-a { max-height: 360px; padding: 0 0 28px; }
  .faq-a > div:nth-child(2) { font-size: 17px; line-height: 1.55; color: rgba(7,9,11,0.7); max-width: 760px; }

  /* ---------- FOOTER ---------- */
  .footer { background: var(--bg); color: var(--light); padding: 100px 0 40px; border-top: 1px solid var(--line-d-strong); }
  .footer-mark { margin: 0; font-family: var(--display); font-weight: 900; font-size: clamp(48px, 14vw, 240px); line-height: 0.82; letter-spacing: -0.06em; max-width: 100%; overflow: hidden; word-break: keep-all; }
  .footer-mark .acc { background: var(--cyan); color: var(--ink); padding: 0 0.04em; }
  .footer-mark .dot { color: var(--cyan); }
  .footer-cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; margin-top: 80px; border-top: 1px solid var(--line-d); padding-top: 40px; }
  .footer-col h5 { margin: 0 0 18px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cyan); }
  .footer-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; font-size: 15px; color: var(--muted-d); }
  .footer-col p { margin: 0; font-size: 15px; color: var(--muted-d); line-height: 1.55; max-width: 320px; }
  .footer-bottom { margin-top: 80px; padding-top: 24px; border-top: 1px solid var(--line-d); display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted-d); }

  /* ─────────── BURGER (mobile) ─────────── */
  .burger {
    display: none;
    width: 44px; height: 44px;
    background: transparent;
    border: 1px solid var(--line-d-strong);
    color: var(--light); padding: 0; cursor: pointer;
    align-items: center; justify-content: center;
    position: relative;
    transition: border-color .15s, background .15s;
  }
  .burger:hover { border-color: var(--cyan); }
  .burger span {
    display: block; width: 18px; height: 2px;
    background: currentColor; position: relative;
    transition: background .2s;
  }
  .burger span::before, .burger span::after {
    content: ""; position: absolute; left: 0; right: 0; height: 2px;
    background: currentColor;
    transition: transform .25s ease, top .25s ease;
  }
  .burger span::before { top: -6px; }
  .burger span::after  { top: 6px; }
  .burger[aria-expanded="true"] span { background: transparent; }
  .burger[aria-expanded="true"] span::before { top: 0; transform: rotate(45deg); }
  .burger[aria-expanded="true"] span::after  { top: 0; transform: rotate(-45deg); }

  /* ─────────── MOBILE MENU ─────────── */
  .mobile-menu {
    position: fixed; inset: 64px 0 0 0; z-index: 49;
    background: var(--bg);
    padding: 32px 24px;
    border-top: 1px solid var(--line-d);
    overflow-y: auto;
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity .2s ease, transform .25s ease;
  }
  .mobile-menu[hidden] { display: block; }
  .mobile-menu.open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .mobile-menu ul {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column;
  }
  .mobile-menu a {
    display: block;
    padding: 20px 4px;
    font-family: var(--display); font-weight: 700; font-size: 28px;
    letter-spacing: -0.01em;
    color: var(--light); text-decoration: none;
    border-bottom: 1px solid var(--line-d);
    transition: color .15s;
  }
  .mobile-menu a:hover { color: var(--cyan); }
  .mobile-cta {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 12px;
    padding: 18px 22px;
    background: var(--cyan); color: var(--ink);
    text-decoration: none;
    font-family: var(--mono); font-weight: 700; font-size: 12px;
    letter-spacing: 0.16em; text-transform: uppercase;
  }
  .mobile-cta .sq { width: 8px; height: 8px; background: var(--ink); }
  .mobile-cta .arr { margin-left: 4px; }
  body.menu-open { overflow: hidden; }

  /* ─────────── RESPONSIVE — TABLET (≤1024px) ─────────── */
  @media (max-width: 1024px) {
    .nav {
      display: flex !important;
      grid-template-columns: none;
      align-items: center;
      justify-content: flex-end;
      gap: 0;
      padding: 12px 20px;
      position: relative;
      min-height: 64px;
    }
    .nav .links { display: none !important; }
    .nav-cta { display: none !important; }
    .nav .brand {
      position: absolute !important;
      left: 50% !important;
      top: 50% !important;
      transform: translate(-50%, -50%) !important;
      margin: 0 !important;
      grid-column: auto !important;
      justify-self: auto !important;
    }
    .nav .brand .logo { height: 39px; }
    .burger {
      display: inline-flex !important;
      margin-left: auto;
      grid-column: auto;
      justify-self: auto;
    }

    .pad { padding: 96px 0; }

    /* Hero */
    .hero { padding: 110px 0 0; }
    .hero-grid { grid-template-columns: 1fr; gap: 32px; align-items: start; padding-bottom: 32px; }
    .hero-head { padding-bottom: 28px; }
    .hero-meta { grid-template-columns: 1fr; gap: 32px; padding: 28px 0 36px; }
    .hero-lead { font-size: 17px; max-width: none; }
    .hero-title { font-size: clamp(56px, 11vw, 120px); }
    .hero-title .row { flex-wrap: wrap; gap: 0.08em 0.12em; }
    .hero-title .small { display: none; }
    .hero-stripe { gap: 12px; font-size: 10px; }
    .hero-stripe > div:nth-child(3) { display: none; }
    .hero-block { grid-template-columns: 1fr; }
    .hero-block .left, .hero-block .right { padding: 44px 32px; }
    .hero-block .right { border-left: 0; border-top: 1px solid var(--line-d-strong); }
    .hero-block .left h3 { font-size: 44px; }
    .hero-block .left .shape { width: 200px; height: 200px; right: -30px; bottom: -30px; opacity: 0.6; }

    /* All section heads */
    .services .sec-head, .process .sec-head, .cases .sec-head,
    .testi .sec-head, .contact .sec-head, .faq .sec-head {
      grid-template-columns: 1fr; gap: 24px; padding-bottom: 40px;
    }
    .services .sec-head h2, .process .sec-head h2, .cases .sec-head h2,
    .testi .sec-head h2, .contact .sec-head h2, .faq .sec-head h2 {
      font-size: clamp(48px, 8vw, 88px);
    }

    /* Services rows */
    .svc-row {
      grid-template-columns: 60px 1fr 56px;
      grid-template-areas:
        "n title go"
        "glyph desc desc"
        "tags tags tags";
      gap: 16px; padding: 28px 0;
    }
    .svc-row .svc-n { grid-area: n; }
    .svc-row .svc-title { grid-area: title; }
    .svc-row .svc-glyph { grid-area: glyph; width: 48px; height: 48px; }
    .svc-row .svc-desc { grid-area: desc; }
    .svc-row .svc-tags { grid-area: tags; }
    .svc-row .svc-go { grid-area: go; width: 48px; height: 48px; }
    .svc-row:hover { padding-left: 16px; padding-right: 16px; }
    .svc-title { font-size: 26px; }

    /* Process — 5 cols → horizontal scroll */
    .proc-grid {
      grid-template-columns: repeat(5, minmax(240px, 1fr));
      overflow-x: auto; scroll-snap-type: x mandatory;
      margin: 0 -24px; padding: 0 24px;
    }
    .proc-step { scroll-snap-align: start; min-height: 320px; padding: 28px 22px; }
    .proc-num { font-size: 72px; }

    /* Cases — 12-col grid → single column */
    .case-grid { grid-template-columns: 1fr; }
    .case-card.c1, .case-card.c2, .case-card.c3, .case-card.c4 { grid-column: 1 / -1; min-height: 0; }
    .case-cover { aspect-ratio: 16 / 10; }
    .case-meta { grid-template-columns: 1fr; gap: 20px; padding: 24px; }
    .case-meta .stat { text-align: left; font-size: 40px; }

    /* Clients */
    .clients-head { flex-direction: column; align-items: flex-start; gap: 8px; }
    .clients-grid { grid-template-columns: repeat(3, 1fr); }

    /* Band — keep but smaller */
    .band { padding: 36px 0; }
    .band-track { font-size: 36px; gap: 48px; }
    .band-track span { gap: 48px; }
    .band-track .sq { width: 12px; height: 12px; }

    /* Testimonials */
    .testi-feature { grid-template-columns: 1fr; }
    .testi-feature .quote { padding: 36px 28px; border-right: 0; border-bottom: 1px solid var(--line-l-strong); }
    .testi-feature blockquote { font-size: 24px; }
    .testi-feature .author { padding: 36px 28px; }
    .testi-row { grid-template-columns: 1fr; }
    .testi-row .card { padding: 28px 24px; border-right: 0; }

    /* Contact */
    .contact-shell { grid-template-columns: 1fr; }
    .contact-form { padding: 28px 24px; border-right: 0; border-bottom: 1px solid var(--line-d-strong); }
    .contact-side { padding: 28px 24px; gap: 24px; }
    .field-row { grid-template-columns: 1fr; }
    .field-row .field + .field { border-left: 0; padding-left: 0; border-top: 1px solid var(--line-d-strong); }
    .form-actions { flex-direction: column; align-items: flex-start; gap: 16px; }
    .form-submit { width: 100%; justify-content: center; }

    /* FAQ */
    .faq-q { grid-template-columns: 48px 1fr 40px; gap: 14px; font-size: 18px; padding: 22px 0; }
    .faq-toggle { width: 32px; height: 32px; font-size: 16px; }
    .faq-a { grid-template-columns: 48px 1fr 40px; gap: 14px; }
    .faq-a > div:nth-child(2) { font-size: 15px; }

    /* Footer */
    .footer { padding: 64px 0 32px; }
    .footer-mark { font-size: clamp(40px, 13vw, 140px); }
    .footer-cols { grid-template-columns: 1fr 1fr; gap: 36px; margin-top: 48px; }
    .footer-bottom { flex-direction: column; gap: 12px; align-items: flex-start; margin-top: 48px; }
  }

  /* ─────────── RESPONSIVE — PHONE (≤640px) ─────────── */
  @media (max-width: 640px) {
    .pad { padding: 72px 0; }

    .hero { padding: 96px 0 0; }
    .hero-stripe { flex-direction: column; gap: 6px; padding: 12px 0; }
    .hero-eyebrow { font-size: 10px; padding: 6px 10px; }
    .hero-title { font-size: clamp(40px, 11vw, 80px); letter-spacing: -0.04em; }
    .hero-meta-right .stat .n { font-size: 36px; }
    .hero-actions { flex-direction: column; align-items: stretch; }
    .hero-actions .btn { justify-content: space-between; }

    .hero-block .left, .hero-block .right { padding: 32px 22px; }
    .hero-block .left h3 { font-size: 32px; }
    .hero-block .left .shape { display: none; }

    /* Service rows extra-compact */
    .svc-row {
      grid-template-columns: 1fr 48px;
      grid-template-areas:
        "n go"
        "title title"
        "desc desc"
        "tags tags";
      gap: 12px; padding: 24px 0;
    }
    .svc-row .svc-glyph { display: none; }
    .svc-title { font-size: 22px; }
    .svc-desc { font-size: 14px; }
    .svc-row:hover { padding-left: 12px; padding-right: 12px; }

    /* Process — 1 col stack */
    .proc-grid {
      grid-template-columns: 1fr;
      overflow-x: visible; margin: 0; padding: 0;
    }
    .proc-step { min-height: 0; border-right: 0; padding: 24px 0; }
    .proc-step:last-child { border-right: 0; }
    .proc-num { font-size: 56px; margin-bottom: 12px; }

    /* Cases */
    .case-meta h3 { font-size: 24px; }

    /* Clients — 2 cols */
    .clients-grid { grid-template-columns: repeat(2, 1fr); }
    .clients-grid .cell { font-size: 16px; }

    /* Band */
    .band-track { font-size: 28px; gap: 32px; }
    .band-track span { gap: 32px; }
    .band-track .sq { width: 10px; height: 10px; }

    /* Testimonials */
    .testi-feature blockquote { font-size: 20px; }
    .testi-feature .meta-row { grid-template-columns: 1fr; gap: 12px; }
    .testi-row .card blockquote { font-size: 18px; }

    /* Contact */
    .contact-form, .contact-side { padding: 24px 18px; }
    .availability { padding: 18px; }

    /* FAQ */
    .faq-q { grid-template-columns: 36px 1fr 32px; gap: 10px; font-size: 16px; padding: 20px 0; }
    .faq-a { grid-template-columns: 36px 1fr 32px; gap: 10px; }
    .faq-a > div:nth-child(2) { font-size: 14px; }

    /* Footer */
    .footer-cols { grid-template-columns: 1fr; gap: 28px; }
    .footer-mark { font-size: clamp(32px, 13vw, 80px); }
  }
