/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/1d64d0bb-c67c-4309-9d7b-6933fb7d2cbd.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("assets/9a64b5c4-44cc-4fee-b1c7-704ba5d7ec04.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("assets/5e5b8f58-bd34-4e18-a0f7-58dbd0b36c3c.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("assets/1d64d0bb-c67c-4309-9d7b-6933fb7d2cbd.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("assets/9a64b5c4-44cc-4fee-b1c7-704ba5d7ec04.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("assets/5e5b8f58-bd34-4e18-a0f7-58dbd0b36c3c.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("assets/1d64d0bb-c67c-4309-9d7b-6933fb7d2cbd.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("assets/9a64b5c4-44cc-4fee-b1c7-704ba5d7ec04.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("assets/5e5b8f58-bd34-4e18-a0f7-58dbd0b36c3c.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("assets/30d6dc1b-8958-4bc5-8373-0fe7a3cf480e.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("assets/17ca316f-44db-4082-b29f-2cf44a5f024f.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("assets/317c1a65-1f04-4b13-a4e5-c305a58129e4.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("assets/f4db7487-aaa6-4385-8ce5-f69ce81ec7a1.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("assets/902d0227-aa82-4414-be6a-e245d2941f4c.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("assets/3a449fd7-1337-4c33-9afb-c3ec1239084c.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: 600;
  font-display: swap;
  src: url("assets/30d6dc1b-8958-4bc5-8373-0fe7a3cf480e.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: 600;
  font-display: swap;
  src: url("assets/17ca316f-44db-4082-b29f-2cf44a5f024f.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: 600;
  font-display: swap;
  src: url("assets/317c1a65-1f04-4b13-a4e5-c305a58129e4.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: 600;
  font-display: swap;
  src: url("assets/f4db7487-aaa6-4385-8ce5-f69ce81ec7a1.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: 600;
  font-display: swap;
  src: url("assets/902d0227-aa82-4414-be6a-e245d2941f4c.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: 600;
  font-display: swap;
  src: url("assets/3a449fd7-1337-4c33-9afb-c3ec1239084c.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: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/67855cbd-875a-4d4b-b8f5-8c5143fc45a2.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: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/102ccf72-c5d3-4a8b-beb8-1194f3655f0d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/0c276c94-ac3a-4d2d-baa5-f7d7fcb10751.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: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/2b06a5cc-4dd0-415e-a749-434fd64d844e.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: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/23928eae-78e0-44e7-8720-cf422ebcd01b.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: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/67855cbd-875a-4d4b-b8f5-8c5143fc45a2.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: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/102ccf72-c5d3-4a8b-beb8-1194f3655f0d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/0c276c94-ac3a-4d2d-baa5-f7d7fcb10751.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: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/2b06a5cc-4dd0-415e-a749-434fd64d844e.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: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/23928eae-78e0-44e7-8720-cf422ebcd01b.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: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/67855cbd-875a-4d4b-b8f5-8c5143fc45a2.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: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/102ccf72-c5d3-4a8b-beb8-1194f3655f0d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/0c276c94-ac3a-4d2d-baa5-f7d7fcb10751.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: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/2b06a5cc-4dd0-415e-a749-434fd64d844e.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: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/23928eae-78e0-44e7-8720-cf422ebcd01b.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: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/67855cbd-875a-4d4b-b8f5-8c5143fc45a2.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: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/102ccf72-c5d3-4a8b-beb8-1194f3655f0d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/0c276c94-ac3a-4d2d-baa5-f7d7fcb10751.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: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/2b06a5cc-4dd0-415e-a749-434fd64d844e.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: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/23928eae-78e0-44e7-8720-cf422ebcd01b.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: #0A0A0A;
    --panel: #141414;
    --panel-2: #181818;
    --line: #262626;
    --line-soft: #1d1d1d;
    --ink: #F5F0E6;
    --ink-dim: #b8b2a6;
    --muted: #6f6a61;
    --muted-2: #555048;
    --amber: #FFB000;
    --orange: #FF6A00;
    --accent-grad: linear-gradient(100deg, #FF6A00 0%, #FFB000 100%);

    --display: "Oswald", "Arial Narrow", sans-serif;
    --body: "Archivo", system-ui, sans-serif;
    --mono: "JetBrains Mono", ui-monospace, monospace;

    --maxw: 1240px;
    --gutter: clamp(24px, 5vw, 80px);
  }

  * { box-sizing: border-box; }
  html {
    scroll-behavior: smooth;
    scroll-snap-type: y proximity;
    scroll-padding-top: 74px;
  }
  /* Snap stops: each top-level band is a "page". The pinned section has only
     one snap point (its start), so the word-reveal plays out uninterrupted
     and the next snap (Section III) only engages once it's complete. */
  .hero, main > section, footer { scroll-snap-align: start; }
  /* The pinned section is a free-scroll zone: no snap point engages until the
     reader has scrolled all the way through the animation to Section III. */
  .pin-wrap { scroll-snap-align: none; }
  body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: var(--body);
    font-size: 18px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }
  ::selection { background: rgba(255,106,0,0.28); color: #fff; }

  a { color: inherit; text-decoration: none; }
  img { display: block; max-width: 100%; }

  .wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }

  /* ---------- Shared type ---------- */
  .display {
    font-family: var(--display);
    font-weight: 700;
    line-height: 0.98;
    letter-spacing: -0.01em;
    text-wrap: balance;
    margin: 0;
  }
  .eyebrow {
    font-family: var(--mono);
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    gap: 14px;
  }
  .eyebrow .num { color: var(--amber); }
  .eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--line);
  }
  .lead {
    font-size: clamp(20px, 2.1vw, 26px);
    line-height: 1.5;
    color: var(--ink-dim);
    max-width: 56ch;
    text-wrap: pretty;
  }
  .accent { color: var(--amber); }
  .accent-grad {
    background: var(--accent-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  /* ---------- Buttons ---------- */
  .btn {
    font-family: var(--mono);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 16px 26px;
    border-radius: 2px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .2s ease;
    white-space: nowrap;
  }
  .btn .arrow { transition: transform .25s ease; }
  .btn:hover .arrow { transform: translateX(4px); }
  .btn-primary {
    background: var(--accent-grad);
    color: #0A0A0A;
    box-shadow: 0 0 0 0 rgba(255,140,0,0);
  }
  .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 40px -12px rgba(255,130,0,0.55);
  }
  .btn-ghost {
    background: transparent;
    color: var(--ink);
    border-color: var(--line);
  }
  .btn-ghost:hover { border-color: var(--amber); color: #fff; }

  /* ---------- Nav ---------- */
  header.nav {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(12px);
    background: rgba(10,10,10,0.72);
    border-bottom: 1px solid transparent;
    transition: border-color .3s ease, background .3s ease;
  }
  header.nav.scrolled {
    border-bottom-color: var(--line-soft);
    background: rgba(10,10,10,0.9);
  }
  .nav-inner {
    height: 74px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
  }
  .logo {
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
  }
  .logo img {
    height: 34px;
    width: auto;
    max-width: none;
    display: block;
  }
  .foot-logo img { height: 30px; }
  .nav-links {
    display: flex;
    gap: 30px;
    margin-left: auto;
    margin-right: 8px;
  }
  .nav-links a {
    font-family: var(--mono);
    font-size: 12.5px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-dim);
    position: relative;
    padding: 4px 0;
    white-space: nowrap;
    transition: color .2s ease;
  }
  .nav-links a::after {
    content: "";
    position: absolute;
    left: 0; bottom: -2px;
    width: 0; height: 1px;
    background: var(--amber);
    transition: width .25s ease;
  }
  .nav-links a:hover { color: var(--ink); }
  .nav-links a:hover::after { width: 100%; }
  .nav .btn { padding: 12px 20px; }

  /* ---------- Mobile nav (hamburger + drawer) ---------- */
  .nav-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    padding: 10px;
    margin-left: auto;
    background: none;
    border: 0;
    cursor: pointer;
    flex: 0 0 auto;
  }
  .nav-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--ink);
    border-radius: 2px;
    transition: transform .3s ease, opacity .2s ease;
  }
  .nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { opacity: 0; }
  .nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  .menu-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(2px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
    z-index: 55;
    display: none;
  }
  .menu-backdrop.show { opacity: 1; pointer-events: auto; }

  .mobile-menu {
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    width: min(82vw, 340px);
    background: #0E0E0E;
    border-left: 1px solid var(--line-soft);
    transform: translateX(100%);
    transition: transform .32s cubic-bezier(.4,0,.2,1);
    z-index: 60;
    display: none;
    flex-direction: column;
    justify-content: center;
    padding: 40px 32px;
  }
  .mobile-menu.open { transform: translateX(0); }
  .mobile-menu-links { display: flex; flex-direction: column; margin-bottom: 28px; }
  .mobile-menu-links a {
    font-family: var(--mono);
    font-size: 15px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-dim);
    padding: 16px 0;
    border-bottom: 1px solid var(--line-soft);
    transition: color .2s ease;
  }
  .mobile-menu-links a:hover { color: var(--ink); }
  .mobile-menu-cta { text-align: center; }

  /* ---------- Section frame ---------- */
  section { position: relative; }
  .sec-pad { padding: clamp(90px, 11vw, 160px) 0; }
  .sec-head { max-width: 860px; }
  .sec-head .display { margin-top: 28px; }
  .divider { height: 1px; background: var(--line-soft); }

  /* ---------- HERO ---------- */
  .hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
  }
  .hero-bg {
    position: absolute;
    inset: 0;
    background: #0A0A0A url("assets/061e3d80-598d-4d86-81ba-611fb62880c6.png") no-repeat center right / cover;
    z-index: 0;
    will-change: transform;
  }
  .hero-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(90deg, rgba(10,10,10,0.97) 0%, rgba(10,10,10,0.86) 30%, rgba(10,10,10,0.45) 60%, rgba(10,10,10,0.12) 100%),
      linear-gradient(0deg, rgba(10,10,10,0.9) 0%, rgba(10,10,10,0) 38%);
  }
  .hero .wrap {
    position: relative;
    z-index: 2;
    width: 100%;
    padding-top: 90px;
    padding-bottom: 110px;
  }
  .hero-copy { max-width: 760px; }
  .hero h1 {
    font-size: clamp(54px, 7.4vw, 116px);
    text-transform: none;
    letter-spacing: -0.02em;
  }
  .hero .sub {
    font-family: var(--display);
    font-weight: 500;
    font-size: clamp(26px, 3.2vw, 44px);
    line-height: 1.05;
    color: var(--ink-dim);
    margin: 22px 0 0;
  }
  .hero .sub em { font-style: normal; color: var(--ink); }
  .hero .sub em.accent-grad { color: transparent; }
  .hero p.line {
    margin: 34px 0 0;
    max-width: 50ch;
    font-size: clamp(17px, 1.5vw, 20px);
    color: var(--ink);
    line-height: 1.6;
  }
  .hero-cta {
    margin-top: 40px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: flex-start;
  }
  .hero-cta .micro {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.06em;
    color: var(--ink-dim);
    text-transform: uppercase;
  }
  /* ---------- I — Diagnosis ---------- */
  .two-col {
    margin-top: clamp(48px, 6vw, 84px);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--line-soft);
    border: 1px solid var(--line-soft);
  }
  .pillar {
    background: var(--bg);
    padding: clamp(34px, 3.6vw, 56px);
  }
  .pillar h3 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(34px, 4vw, 56px);
    text-transform: uppercase;
    letter-spacing: 0.01em;
    margin: 0;
    line-height: 1;
  }
  .pillar .pillar-sub {
    margin: 16px 0 28px;
    font-size: clamp(19px, 1.7vw, 23px);
    color: var(--ink);
    max-width: 30ch;
    line-height: 1.35;
  }
  .pillar ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
  .pillar li {
    position: relative;
    padding-left: 26px;
    color: var(--ink-dim);
    font-size: 16.5px;
    line-height: 1.5;
  }
  .pillar li::before {
    content: "";
    position: absolute;
    left: 0; top: 11px;
    width: 9px; height: 1px;
    background: var(--orange);
  }
  .pillar-index {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.2em;
    color: var(--muted);
    text-transform: uppercase;
    display: block;
    margin-bottom: 22px;
  }
  .carousel-hint { display: none; }

  /* ---------- Statement band (reused) ---------- */
  .band {
    background: var(--panel);
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
  }
  .band .display {
    font-size: clamp(38px, 5.6vw, 84px);
    text-transform: none;
    max-width: 18ch;
    letter-spacing: -0.015em;
  }
  .band .lead { margin-top: 34px; max-width: 60ch; font-size: clamp(20px, 1.9vw, 24px); }

  /* ---------- II — What Changed (pinned moment) ---------- */
  .pin-wrap {
    height: 240vh;
    position: relative;
    background: var(--panel);
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
  }
  .pin-sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
  }
  .pin-eyebrow { margin-bottom: 26px; }
  .pin-intro {
    font-family: var(--display);
    font-weight: 500;
    font-size: clamp(20px, 2.3vw, 30px);
    line-height: 1.2;
    color: var(--ink-dim);
    margin: 0 0 22px;
    max-width: 26ch;
    text-wrap: balance;
  }
  .pin-statement {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(40px, 6.4vw, 96px);
    line-height: 1.02;
    letter-spacing: -0.015em;
    max-width: 17ch;
    text-wrap: balance;
  }
  .pin-statement .w {
    color: #5a5349;
    transition: color .35s ease;
    display: inline;
  }
  .pin-statement .w.lit { color: var(--ink); }
  .pin-statement .w.amber.lit {
    color: transparent;
    background: var(--accent-grad);
    -webkit-background-clip: text;
    background-clip: text;
  }
  .pin-sub {
    margin-top: 44px;
    max-width: 58ch;
    font-size: clamp(19px, 1.7vw, 23px);
    line-height: 1.55;
    color: var(--ink-dim);
    opacity: 0;
    transform: translateY(16px);
    transition: opacity .6s ease, transform .6s ease;
  }
  .pin-sub.show { opacity: 1; transform: none; }
  .pin-progress {
    position: absolute;
    left: var(--gutter); right: var(--gutter);
    bottom: 56px;
    height: 1px;
    background: var(--line);
  }
  .pin-progress i {
    position: absolute;
    left: 0; top: 0; height: 100%;
    width: 0%;
    background: var(--accent-grad);
  }

  /* ---------- III — Why We Exist ---------- */
  .why-grid {
    margin-top: clamp(48px, 6vw, 80px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .card {
    background: var(--panel);
    border: 1px solid var(--line-soft);
    padding: clamp(28px, 2.6vw, 40px);
    position: relative;
    transition: border-color .3s ease, transform .3s ease;
  }
  .card:hover { border-color: #2f2a22; transform: translateY(-3px); }
  .card .kicker {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
    display: block;
    margin-bottom: 18px;
  }
  .card h4 {
    font-family: var(--display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: clamp(26px, 2.4vw, 32px);
    margin: 0 0 14px;
    line-height: 1.02;
  }
  .card p { margin: 0; color: var(--ink-dim); font-size: 16.5px; line-height: 1.55; }
  .why-close {
    margin-top: clamp(40px, 5vw, 64px);
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(28px, 3.6vw, 50px);
    line-height: 1.08;
    letter-spacing: -0.01em;
    max-width: 22ch;
  }

  /* ---------- IV — How We Work (tiers) ---------- */
  .tiers {
    margin-top: clamp(48px, 6vw, 80px);
    display: grid;
    grid-template-columns: 1.25fr 1fr 1fr;
    gap: 20px;
    align-items: end;
  }
  .tier {
    border: 1px solid var(--line-soft);
    background: var(--panel);
    padding: clamp(30px, 2.8vw, 44px);
    display: flex;
    flex-direction: column;
    min-height: 400px;
    position: relative;
    overflow: hidden;
  }
  .tier.anchor {
    min-height: 480px;
    background:
      radial-gradient(120% 80% at 0% 0%, rgba(255,106,0,0.10), rgba(255,106,0,0) 60%),
      var(--panel-2);
    border-color: #34291a;
    box-shadow: 0 30px 80px -50px rgba(255,130,0,0.5);
  }
  .tier .step {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.2em;
    color: var(--muted);
    text-transform: uppercase;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .tier.anchor .step .tag {
    color: #0A0A0A;
    background: var(--accent-grad);
    padding: 4px 9px;
    border-radius: 2px;
    letter-spacing: 0.1em;
    font-weight: 600;
  }
  .tier h3 {
    font-family: var(--display);
    font-weight: 800;
    text-transform: uppercase;
    font-size: clamp(40px, 4.4vw, 60px);
    margin: 26px 0 0;
    line-height: 0.92;
  }
  .tier.anchor h3 { color: var(--ink); }
  .tier .tdesc {
    margin: 18px 0 0;
    color: var(--ink-dim);
    font-size: 16.5px;
    line-height: 1.5;
    flex: 1;
  }
  .tier .meta {
    margin-top: 26px;
    padding-top: 22px;
    border-top: 1px solid var(--line);
    display: grid;
    gap: 10px;
  }
  .tier .meta .row {
    font-family: var(--mono);
    font-size: 13px;
    letter-spacing: 0.02em;
    color: var(--ink-dim);
    display: flex;
    gap: 10px;
    align-items: baseline;
  }
  .tier .meta .row .dot { color: var(--orange); }
  .tier .price {
    font-family: var(--display);
    font-weight: 800;
    font-size: clamp(30px, 3vw, 40px);
    letter-spacing: 0;
  }
  .tier.anchor .price { color: transparent; background: var(--accent-grad); -webkit-background-clip: text; background-clip: text; }
  .tier .price small { font-family: var(--mono); font-size: 12px; font-weight: 500; letter-spacing: 0.1em; color: var(--muted); display:block; margin-bottom: 4px; }
  .tier .selective {
    font-family: var(--mono);
    font-size: 12.5px;
    letter-spacing: 0.06em;
    color: var(--muted);
    text-transform: uppercase;
  }

  /* ---------- V — Team ---------- */
  .team-grid {
    margin-top: clamp(48px, 6vw, 80px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(22px, 2.8vw, 40px);
    background: transparent;
    border: none;
  }
  .person {
    background: transparent;
    display: flex;
    flex-direction: column;
    overflow: visible;
  }
  .person .photo {
    position: relative;
    width: 70%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: #0A0A0A;
    border: 1px solid var(--line);
  }
  .person .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .6s cubic-bezier(.2,.7,.2,1);
  }
  .person:hover .photo img { transform: scale(1.04); }
  .person .pbody {
    padding: 24px 2px 0;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .person .pnum {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.2em;
    color: var(--muted);
  }
  .person h4 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(24px, 2.2vw, 32px);
    text-transform: uppercase;
    margin: 14px 0 6px;
    line-height: 1;
  }
  .person .lens { color: var(--amber); font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.08em; text-transform: uppercase; }
  .person p { margin: 16px 0 0; color: var(--ink-dim); font-size: 15.5px; line-height: 1.5; }

  /* ---------- VI — In Practice ---------- */
  .cases {
    margin-top: clamp(48px, 6vw, 80px);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .case {
    border: 1px solid var(--line-soft);
    background: var(--panel);
    padding: clamp(32px, 3vw, 50px);
    position: relative;
  }
  .case .ctag {
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--muted);
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .case .ctag b { color: var(--amber); font-weight: 600; }
  .case h4 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(28px, 3vw, 42px);
    text-transform: none;
    letter-spacing: -0.01em;
    margin: 26px 0 18px;
    line-height: 1.02;
  }
  .case h4 .hl { color: var(--ink); }
  .case p { margin: 0; color: var(--ink-dim); font-size: 17px; line-height: 1.6; }
  .case .via {
    margin-top: 26px;
    font-family: var(--mono);
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
    padding-top: 20px;
    border-top: 1px solid var(--line);
  }
  .case .via span { color: var(--ink-dim); }

  /* ---------- VII — Invitation ---------- */
  .invite { text-align: center; }
  .invite .wrap { display: flex; flex-direction: column; align-items: center; }
  .invite .display {
    font-size: clamp(52px, 8vw, 124px);
    text-transform: none;
    letter-spacing: -0.025em;
  }
  .invite .lead { margin: 30px auto 0; text-align: center; }
  .invite .closing {
    margin: clamp(40px,5vw,60px) auto 44px;
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(24px, 3vw, 38px);
    line-height: 1.1;
    max-width: 24ch;
    text-wrap: balance;
  }
  .invite .closing .accent-grad { font-weight: 700; }

  /* ---------- FAQ ---------- */
  .faq-list {
    margin-top: 48px;
    border-top: 1px solid var(--line);
  }
  .faq-item {
    border-bottom: 1px solid var(--line);
  }
  .faq-q {
    width: 100%;
    background: none;
    border: 0;
    cursor: pointer;
    text-align: left;
    color: var(--ink);
    font-family: inherit;
    font-size: clamp(18px, 2.1vw, 23px);
    font-weight: 500;
    line-height: 1.35;
    padding: 28px 56px 28px 0;
    position: relative;
    display: block;
    transition: color .25s ease;
  }
  .faq-q:hover { color: #fff; }
  .faq-q .faq-icon {
    position: absolute;
    right: 4px;
    top: 50%;
    width: 22px;
    height: 22px;
    margin-top: -11px;
    flex: none;
  }
  .faq-q .faq-icon::before,
  .faq-q .faq-icon::after {
    content: "";
    position: absolute;
    background: var(--amber);
    transition: transform .3s ease, opacity .3s ease;
  }
  .faq-q .faq-icon::before {
    top: 50%; left: 0;
    width: 100%; height: 2px;
    margin-top: -1px;
  }
  .faq-q .faq-icon::after {
    left: 50%; top: 0;
    width: 2px; height: 100%;
    margin-left: -1px;
  }
  .faq-item.open .faq-q .faq-icon::after { transform: scaleY(0); opacity: 0; }
  .faq-a {
    overflow: hidden;
    max-height: 0;
    transition: max-height .4s ease;
  }
  .faq-a-inner {
    padding: 0 56px 30px 0;
    color: var(--ink-dim);
    font-size: clamp(15px, 1.6vw, 17.5px);
    line-height: 1.7;
    max-width: 70ch;
  }
  .faq-a-inner .accent { color: var(--amber); font-weight: 500; }

  /* ---------- Footer ---------- */
  footer {
    border-top: 1px solid var(--line-soft);
    padding: 48px 0;
  }
  .foot-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
  }
  .foot-links { display: flex; gap: 26px; }
  .foot-links a {
    font-family: var(--mono);
    font-size: 12.5px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-dim);
    transition: color .2s ease;
  }
  .foot-links a:hover { color: var(--amber); }
  .foot-copy { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--muted); }

  /* ---------- Reveal animation ---------- */
  .reveal { opacity: 0; transform: translateY(22px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
  .reveal.in { opacity: 1; transform: none; }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
    html { scroll-behavior: auto; scroll-snap-type: none; }
  }

  /* ---------- Responsive ---------- */
  @media (max-width: 860px) {
    .hero-grid { grid-template-columns: 1fr; }
    .hero-visual { aspect-ratio: 16/10; max-height: 320px; }
    .why-grid, .tiers, .team-grid, .cases { grid-template-columns: 1fr; }
    .nav-links { display: none; }
    .nav-inner .nav-cta { display: none; }
    .nav-toggle { display: flex; }
    .menu-backdrop { display: block; }
    .mobile-menu { display: flex; }

    /* Eyebrow labels — consistent, no overflow on narrow screens */
    .eyebrow {
      font-size: 10.5px;
      letter-spacing: 0.16em;
      gap: 10px;
    }
    .eyebrow::before { width: 18px; }

    /* Reusable swipe carousel (Sections I, III, IV, V) */
    .carousel {
      display: flex;
      overflow-x: auto;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    .carousel::-webkit-scrollbar { display: none; }
    .carousel > * {
      flex: 0 0 100%;
      scroll-snap-align: start;
    }
    .carousel-hint {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      margin-top: 22px;
    }
    .carousel-hint .dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: var(--line-soft);
      transition: background .25s ease, transform .25s ease;
    }
    .carousel-hint .dot.active {
      background: var(--orange);
      transform: scale(1.3);
    }
    .carousel-next {
      width: 42px;
      height: 42px;
      border-radius: 50%;
      border: 1px solid var(--line-soft);
      background: rgba(245,240,230,0.03);
      color: var(--ink);
      font-size: 18px;
      line-height: 1;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: border-color .2s ease, background .2s ease;
    }
    .carousel-next:hover { border-color: var(--orange); }
  }

  /* ---------- Phone tightening (Samsung S23 ~360px) ---------- */
  @media (max-width: 540px) {
    /* Section vertical rhythm — clamp mins were tuned for tablets; halve them on phones */
    .sec-pad { padding: 52px 0; }
    .hero { padding-top: 52px; padding-bottom: 56px; }
    .hero-visual { max-height: 240px; }

    /* Heading-to-content gaps */
    .two-col,
    .why-grid,
    .tiers,
    .team-grid,
    .cases { margin-top: 30px; }
    .why-close { margin-top: 28px; }
    .band .lead { margin-top: 22px; }
    .hero .sub { margin-top: 16px; }
    .hero p.line { margin-top: 22px; }
    .hero-cta { margin-top: 28px; }

    /* Invitation block */
    .invite .lead { margin-top: 22px; }
    .invite .closing { margin: 30px auto 30px; }

    /* Card / panel inner padding */
    .pillar { padding: 28px 22px; }
    .card { padding: 24px 22px; }
    .tier { padding: 26px 22px; }
    .case { padding: 26px 22px; }

    /* Carousel hint spacing */
    .carousel-hint { margin-top: 16px; }

    /* Footer */
    footer { padding: 36px 0; }
  }

  /* ---------- Contact modal ---------- */
  .modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(5,5,5,0.72);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    opacity: 0;
    visibility: hidden;
    transition: opacity .28s ease, visibility .28s ease;
  }
  .modal-backdrop.open { opacity: 1; visibility: visible; }
  .modal {
    width: 100%;
    max-width: 480px;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 4px;
    padding: clamp(28px, 4vw, 44px);
    position: relative;
    transform: translateY(14px) scale(0.98);
    transition: transform .28s ease;
  }
  .modal-backdrop.open .modal { transform: none; }
  .modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    height: 36px;
    border: 1px solid var(--line);
    background: transparent;
    color: var(--ink-dim);
    border-radius: 50%;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    transition: border-color .2s ease, color .2s ease;
  }
  .modal-close:hover { border-color: var(--orange); color: var(--ink); }
  .modal .eyebrow { margin-bottom: 16px; }
  .modal h3 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(26px, 4vw, 34px);
    line-height: 1.05;
    margin: 0 0 8px;
    text-transform: uppercase;
    letter-spacing: 0.01em;
  }
  .modal p.modal-intro {
    color: var(--ink-dim);
    font-size: 15px;
    line-height: 1.5;
    margin: 0 0 24px;
  }
  .form-field { margin-bottom: 16px; }
  .form-field label {
    display: block;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 8px;
  }
  .form-field input {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 2px;
    padding: 13px 14px;
    color: var(--ink);
    font-family: var(--body);
    font-size: 15px;
    transition: border-color .2s ease;
  }
  .form-field input::placeholder { color: var(--muted-2); }
  .form-field input:focus { outline: none; border-color: var(--orange); }
  .form-field input.invalid { border-color: #c0392b; }
  .modal .btn-primary {
    width: 100%;
    justify-content: center;
    margin-top: 8px;
  }
  .modal .btn-primary[disabled] { opacity: 0.6; cursor: default; }
  .form-error {
    color: #e07a5f;
    font-size: 13px;
    margin: 0 0 14px;
    min-height: 0;
  }
  .modal-success { text-align: center; padding: 8px 0; }
  .modal-success .tick {
    width: 64px;
    height: 64px;
    margin: 0 auto 22px;
    border-radius: 50%;
    border: 1.5px solid var(--orange);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    color: transparent;
    background: var(--accent-grad);
    -webkit-background-clip: text;
    background-clip: text;
  }
  .modal-success h3 { margin-bottom: 12px; }
  .modal-success p {
    color: var(--ink-dim);
    font-size: 15px;
    line-height: 1.55;
    max-width: 34ch;
    margin: 0 auto;
  }
