/* =====================================================================
   AD SCALING — Marketing Agency Funnel
   Futuristic dark · violet accent · iPhone-anchored sections
   ===================================================================== */

/* latin-ext */
@font-face {
  font-family: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/2cb3077b-9cda-4c5a-a93c-06629588d6a9.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: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/3019a3a6-a409-4e86-840f-e62c2e35e380.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;
}
/* latin-ext */
@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/23581557-7382-462c-abad-c2187ed7e300.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: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/f2633238-02cd-4048-978b-31f4f38c42b1.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/f9ab705f-61a2-4f25-94ed-1414a0e809bc.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: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/bae2bd02-e1f4-45e6-9df9-3b1d9b9e26b3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/4fb89993-36a9-4242-919a-5be5d74f4df8.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/e5d813d6-f6f1-4e8a-a0b1-dda2359edcd6.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: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/7425889c-4a47-4f27-9846-912f8aef9cc2.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: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/6ce7c79d-58e9-4a32-80d6-3feedb9a9ab8.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: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/e9453cae-d17b-4461-955b-40f67d835104.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/71050156-a6bd-4a47-92b9-8b6adb32c579.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/9188e83a-7b98-4d47-99d1-9b3a9533ff4f.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/4febf14f-7834-4486-ad1d-8b824d10a879.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/7c3ef163-8385-4efe-be70-92d2f5ed09de.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/622a0650-51dd-41f5-83a5-446d31d45da0.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/7d33dcb4-a895-449e-87f5-a7f1eef328bf.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/71050156-a6bd-4a47-92b9-8b6adb32c579.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/9188e83a-7b98-4d47-99d1-9b3a9533ff4f.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/4febf14f-7834-4486-ad1d-8b824d10a879.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/7c3ef163-8385-4efe-be70-92d2f5ed09de.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/622a0650-51dd-41f5-83a5-446d31d45da0.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/7d33dcb4-a895-449e-87f5-a7f1eef328bf.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("fonts/71050156-a6bd-4a47-92b9-8b6adb32c579.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("fonts/9188e83a-7b98-4d47-99d1-9b3a9533ff4f.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("fonts/4febf14f-7834-4486-ad1d-8b824d10a879.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("fonts/7c3ef163-8385-4efe-be70-92d2f5ed09de.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("fonts/622a0650-51dd-41f5-83a5-446d31d45da0.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("fonts/7d33dcb4-a895-449e-87f5-a7f1eef328bf.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 {
  /* surfaces */
  --bg:        #07060B;
  --bg-1:      #0C0B12;
  --bg-2:      #110F1A;
  --bg-3:      #181624;
  --bg-4:      #221F31;

  /* ink */
  --fg:        #F5F4F8;
  --fg-2:      #B4B1C0;
  --fg-3:      #7A7686;
  --fg-4:      #4A4658;
  --fg-5:      #2E2B38;

  /* lines */
  --line:      rgba(255,255,255,0.06);
  --line-2:    rgba(255,255,255,0.10);
  --line-3:    rgba(255,255,255,0.16);

  /* violet system */
  --v-50:  oklch(0.96 0.04 295);
  --v-100: oklch(0.88 0.10 295);
  --v-200: oklch(0.78 0.16 295);
  --v-300: oklch(0.68 0.20 295);
  --v-400: oklch(0.58 0.22 295);    /* primary */
  --v-500: oklch(0.50 0.22 295);
  --v-600: oklch(0.42 0.20 295);
  --v-700: oklch(0.32 0.16 295);
  --v-800: oklch(0.22 0.10 295);
  --v-900: oklch(0.14 0.06 295);

  --violet: var(--v-400);
  --violet-soft: oklch(0.58 0.22 295 / 0.12);
  --violet-glow: oklch(0.62 0.24 295 / 0.55);

  /* feedback */
  --ok:    oklch(0.74 0.18 145);
  --warn:  oklch(0.78 0.16 75);
  --bad:   oklch(0.65 0.22 25);

  /* type */
  --sans:  'Inter', system-ui, -apple-system, sans-serif;
  --serif: 'Instrument Serif', 'Times New Roman', serif;
  --mono:  'JetBrains Mono', ui-monospace, monospace;

  --pad-x: clamp(20px, 4vw, 56px);
  --maxw:  1240px;
  --r-lg:  20px;
  --r:     14px;
  --r-sm:  10px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  font-feature-settings: "ss01", "cv11", "tnum";
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
::selection { background: var(--violet-soft); color: var(--fg); }

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

/* ----- Global ambient grid + glow ----- */
.world-bg {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 800px 500px at 80% 0%, oklch(0.42 0.20 295 / 0.30), transparent 70%),
    radial-gradient(ellipse 700px 500px at 0% 30%, oklch(0.40 0.18 280 / 0.25), transparent 70%),
    var(--bg);
}
.world-grid {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px, 64px 64px;
  mask-image: radial-gradient(ellipse 100% 80% at 50% 30%, black, transparent 80%);
}

/* ----- Type primitives ----- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--v-200);
  padding: 6px 12px;
  background: var(--violet-soft);
  border: 1px solid oklch(0.58 0.22 295 / 0.25);
  border-radius: 999px;
}
.eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--v-300);
  box-shadow: 0 0 12px var(--v-300);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.4); }
}

h1.display, h2.display {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.96;
  text-wrap: balance;
}
h1.display {
  font-size: clamp(48px, 7.4vw, 96px);
}
h2.display {
  font-size: clamp(36px, 5.2vw, 72px);
}
.display .v {
  background: linear-gradient(180deg, var(--v-200), var(--v-400));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.display .it {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
}
.lede {
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.55;
  color: var(--fg-2);
  text-wrap: pretty;
}
.mono { font-family: var(--mono); }

/* ----- Buttons ----- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 600;
  padding: 12px 20px;
  border-radius: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: transform .18s ease, box-shadow .18s ease, background .18s, border-color .18s;
}
.btn-violet {
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.25),
    0 0 0 1px rgba(255,255,255,0.06),
    0 18px 40px -12px var(--violet-glow);
}
.btn-violet:hover {
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.3),
    0 0 0 1px rgba(255,255,255,0.08),
    0 24px 50px -12px var(--violet-glow);
}
.btn-ghost {
  color: var(--fg);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line-2);
}
.btn-ghost:hover { background: rgba(255,255,255,0.08); border-color: var(--line-3); }
.btn-glass {
  color: var(--fg);
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line-2);
}
.btn-soft {
  color: var(--v-100);
  background: var(--violet-soft);
  border: 1px solid oklch(0.58 0.22 295 / 0.30);
}
.btn-soft:hover { background: oklch(0.58 0.22 295 / 0.18); }
.btn .arrow { transition: transform .2s; }
.btn:hover .arrow { transform: translateX(3px); }

.kbd {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 10px;
  padding: 2px 6px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 4px;
  color: var(--fg-2);
}

/* ----- NAV ----- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px var(--pad-x);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  background: rgba(7,6,11,0.62);
  border-bottom: 1px solid var(--line);
}
.nav-mark {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 15px;
  letter-spacing: -0.01em;
}
.nav-logo {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: linear-gradient(160deg, var(--v-300), var(--v-600));
  display: grid; place-items: center;
  position: relative; overflow: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.25),
    0 0 0 1px rgba(255,255,255,0.05),
    0 8px 22px -6px var(--violet-glow);
  flex: 0 0 auto;
}
.nav-logo::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 25%, rgba(255,255,255,0.4), transparent 50%);
}
.nav-logo svg { width: 16px; height: 16px; position: relative; }
.nav-links { display: flex; gap: 4px; align-items: center; }
.nav-links a {
  font-size: 13px; font-weight: 500;
  color: var(--fg-2);
  padding: 7px 12px;
  border-radius: 8px;
  transition: color .15s, background .15s;
}
.nav-links a:hover { color: var(--fg); background: var(--bg-3); }
.nav-right { display: flex; gap: 8px; align-items: center; }
@media (max-width: 880px) { .nav-links { display: none; } }

/* ── Hamburger button ── */
.nav-hamburger {
  display: none;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px; width: 40px; height: 40px; padding: 0;
  background: none; border: none; cursor: pointer; border-radius: 8px;
}
.nav-hamburger span {
  display: block; width: 22px; height: 2px;
  background: #fff; border-radius: 2px;
  transition: transform .2s, opacity .2s;
}
@media (max-width: 880px) {
  .nav-hamburger { display: flex; }
  .nav-cta-desktop { display: none !important; }
  .nav-cta-mobile { display: inline-flex !important; padding: 8px 14px !important; font-size: 13px !important; }
}
@media (min-width: 881px) {
  .nav-cta-mobile { display: none !important; }
}

/* ── Mobile drawer ── */
.nav-drawer-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(10,9,18,0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.nav-drawer {
  position: absolute; top: 0; right: 0;
  width: min(320px, 88vw); height: 100%;
  background: #fff;
  display: flex; flex-direction: column;
  padding: 20px 24px 32px;
  box-shadow: -4px 0 32px rgba(10,9,18,0.12);
  overflow-y: auto;
}
.nav-drawer-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 40px;
}
.nav-drawer-close {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(10,9,18,0.12); background: none;
  font-size: 16px; cursor: pointer; color: var(--fg);
  display: flex; align-items: center; justify-content: center;
}
.nav-drawer-links {
  display: flex; flex-direction: column; gap: 4px;
}
.nav-drawer-link {
  font-size: 20px; font-weight: 600; color: var(--fg);
  text-decoration: none; padding: 10px 0;
  border-bottom: 1px solid rgba(10,9,18,0.07);
  transition: color .15s;
}
.nav-drawer-link.active { color: var(--violet); }
.nav-drawer-link:hover { color: var(--violet); }
.nav-drawer-cta {
  display: block; text-align: center; margin-top: 16px;
  padding: 15px 24px !important; font-size: 16px !important;
  flex-shrink: 0;
}

/* =====================================================================
   IPHONE FRAME (used everywhere)
   ===================================================================== */
.iphone {
  --w: 320px;
  width: var(--w);
  aspect-ratio: 9 / 19.5;
  position: relative;
  border-radius: 44px;
  background: linear-gradient(160deg, #2A2733, #0C0B12);
  padding: 9px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 0 0 1px rgba(0,0,0,0.6),
    0 60px 120px -30px rgba(0,0,0,0.85),
    0 0 80px -10px var(--violet-glow);
}
.iphone.landscape {
  aspect-ratio: 19.5 / 9;
  --w: 600px;
  border-radius: 44px;
}
.iphone-screen {
  position: absolute; inset: 9px;
  border-radius: 36px;
  background: #000;
  overflow: hidden;
  isolation: isolate;
}
.iphone-notch {
  position: absolute;
  top: 14px; left: 50%; transform: translateX(-50%);
  width: 96px; height: 28px;
  background: #000;
  border-radius: 16px;
  z-index: 10;
}
.iphone.landscape .iphone-notch {
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  width: 28px; height: 96px;
  border-radius: 16px;
}
.iphone-side {
  position: absolute;
  background: #1A1825;
  border-radius: 1px;
}
.iphone-side.l-vol-1 { left: -2px; top: 18%; width: 3px; height: 28px; }
.iphone-side.l-vol-2 { left: -2px; top: 26%; width: 3px; height: 50px; }
.iphone-side.l-vol-3 { left: -2px; top: 36%; width: 3px; height: 50px; }
.iphone-side.r-pwr   { right: -2px; top: 25%; width: 3px; height: 80px; }

/* status bar */
.ios-status {
  position: relative; z-index: 5;
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 28px 6px;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  color: white;
}
.ios-status .icons { display: inline-flex; gap: 5px; align-items: center; }
.ios-status .icons svg { width: 16px; height: 11px; }
.ios-status .battery {
  width: 24px; height: 11px;
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: 3px;
  position: relative;
  padding: 1px;
}
.ios-status .battery::after {
  content: ""; position: absolute;
  right: -3px; top: 3px;
  width: 2px; height: 5px;
  background: rgba(255,255,255,0.6);
  border-radius: 0 1px 1px 0;
}
.ios-status .battery span {
  display: block; height: 100%;
  width: 78%;
  background: white;
  border-radius: 1px;
}

/* iPhone home indicator */
.ios-home-bar {
  position: absolute;
  bottom: 8px; left: 50%; transform: translateX(-50%);
  width: 134px; height: 5px;
  background: rgba(255,255,255,0.5);
  border-radius: 3px;
  z-index: 5;
}

/* =====================================================================
   SECTION SHELL
   ===================================================================== */
.sec {
  position: relative; z-index: 1;
  padding: 64px var(--pad-x);
}
.sec-inner {
  max-width: var(--maxw); margin: 0 auto;
}
@media (max-width: 880px) {
  .sec { padding: 44px var(--pad-x); }
  .hero { padding: 88px var(--pad-x) 48px; }
}

/* =====================================================================
   §1 HERO
   ===================================================================== */
.hero {
  position: relative; z-index: 1;
  padding: 132px var(--pad-x) 80px;
  text-align: center;
}
.hero-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 6px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  font-size: 12px; color: var(--fg-2);
  margin-bottom: 28px;
}
.hero-chip .badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white; font-weight: 700;
  border-radius: 999px;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.hero-chip .badge svg { width: 11px; height: 11px; }

.hero h1 {
  margin: 0 auto 20px;
  max-width: 18ch;
}
.hero h1 br { content: ""; }

.hero p.lede {
  max-width: 60ch;
  margin: 0 auto 32px;
}

.hero-ctas {
  display: inline-flex; gap: 12px; flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 48px;
}

.hero-trust {
  display: flex; justify-content: center; gap: 28px;
  font-family: var(--mono); font-size: 11px;
  color: var(--fg-3); letter-spacing: 0.04em;
  margin-bottom: 60px;
  flex-wrap: wrap;
}
.hero-trust b { color: var(--fg); font-weight: 600; }
.hero-trust span { display: inline-flex; align-items: center; gap: 8px; }
.hero-trust .sep { color: var(--fg-5); }

/* trust strip — BIG */
.hero-trust-big {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(20px, 4vw, 56px);
  margin: 36px auto 60px;
  flex-wrap: wrap;
  max-width: 980px;
}
.hero-trust-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.hero-trust-item .num {
  font-family: var(--mono);
  font-size: clamp(24px, 3.4vw, 38px);
  font-weight: 700;
  color: var(--fg);
  letter-spacing: -0.02em;
  line-height: 1;
}
.hero-trust-item .lab {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--fg-3);
  font-weight: 500;
}
.hero-trust-sep {
  width: 1px;
  height: 32px;
  background: linear-gradient(180deg, transparent, var(--line) 30%, var(--line) 70%, transparent);
}
@media (max-width: 720px) {
  .hero-trust-big { gap: 18px 28px; margin-bottom: 40px; }
  .hero-trust-sep { display: none; }
}

/* exclusive callout */
.calc2-exclusive {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  margin: 28px auto 0;
  padding: 14px 22px;
  border-radius: 14px;
  background: linear-gradient(180deg, oklch(0.55 0.24 285 / 0.10), oklch(0.55 0.24 285 / 0.04));
  border: 1px solid oklch(0.55 0.24 285 / 0.32);
  color: var(--fg-2);
  font-size: 14px;
  text-align: center;
  flex-wrap: wrap;
}
.calc2-exclusive .hl { color: var(--fg); font-weight: 600; }
.calc2-exclusive b { color: var(--fg); font-weight: 700; }
.calc2-exclusive-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--violet, #9b6bff);
  box-shadow: 0 0 12px var(--violet, #9b6bff);
  flex-shrink: 0;
}

.hero-stage {
  position: relative;
  display: grid; place-items: center;
  margin: 0 auto;
  width: fit-content;
  padding: 80px 60px;
}
.hero-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 50% 50%, var(--violet-glow), transparent 70%);
  z-index: 0;
  filter: blur(20px);
}
.hero-stage .iphone { position: relative; z-index: 1; }

/* phone-flip card holder */
.flip-stage {
  position: absolute; inset: 0;
  perspective: 1600px;
}
.flip-card {
  position: absolute; inset: 0;
  transform-style: preserve-3d;
  transition: transform 1.4s cubic-bezier(.7,0,.18,1);
}
.flip-card.flipped { transform: rotateY(180deg); }
.flip-face {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  overflow: hidden;
  border-radius: 36px;
}
.flip-face.back { transform: rotateY(180deg); }

/* viral ad creative */
.ad-creative {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  justify-content: flex-end;
  padding: 0;
  background: linear-gradient(180deg, #0a0a14 0%, #1c0a2a 60%, var(--v-700) 100%);
  color: white;
}
.ad-creative.clinic { background: linear-gradient(180deg, #051515 0%, #0e2a2a 60%, #1d4a48 100%); }
.ad-creative.home   { background: linear-gradient(180deg, #15090a 0%, #2a0e10 60%, #4a1d20 100%); }
.ad-creative.coach  { background: linear-gradient(180deg, #0a0a14 0%, #1c0a2a 60%, var(--v-700) 100%); }

.ad-bg-stripes {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 14px);
  pointer-events: none;
}
.ad-tl-tag {
  position: absolute; top: 56px; left: 18px;
  font-family: var(--mono); font-size: 10px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 4px 8px;
  border-radius: 6px;
  letter-spacing: 0.06em;
  backdrop-filter: blur(4px);
}
.ad-headline {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 28px;
  letter-spacing: -0.02em;
  line-height: 1.05;
  padding: 0 22px 10px;
  position: relative;
  text-wrap: balance;
}
.ad-headline em { font-family: var(--serif); font-style: italic; font-weight: 400; }
.ad-sub {
  font-size: 13px;
  opacity: 0.85;
  padding: 0 22px 18px;
  position: relative;
}
.ad-meta {
  margin: 0 18px 18px;
  padding: 12px 14px;
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  display: flex; align-items: center; gap: 10px;
  position: relative;
  backdrop-filter: blur(6px);
}
.ad-meta .av {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, #fff, oklch(0.82 0.10 285));
  flex: 0 0 auto;
  font-family: var(--sans); font-weight: 700;
  display: grid; place-items: center;
  color: oklch(0.22 0.10 285); font-size: 12px;
}
.ad-meta .info { flex: 1; min-width: 0; }
.ad-meta .nm { font-size: 12px; font-weight: 600; }
.ad-meta .lab { font-size: 10px; opacity: 0.7; }
.ad-meta .cta {
  font-size: 11px; font-weight: 700;
  padding: 6px 10px;
  background: white; color: oklch(0.22 0.10 285);
  border-radius: 6px;
}

.ad-progress {
  position: absolute; top: 50px; left: 18px; right: 18px;
  display: flex; gap: 4px;
}
.ad-progress span {
  flex: 1; height: 2px;
  background: rgba(255,255,255,0.25);
  border-radius: 2px;
  overflow: hidden;
}
.ad-progress span.active::after {
  content: ""; display: block; height: 100%;
  width: var(--p, 0%);
  background: white;
  transition: width 0.1s linear;
}
.ad-progress span.done { background: rgba(255,255,255,0.85); }

/* notifications back face */
.notif-face {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, #0a0a14 0%, var(--v-800) 100%);
  padding: 56px 12px 24px;
  display: flex; flex-direction: column; gap: 8px;
  overflow: hidden;
}
.notif-face::before {
  content: "Notifications";
  position: absolute; top: 16px; left: 0; right: 0;
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.04em;
}
.notif {
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 10px 12px;
  display: flex; gap: 10px;
  align-items: flex-start;
  opacity: 0;
  transform: translateY(20px);
  animation: notifIn 0.5s cubic-bezier(.4,0,.2,1) forwards;
}
.notif .ico {
  width: 28px; height: 28px; border-radius: 7px;
  background: linear-gradient(160deg, var(--v-300), var(--v-600));
  flex: 0 0 auto;
  display: grid; place-items: center;
  font-size: 12px;
  font-weight: 800;
  color: white;
}
.notif .body { flex: 1; min-width: 0; }
.notif .top { display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
.notif .app { font-size: 11px; font-weight: 700; color: rgba(255,255,255,0.95); letter-spacing: 0.02em; }
.notif .when { font-size: 10px; color: rgba(255,255,255,0.5); }
.notif .ttl { font-size: 12px; color: white; margin-top: 2px; font-weight: 600; }
.notif .desc { font-size: 11px; color: rgba(255,255,255,0.7); margin-top: 1px; }
@keyframes notifIn {
  to { opacity: 1; transform: translateY(0); }
}

/* hero side-floats */
.hero-float {
  position: absolute;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  padding: 12px 14px;
  z-index: 2;
  display: flex; align-items: center; gap: 10px;
  font-size: 12px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
}
.hero-float .ico {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--violet-soft);
  color: var(--v-200);
  font-weight: 700;
  flex: 0 0 auto;
}
.hero-float .num { font-family: var(--mono); font-weight: 600; color: var(--fg); }
.hero-float .lab { color: var(--fg-3); font-size: 11px; }

@media (max-width: 720px) {
  .hero-float { display: none; }
  .hero-stage { padding: 40px 0; }
}

/* =====================================================================
   §2 LIVE DASHBOARD
   ===================================================================== */
.dash-wrap {
  text-align: center;
  position: relative;
}
.dash-counters {
  display: flex; justify-content: center; gap: 56px;
  margin: 40px 0 32px;
  flex-wrap: wrap;
}
.dash-counter .num {
  font-size: clamp(48px, 6vw, 80px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(180deg, #fff, var(--v-200));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-variant-numeric: tabular-nums;
}
.dash-counter .lab {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-3);
  margin-top: 8px;
}

.dash-pills {
  display: inline-flex; gap: 6px;
  padding: 6px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 999px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  justify-content: center;
}
.dash-pill {
  font-size: 13px; font-weight: 500;
  padding: 8px 16px;
  border-radius: 999px;
  color: var(--fg-2);
  transition: all .2s;
  display: inline-flex; align-items: center; gap: 8px;
}
.dash-pill .count {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-4);
  padding: 1px 5px;
  border-radius: 4px;
  border: 1px solid var(--line-2);
}
.dash-pill.active {
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white;
  box-shadow: 0 8px 20px -6px var(--violet-glow);
}
.dash-pill.active .count { color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.25); }

/* landscape phone */
.landscape-stage {
  position: relative;
  display: grid; place-items: center;
  padding: 60px 20px;
}
.landscape-stage::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse 50% 60% at 50% 50%, var(--violet-glow), transparent 70%);
  z-index: 0;
  filter: blur(40px);
}
.landscape-stage .iphone { z-index: 1; }

.dash-screen {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.30 0.12 295 / 0.4), transparent 50%),
    #07060B;
  display: flex; flex-direction: column;
  font-family: var(--sans);
  color: white;
  padding: 12px 20px 12px 56px;
}
.dash-screen-top {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; color: rgba(255,255,255,0.6);
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 10px;
}
.dash-screen-top .live {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono);
  letter-spacing: 0.06em;
}
.dash-screen-top .live .pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 8px var(--ok);
  animation: pulse 1.6s ease-in-out infinite;
}
.dash-screen-top .ts {
  font-family: var(--mono); font-size: 10px;
  color: rgba(255,255,255,0.5);
}
.dash-headers {
  display: grid;
  grid-template-columns: 1.6fr 0.85fr 0.75fr 0.9fr 0.85fr 0.75fr 0.95fr 1fr;
  gap: 10px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  padding: 8px 10px;
}

.dash-row {
  display: grid;
  grid-template-columns: 1.6fr 0.85fr 0.75fr 0.9fr 0.85fr 0.75fr 0.95fr 1fr;
  gap: 10px;
  padding: 12px 10px;
  align-items: center;
  border-radius: 10px;
  transition: background .2s;
  font-size: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.dash-row:hover { background: rgba(255,255,255,0.04); }
.dash-row .client {
  display: flex; align-items: center; gap: 8px;
}
.dash-row .client .av {
  width: 24px; height: 24px; border-radius: 6px;
  background: linear-gradient(135deg, var(--v-300), var(--v-600));
  display: grid; place-items: center;
  font-size: 9px; font-weight: 700;
  flex: 0 0 auto;
}
.dash-row .client .nm { font-weight: 600; color: white; font-size: 12px; }
.dash-row .client .stat {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 6px var(--ok);
  margin-left: auto;
  flex: 0 0 auto;
}
.dash-row .num {
  font-family: var(--mono);
  font-weight: 600;
  color: white;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.dash-row .num .sub { color: rgba(255,255,255,0.4); font-size: 10px; margin-left: 2px; }
.dash-row .roas {
  font-family: var(--mono); font-weight: 700;
  color: var(--ok);
  font-size: 12px;
}
.dash-row .spark { width: 80px; height: 24px; }
.dash-row .spark path.line { stroke: var(--v-200); stroke-width: 1.5; fill: none; }
.dash-row .spark path.fill { fill: var(--violet-soft); }

.dash-cap {
  margin-top: 32px;
  font-size: 14px;
  color: var(--fg-2);
  text-align: center;
}
.dash-cap a {
  color: var(--v-200);
  border-bottom: 1px solid currentColor;
}

/* =====================================================================
   §3 SERVICES JOURNEY (sticky scroll)
   ===================================================================== */
.journey {
  position: relative;
  padding: 0 var(--pad-x);
  background: var(--bg-1);
}
.journey-rail {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 80px;
  position: relative;
}
@media (max-width: 920px) {
  .journey-rail { grid-template-columns: 1fr; gap: 32px; }
  .journey-phone-sticky { position: static; padding: 24px 0 8px; }
  .journey-phone-col { display: none; }
}

.journey-phone-col {
  /* position: relative so phone can be offset via JS translateY */
  position: relative;
}
.journey-phone-sticky {
  position: relative; /* JS scroll handler applies translateY */
  display: flex; flex-direction: column;
  align-items: center;
  padding: 12px 0;
  will-change: transform;
}
.journey-phone-sticky::before {
  content: ""; position: absolute; inset: 20% -30%;
  background: radial-gradient(ellipse, var(--violet-glow), transparent 70%);
  filter: blur(30px);
  z-index: 0;
}
.journey-phone-sticky .iphone { z-index: 1; }

.journey-steps {
  display: flex; flex-direction: column; gap: 0;
}
.journey-step {
  min-height: auto;
  padding: 48px 0;
  display: flex; flex-direction: column;
  justify-content: flex-start;
}
.journey-step .step-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--v-200);
  letter-spacing: 0.1em;
  margin-bottom: 14px;
  display: inline-flex; align-items: center; gap: 10px;
}
.journey-step .step-num .line {
  width: 32px; height: 1px; background: var(--v-400);
}
.journey-step h3 {
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin-bottom: 18px;
  text-wrap: balance;
}
.journey-step h3 .it { font-family: var(--serif); font-style: italic; font-weight: 400; }
.journey-step p { color: var(--fg-2); font-size: 16px; line-height: 1.55; max-width: 44ch; }
.journey-step ul {
  margin-top: 20px;
  display: flex; flex-direction: column; gap: 10px;
  list-style: none;
}
.journey-step ul li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14px;
  color: var(--fg-2);
}
.journey-step ul li .check {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--violet-soft);
  color: var(--v-200);
  display: grid; place-items: center;
  flex: 0 0 auto;
  margin-top: 1px;
  font-size: 10px;
  font-weight: 700;
}

/* meta browser frame on phone (for ad-click view) — clean landing page */
.meta-frame {
  position: absolute; inset: 0;
  background: #fff;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.meta-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 54px 12px 8px;
  background: #fff;
  border-bottom: 1px solid rgba(10,9,18,0.09);
}
.meta-bar .dots { display: flex; gap: 4px; }
.meta-bar .dots span {
  width: 7px; height: 7px; border-radius: 50%;
  background: oklch(0.82 0.06 285);
}
.meta-bar .url {
  flex: 1;
  font-size: 10px;
  color: oklch(0.46 0.10 285);
  background: oklch(0.96 0.05 285);
  padding: 5px 10px;
  border-radius: 8px;
  font-family: var(--mono);
  text-align: center;
  letter-spacing: 0.02em;
}
.meta-bar .lock { font-size: 9px; color: oklch(0.60 0.08 285); }

.meta-body {
  flex: 1;
  background: oklch(0.97 0.03 285);
  overflow: hidden;
  padding: 14px 12px 12px;
  display: flex; flex-direction: column; gap: 10px;
}

/* brand row */
.meta-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid rgba(10,9,18,0.09);
  border-radius: 12px;
}
.meta-logo {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--v-400), var(--v-600));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 14px;
  letter-spacing: -0.02em;
}
.meta-brand-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.meta-brand-meta .bn {
  font-size: 11px; font-weight: 700;
  color: #0a0912;
  letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.meta-brand-meta .bs {
  font-size: 9px;
  color: oklch(0.46 0.10 285);
  font-family: var(--mono);
  letter-spacing: 0.02em;
}

/* hero card */
.meta-hero {
  background: linear-gradient(180deg, #fff 0%, oklch(0.97 0.04 285) 100%);
  border: 1px solid rgba(10,9,18,0.09);
  border-radius: 14px;
  padding: 14px 14px 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.meta-tag {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: 0.16em;
  color: var(--v-400);
  background: oklch(0.42 0.26 285 / 0.08);
  padding: 4px 8px;
  border-radius: 4px;
  align-self: flex-start;
  font-weight: 600;
}
.meta-hero h4 {
  font-size: 17px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0a0912;
  margin: 4px 0 0;
}
.meta-hero h4 i {
  font-family: 'Instrument Serif', serif;
  font-weight: 400;
  font-style: italic;
  color: var(--v-400);
  font-size: 17px;
  letter-spacing: -0.01em;
}
.meta-hero p {
  font-size: 10px;
  color: oklch(0.46 0.10 285);
  line-height: 1.4;
  margin: 0;
}

/* form */
.meta-form {
  padding: 12px;
  display: flex; flex-direction: column; gap: 6px;
  background: #fff;
  border: 1px solid rgba(10,9,18,0.09);
  border-radius: 14px;
}
.meta-form .lab {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: 0.12em;
  color: oklch(0.46 0.10 285);
  text-transform: uppercase;
  margin-top: 2px;
}
.meta-form .field {
  background: oklch(0.96 0.05 285);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 11px;
  color: oklch(0.46 0.10 285);
  border: 1px solid transparent;
  transition: all .2s;
  min-height: 14px;
}
.meta-form .field.filled { color: #0a0912; font-weight: 500; background: oklch(0.97 0.04 285); }
.meta-form .field.focused {
  background: #fff;
  border-color: var(--v-400);
  box-shadow: 0 0 0 3px oklch(0.42 0.26 285 / 0.12);
}
.meta-form .field.focused span.typed { color: #0a0912; }
.meta-form .field span.cur {
  display: inline-block;
  width: 1px; height: 11px;
  background: var(--v-400);
  margin-left: 1px;
  vertical-align: middle;
  animation: blink 0.8s steps(2) infinite;
}
@keyframes blink { to { opacity: 0; } }
.meta-form button {
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white;
  padding: 11px;
  border-radius: 9px;
  font-weight: 700;
  font-size: 11px;
  border: none;
  margin-top: 4px;
  letter-spacing: -0.01em;
  box-shadow: 0 6px 16px -6px var(--v-400);
  transition: background .3s;
}
.meta-form button.submitting {
  background: linear-gradient(180deg, #1aa14a, #128a3a);
  box-shadow: 0 6px 16px -6px #1a8a3a;
}
.meta-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px;
  font-family: var(--mono);
  font-size: 8px;
  color: oklch(0.46 0.10 285);
  letter-spacing: 0.04em;
  margin-top: 4px;
}

/* incoming call */
.call-screen {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 30%, oklch(0.30 0.12 295), #050310 80%);
  display: flex; flex-direction: column;
  justify-content: space-between;
  padding: 80px 0 40px;
  color: white;
  text-align: center;
}
.call-screen .lab {
  font-size: 13px; opacity: 0.7;
  font-weight: 500;
}
.call-screen .name {
  font-family: var(--sans);
  font-size: 38px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-top: 6px;
}
.call-screen .av {
  width: 110px; height: 110px;
  border-radius: 50%;
  margin: 32px auto;
  background: linear-gradient(160deg, var(--v-200), var(--v-500));
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 50px -10px var(--violet-glow);
}
.call-screen .av::before {
  content: "M";
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--serif); font-style: italic;
  font-size: 56px; color: white;
}
.call-screen .av-rings::before,
.call-screen .av-rings::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50%;
  animation: ring 2.4s ease-out infinite;
}
.call-screen .av-rings::after { animation-delay: 1.2s; }
@keyframes ring {
  0% { inset: -10px; opacity: 0.7; }
  100% { inset: -50px; opacity: 0; }
}
.call-actions {
  display: flex; justify-content: space-around;
  padding: 0 40px;
}
.call-btn {
  width: 64px; height: 64px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 24px;
  color: white;
}
.call-btn.decline { background: var(--bad); }
.call-btn.answer {
  background: var(--ok);
  position: relative;
}
.call-btn.answer::after {
  content: "";
  position: absolute; inset: -8px;
  border-radius: 50%;
  background: var(--ok);
  opacity: 0;
  animation: pulseRing 1.6s ease-out infinite;
  z-index: -1;
}
@keyframes pulseRing {
  0% { opacity: 0.6; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.6); }
}

/* iMessage */
.imessage {
  position: absolute; inset: 0;
  background: #000;
  display: flex; flex-direction: column;
  padding: 56px 0 44px;
}
.imessage-hd {
  text-align: center;
  padding: 8px 0 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.imessage-hd .av {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(160deg, var(--v-200), var(--v-500));
  margin: 0 auto 4px;
  display: grid; place-items: center;
  font-family: var(--serif); font-style: italic;
  color: white; font-size: 18px;
}
.imessage-hd .nm { font-size: 12px; color: white; font-weight: 500; }
.imessage-hd .sub { font-size: 9px; color: rgba(255,255,255,0.4); }
.imessage-body {
  flex: 1;
  padding: 14px 12px;
  display: flex; flex-direction: column; gap: 4px;
  overflow: hidden;
}
.bubble {
  max-width: 78%;
  padding: 8px 12px;
  border-radius: 18px;
  font-size: 13px;
  line-height: 1.35;
  position: relative;
  word-wrap: break-word;
}
.bubble.in {
  align-self: flex-start;
  background: oklch(0.22 0.06 285);
  color: white;
  border-bottom-left-radius: 4px;
}
.bubble.out {
  align-self: flex-end;
  background: linear-gradient(180deg, #1A88FF, #0066E0);
  color: white;
  border-bottom-right-radius: 4px;
}
.bubble.typing {
  background: oklch(0.22 0.06 285);
  align-self: flex-start;
  display: inline-flex; gap: 4px;
  padding: 12px 14px;
}
.bubble.typing span {
  width: 6px; height: 6px;
  background: rgba(255,255,255,0.5);
  border-radius: 50%;
  animation: typing 1.2s ease-in-out infinite;
}
.bubble.typing span:nth-child(2) { animation-delay: 0.15s; }
.bubble.typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes typing {
  0%, 100% { opacity: 0.3; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-3px); }
}
.bubble + .bubble.same { margin-top: -2px; }

/* iOS push notification */
.push-screen {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, oklch(0.30 0.10 285), #07060B 80%);
  padding: 60px 12px 24px;
  display: flex; flex-direction: column;
  gap: 12px;
}
.push-screen .time {
  text-align: center;
  font-size: 64px;
  font-weight: 200;
  color: white;
  margin-top: 60px;
  letter-spacing: -0.04em;
  line-height: 1;
}
.push-screen .date {
  text-align: center;
  font-size: 14px; color: rgba(255,255,255,0.7);
  font-weight: 500;
  margin-bottom: 32px;
}
.push-card {
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 12px 14px;
  display: flex; gap: 12px;
  animation: notifIn 0.6s cubic-bezier(.4,0,.2,1) backwards;
}
.push-card .ico {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: linear-gradient(160deg, var(--v-300), var(--v-600));
  flex: 0 0 auto;
  display: grid; place-items: center;
  font-size: 14px;
}
.push-card .body { flex: 1; min-width: 0; color: white; }
.push-card .top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.push-card .top .app { font-size: 11px; font-weight: 700; }
.push-card .top .when { font-size: 10px; color: rgba(255,255,255,0.5); }
.push-card .ttl { font-size: 13px; font-weight: 600; margin-top: 2px; }
.push-card .desc { font-size: 11px; color: rgba(255,255,255,0.7); margin-top: 1px; }

.push-cal {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 10px;
  margin-top: auto;
}
.push-cal-hd {
  display: flex; justify-content: space-between;
  font-size: 10px;
  color: white;
  font-weight: 600;
  padding: 4px 6px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.push-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-top: 6px;
}
.push-cal-grid .d {
  aspect-ratio: 1;
  border-radius: 4px;
  font-size: 9px;
  display: grid; place-items: center;
  color: rgba(255,255,255,0.5);
  background: rgba(255,255,255,0.03);
}
.push-cal-grid .d.book {
  background: var(--ok);
  color: white;
  font-weight: 700;
  box-shadow: 0 0 12px oklch(0.74 0.18 145 / 0.5);
}
.push-cal-grid .d.book.new { animation: bookFlash 0.6s ease-out; }
@keyframes bookFlash {
  0% { background: white; transform: scale(1.2); }
  100% { background: var(--ok); transform: scale(1); }
}

/* "your account" dashboard back face */
.your-account {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.30 0.12 295 / 0.5), transparent 50%),
    #07060B;
  padding: 56px 16px 24px;
  color: white;
  display: flex; flex-direction: column;
  gap: 12px;
}
.your-account .hd {
  display: flex; justify-content: space-between;
  font-size: 11px; color: rgba(255,255,255,0.6);
  font-family: var(--mono);
  letter-spacing: 0.06em;
}
.your-account .title {
  font-size: 18px; font-weight: 700;
  letter-spacing: -0.01em;
}
.your-account .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.ya-tile {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 14px 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.ya-tile.span2 { grid-column: span 2; }
.ya-tile .l { font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.ya-tile .v { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; }
.ya-tile .v .sub { font-size: 11px; color: rgba(255,255,255,0.5); margin-left: 2px; }
.ya-tile .delta { font-family: var(--mono); font-size: 10px; color: var(--ok); }
.ya-chart { height: 60px; }
.ya-chart path.line { stroke: var(--v-200); stroke-width: 2; fill: none; }
.ya-chart path.fill { fill: url(#yaGrad); opacity: 0.4; }

/* =====================================================================
   §3.5 FROM THE BOOK — fanned cards
   ===================================================================== */
/* =====================================================================
   FAN STAGE — Lando-style portrait card fan
   ===================================================================== */
.fan-stage {
  position: relative;
  height: 580px;
  margin-top: 56px;
  display: flex; justify-content: center;
  align-items: flex-start;
  perspective: 1600px;
}
.fan-card {
  position: absolute;
  left: 50%;
  top: 60px;
  width: 220px;
  aspect-ratio: 9 / 14;
  border-radius: 22px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  transform-origin: 50% 110%;
  transition: transform 0.55s cubic-bezier(.4,0,.2,1), box-shadow .4s, border-color .3s;
  cursor: pointer;
  box-shadow:
    0 30px 60px -16px rgba(10,9,18,0.30),
    inset 0 1px 0 rgba(255,255,255,0.06);
}
.fan-card:hover {
  z-index: 999 !important;
  transform: var(--t-hover) !important;
  box-shadow: 0 60px 110px -20px var(--violet-glow), 0 0 0 1px var(--v-400);
  border-color: var(--v-400);
}
.fan-card.center {
  width: 240px;
  z-index: 100;
  box-shadow:
    0 50px 100px -20px var(--violet-glow),
    0 0 0 1px rgba(255,255,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.10);
}
.fan-card-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 20%, oklch(0.55 0.24 285 / 0.55), transparent 60%),
    linear-gradient(180deg, oklch(0.20 0.16 285), oklch(0.10 0.08 285));
}
.fan-card.flagship .fan-card-bg {
  background:
    radial-gradient(ellipse at 30% 20%, oklch(0.62 0.26 285 / 0.7), transparent 55%),
    linear-gradient(180deg, oklch(0.32 0.22 285), oklch(0.14 0.12 285));
}
.fan-card-inner {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 8px;
  height: 100%;
  padding: 18px;
  color: white;
}
.fan-card .flag-tag {
  position: absolute;
  top: 14px; right: 14px; z-index: 2;
  font-family: var(--mono); font-size: 9px;
  padding: 3px 7px;
  background: rgba(255,255,255,0.18);
  border: 1px solid rgba(255,255,255,0.30);
  color: white;
  border-radius: 4px;
  letter-spacing: 0.08em;
}
.fan-card .niche {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
}
.fan-card .name {
  font-size: 17px; font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin-top: 4px;
  color: white;
}
.fan-card .divider {
  height: 1px; background: rgba(255,255,255,0.12);
  margin: 8px 0 6px;
}
.fan-card .stat-row { display: flex; flex-direction: column; gap: 3px; }
.fan-card .stat-row .l {
  font-family: var(--mono); font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.55);
}
.fan-card .stat-row .v {
  font-size: 28px; font-weight: 700;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(180deg, #fff, oklch(0.78 0.16 285));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.fan-card .stat-row .ext {
  font-size: 11px; color: rgba(255,255,255,0.75);
  margin-top: 2px;
}
.fan-card .footer-row {
  margin-top: auto;
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 9px;
  color: rgba(255,255,255,0.55);
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.10);
  letter-spacing: 0.06em;
}

@media (max-width: 880px) {
  .fan-stage {
    height: auto;
    perspective: none;
    flex-direction: column;
    gap: 12px; align-items: center;
    padding: 0 16px;
  }
  .fan-card {
    position: relative !important;
    left: auto;
    top: 0;
    transform: none !important;
    width: 100%;
    max-width: 360px;
    aspect-ratio: auto;
    min-height: 220px;
  }
  .fan-card:hover { transform: none !important; }
}
.book-card { display: none; }



/* =====================================================================
   §4 NICHE CALCULATOR
   ===================================================================== */
.calc-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 80px;
  align-items: center;
  margin-top: 56px;
}
@media (max-width: 920px) { .calc-grid { grid-template-columns: 1fr; gap: 40px; } }

.calc-picker { display: flex; flex-direction: column; gap: 12px; }
.calc-stage1 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.calc-vert {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 22px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  cursor: pointer;
  transition: border-color .2s, background .2s, transform .2s;
  text-align: left;
  width: 100%;
}
.calc-vert:hover { border-color: var(--line-3); background: var(--bg-3); }
.calc-vert.active {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.42 0.20 295 / 0.30), transparent 70%),
    var(--bg-3);
  border-color: var(--v-400);
  box-shadow: 0 12px 30px -10px var(--violet-glow);
}
.calc-vert .ico {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--violet-soft);
  display: grid; place-items: center;
  color: var(--v-200);
  font-size: 16px;
  flex: 0 0 auto;
}
.calc-vert.active .ico { background: linear-gradient(180deg, var(--v-300), var(--v-500)); color: white; }
.calc-vert .body { flex: 1; min-width: 0; }
.calc-vert .nm { font-size: 15px; font-weight: 600; color: var(--fg); }
.calc-vert .desc { font-size: 12px; color: var(--fg-3); margin-top: 2px; }
.calc-vert .arrow {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  transition: color .2s, transform .2s;
}
.calc-vert.active .arrow { color: var(--v-200); transform: translateX(3px); }

.calc-stage2 {
  margin-top: 4px;
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 14px;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 14px;
}
.calc-sub {
  font-size: 12px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  color: var(--fg-2);
  cursor: pointer;
  transition: all .2s;
}
.calc-sub:hover { background: rgba(255,255,255,0.06); color: var(--fg); }
.calc-sub.active {
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white;
  border-color: transparent;
  box-shadow: 0 6px 16px -6px var(--violet-glow);
}

.calc-phone-stage {
  position: relative;
  display: grid; place-items: center;
  padding: 40px 20px;
}
.calc-phone-stage::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, var(--violet-glow), transparent 70%);
  filter: blur(20px);
  z-index: 0;
}
.calc-phone-stage .iphone { z-index: 1; }

.calc-screen {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, oklch(0.30 0.12 295 / 0.5), transparent 60%),
    #07060B;
  padding: 64px 18px 24px;
  color: white;
  display: flex; flex-direction: column; gap: 16px;
}
.calc-screen .niche-tag {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--v-200);
}
.calc-screen .niche-name {
  font-size: 22px; font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.calc-screen .big {
  text-align: center;
  margin: 8px 0;
}
.calc-screen .big .l {
  font-family: var(--mono); font-size: 9px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55);
}
.calc-screen .big .v {
  font-size: 60px;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(180deg, #fff, var(--v-200));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
}
.calc-screen .big .v .pre { font-size: 22px; vertical-align: super; opacity: 0.7; }
.calc-screen .compare {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 12px 14px;
}
.calc-screen .compare .row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0;
  font-size: 11px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.calc-screen .compare .row:last-child { border: 0; }
.calc-screen .compare .row .lab { color: rgba(255,255,255,0.6); }
.calc-screen .compare .row .val {
  font-family: var(--mono); font-weight: 600;
  font-size: 12px;
}
.calc-screen .compare .row .val.up { color: var(--ok); }
.calc-screen .compare .row .val.down { color: var(--bad); }
.calc-screen .top-perf {
  background: var(--violet-soft);
  border: 1px solid oklch(0.58 0.22 295 / 0.30);
  border-radius: 12px;
  padding: 10px 12px;
}
.calc-screen .top-perf .l { font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--v-100); }
.calc-screen .top-perf .v { font-size: 13px; font-weight: 600; margin-top: 4px; }

/* =====================================================================
   §4b ROI CALCULATOR — DASHBOARD-STYLE PANEL
   ===================================================================== */
.calc-sec .calc2-card {
  margin-top: 48px;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.42 0.20 295 / 0.18), transparent 55%),
    radial-gradient(ellipse at 100% 100%, oklch(0.55 0.22 290 / 0.10), transparent 60%),
    linear-gradient(180deg, #0d0c14 0%, #0a0912 100%);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    0 50px 100px -30px rgba(40,18,120,0.45),
    0 0 0 1px rgba(255,255,255,0.03) inset;
  padding: 28px 32px 24px;
}
.calc-sec .calc2-card::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 90%);
}

.calc2-tabs {
  display: flex; gap: 6px; flex-wrap: wrap;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-bottom: 14px;
  margin-bottom: 18px;
}
.calc2-tab {
  font-size: 13px; font-weight: 600;
  padding: 10px 18px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(255,255,255,0.55);
  cursor: pointer;
  transition: all .18s;
  letter-spacing: -0.005em;
}
.calc2-tab:hover { color: rgba(255,255,255,0.9); background: rgba(255,255,255,0.04); }
.calc2-tab.active {
  background: white;
  color: #0a0912;
  border-color: rgba(255,255,255,0.12);
}

.calc2-subs {
  display: flex; gap: 8px; flex-wrap: wrap;
  position: relative;
  margin-bottom: 28px;
}
.calc2-sub {
  font-size: 12px; font-weight: 500;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.025);
  color: rgba(255,255,255,0.65);
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
  letter-spacing: -0.005em;
}
.calc2-sub:hover { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.95); border-color: rgba(255,255,255,0.18); }
.calc2-sub.active {
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 14px -4px var(--violet-glow);
}

.calc2-spend {
  position: relative;
  padding: 28px 0 24px;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.calc2-spend-top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px;
}
.calc2-spend-top .lab {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.calc2-spend-top .hint {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.35);
}
.calc2-amount {
  font-size: 72px; font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 0.95;
  color: white;
  font-feature-settings: "tnum" 1;
  margin: 6px 0 18px;
}
.calc2-slider-wrap { position: relative; height: 24px; display: flex; align-items: center; }
.calc2-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px; border-radius: 999px;
  background: linear-gradient(
    to right,
    var(--v-400) 0%,
    var(--v-300) var(--pct, 0%),
    rgba(255,255,255,0.10) var(--pct, 0%),
    rgba(255,255,255,0.10) 100%
  );
  outline: none;
  cursor: pointer;
}
.calc2-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: oklch(0.65 0.22 260);
  border: 3px solid #0d0c14;
  box-shadow: 0 0 0 1px oklch(0.65 0.22 260), 0 0 18px oklch(0.65 0.22 260 / 0.6);
  cursor: grab;
}
.calc2-slider::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: oklch(0.65 0.22 260);
  border: 3px solid #0d0c14;
  box-shadow: 0 0 0 1px oklch(0.65 0.22 260), 0 0 18px oklch(0.65 0.22 260 / 0.6);
  cursor: grab;
}
.calc2-slider-marks {
  display: flex; justify-content: space-between;
  margin-top: 10px;
  font-family: var(--mono); font-size: 11px;
  color: rgba(255,255,255,0.35);
  letter-spacing: 0.04em;
}

.calc2-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.calc2-metric {
  padding: 28px 28px 28px 0;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.calc2-metric:nth-child(2) { padding-left: 28px; }
.calc2-metric:nth-child(3) { padding-left: 28px; border-right: 0; }
.calc2-metric .lab {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  margin-bottom: 12px;
}
.calc2-metric .val {
  font-size: 48px; font-weight: 800;
  letter-spacing: -0.04em; line-height: 1;
  color: white;
  font-feature-settings: "tnum" 1;
}
.calc2-metric .val.v-violet {
  background: linear-gradient(180deg, oklch(0.85 0.16 295), oklch(0.65 0.24 290));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.calc2-metric .val .x { font-size: 0.7em; opacity: 0.85; margin-left: 2px; }
.calc2-metric .sub {
  margin-top: 10px;
  font-family: var(--mono); font-size: 12px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.02em;
}
.calc2-metric .sub s {
  color: rgba(255,255,255,0.3);
  margin-right: 6px;
}

.calc2-costs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.calc2-cost {
  padding: 28px 28px 28px 0;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.calc2-cost:nth-child(2) { padding-left: 28px; border-right: 0; }
.calc2-cost .cost-top {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 12px;
}
.calc2-cost .lab {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.badge-lower {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 10px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  background: oklch(0.32 0.15 155 / 0.4);
  color: oklch(0.85 0.20 165);
  border: 1px solid oklch(0.55 0.18 155 / 0.4);
  letter-spacing: 0.02em;
}
.calc2-cost .cost-row {
  display: flex; align-items: baseline; gap: 16px;
}
.calc2-cost .big-num {
  font-size: 52px; font-weight: 800;
  letter-spacing: -0.04em; line-height: 1;
  color: white;
  font-feature-settings: "tnum" 1;
}
.calc2-cost .strike {
  font-family: var(--mono); font-size: 22px;
  color: rgba(255,255,255,0.4);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}
.calc2-cost .cost-sub {
  margin-top: 6px;
  font-family: var(--mono); font-size: 12px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.02em;
}

.calc2-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
  padding-top: 22px;
  position: relative;
}
.calc2-foot-line {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 11px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.08em;
}
.calc2-foot-line .dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: rgba(255,255,255,0.25);
}

@media (max-width: 880px) {
  .calc-sec .calc2-card { padding: 24px 20px 22px; }
  .calc2-amount { font-size: 64px; }  .calc2-metric .val, .calc2-cost .big-num { font-size: 44px; }
  .calc2-metrics { grid-template-columns: 1fr; }
  .calc2-metric { padding: 18px 0 !important; border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.06); }
  .calc2-metric:last-child { border-bottom: 0; }
  .calc2-costs { grid-template-columns: 1fr; }
  .calc2-cost { padding: 18px 0 !important; border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.06); }
  .calc2-cost:last-child { border-bottom: 0; }
}

/* =====================================================================
   §5 COMPARISON
   ===================================================================== */
.compare-table {
  margin-top: 64px;
  border: 1px solid var(--line-2);
  border-radius: 14px;
  background: var(--bg-2);
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}
.compare-table .compare-head { border-radius: 14px 14px 0 0; }
.compare-table .compare-row:last-of-type, .compare-table .compare-total { border-radius: 0 0 14px 0; }
.compare-table .compare-head .h.us {
  overflow: visible;
}
.compare-table .compare-head { overflow: visible; }
.compare-table .compare-head .h:last-child { border-radius: 0 18px 0 0; }
.compare-table .compare-row:last-of-type .c:last-child { border-radius: 0 0 18px 0; }
/* highlight Ad Scaling column subtle scale */
.compare-table .h.us {
  transform: scale(1.025);
  transform-origin: bottom center;
  z-index: 2;
}
.compare-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
}
.compare-head .h {
  padding: 14px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-2);
  border-right: 1px solid var(--line);
}
.compare-head .h:last-child { border-right: 0; }
.compare-head .h.us {
  background:
    radial-gradient(ellipse at 50% 0%, oklch(0.42 0.20 295 / 0.4), transparent 70%),
    var(--bg-3);
  color: var(--fg);
  font-weight: 700;
  position: relative;
  padding-top: 30px; /* room for the pill inside the cell */
}
.compare-head .h.us::after {
  content: "BEST OPTION";
  position: absolute;
  top: 6px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 10px;
  padding: 5px 12px;
  background: linear-gradient(180deg, var(--v-200), var(--v-400));
  color: white;
  border-radius: 999px;
  letter-spacing: 0.12em;
  font-weight: 700;
  box-shadow: 0 6px 18px -4px oklch(0.42 0.20 295 / 0.6), 0 0 0 1px oklch(0.42 0.20 295 / 0.4);
  animation: badgePulse 2.4s ease-in-out infinite;
  white-space: nowrap;
}
@keyframes badgePulse {
  0%, 100% { box-shadow: 0 6px 18px -4px oklch(0.42 0.20 295 / 0.6), 0 0 0 1px oklch(0.42 0.20 295 / 0.4); }
  50%      { box-shadow: 0 6px 26px -4px oklch(0.55 0.24 295 / 0.85), 0 0 0 4px oklch(0.55 0.24 295 / 0.18); }
}
.compare-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  border-bottom: 1px solid var(--line);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s ease, transform .6s ease;
}
.compare-row.in { opacity: 1; transform: translateY(0); }
.compare-row:last-child { border-bottom: 0; }
.compare-row .c {
  padding: 13px 18px;
  font-size: 13px;
  color: var(--fg-2);
  border-right: 1px solid var(--line);
  display: flex; align-items: center; gap: 8px;
  line-height: 1.35;
}
.compare-row .c:last-child { border-right: 0; }
.compare-row .c.lab {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.compare-row .c.us {
  background: linear-gradient(90deg, oklch(0.42 0.20 295 / 0.18), oklch(0.42 0.20 295 / 0.08));
  color: var(--fg);
  font-weight: 600;
  position: relative;
}
.compare-row .c.us::before {
  content: "✓";
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--v-400);
  color: white;
  font-size: 11px;
  font-weight: 700;
  display: grid; place-items: center;
  flex: 0 0 auto;
}
.compare-row .c.bad { color: var(--fg); }
.compare-row .c.bad::before {
  content: "×";
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  color: var(--fg-4);
  font-size: 14px;
  display: grid; place-items: center;
  flex: 0 0 auto;
}

.compare-total {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  background: var(--bg-3);
  border-top: 2px solid var(--line-2);
}
.compare-total .c {
  padding: 28px 24px;
  border-right: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 26px;
  font-weight: 700;
  color: var(--fg);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.compare-total .c:last-child { border-right: 0; }
.compare-total .c.lab {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--mono);
  display: flex; align-items: center;
}
.compare-total .c.us {
  background: linear-gradient(90deg, oklch(0.42 0.20 295 / 0.25), oklch(0.42 0.20 295 / 0.10));
  color: var(--v-100);
  font-size: 32px;
}

@media (max-width: 880px) {
  /* Wrap the table in a card shell */
  .compare-table {
    margin-top: 40px; overflow: hidden; width: 100%;
    border-radius: 20px;
    border: 1px solid var(--line);
    box-shadow: 0 8px 40px rgba(0,0,0,0.06);
  }
  .compare-head, .compare-row, .compare-total {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
  /* Row category label — thin divider line */
  .compare-head .h:nth-child(1), .compare-row .c.lab, .compare-total .c.lab {
    grid-column: span 2;
    background: transparent;
    color: var(--fg-3);
    border-right: 0;
    border-top: 1px solid var(--line);
    border-bottom: none;
    padding: 10px 18px 2px;
    font-size: 8px;
    font-weight: 600;
    letter-spacing: 0.18em;
    line-height: 1;
    align-items: flex-end;
  }
  .compare-row:first-child .c.lab {
    border-top: none;
    padding-top: 14px;
  }
  /* hide the "In-house" column on mobile — keep Typical Agency vs Ad Scaling */
  .compare-head .h:nth-child(2), .compare-row .c:nth-child(2), .compare-total .c:nth-child(2) { display: none; }
  /* keep Agency (3) and Us (4) */
  .compare-head .h, .compare-row .c, .compare-total .c { padding: 14px 18px; font-size: 13px; }
  /* Competitor column: legible dark */
  .compare-row .c:nth-child(3) { color: var(--fg); font-size: 13px; }
  /* Our column: violet-highlighted */
  .compare-row .c.us {
    background: oklch(0.42 0.26 285 / 0.10) !important;
    color: oklch(0.35 0.20 285) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    border-left: 2px solid oklch(0.42 0.26 285 / 0.30) !important;
  }
  /* Column headers */
  .compare-head .h { font-size: 13px; font-weight: 700; padding: 16px 18px; }
  .compare-head .h.us {
    background: linear-gradient(160deg, oklch(0.42 0.26 285), oklch(0.30 0.20 285)) !important;
    color: #fff !important;
  }
  .compare-head .h.us::after { font-size: 9px; padding: 4px 9px; top: 5px; }
  .compare-table .h.us { transform: none; }
}

/* =====================================================================
   §6 MEET MOI
   ===================================================================== */
.moi-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: center;
  margin-top: 32px;
}
@media (max-width: 880px) { .moi-grid { grid-template-columns: 1fr; gap: 32px; } }

.moi-portrait {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: 18px;
  overflow: hidden;
  background: none;
  border: 1px solid var(--line-2);
}
.moi-portrait::before {
  content: none;
}
.moi-portrait .placeholder-tag {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--mono); font-size: 10px;
  padding: 4px 8px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 6px;
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.06em;
}
.moi-portrait .ph-shape {
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 60%;
  height: 70%;
  background:
    radial-gradient(ellipse at 50% 30%, oklch(0.55 0.10 290), transparent 70%);
  filter: blur(20px);
  opacity: 0.5;
}

.moi-copy h2 { margin-bottom: 24px; }
.moi-pull {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.3;
  color: var(--v-100);
  border-left: 2px solid var(--v-400);
  padding-left: 20px;
  margin: 28px 0;
  text-wrap: pretty;
}
.moi-bio { display: flex; flex-direction: column; gap: 14px; color: var(--fg-2); font-size: 15px; line-height: 1.6; }
.moi-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 32px;
}
.moi-tile {
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 12px;
  padding: 16px;
}
.moi-tile .l { font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-3); }
.moi-tile .v { font-size: 18px; font-weight: 700; margin-top: 6px; letter-spacing: -0.01em; }

/* =====================================================================
   §7 FAQ
   ===================================================================== */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 80px;
  align-items: flex-start;
  margin-top: 56px;
}
@media (max-width: 920px) { .faq-grid { grid-template-columns: 1fr; gap: 40px; } }

.faq-list { display: flex; flex-direction: column; gap: 4px; }
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 4px 0;
}
.faq-q {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 22px 0;
  font-size: clamp(16px, 1.7vw, 19px);
  font-weight: 500;
  color: var(--fg);
  text-align: left;
  cursor: pointer;
}
.faq-q .plus {
  width: 28px; height: 28px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  display: grid; place-items: center;
  font-size: 14px;
  color: var(--fg-2);
  flex: 0 0 auto;
  transition: transform .3s, background .3s;
}
.faq-item.open .faq-q .plus {
  transform: rotate(45deg);
  background: var(--v-400);
  color: white;
  border-color: var(--v-400);
}
.faq-a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .35s ease;
}
.faq-item.open .faq-a { grid-template-rows: 1fr; }
.faq-a > div {
  overflow: hidden;
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.55;
  padding-bottom: 0;
}
.faq-item.open .faq-a > div { padding-bottom: 22px; }
.faq-q.guarantee::before {
  content: "★";
  color: var(--v-200);
  margin-right: 10px;
  font-size: 14px;
}

.faq-phone-stage {
  position: sticky; top: 100px;
  display: grid; place-items: center;
  padding: 20px;
  position: relative;
}
.faq-phone-stage::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, var(--violet-glow), transparent 70%);
  filter: blur(20px);
  z-index: 0;
}
.faq-phone-stage .iphone { z-index: 1; }

/* =====================================================================
   §8 FINAL CTA — incoming call
   ===================================================================== */
.final-cta {
  text-align: center;
  position: relative;
  padding: 140px var(--pad-x) 100px;
}
.final-cta-inner {
  max-width: 760px;
  margin: 0 auto;
}
.final-cta h2 { margin-bottom: 24px; }
.final-cta .lede { max-width: 56ch; margin: 0 auto 36px; }

.slot-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px;
  background: oklch(0.55 0.22 25 / 0.14);
  border: 1px solid oklch(0.62 0.22 25 / 0.55);
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 12px;
  color: oklch(0.78 0.18 25);
  letter-spacing: 0.08em;
  font-weight: 600;
  margin-bottom: 40px;
  animation: slot-flash 1.6s ease-in-out infinite;
}
@keyframes slot-flash {
  0%, 100% {
    box-shadow: 0 0 0 0 oklch(0.62 0.22 25 / 0.0), 0 0 18px -2px oklch(0.62 0.22 25 / 0.25);
    border-color: oklch(0.62 0.22 25 / 0.55);
  }
  50% {
    box-shadow: 0 0 0 6px oklch(0.62 0.22 25 / 0.0), 0 0 28px 0 oklch(0.62 0.22 25 / 0.55);
    border-color: oklch(0.72 0.24 25 / 0.95);
  }
}
.slot-pill .pulse {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: oklch(0.62 0.22 25);
  box-shadow: 0 0 14px oklch(0.62 0.22 25);
  animation: pulse 1.0s ease-in-out infinite;
}

.final-phone-stage {
  position: relative;
  display: grid; place-items: center;
  padding: 40px 20px 20px;
}
.final-phone-stage::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, var(--violet-glow), transparent 70%);
  filter: blur(40px);
  z-index: 0;
}
.final-phone-stage .iphone { z-index: 1; transform: scale(1.05); }

.final-ctas {
  margin-top: 32px;
  display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center;
}
.final-microcopy {
  margin-top: 24px;
  font-family: var(--mono); font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer {
  position: relative;
  border-top: 1px solid var(--line);
  padding: 56px var(--pad-x) 32px;
  background: var(--bg-1);
  z-index: 1;
}
.footer-inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 32px;
}
@media (max-width: 720px) { .footer-inner { grid-template-columns: 1fr 1fr; } }
.footer-brand { display: flex; flex-direction: column; gap: 12px; }
.footer-brand p { color: var(--fg-3); font-size: 13px; line-height: 1.5; max-width: 32ch; }
.footer-col h4 {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--fg-4);
  margin-bottom: 14px; font-weight: 500;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.footer-col a { color: var(--fg-2); }
.footer-col a:hover { color: var(--fg); }
.footer-bot {
  max-width: var(--maxw); margin: 56px auto 0;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 11px;
  color: var(--fg-4); letter-spacing: 0.04em;
  flex-wrap: wrap; gap: 12px;
}

/* =====================================================================
   FAQ — wide list (new layout, no phone)
   ===================================================================== */
.faq-list-wide {
  max-width: 920px;
  margin: 56px auto 0;
  display: flex; flex-direction: column; gap: 0;
  border-top: 1px solid var(--line);
}
.faq-list-wide .faq-item {
  border-bottom: 1px solid var(--line);
  padding: 0;
}
.faq-list-wide .faq-q {
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 18px;
  padding: 24px 8px;
  background: transparent;
  border: 0;
  text-align: left;
  font-family: inherit;
  font-size: 18px;
  font-weight: 500;
  color: var(--fg);
  cursor: pointer;
  transition: padding-left .25s ease;
}
.faq-list-wide .faq-q:hover { padding-left: 16px; }
.faq-list-wide .faq-q-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-4);
  letter-spacing: 0.08em;
}
.faq-list-wide .faq-q-text { line-height: 1.3; }
.faq-list-wide .faq-q-tag {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  padding: 4px 8px;
  border-radius: 4px;
  background: linear-gradient(180deg, oklch(0.55 0.24 285 / 0.18), oklch(0.55 0.24 285 / 0.08));
  border: 1px solid oklch(0.55 0.24 285 / 0.4);
  color: var(--v-100);
  font-weight: 700;
}
.faq-list-wide .faq-item.is-exclusive .faq-q-tag {
  background: linear-gradient(180deg, oklch(0.65 0.18 50 / 0.18), oklch(0.65 0.18 50 / 0.08));
  border-color: oklch(0.65 0.18 50 / 0.4);
  color: oklch(0.85 0.14 60);
}
.faq-list-wide .faq-q .plus {
  width: 32px; height: 32px;
  border: 1px solid var(--line-2);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 18px; font-weight: 300;
  color: var(--fg-2);
  transition: transform .3s, background .3s, color .3s, border-color .3s;
}
.faq-list-wide .faq-item.open .faq-q .plus {
  transform: rotate(45deg);
  background: var(--v-400);
  color: white;
  border-color: var(--v-400);
}
.faq-list-wide .faq-item.is-guarantee.open .faq-q-num,
.faq-list-wide .faq-item.is-exclusive.open .faq-q-num {
  color: var(--v-200);
}
.faq-list-wide .faq-a {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows .35s ease;
}
.faq-list-wide .faq-item.open .faq-a { grid-template-rows: 1fr; }
.faq-list-wide .faq-a > div {
  overflow: hidden;
  color: var(--fg-2);
  line-height: 1.65;
  font-size: 15px;
  padding: 0 8px;
  max-width: 70ch;
}
.faq-list-wide .faq-item.open .faq-a > div { padding: 0 8px 28px; }
.faq-list-wide .faq-q.guarantee::before,
.faq-list-wide .faq-q.exclusive::before { display: none; }

@media (max-width: 720px) {
  .faq-list-wide .faq-q {
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    font-size: 15px;
    padding: 20px 4px;
  }
  .faq-list-wide .faq-q-tag { display: none; }
}

/* =====================================================================
   FINAL CTA — 4-card "what you get" row
   ===================================================================== */
.final-cta.v2 .final-display {
  margin-top: 24px;
  font-size: clamp(48px, 6.5vw, 88px);
  line-height: 1.05;
  letter-spacing: -0.03em;
}
.final-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 56px auto 40px;
  max-width: 1040px;
}
.final-step {
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 16px;
  padding: 22px 20px 20px;
  text-align: left;
  position: relative;
  transition: transform .3s ease, border-color .3s ease, background .3s ease;
}
.final-step:hover {
  transform: translateY(-3px);
  border-color: oklch(0.55 0.24 285 / 0.4);
  background: linear-gradient(180deg, var(--bg-2), oklch(0.55 0.24 285 / 0.04));
}
.final-step-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--v-200);
  letter-spacing: 0.12em;
  font-weight: 700;
  margin-bottom: 12px;
}
.final-step-ttl {
  font-size: 17px;
  font-weight: 600;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}
.final-step-sub {
  font-size: 13px;
  color: var(--fg-3);
  line-height: 1.5;
}
.final-cta.v2 .final-microcopy { margin-top: 14px; }
@media (max-width: 880px) {
  .final-steps { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}
@media (max-width: 480px) {
  .final-steps { grid-template-columns: 1fr; }
}

/* =====================================================================
   FOOTER v2 — top bar with stats
   ===================================================================== */
.footer.v2 .footer-top {
  max-width: var(--maxw);
  margin: 0 auto 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.footer-top-l {
  display: flex; align-items: center; gap: 14px;
}
.footer-top-l .nav-logo.big {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: grid; place-items: center;
  background: linear-gradient(180deg, var(--v-300), var(--v-500));
  box-shadow: 0 8px 24px -8px var(--violet);
}
.footer-top-l .nav-logo.big svg { width: 22px; height: 22px; }
.footer-wordmark {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg);
}
.footer-top-r {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--mono); font-size: 11px;
  color: var(--fg-3); letter-spacing: 0.08em;
  flex-wrap: wrap;
}
.footer-stat b { color: var(--fg); font-weight: 700; }
.footer-stat-sep { color: var(--fg-5); }
.footer-stat.live {
  display: inline-flex; align-items: center; gap: 6px;
  color: oklch(0.78 0.18 142);
  font-weight: 700;
}
.footer-stat.live .pulse-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: oklch(0.72 0.20 142);
  box-shadow: 0 0 8px oklch(0.72 0.20 142);
  animation: livePulse 1.6s ease-in-out infinite;
}
@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.6; transform: scale(1.3); }
}

.footer-inner.v2 {
  grid-template-columns: repeat(4, 1fr);
}
.footer-inner.v2 .footer-col h4 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--v-200);
  margin-bottom: 14px;
  font-weight: 700;
}
.footer-inner.v2 .footer-col ul li { margin-bottom: 8px; }
.footer-inner.v2 .footer-col a {
  font-size: 14px;
  color: var(--fg-2);
  transition: color .2s;
}
.footer-inner.v2 .footer-col a:hover { color: var(--fg); }

@media (max-width: 720px) {
  .footer.v2 .footer-top { flex-direction: column; align-items: flex-start; }
  .footer-inner.v2 { grid-template-columns: 1fr 1fr; }
}


/* =====================================================================
   §3b CLIENT RESULTS — fanned card stack
   ===================================================================== */
.results-section {
  position: relative;
  padding: 140px 24px 120px;
  overflow: hidden;
  background: var(--bg);
}
.results-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 80px;
}
.results-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.24em;
  color: var(--fg-3);
  margin-bottom: 18px;
}
.results-title {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--fg);
  margin: 0 0 14px;
  text-wrap: balance;
}
.results-title .it {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
}
.results-sub {
  font-size: 16px;
  color: var(--fg-2);
  margin: 0;
}

.results-fan {
  position: relative;
  height: 560px;
  margin: 0 auto;
  max-width: 1200px;
}
.results-fan-inner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
}
.results-card {
  position: absolute;
  top: 0;
  left: 0;
  width: 260px;
  height: 400px;
  border-radius: 22px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  box-shadow:
    0 30px 60px -12px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.04) inset;
  transform-origin: 50% 50%;
  transition: transform 0.5s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
  cursor: pointer;
}
.results-card.is-center {
  width: 280px;
  height: 440px;
  box-shadow:
    0 40px 80px -10px var(--violet-glow, rgba(155,107,255,0.4)),
    0 0 0 1px rgba(255,255,255,0.08) inset;
}
.results-card:hover {
  z-index: 10 !important;
  box-shadow: 0 50px 90px -10px rgba(0,0,0,0.7);
}

.results-card-photo {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--bg-3), var(--bg-2));
  overflow: hidden;
}
.results-card-placeholder {
  /* empty — photo or gradient fills .results-card-photo directly */
}

.results-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
    rgba(0,0,0,0.95) 0%,
    rgba(0,0,0,0.75) 40%,
    rgba(0,0,0,0.3) 65%,
    rgba(0,0,0,0) 85%);
  pointer-events: none;
}

.results-card-meta {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  color: #fff;
  text-shadow: 0 1px 6px rgba(0,0,0,0.9), 0 2px 16px rgba(0,0,0,0.7);
}
.results-card-tag {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.9);
  margin-bottom: 8px;
}
.results-card.is-center .results-card-tag {
  color: var(--v-200);
}
.results-card-name {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: 12px;
  text-wrap: balance;
}
.results-card-stat {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.3);
}
.results-card-stat .m {
  font-family: 'Instrument Serif', serif;
  font-size: 40px;
  font-weight: 400;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  color: #fff;
}
.results-card.is-center .results-card-stat .m {
  color: var(--v-100);
}
.results-card-stat .l {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.4;
}
.results-card-time-row {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  gap: 6px;
}
.results-card-time-row .time-ico {
  font-size: 11px;
  opacity: 0.7;
}
.results-card-time-row .time-val {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  font-weight: 500;
}

.results-foot {
  text-align: center;
  margin-top: 60px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.results-foot-line {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 18px;
  color: var(--fg);
}
.results-foot-link {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px solid var(--line-3);
  padding-bottom: 4px;
  transition: color 0.2s, border-color 0.2s;
}
.results-foot-link:hover {
  color: var(--v-200);
  border-color: var(--v-200);
}

/* tablet — tighten the fan */
@media (max-width: 960px) {
  .results-fan { height: 480px; }
  .results-card { width: 200px; height: 320px; }
  .results-card.is-center { width: 220px; height: 350px; }
  /* JS-driven transforms still apply; CSS shrinks the cards proportionally */
}

/* mobile — collapse fan into horizontal scroll */
@media (max-width: 720px) {
  .results-section { padding: 100px 0 80px; }
  .results-head { padding: 0 24px; margin-bottom: 50px; }
  .results-fan {
    height: auto;
    max-width: none;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 20px 24px 30px;
  }
  .results-fan::-webkit-scrollbar { display: none; }
  .results-fan-inner {
    position: static;
    display: flex;
    gap: 14px;
    width: max-content;
  }
  .results-card {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: 220px !important;
    height: 340px !important;
    flex-shrink: 0;
    scroll-snap-align: center;
  }
  .results-card.is-center {
    width: 240px !important;
    height: 360px !important;
  }
}


/* Your-account dashboard — extra rows + bookings list */
.your-account .ya-sub {
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  font-family: var(--mono);
  letter-spacing: 0.04em;
  margin-top: -8px;
  margin-bottom: 4px;
}
.ya-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
}
.ya-row + .ya-row { margin-top: -2px; }
.ya-row-l {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.ya-row-v {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.ya-row-d {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--ok, #4ade80);
}
.ya-section {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  margin-top: 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.ya-list {
  display: flex; flex-direction: column;
  gap: 4px;
}
.ya-li {
  display: grid;
  grid-template-columns: 38px 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  background: rgba(255,255,255,0.025);
  border-radius: 8px;
  font-size: 11px;
}
.ya-li .t {
  font-family: var(--mono);
  font-size: 10px;
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.04em;
}
.ya-li .n {
  color: #fff;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.ya-li .b {
  font-family: var(--mono);
  font-size: 9px;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.06em;
  background: rgba(255,255,255,0.05);
  padding: 2px 6px;
  border-radius: 4px;
}
.ya-li .b.new {
  color: var(--v-100);
  background: oklch(0.42 0.20 295 / 0.30);
  border: 1px solid oklch(0.62 0.22 295 / 0.5);
}
.ya-foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.10em;
  color: rgba(255,255,255,0.4);
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* Make your-account scroll if needed inside phone */
.your-account {
  overflow-y: auto;
  scrollbar-width: none;
}
.your-account::-webkit-scrollbar { display: none; }


/* =====================================================================
   §2 LIVE DASHBOARD — clean panel (replaces phone landscape)
   ===================================================================== */
.dash-panel {
  position: relative;
  margin: 56px auto 0;
  max-width: 1100px;
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.32 0.14 295 / 0.18), transparent 60%),
    linear-gradient(180deg, #0F0D17 0%, #0A0810 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  padding: 18px 24px 14px;
  box-shadow:
    0 50px 100px -20px rgba(0,0,0,0.5),
    0 0 0 1px rgba(255,255,255,0.02) inset,
    0 0 80px -20px var(--violet-glow);
  overflow: hidden;
}
.dash-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 40% 60% at 50% -10%, oklch(0.42 0.20 295 / 0.25), transparent 70%);
  pointer-events: none;
}
.dash-panel-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 14px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  position: relative;
  z-index: 1;
}
.dash-panel-l, .dash-panel-r {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.dash-panel-l .live {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--ok, #4ade80);
}
.dash-panel-l .live .pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--ok, #4ade80);
  box-shadow: 0 0 0 0 var(--ok, #4ade80);
  animation: pulse 1.6s ease-in-out infinite;
}
.dash-panel-sep {
  color: rgba(255,255,255,0.25);
  font-size: 11px;
}
.dash-panel-meta {
  font-family: var(--mono);
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.06em;
}

/* Override inherited landscape sizes — make table breathe at full width */
.dash-panel .dash-headers {
  display: grid;
  grid-template-columns: 1.6fr 0.85fr 0.75fr 0.9fr 0.85fr 0.75fr 0.95fr 1fr;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  padding: 14px 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  position: relative;
  z-index: 1;
}
.dash-panel .dash-row {
  display: grid;
  grid-template-columns: 1.6fr 0.85fr 0.75fr 0.9fr 0.85fr 0.75fr 0.95fr 1fr;
  align-items: center;
  padding: 16px 6px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  position: relative;
  z-index: 1;
  transition: background .2s;
}
.dash-panel .dash-row:last-of-type { border-bottom: none; }
.dash-panel .dash-row:hover { background: rgba(255,255,255,0.025); }
.dash-panel .dash-row .client {
  display: flex; align-items: center; gap: 12px;
}
.dash-panel .dash-row .client .av {
  width: 32px; height: 32px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 800;
}
.dash-panel .dash-row .client .nm {
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.dash-panel .dash-row .client .niche {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.42);
  margin-top: 3px;
}
.dash-range {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  padding: 3px 8px;
  border-radius: 999px;
  background: oklch(0.42 0.20 295 / 0.18);
  color: oklch(0.85 0.16 295);
  border: 1px solid oklch(0.55 0.22 295 / 0.30);
}
.dash-panel .dash-row .num {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
}
.dash-panel .dash-row .roas {
  font-size: 14px;
  font-weight: 700;
}
.dash-panel .dash-row .spark {
  width: 110px;
  height: 32px;
}

.dash-panel-foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.35);
  padding-top: 14px;
  margin-top: 6px;
  border-top: 1px solid rgba(255,255,255,0.05);
  position: relative;
  z-index: 1;
}

@media (max-width: 720px) {
  .dash-panel {
    padding: 14px 12px 10px;
    margin: 36px 0 0;
    border-radius: 14px;
  }
  .dash-panel-top { flex-direction: column; align-items: flex-start; gap: 6px; }
  .dash-panel .dash-headers,
  .dash-panel .dash-row {
    grid-template-columns: 1.5fr 0.8fr 1fr;
    padding: 12px 10px !important;
    gap: 6px !important;
  }
  /* Mobile: Show Client (1), Bookings (4), Revenue (7). Hide Spend (2), Leads (3), CPL (5), CTR (6), Trend (8) */
  .dash-panel .dash-headers > :nth-child(2),
  .dash-panel .dash-row > :nth-child(2),
  .dash-panel .dash-headers > :nth-child(3),
  .dash-panel .dash-row > :nth-child(3),
  .dash-panel .dash-headers > :nth-child(5),
  .dash-panel .dash-row > :nth-child(5),
  .dash-panel .dash-headers > :nth-child(6),
  .dash-panel .dash-row > :nth-child(6),
  .dash-panel .dash-headers > :nth-child(8),
  .dash-panel .dash-row > :nth-child(8) {
    display: none !important;
  }
  .dash-panel .dash-row .client .nm { font-size: 12px; }
  .dash-panel .dash-row .num { font-size: 13px; font-weight: 600; }
  .dash-panel-foot { font-size: 9px; gap: 8px; flex-wrap: wrap; }

  /* Pills horizontal scroll on mobile */
  /* Tab pills — wrap to 2 rows, no scroll */
  .dash-pills {
    flex-wrap: wrap !important;
    overflow-x: hidden !important;
    width: auto;
    max-width: calc(100vw - 32px);
    justify-content: center !important;
    gap: 6px !important;
  }
  .dash-pill { white-space: nowrap; flex-shrink: 0; }

  /* Stats counters — side by side, never wrap */
  .dash-counters { gap: 32px !important; flex-wrap: nowrap !important; justify-content: center !important; }
  .dash-counter .num { font-size: 34px !important; }
  .dash-counter .lab { font-size: 10px !important; }
}


/* =====================================================================
   LIGHT MODE OVERRIDE — applied on top of styles.css
   ===================================================================== */

:root {
  /* surfaces — pure white */
  --bg:        #FFFFFF;
  --bg-1:      oklch(0.98 0.02 285);
  --bg-2:      #FFFFFF;
  --bg-3:      oklch(0.98 0.02 285);
  --bg-4:      oklch(0.95 0.04 285);

  /* ink — full contrast stack */
  --fg:        #0A0912;
  --fg-2:      #0D0A1A;
  --fg-3:      #1A1628;
  --fg-4:      #2E2A3C;
  --fg-5:      oklch(0.46 0.10 285);

  /* lines — hairline */
  --line:      rgba(10, 9, 18, 0.05);
  --line-2:    rgba(10, 9, 18, 0.08);
  --line-3:    rgba(10, 9, 18, 0.14);

  /* DEEP violet system — shifted toward indigo, lower L */
  --v-50:  oklch(0.96 0.05 285);
  --v-100: oklch(0.85 0.14 285);
  --v-200: oklch(0.70 0.20 285);
  --v-300: oklch(0.55 0.24 285);
  --v-400: oklch(0.42 0.26 285);   /* primary deep */
  --v-500: oklch(0.34 0.22 285);
  --v-600: oklch(0.26 0.18 285);
  --v-700: oklch(0.20 0.14 285);
  --v-800: oklch(0.14 0.10 285);
  --v-900: oklch(0.10 0.06 285);

  --violet: var(--v-400);
  --violet-soft: oklch(0.42 0.26 285 / 0.08);
  --violet-glow: oklch(0.42 0.26 285 / 0.25);
}

body { background: #fff; color: var(--fg); }

/* ambient backdrop — cooler, sparser */
.world-bg {
  background: #fff;
}
.world-grid {
  background-image:
    linear-gradient(to right, rgba(10,9,18,0.028) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,9,18,0.020) 1px, transparent 1px);
  background-size: 96px 96px, 96px 96px;
}

::selection { background: var(--violet-soft); color: var(--fg); }

/* nav — white glass for light-hero pages (default) */
.nav { background: rgba(255,255,255,0.82); border-bottom: 1px solid var(--line); }

/* nav — dark glass for pages with dark heroes (add data-nav="dark" to <body>) */
[data-nav="dark"] .nav { background: rgba(7,6,11,0.62) !important; border-bottom: 1px solid rgba(255,255,255,0.06) !important; }
[data-nav="dark"] .nav-mark { color: rgba(255,255,255,0.95) !important; }
[data-nav="dark"] .nav-links a { color: rgba(255,255,255,0.88) !important; }
[data-nav="dark"] .nav-links a:hover { background: rgba(255,255,255,0.08) !important; color: #fff !important; }
[data-nav="dark"] .nav-links a.active { color: #fff !important; }
[data-nav="dark"] .nav-hamburger span { background: #fff !important; }

/* eyebrow — deep violet ink */
.eyebrow {
  color: oklch(0.34 0.22 285);
  background: oklch(0.42 0.26 285 / 0.07);
  border-color: oklch(0.42 0.26 285 / 0.18);
}
.eyebrow .dot { background: oklch(0.42 0.26 285); box-shadow: 0 0 12px oklch(0.42 0.26 285 / 0.6); }

/* gradient text — deep, two-stop */
.display .v {
  background: linear-gradient(180deg, oklch(0.42 0.26 285), oklch(0.22 0.16 285));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* primary button — deeper, with subtle inner glow */
.btn-violet {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.22),
    0 0 0 1px oklch(0.34 0.22 285 / 0.3),
    0 16px 36px -10px oklch(0.42 0.26 285 / 0.5);
}
.btn-violet:hover {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.28),
    0 0 0 1px oklch(0.34 0.22 285 / 0.4),
    0 22px 48px -10px oklch(0.42 0.26 285 / 0.6);
}

/* nav logo deeper */
.nav-logo {
  background: linear-gradient(160deg, oklch(0.50 0.24 285), oklch(0.22 0.16 285));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.28),
    0 0 0 1px rgba(10,9,18,0.06),
    0 8px 22px -6px oklch(0.42 0.26 285 / 0.5);
}

/* buttons */
.btn-ghost {
  color: var(--fg);
  background: rgba(10,9,18,0.04);
  border: 1px solid var(--line-2);
}
.btn-ghost:hover { background: rgba(10,9,18,0.08); border-color: var(--line-3); }
.btn-glass {
  color: var(--fg);
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--line-2);
}
.btn-soft {
  color: oklch(0.38 0.20 295);
  background: var(--violet-soft);
  border: 1px solid oklch(0.58 0.22 295 / 0.25);
}
.kbd {
  background: rgba(10,9,18,0.06);
  border-color: rgba(10,9,18,0.10);
  color: var(--fg-2);
}

/* hero chip */
.hero-chip {
  background: rgba(255,255,255,0.6);
  border-color: var(--line-2);
  color: var(--fg-2);
  box-shadow: 0 4px 16px rgba(10,9,18,0.04);
}

/* trust strip */
.hero-trust b { color: var(--fg); }
.hero-trust { color: var(--fg-3); }
.hero-trust .sep { color: var(--fg-5); }
.hero-trust-item .num { color: var(--fg); }
.hero-trust-item .lab { color: var(--fg-3); }
.hero-trust-sep { background: linear-gradient(180deg, transparent, var(--line) 30%, var(--line) 70%, transparent); }

/* hero floats — frosted, sharp */
.hero-float {
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(10,9,18,0.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 30px 60px -24px rgba(10,9,18,0.18),
    0 4px 12px -4px rgba(10,9,18,0.06);
}
.hero-float .ico {
  background: oklch(0.42 0.26 285 / 0.10);
  color: oklch(0.34 0.22 285);
}
.hero-float .lab { color: var(--fg-3); }
.hero-float .num { color: var(--fg); }

/* hero chip */
.hero-chip {
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(14px);
  border-color: rgba(10,9,18,0.06);
  box-shadow: 0 8px 22px -8px rgba(10,9,18,0.10), inset 0 1px 0 rgba(255,255,255,0.8);
}
.hero-chip .badge {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.28 0.18 285));
}

/* ===== Dashboard ===== */
.dash-pills { background: var(--bg-2); border-color: var(--line); box-shadow: 0 4px 14px rgba(10,9,18,0.04); }
.dash-pill { color: var(--fg-2); }
.dash-pill .count { color: var(--fg-4); border-color: var(--line-2); }
.dash-pill.active .count { color: rgba(255,255,255,0.9); border-color: rgba(255,255,255,0.3); }

.dash-counter .num {
  background: linear-gradient(180deg, var(--fg), oklch(0.32 0.22 285));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dash-pill.active {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  box-shadow: 0 8px 18px -6px oklch(0.42 0.26 285 / 0.5);
}
.dash-counter .lab { color: var(--fg-3); }
.dash-cap { color: var(--fg-2); }
.dash-cap a { color: oklch(0.34 0.22 285); }

/* ===== Journey copy ===== */
.journey-step h3 { color: var(--fg); }
.journey-step p { color: var(--fg-2); }
.journey-step ul li { color: var(--fg-2); }
.journey-step .step-num { color: oklch(0.34 0.22 285); }
.journey-step .step-num .line { background: oklch(0.42 0.26 285); }
.journey-step ul li .check {
  background: oklch(0.42 0.26 285 / 0.10);
  color: oklch(0.34 0.22 285);
}

/* ===== From the Book ===== */
.book-card {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.78 0.16 295 / 0.18), transparent 60%),
    var(--bg-2);
  border-color: var(--line-2);
  box-shadow:
    0 20px 40px -16px rgba(10,9,18,0.10),
    inset 0 1px 0 rgba(255,255,255,0.6);
}
.book-card .niche { color: var(--fg-3); }
.book-card .stat-row .l { color: var(--fg-3); }
.book-card .stat-row .v { color: var(--fg); }
.book-card .stat-row .ext { color: var(--fg-2); }
.book-card .footer-row { color: var(--fg-3); border-top-color: var(--line); }
.book-card .divider { background: var(--line); }
.book-card.flagship {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.55 0.24 285 / 0.20), transparent 60%),
    linear-gradient(180deg, #ffffff, oklch(0.94 0.04 285));
  border-color: oklch(0.42 0.26 285 / 0.35);
  box-shadow:
    0 30px 60px -16px oklch(0.42 0.26 285 / 0.20),
    inset 0 1px 0 rgba(255,255,255,0.9);
}
.book-card .flag-tag {
  background: oklch(0.42 0.26 285 / 0.12);
  color: oklch(0.26 0.18 285);
  border-color: oklch(0.42 0.26 285 / 0.30);
}
.book-card:hover {
  border-color: oklch(0.42 0.26 285 / 0.4);
  box-shadow: 0 30px 60px -10px oklch(0.42 0.26 285 / 0.25);
}

/* ===== Calculator picker ===== */
.calc-vert {
  background: var(--bg-2);
  border-color: var(--line-2);
  box-shadow: 0 2px 8px rgba(10,9,18,0.03);
}
.calc-vert:hover { background: var(--bg-3); border-color: var(--line-3); }
.calc-vert.active {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.55 0.24 285 / 0.12), transparent 70%),
    var(--bg-2);
  border-color: oklch(0.42 0.26 285);
  box-shadow: 0 16px 36px -12px oklch(0.42 0.26 285 / 0.30);
}
.calc-vert .ico { background: oklch(0.42 0.26 285 / 0.08); color: oklch(0.34 0.22 285); }
.calc-vert.active .ico {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  color: white;
}
.calc-vert .nm { color: var(--fg); }
.calc-vert .desc { color: var(--fg-3); }
.calc-vert .arrow { color: var(--fg-3); }
.calc-vert.active .arrow { color: oklch(0.34 0.22 285); }
.calc-sub.active {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  box-shadow: 0 6px 16px -6px oklch(0.42 0.26 285 / 0.45);
}
.calc-stage2 { background: var(--bg-2); border-color: var(--line-2); }
.calc-sub {
  background: rgba(10,9,18,0.03);
  border-color: var(--line);
  color: var(--fg-2);
}
.calc-sub:hover { background: rgba(10,9,18,0.06); color: var(--fg); }

/* ===== Comparison table ===== */
.compare-table {
  background: var(--bg-2);
  border-color: var(--line-2);
  box-shadow: 0 30px 60px -20px rgba(10,9,18,0.10);
}
.compare-head { background: var(--bg-3); border-bottom-color: var(--line); }
.compare-head .h { color: var(--fg-2); border-right-color: var(--line); }
.compare-head .h.us {
  background:
    radial-gradient(ellipse at 50% 0%, oklch(0.55 0.24 285 / 0.20), transparent 70%),
    var(--bg-3);
  color: var(--fg);
}
.compare-head .h.us::after {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
}
.compare-row { border-bottom-color: var(--line); }
.compare-row .c { color: var(--fg-2); border-right-color: var(--line); }
.compare-row .c.lab { color: var(--fg-3); }
.compare-row .c.us {
  background: linear-gradient(90deg, oklch(0.42 0.26 285 / 0.10), oklch(0.42 0.26 285 / 0.03));
  color: var(--fg);
}
.compare-row .c.us::before {
  background: oklch(0.42 0.26 285);
}
.compare-row .c.bad { color: var(--fg); }
.compare-row .c.bad::before {
  background: rgba(10,9,18,0.06);
  color: var(--fg-4);
}
.compare-total { background: var(--bg-3); border-top-color: var(--line-2); }
.compare-total .c { color: var(--fg); border-right-color: var(--line); }
.compare-total .c.lab { color: var(--fg-3); }
.compare-total .c.us {
  background: linear-gradient(90deg, oklch(0.42 0.26 285 / 0.16), oklch(0.42 0.26 285 / 0.04));
  color: oklch(0.26 0.18 285);
}

/* ===== Moi ===== */
.moi-portrait {
  background: none;
  border-color: var(--line-2);
}
.moi-portrait .placeholder-tag {
  background: rgba(255,255,255,0.85);
  border-color: var(--line-2);
  color: var(--fg-2);
}
.moi-portrait::before {
  content: none;
}
.moi-pull { color: oklch(0.26 0.18 285); border-left-color: oklch(0.42 0.26 285); }
.moi-bio { color: var(--fg-2); }
.moi-tile { background: var(--bg-2); border-color: var(--line-2); box-shadow: 0 2px 8px rgba(10,9,18,0.03); }
.moi-tile .l { color: var(--fg-3); }

/* ===== FAQ ===== */
.faq-item { border-bottom-color: var(--line); }
.faq-q { color: var(--fg); }
.faq-q .plus { border-color: var(--line-2); color: var(--fg-2); }
.faq-a > div { color: var(--fg-2); }

/* ===== Final CTA ===== */
.slot-pill {
  background: oklch(0.65 0.22 25 / 0.10);
  border-color: oklch(0.62 0.22 25 / 0.55);
  color: oklch(0.45 0.22 25);
}
.slot-pill .pulse {
  background: oklch(0.55 0.22 25);
  box-shadow: 0 0 12px oklch(0.55 0.22 25 / 0.7);
}
.final-microcopy { color: var(--fg-3); }

/* ===== Footer ===== */
.footer {
  background: #fff !important;
  border-top-color: var(--line);
}
.footer-brand p { color: var(--fg-3); }
.footer-col h4 { color: var(--fg-4); }
.footer-col a { color: var(--fg-2); }
.footer-col a:hover { color: var(--fg); }
.footer-bot { color: var(--fg-4); border-top-color: var(--line); }

/* ===== Site Footer (faq-cta.jsx Footer component) ===== */
.site-footer {
  padding: 56px var(--pad-x) 32px;
  border-top: 1px solid var(--line);
  background: #fff !important;
}
.footer-inner-wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.footer-brand-col {
  display: flex; flex-direction: column; gap: 12px; max-width: 240px;
}
.footer-logo-mark {
  display: inline-flex; align-items: center; gap: 10px;
  text-decoration: none;
}
.footer-wordmark-text {
  font-size: 16px; font-weight: 700; color: var(--fg);
  letter-spacing: 0.3px;
}
.footer-tagline {
  font-size: 14px; color: var(--fg);
  font-family: inherit; letter-spacing: 0; line-height: 1.6; font-weight: 500;
}
.footer-nav-cols {
  display: flex; gap: 64px; flex-wrap: wrap;
}
.footer-nav-col {
  display: flex; flex-direction: column; gap: 10px;
}
.footer-col-label {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; color: var(--fg-4);
  text-transform: uppercase; margin-bottom: 4px; font-weight: 500;
}
.footer-nav-col a {
  font-size: 14px; font-weight: 500; color: var(--fg-2);
  text-decoration: none; transition: color .15s;
}
.footer-nav-col a:hover { color: var(--fg); }
.footer-bottom-bar {
  max-width: var(--maxw); margin: 24px auto 0;
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 20px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.06em; color: var(--fg-4);
}
.footer-sep { color: var(--fg-5); }
.footer-live {
  color: #10b981;
  display: inline-flex; align-items: center; gap: 5px;
}
.footer-live-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #10b981; flex-shrink: 0;
}
@media (max-width: 640px) {
  .footer-inner-wrap { flex-direction: column; gap: 32px; }
  .footer-nav-cols { gap: 32px; }
}

/* ===== iPhone screens stay dark internally — they're devices ===== */
/* (dashboard, calc, push, your-account screens etc keep their dark UI) */

/* iPhone bezel — sleek dark, deep violet halo */
.iphone {
  background: linear-gradient(160deg, #1F1C2A, #0A0812);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.07),
    inset 0 1px 0 rgba(255,255,255,0.16),
    0 0 0 1px rgba(0,0,0,0.4),
    0 60px 120px -30px rgba(10,9,18,0.30),
    0 0 90px -10px oklch(0.42 0.26 285 / 0.45);
}

/* phone halos — deep, concentrated */
.hero-stage::before,
.landscape-stage::before,
.calc-phone-stage::before,
.faq-phone-stage::before,
.final-phone-stage::before,
.journey-phone-sticky::before {
  background: radial-gradient(ellipse 55% 55% at 50% 50%, oklch(0.42 0.26 285 / 0.32), transparent 70%);
  filter: blur(28px);
}

/* sleek hairline section dividers — give the page rhythm */
.sec { position: relative; }
.sec::before {
  content: "";
  position: absolute; top: 0; left: 50%;
  transform: translateX(-50%);
  width: 80%; max-width: 1240px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(10,9,18,0.10), transparent);
}

/* deeper, sharper card surfaces — used by .moi-tile, calc-stage2, etc */
.moi-tile, .calc-stage2 {
  box-shadow:
    0 1px 0 rgba(255,255,255,0.9) inset,
    0 12px 30px -16px rgba(10,9,18,0.10);
}
.compare-table {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 40px 80px -28px rgba(10,9,18,0.18);
}

/* footer stronger contrast */
.footer { background: #fff; }


/* =====================================================================
   §3b CLIENT RESULTS — light theme overrides
   ===================================================================== */
.results-section {
  background: var(--bg);
}
.results-card {
  background: #fff;
  box-shadow:
    0 30px 60px -12px rgba(10, 9, 18, 0.18),
    0 0 0 1px rgba(10, 9, 18, 0.04) inset;
}
.results-card.is-center {
  box-shadow:
    0 40px 80px -10px var(--violet-glow),
    0 0 0 1px rgba(10, 9, 18, 0.06) inset;
}
.results-card:hover {
  box-shadow: 0 50px 90px -10px rgba(10, 9, 18, 0.25);
}
.results-card-photo {
  background: linear-gradient(135deg, var(--bg-3), var(--bg-1));
}
.results-card-placeholder {
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(10,9,18,0.025) 0 12px,
      rgba(10,9,18,0.05) 12px 24px
    );
  color: var(--fg-4);
}
.results-card.is-center .results-card-placeholder {
  background-image:
    repeating-linear-gradient(
      45deg,
      oklch(0.42 0.26 285 / 0.10) 0 12px,
      oklch(0.42 0.26 285 / 0.16) 12px 24px
    );
  color: var(--v-400);
}
/* Overlay: slightly softer on light bg, but cards still need contrast for white text */
.results-card-overlay {
  background: linear-gradient(to top,
    rgba(20, 16, 38, 0.78) 0%,
    rgba(20, 16, 38, 0.35) 35%,
    rgba(20, 16, 38, 0) 60%);
}


/* =====================================================================
   §2 LIVE DASHBOARD — light theme overrides for clean panel
   ===================================================================== */
.dash-panel {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.85 0.12 285 / 0.20), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #fbfaff 100%);
  border: 1px solid rgba(10, 9, 18, 0.08);
  box-shadow:
    0 50px 100px -20px rgba(10, 9, 18, 0.18),
    0 0 0 1px rgba(10, 9, 18, 0.02) inset,
    0 0 80px -20px var(--violet-glow);
}
.dash-panel::before {
  background:
    radial-gradient(ellipse 40% 60% at 50% -10%, oklch(0.42 0.26 285 / 0.10), transparent 70%);
}
.dash-panel-top {
  border-bottom-color: rgba(10, 9, 18, 0.06);
}
.dash-panel-l .live { color: #128a3a; }
.dash-panel-l .live .pulse { background: #1aa14a; }
.dash-panel-sep { color: rgba(10, 9, 18, 0.25); }
.dash-panel-meta { color: rgba(10, 9, 18, 0.55); }
.dash-panel .dash-headers {
  color: rgba(10, 9, 18, 0.45);
  border-bottom-color: rgba(10, 9, 18, 0.06);
}
.dash-panel .dash-row {
  border-bottom-color: rgba(10, 9, 18, 0.05);
}
.dash-panel .dash-row:hover { background: rgba(10, 9, 18, 0.025); }
.dash-panel .dash-row .client .nm { color: #0a0912; }
.dash-panel .dash-row .num { color: rgba(10, 9, 18, 0.85); }
.dash-panel .dash-row .roas { color: #128a3a; }
.dash-panel-foot {
  color: rgba(10, 9, 18, 0.40);
  border-top-color: rgba(10, 9, 18, 0.05);
}
.dash-panel .dash-row .client .niche { color: rgba(10, 9, 18, 0.42); }
.dash-range {
  background: oklch(0.55 0.24 285 / 0.08);
  color: oklch(0.34 0.22 285);
  border-color: oklch(0.55 0.24 285 / 0.20);
}

/* ===== Calculator (calc2) — WHITE light-mode ===== */
.calc-sec .calc2-card {
  background:
    radial-gradient(ellipse at 0% 0%, oklch(0.78 0.16 295 / 0.12), transparent 55%),
    radial-gradient(ellipse at 100% 100%, oklch(0.85 0.14 295 / 0.08), transparent 60%),
    #FFFFFF;
  border: 1px solid rgba(10, 9, 18, 0.06);
  box-shadow:
    0 30px 60px -20px rgba(40, 18, 120, 0.12),
    0 1px 0 rgba(255,255,255,1) inset;
}
.calc-sec .calc2-card::before {
  background-image:
    linear-gradient(to right, rgba(10,9,18,0.022) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,9,18,0.022) 1px, transparent 1px);
}

.calc2-tabs { border-bottom-color: rgba(10, 9, 18, 0.06); }
.calc2-tab { color: var(--fg-3); }
.calc2-tab:hover { color: var(--fg); background: rgba(10, 9, 18, 0.04); }
.calc2-tab.active {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  color: white;
  border-color: transparent;
  box-shadow: 0 6px 14px -4px oklch(0.42 0.26 285 / 0.4);
}

.calc2-sub {
  background: rgba(10, 9, 18, 0.025);
  border-color: rgba(10, 9, 18, 0.08);
  color: var(--fg-2);
}
.calc2-sub:hover { background: rgba(10, 9, 18, 0.06); color: var(--fg); border-color: rgba(10, 9, 18, 0.18); }
.calc2-sub.active {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 12px -4px oklch(0.42 0.26 285 / 0.45);
}

.calc2-spend {
  border-top-color: rgba(10, 9, 18, 0.05);
  border-bottom-color: rgba(10, 9, 18, 0.05);
}
.calc2-spend-top .lab { color: var(--fg-3); }
.calc2-spend-top .hint { color: var(--fg-4); }
.calc2-amount {
  color: var(--fg);
  background: linear-gradient(180deg, oklch(0.34 0.22 285), oklch(0.42 0.26 285));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.calc2-slider {
  background: linear-gradient(
    to right,
    oklch(0.42 0.26 285) 0%,
    oklch(0.55 0.24 285) var(--pct, 0%),
    rgba(10, 9, 18, 0.08) var(--pct, 0%),
    rgba(10, 9, 18, 0.08) 100%
  );
}
.calc2-slider::-webkit-slider-thumb {
  background: oklch(0.42 0.26 285);
  border: 3px solid #FFFFFF;
  box-shadow: 0 0 0 1px oklch(0.42 0.26 285), 0 4px 12px oklch(0.42 0.26 285 / 0.4);
}
.calc2-slider::-moz-range-thumb {
  background: oklch(0.42 0.26 285);
  border: 3px solid #FFFFFF;
  box-shadow: 0 0 0 1px oklch(0.42 0.26 285), 0 4px 12px oklch(0.42 0.26 285 / 0.4);
}
.calc2-slider-marks { color: var(--fg-4); }

.calc2-metrics { border-bottom-color: rgba(10, 9, 18, 0.05); }
.calc2-metric { border-right-color: rgba(10, 9, 18, 0.05); }
.calc2-metric .lab { color: var(--fg-3); }
.calc2-metric .val { color: var(--fg); }
.calc2-metric .val.v-violet {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.calc2-metric .sub { color: var(--fg-3); }
.calc2-metric .sub s { color: var(--fg-4); }

.calc2-costs { border-bottom-color: rgba(10, 9, 18, 0.05); }
.calc2-cost { border-right-color: rgba(10, 9, 18, 0.05); }
.calc2-cost .lab { color: var(--fg-3); }
.calc2-cost .big-num { color: var(--fg); }
.calc2-cost .strike { color: var(--fg-4); }
.calc2-cost .cost-sub { color: var(--fg-3); }

.badge-lower {
  background: oklch(0.92 0.10 155 / 0.6);
  color: oklch(0.34 0.16 155);
  border-color: oklch(0.65 0.18 155 / 0.35);
}

.calc2-foot-line { color: var(--fg-3); }
.calc2-foot-line .dot { background: var(--fg-4); }

/* exclusivity callout */
.calc2-exclusive {
  background: linear-gradient(180deg, oklch(0.55 0.24 285 / 0.06), oklch(0.55 0.24 285 / 0.02));
  border-color: oklch(0.42 0.26 285 / 0.28);
  color: var(--fg-2);
}
.calc2-exclusive .hl, .calc2-exclusive b { color: var(--fg); }
.calc2-exclusive-dot { background: oklch(0.42 0.26 285); box-shadow: 0 0 12px oklch(0.42 0.26 285); }

/* FAQ wide list */
.faq-list-wide { border-top-color: var(--line); }
.faq-list-wide .faq-item { border-bottom-color: var(--line); }
.faq-list-wide .faq-q { color: var(--fg); }
.faq-list-wide .faq-q-num { color: var(--fg-4); }
.faq-list-wide .faq-q-tag {
  background: linear-gradient(180deg, oklch(0.55 0.24 285 / 0.10), oklch(0.55 0.24 285 / 0.04));
  border-color: oklch(0.42 0.26 285 / 0.32);
  color: oklch(0.34 0.20 285);
}
.faq-list-wide .faq-item.is-exclusive .faq-q-tag {
  background: linear-gradient(180deg, oklch(0.78 0.16 50 / 0.16), oklch(0.78 0.16 50 / 0.06));
  border-color: oklch(0.55 0.18 50 / 0.4);
  color: oklch(0.40 0.16 50);
}
.faq-list-wide .faq-q .plus { border-color: var(--line-2); color: var(--fg-3); }
.faq-list-wide .faq-a > div { color: var(--fg-2); }

/* Final CTA cards */
.final-step {
  background: var(--bg-2);
  border-color: var(--line-2);
  box-shadow: 0 1px 0 rgba(255,255,255,0.85) inset, 0 12px 30px -16px rgba(10,9,18,0.10);
}
.final-step:hover { background: linear-gradient(180deg, var(--bg-2), oklch(0.55 0.24 285 / 0.05)); }
.final-step-num { color: oklch(0.42 0.26 285); }
.final-step-ttl { color: var(--fg); }
.final-step-sub { color: var(--fg-3); }

/* Footer top bar */
.footer.v2 .footer-top { border-bottom-color: var(--line); }
.footer-top-l .nav-logo.big {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285));
  box-shadow: 0 8px 24px -8px oklch(0.42 0.26 285 / 0.4);
}
.footer-wordmark { color: var(--fg); }
.footer-top-r { color: var(--fg-3); }
.footer-stat b { color: var(--fg); }
.footer-stat-sep { color: var(--fg-5); }
.footer-stat.live { color: oklch(0.45 0.18 142); }
.footer-stat.live .pulse-dot { background: oklch(0.55 0.20 142); box-shadow: 0 0 8px oklch(0.55 0.20 142); }
.footer-inner.v2 .footer-col h4 { color: oklch(0.34 0.20 285); }
.footer-inner.v2 .footer-col a { color: var(--fg-2); }
.footer-inner.v2 .footer-col a:hover { color: var(--fg); }

/* Compare BEST OPTION badge */
.compare-head .h.us::after {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.34 0.22 285));
  box-shadow: 0 6px 18px -4px oklch(0.42 0.26 285 / 0.5), 0 0 0 1px oklch(0.42 0.26 285 / 0.3);
}

/* Hide dashboard-bottom (no longer relevant — the journey-phone-col fades at 920px which is fine for light too) */

/* Dashboard empty-state row */
.dash-empty {
  display: flex; align-items: center; gap: 16px;
  padding: 28px 22px;
  background: linear-gradient(90deg, oklch(0.42 0.20 295 / 0.05), transparent);
  border-radius: 12px;
}
.dash-empty-ico {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: oklch(0.42 0.20 295 / 0.10);
  color: var(--v-300, oklch(0.55 0.22 295));
  display: grid; place-items: center;
  font-size: 18px;
  flex: 0 0 auto;
  animation: pulse 1.6s ease-in-out infinite;
}
.dash-empty-body { flex: 1 1 auto; min-width: 0; }
.dash-empty-ttl {
  font-weight: 600; font-size: 15px; letter-spacing: -0.01em;
  color: var(--fg);
}
.dash-empty-sub {
  margin-top: 4px;
  font-size: 13px; color: var(--fg-3);
  line-height: 1.4;
}
@media (max-width: 720px) {
  .dash-empty { flex-direction: column; align-items: flex-start; padding: 18px 14px; }
  .dash-empty-body { width: 100%; }
  .dash-empty .btn { width: 100%; justify-content: center; }
}

/* =====================================================================
   MOBILE-FIRST POLISH — final overrides
   ===================================================================== */
@media (max-width: 720px) {
  /* Section-level breathing room */
  .sec, section.sec { padding-left: 0; padding-right: 0; }
  .sec-inner { padding-left: 18px; padding-right: 18px; }

  /* Hero — tighter spacing, smaller chip, single-column CTAs */
  .hero { padding: 80px 18px 40px; }
  .hero-chip { font-size: 11px; padding: 6px 10px; gap: 8px; }
  .hero-chip .badge { font-size: 9px; padding: 3px 7px; }
  h1.display { font-size: clamp(36px, 11vw, 56px); line-height: 1.05; }
  .hero .lede { font-size: 15px; line-height: 1.55; max-width: 38ch; }
  .hero-ctas { flex-direction: column; gap: 10px; width: 100%; }
  .hero-ctas .btn { width: 100%; justify-content: center; padding: 13px 18px; font-size: 14px; }
  .hero-trust-big {
    grid-template-columns: 1fr 1fr;
    gap: 14px 18px !important;
    margin-bottom: 32px !important;
  }
  .hero-trust-item .num { font-size: 22px; }
  .hero-trust-item .lab { font-size: 10px; }
  .hero-stage { padding: 30px 0 0 !important; transform: scale(0.85); transform-origin: center top; margin-bottom: -40px; }

  /* Nav */
  .nav { padding: 14px 18px; }
  .nav-mark { font-size: 14px; }
  .nav-right .btn { padding: 8px 12px; font-size: 12px; }

  /* Section titles */
  h2.display { font-size: clamp(28px, 8.5vw, 44px); line-height: 1.1; }
  .eyebrow { font-size: 10px; }
  .lede { font-size: 14px !important; line-height: 1.55; }

  /* Dashboard */
  .dash-wrap { padding-top: 60px !important; padding-bottom: 60px !important; }
  .dash-counters { grid-template-columns: 1fr 1fr; gap: 10px; }
  .dash-counter { padding: 14px 12px; }
  .dash-counter .num { font-size: 20px; }
  .dash-counter .lab { font-size: 10px; }
  .dash-pills { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; -webkit-overflow-scrolling: touch; }
  .dash-pill { flex: 0 0 auto; white-space: nowrap; font-size: 12px; padding: 8px 14px; }
  .dash-panel-r { flex-wrap: wrap; gap: 6px 8px; font-size: 10px; }
  .dash-range { font-size: 9px !important; }
  .dash-panel .dash-row .client .nm { font-size: 13px; }
  .dash-panel .dash-row .client .niche { font-size: 10px; }
  .dash-panel .dash-row .client .av { width: 28px; height: 28px; font-size: 10px; }
  .dash-panel .dash-row .num { font-size: 13px; }

  /* Journey */
  .journey { padding: 60px 0 !important; }
  .journey-step h3 { font-size: 22px; line-height: 1.2; }
  .journey-step p { font-size: 14px; line-height: 1.55; }
  .journey-step ul li { font-size: 13px; }
  .step-num { font-size: 11px; }
  .journey-phone-sticky .iphone { transform: scale(0.78) !important; transform-origin: center top; }
  .journey-phone-col { margin-bottom: -60px; }

  /* Calculator */
  .calc-sec { padding: 60px 0 !important; }
  .calc-sec .calc2-amount { font-size: 48px !important; }
  .calc-sec .calc2-metric .val, .calc-sec .calc2-cost .big-num { font-size: 32px !important; }
  .calc-sec .calc2-card { padding: 18px 16px !important; }

  /* Comparison */
  .compare-sec { padding: 60px 0 !important; }

  /* Meet Moi */
  .moi-grid { gap: 20px; }
  .moi-portrait { aspect-ratio: 4 / 5; }

  /* FAQ */
  .faq-sec { padding: 60px 0 !important; }
  .faq-list-wide .faq-q { padding: 14px 16px !important; gap: 10px !important; }
  .faq-list-wide .faq-q-text { font-size: 14px; }
  .faq-list-wide .faq-q-num { font-size: 11px; }
  .faq-a > div { font-size: 13px; line-height: 1.55; padding: 0 16px 14px 16px !important; }

  /* Final CTA */
  .final-cta { padding: 70px 18px !important; }
  .final-display { font-size: clamp(30px, 9vw, 48px) !important; }
  .slot-pill { font-size: 10px; padding: 8px 12px; letter-spacing: 0.06em; gap: 8px; }
  .final-steps { grid-template-columns: 1fr 1fr; gap: 10px !important; }
  .final-step { padding: 14px 12px; }
  .final-step-ttl { font-size: 14px; }
  .final-step-sub { font-size: 11px; line-height: 1.4; }
  .final-step-num { font-size: 11px; }
  .final-ctas { width: 100%; flex-direction: column; }
  .final-ctas .btn { width: 100%; justify-content: center; padding: 13px 18px !important; font-size: 14px !important; }
  .final-microcopy { font-size: 9.5px; letter-spacing: 0.04em; }

  /* Footer */
  .footer.v2 .footer-top-r { gap: 6px; flex-wrap: wrap; font-size: 10px; }
  .footer-stat-sep { display: none; }
}

@media (max-width: 420px) {
  .hero-trust-big { grid-template-columns: 1fr 1fr; }
  .hero-stage { transform: scale(0.78); margin-bottom: -60px; }
  .journey-phone-sticky .iphone { transform: scale(0.7) !important; }
  .dash-panel { padding: 12px 10px 8px !important; }
}

/* =====================================================================
   MOBILE FIXES — applied after all above
   ===================================================================== */

/* FAQ — fix specificity for light theme */
.faq-list-wide .faq-item { border-bottom-color: var(--line); }
.faq-list-wide .faq-q { color: var(--fg); }
.faq-list-wide .faq-q .plus { border-color: var(--line-2); color: var(--fg-3); }
.faq-list-wide .faq-a > div { color: var(--fg-2); }
.faq-list-wide .faq-q-tag {
  background: oklch(0.42 0.26 285 / 0.08);
  border-color: oklch(0.42 0.26 285 / 0.30);
  color: var(--v-500);
}
.faq-list-wide .faq-item.is-exclusive .faq-q-tag {
  background: oklch(0.65 0.18 50 / 0.08);
  border-color: oklch(0.65 0.18 50 / 0.30);
  color: oklch(0.52 0.18 55);
}
.faq-sec { background: var(--bg); }

/* Comparison table — more compact on mobile */
@media (max-width: 720px) {
  .compare-head, .compare-row, .compare-total {
    grid-template-columns: 1fr 1fr !important;
  }
  .compare-head .h:nth-child(1), .compare-row .c.lab, .compare-total .c.lab {
    grid-column: span 2 !important;
  }
  .compare-head .h:nth-child(2), .compare-row .c:nth-child(2), .compare-total .c:nth-child(2) { display: none; }
  .compare-head .h, .compare-row .c, .compare-total .c { padding: 10px 12px; font-size: 11.5px; }
  .compare-row .c.lab { padding: 7px 12px !important; font-size: 9px !important; }
  .compare-row .c.us { font-size: 11.5px !important; }
  .compare-row .c.bad { font-size: 11.5px !important; }
  .compare-sec .display { font-size: clamp(26px, 8vw, 38px) !important; }
}

/* ROI Calculator — tighter on mobile */
@media (max-width: 720px) {
  .calc2-tabs { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 12px; gap: 4px; -webkit-overflow-scrolling: touch; }
  .calc2-tab { flex: 0 0 auto; padding: 9px 14px !important; font-size: 12px !important; }
  .calc2-subs { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 8px; -webkit-overflow-scrolling: touch; margin-bottom: 18px; }
  .calc2-sub { flex: 0 0 auto; padding: 7px 13px !important; font-size: 11px !important; }
  .calc2-spend { padding: 14px 0 10px !important; }
  .calc2-spend-top { margin-bottom: 4px; }
  .calc2-amount { font-size: 44px !important; }
  .calc2-slider-wrap { height: 20px; }
  .calc2-metric .val, .calc2-cost .big-num { font-size: 30px !important; }
  .calc2-metrics { gap: 0; }
  .calc2-costs { gap: 0; }
  .calc2-exclusive { font-size: 12px; padding: 12px 14px; }
  .calc2-foot-line { font-size: 9px; gap: 8px; }
  .calc2-foot { flex-direction: column; gap: 14px; align-items: stretch; }
  .calc2-foot .btn { text-align: center; justify-content: center; }
}

/* Moi section — headline on mobile */
@media (max-width: 720px) {
  .moi-copy h2.display { font-size: clamp(26px, 8vw, 36px) !important; }
  .moi-pull { font-size: 18px !important; }
  .moi-bio { font-size: 14px; }
  .moi-tiles { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .moi-tile { padding: 12px; }
  .moi-tile .v { font-size: 15px; }
}

/* =====================================================================
   MOBILE FIXES
   ===================================================================== */

/* FIX 1 — Journey: kill the 80vh min-height per step on mobile */
@media (max-width: 920px) {
  .journey-step { min-height: auto !important; padding: 36px 0; }
  .journey-steps { gap: 0; }
}

/* FIX 2 — ROI Calculator: tabs + pills scroll horizontally instead of clipping */
@media (max-width: 680px) {
  .calc-sec .calc2-card { padding: 20px 16px 20px !important; }

  /* Tabs: single scrollable row */
  .calc2-tabs {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 12px !important;
    margin-bottom: 14px !important;
    gap: 6px !important;
  }
  .calc2-tabs::-webkit-scrollbar { display: none; }
  .calc2-tab { font-size: 12px !important; padding: 8px 14px !important; white-space: nowrap; flex-shrink: 0; }

  /* Pills: single scrollable row */
  .calc2-subs {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 6px !important;
    margin-bottom: 14px !important;
  }
  .calc2-subs::-webkit-scrollbar { display: none; }
  .calc2-sub { font-size: 12px !important; padding: 6px 12px !important; white-space: nowrap; flex-shrink: 0; }

  /* Amount + metrics */
  .calc2-amount { font-size: 48px !important; }
  .calc2-metric .val,
  .calc2-cost .big-num { font-size: 38px !important; }
  .calc2-metric .lab,
  .calc2-cost .lab { font-size: 9px; letter-spacing: 0.08em; }
  .calc2-foot { flex-direction: column; align-items: stretch; gap: 12px; }
  .calc2-foot .btn { text-align: center; justify-content: center; width: 100%; }
}

/* FIX 3a — Comparison: horizontal scroll so table stays intact */
@media (max-width: 680px) {
  .compare-sec .sec-inner { padding-left: 0; padding-right: 0; }
  .compare-table {
    margin-left: 20px;
    margin-right: 20px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Reset 2-col override — let all 4 cols show via horizontal scroll */
  .compare-head, .compare-row, .compare-total {
    grid-template-columns: 90px 120px 120px 140px !important;
    min-width: 470px;
  }
  .compare-head .h:nth-child(1), .compare-row .c.lab, .compare-total .c.lab {
    grid-column: 1 !important;
    background: var(--bg-3);
    font-size: 9px !important;
    padding: 8px 10px !important;
  }
  .compare-head .h:nth-child(3), .compare-row .c:nth-child(3), .compare-total .c:nth-child(3) {
    display: grid !important;
  }
  .compare-head .h, .compare-row .c, .compare-total .c { padding: 10px 10px !important; font-size: 11px !important; }
  .compare-head .h.us::after { top: 5px; font-size: 8px; padding: 3px 7px; }
  .compare-table .h.us { transform: none; }
  .compare-row .c.us::before, .compare-row .c.bad::before { width: 14px; height: 14px; font-size: 9px; flex: 0 0 14px; }
}

/* FIX 3b — FAQ: readable on small screens */
@media (max-width: 520px) {
  .faq-list-wide .faq-q {
    grid-template-columns: auto 1fr auto !important;
    gap: 10px;
    padding: 20px 4px;
    font-size: 15px;
  }
  .faq-list-wide .faq-q-tag { display: none; }
  .faq-list-wide .faq-q .plus { width: 28px; height: 28px; font-size: 16px; }
}

/* FIX 4 — Moi portrait: explicit height, remove aspect-ratio so it doesn't dominate */
@media (max-width: 880px) {
  .moi-portrait { height: 260px; aspect-ratio: unset !important; }
}

/* FIX 5 — FinalCTA: consistent button color */
.final-cta-card .btn-violet {
  background: linear-gradient(180deg, oklch(0.48 0.26 285), oklch(0.30 0.20 285)) !important;
}

/* FIX 6 — FinalCTA mobile: BOOK button first, then WORK + COMPANY side-by-side */
@media (max-width: 720px) {
  .final-cta-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 20px 12px !important;
    text-align: left !important;
  }
  /* Center column (the button) spans full width and goes to top */
  .final-cta-grid > div:nth-child(2) {
    grid-column: 1 / -1;
    order: -1;
  }
  /* Left col (WORK) */
  .final-cta-grid .final-col:first-child {
    text-align: left !important;
  }
  /* Right col (COMPANY) */
  .final-cta-grid .final-col:last-child {
    text-align: left !important;
  }
  .final-cta-card { padding: 36px 20px 20px !important; border-radius: 20px !important; }
  .final-cta-card h2 { font-size: 36px !important; line-height: 1.05 !important; }
  .final-cta-bottom { flex-direction: column !important; text-align: center !important; gap: 6px !important; }
}

/* ============================================================
   MOBILE PATCH v3 — Journey phone / Results fan / Calculator
   ============================================================ */

/* Journey mobile handled by isMobile React state in journey.jsx */

/* RESULTS FAN — Scale to fit mobile, show only center 3 cards */
@media (max-width: 680px) {
  .results-fan { height: 280px !important; overflow: hidden; }
  .results-card:nth-child(1),
  .results-card:nth-child(2),
  .results-card:nth-child(6),
  .results-card:nth-child(7) { display: none !important; }
  .results-fan-inner { transform: scale(0.65) !important; }
  /* Results headline — white bg, punchy title */
  .results-section { background: #fff !important; padding-top: 48px !important; padding-bottom: 60px !important; }
  .results-head { padding: 16px 24px 8px !important; text-align: center; margin-bottom: 0 !important; }
  .results-title {
    font-size: clamp(34px, 9vw, 48px) !important;
    letter-spacing: -0.03em !important;
    line-height: 1.05 !important;
    color: var(--fg) !important;
    background: none !important;
    -webkit-text-fill-color: unset !important;
  }
  .results-title .it {
    font-size: 110% !important;
  }
  .results-sub { font-size: 14px !important; color: #0A0912 !important; font-family: 'JetBrains Mono', monospace !important; font-weight: 700 !important; letter-spacing: 0.06em !important; text-transform: uppercase !important; }
  .results-foot { padding: 0 20px 24px; margin-top: -8px; }
  .results-foot-line { color: #0A0912 !important; }
  .results-foot-link { color: oklch(0.42 0.26 285) !important; }
}

/* CALCULATOR — More compact on mobile */
@media (max-width: 680px) {
  .calc-sec { padding: 40px 0 32px !important; }
  .calc-sec .display { line-height: 1.1 !important; margin-top: 8px !important; }
  .calc-sec .lede { font-size: 13px !important; margin-top: 12px !important; }
  .calc2-card { padding: 18px 14px 14px !important; margin-top: 24px !important; }
  .calc2-spend { margin: 12px 0 10px !important; }
  .calc2-spend-top .lab { font-size: 9px !important; }
  .calc2-amount { font-size: 34px !important; line-height: 1 !important; margin: 4px 0 !important; }
  .calc2-metrics { gap: 6px !important; margin: 12px 0 !important; padding: 14px 10px !important; }
  .calc2-metric .val { font-size: 30px !important; }
  .calc2-metric .lab { font-size: 8px !important; }
  .calc2-metric .sub { font-size: 11px !important; }
  .calc2-costs { gap: 6px !important; margin: 10px 0 !important; }
  .calc2-cost { padding: 12px 10px !important; }
  .calc2-cost .big-num { font-size: 26px !important; }
  .calc2-cost .strike { font-size: 14px !important; }
  .calc2-cost .lab { font-size: 8px !important; }
  .calc2-exclusive { padding: 10px 12px !important; font-size: 12px !important; margin: 10px 0 !important; }
  .calc2-foot { padding: 14px 0 0 !important; margin-top: 12px !important; }
  .calc2-foot-line { font-size: 8px !important; }
  .calc2-foot .btn { padding: 12px 24px !important; font-size: 13px !important; }
}

/* CALCULATOR — keep metrics 3-col and costs 2-col on mobile (override 880px collapse) */
@media (max-width: 680px) {
  .calc2-metrics { grid-template-columns: 1fr 1fr 1fr !important; }
  .calc2-metric { padding: 16px 8px 16px 0 !important; }
  .calc2-metric:nth-child(2) { padding-left: 8px !important; }
  .calc2-metric:nth-child(3) { padding-left: 8px !important; }
  .calc2-costs { grid-template-columns: 1fr 1fr !important; }
  .calc2-cost { padding: 14px 8px 14px 0 !important; }
  .calc2-cost:nth-child(2) { padding-left: 8px !important; }
}

/* ── JOURNEY MOBILE LAYOUT ── */
.journey-mobile {
  padding: 0 20px;
}
.journey-mobile-step {
  padding: 48px 0 16px;
  border-top: 1px solid var(--line);
}
.journey-mobile-step:first-child {
  border-top: none;
  padding-top: 16px;
}
.journey-mobile-phone {
  display: flex;
  justify-content: center;
  /* phone layout=365px, visual=190px → dead space=175px.
     pull next element up so it starts 24px below visual phone bottom */
  margin-bottom: -309px; /* layout 693px - visual 361px - 23px gap = 309px to pull up */
}
.journey-mobile-phone .iphone {
  transform: scale(0.52);
  transform-origin: top center;
}
.journey-mobile-content h3 {
  font-size: 28px;
  line-height: 1.15;
  margin: 14px 0 12px;
  font-weight: 900;
  color: var(--fg);
}
.journey-mobile-content p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--fg-2);
  margin-bottom: 14px;
}
.journey-mobile-content ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.journey-mobile-content ul li {
  font-size: 13px;
  color: var(--fg-2);
  display: flex;
  gap: 8px;
}
.journey-mobile-content ul li .check {
  color: var(--violet);
  flex-shrink: 0;
}

/* ── RESULTS — horizontal scroll strip on mobile ── */
@media (max-width: 680px) {
  .results-fan { display: none !important; }
  .results-mobile-strip {
    display: flex !important;
    overflow-x: auto;
    gap: 12px;
    padding: 8px 20px 20px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .results-mobile-strip::-webkit-scrollbar { display: none; }
  .results-mobile-card {
    flex: 0 0 240px;
    height: 320px;
    border-radius: 18px;
    overflow: hidden;
    position: relative;
    scroll-snap-align: center;
    background: linear-gradient(160deg, oklch(0.22 0.08 285), oklch(0.14 0.05 285));
  }
  .results-mobile-card.featured {
    flex: 0 0 260px;
    border: 2px solid oklch(0.42 0.26 285 / 0.6);
  }
  .results-mobile-card-meta {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 20px 16px;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 100%);
  }
  .results-mobile-card-tag {
    font-family: var(--mono);
    font-size: 9px;
    letter-spacing: 0.14em;
    color: rgba(255,255,255,0.55);
    margin-bottom: 4px;
  }
  .results-mobile-card-name {
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 8px;
  }
  .results-mobile-card-stat .m {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1;
  }
  .results-mobile-card-stat .l {
    font-size: 11px;
    color: rgba(255,255,255,0.55);
    margin-left: 4px;
    font-family: var(--mono);
    letter-spacing: 0.05em;
    text-transform: uppercase;
  }
  .results-mobile-card-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--mono);
    font-size: 10px;
    color: rgba(255,255,255,0.15);
    letter-spacing: 0.1em;
  }
}
@media (min-width: 681px) {
  .results-mobile-strip { display: none; }
}

/* JOURNEY — CSS-controlled show/hide for mobile vs desktop layout */
/* Mobile layout hidden by default (desktop) */
.journey-mobile { display: none; }

/* At mobile: show mobile layout, hide desktop rail */
@media (max-width: 920px) {
  .journey-mobile { display: block; }
  .journey-rail { display: none !important; }
}

/* ================================================================
   COMPREHENSIVE MOBILE OVERHAUL — v3
   ================================================================ */

/* ── 1. PHONE ARTIFACT FIX: hide side buttons in scaled mobile phones ── */
.journey-mobile-phone .iphone-side {
  display: none;
}

/* ── 2. JOURNEY MOBILE: step header ABOVE phone ── */
.journey-mobile-label {
  margin-bottom: 16px;
}
.journey-mobile-step .step-num {
  font-family: var(--mono);
  font-size: 15px;
  color: oklch(0.42 0.26 285);
  letter-spacing: 0.12em;
  font-weight: 800;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.journey-mobile-step .step-num .line {
  width: 40px;
  height: 2px;
  background: oklch(0.42 0.26 285);
  flex-shrink: 0;
}
.step-eyebrow {
  color: oklch(0.42 0.26 285);
  font-weight: 800;
  letter-spacing: 0.12em;
  font-size: 15px;
}

/* ── 3. RESULTS — Lando-style mobile fan ── */
.rmf-wrap {
  display: none;
}
@media (max-width: 680px) {
  /* hide desktop fan + old strip */
  .results-fan { display: none !important; }
  .results-mobile-strip { display: none !important; }
  .rmf-wrap {
    display: block;
    padding: 4px 0 0;
    overflow: hidden;
  }
  .rmf-stage {
    position: relative;
    height: 340px;
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
  }
  .rmf-card {
    position: absolute;
    width: 175px;
    height: 248px;
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(160deg, oklch(0.22 0.08 285), oklch(0.14 0.05 285));
    transition: transform 0.3s ease;
  }
  .rmf-photo {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, oklch(0.20 0.07 285), oklch(0.12 0.04 285));
  }
  .rmf-ph-inner {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--mono);
    font-size: 9px;
    color: rgba(255,255,255,0.12);
    letter-spacing: 0.1em;
  }
  .rmf-overlay {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 65%;
    background: linear-gradient(to top, rgba(0,0,0,0.88) 0%, transparent 100%);
  }
  .rmf-meta {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 14px 14px 16px;
  }
  .rmf-tag {
    font-family: var(--mono);
    font-size: 8px;
    letter-spacing: 0.14em;
    color: rgba(255,255,255,0.5);
    margin-bottom: 3px;
    text-transform: uppercase;
  }
  .rmf-name {
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 6px;
  }
  .rmf-stat {
    display: flex;
    align-items: baseline;
    gap: 5px;
  }
  .rmf-m {
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    line-height: 1;
  }
  .rmf-l {
    font-size: 9px;
    color: rgba(255,255,255,0.55);
    font-family: var(--mono);
    letter-spacing: 0.06em;
    text-transform: uppercase;
  }
  /* Fan positions */
  .rmf-back-l {
    transform: translate(-130px, 20px) rotate(-10deg);
    z-index: 1;
    opacity: 0.6;
  }
  .rmf-left {
    transform: translate(-65px, 10px) rotate(-5deg);
    z-index: 2;
    opacity: 0.75;
  }
  .rmf-center {
    transform: translate(0, 0) rotate(0deg);
    z-index: 5;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.08);
    width: 190px;
    height: 268px;
    border-radius: 18px;
  }
  .rmf-right {
    transform: translate(65px, 10px) rotate(5deg);
    z-index: 2;
    opacity: 0.75;
  }
  .rmf-back-r {
    transform: translate(130px, 20px) rotate(10deg);
    z-index: 1;
    opacity: 0.6;
  }
}
@media (min-width: 681px) {
  .rmf-wrap { display: none !important; }
}

/* ── CARD CAROUSEL (mobile) ── */
.card-carousel {
  position: relative;
  padding-bottom: 44px;
}
.card-carousel-track {
  display: flex;
  gap: 14px;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* padding centers first + last card */
  padding-inline: calc((100% - 76vw) / 2);
}
.card-carousel-track::-webkit-scrollbar { display: none; }
.card-carousel-item {
  flex-shrink: 0;
  width: 76vw;
  height: 460px;
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  text-decoration: none;
  display: block;
  scroll-snap-align: center;
  box-shadow: 0 16px 40px rgba(0,0,0,0.35);
  transition: box-shadow 0.3s;
}
.card-carousel-item.is-active {
  box-shadow: 0 24px 60px rgba(155,107,255,0.3), 0 0 0 1px rgba(255,255,255,0.1) inset;
}
/* arrows */
.carousel-arrow {
  position: absolute;
  top: calc(50% - 28px);
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  font-size: 26px;
  line-height: 38px;
  text-align: center;
  cursor: pointer;
  z-index: 10;
  transition: background 0.2s, opacity 0.2s;
  padding: 0;
}
.carousel-arrow:disabled { opacity: 0.2; pointer-events: none; }
.carousel-arrow:not(:disabled):active { background: rgba(155,107,255,0.5); }
.carousel-prev { left: 8px; }
.carousel-next { right: 8px; }
/* dots */
.carousel-dots {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  align-items: center;
}
.carousel-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(155,107,255,0.3);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s, transform 0.2s;
}
.carousel-dot.active {
  background: oklch(0.62 0.22 285);
  transform: scale(1.5);
}

/* ── 4. CALCULATOR: 2×2 tabs + wrapping pills on mobile ── */
@media (max-width: 680px) {
  .calc2-tabs {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    flex-wrap: unset !important;
    overflow: visible !important;
    padding-bottom: 0 !important;
    gap: 6px !important;
  }
  .calc2-tab {
    flex: unset !important;
    text-align: center !important;
    white-space: normal !important;
    font-size: 11px !important;
    padding: 10px 8px !important;
    line-height: 1.3 !important;
    border-radius: 10px !important;
  }
  .calc2-subs {
    flex-wrap: wrap !important;
    overflow-x: visible !important;
    padding-bottom: 0 !important;
    gap: 6px !important;
    margin-bottom: 16px !important;
  }
  .calc2-sub {
    flex: 0 0 auto !important;
    white-space: normal !important;
    font-size: 11px !important;
    padding: 6px 11px !important;
  }
}

/* ── 5. COMPARISON: 3-col no-scroll at ≤500px → [label | Typical | Ad Scaling] ── */
/* COMPARISON MOBILE REDESIGN: header=[Typical|AdScaling], rows=[LABEL full-width / typical|us]
   Overrides FIX 3a (same breakpoint, later in file = wins) */
@media (max-width: 680px) {
  .compare-sec .sec-inner { padding: 0 16px !important; }
  .compare-table {
    margin: 28px 0 0 !important;
    overflow: hidden !important;
    overflow-x: hidden !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  /* HEADER: 2 equal cols, hide empty + in-house */
  .compare-head {
    grid-template-columns: 1fr 1fr !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .compare-head .h:nth-child(1) { display: none !important; }
  .compare-head .h:nth-child(2) { display: none !important; }
  .compare-head .h:nth-child(3) {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px !important;
    padding: 14px 10px !important;
    text-align: center !important;
  }
  .compare-head .h.us {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-end !important;
    font-size: 12px !important;
    padding: 28px 10px 14px !important;
    text-align: center !important;
  }
  /* Reposition badge INSIDE the cell so overflow:hidden doesn't clip it */
  .compare-head .h.us::after {
    font-size: 7px !important;
    padding: 2px 8px !important;
    position: absolute !important;
    top: 7px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
  }
  .compare-table .h.us { transform: none !important; }

  /* ROWS: label spans full width (row 1), values side-by-side (row 2) */
  .compare-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .compare-row .c.lab {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    font-size: 9px !important;
    letter-spacing: 0.09em !important;
    padding: 8px 14px !important;
    line-height: 1.3 !important;
  }
  .compare-row .c:nth-child(2) { display: none !important; }
  .compare-row .c:nth-child(3) {
    display: flex !important;
    align-items: flex-start !important;
    grid-column: 1 !important;
    grid-row: 2 !important;
    font-size: 12px !important;
    padding: 12px 14px !important;
    line-height: 1.5 !important;
  }
  .compare-row .c.us {
    display: flex !important;
    align-items: flex-start !important;
    grid-column: 2 !important;
    grid-row: 2 !important;
    font-size: 12px !important;
    padding: 12px 14px !important;
    line-height: 1.5 !important;
    background: linear-gradient(135deg, oklch(0.42 0.20 295 / 0.22), oklch(0.42 0.20 295 / 0.10)) !important;
    color: var(--fg) !important;
    font-weight: 700 !important;
    border-left: 2px solid oklch(0.55 0.24 295 / 0.6) !important;
  }
  .compare-row .c.us::before {
    content: "✓" !important;
    display: inline-flex !important;
    width: 16px !important; height: 16px !important;
    border-radius: 50% !important;
    background: var(--v-400) !important;
    color: white !important;
    font-size: 9px !important; font-weight: 700 !important;
    align-items: center !important; justify-content: center !important;
    flex: 0 0 auto !important;
    margin-right: 6px !important;
  }
  .compare-row .c:nth-child(3) {
    color: var(--fg-3) !important;
    font-size: 12px !important;
  }
  .compare-row .c.bad::before { display: none !important; }
  /* Mobile header: mute Typical Agency, purple-highlight Ad Scaling */
  .compare-head .h:nth-child(3) {
    background: none !important;
    color: var(--fg-3) !important;
    font-weight: 500 !important;
    border-left: none !important;
  }
  .compare-head .h.us {
    background: linear-gradient(135deg, oklch(0.42 0.20 295 / 0.25), oklch(0.42 0.20 295 / 0.08)) !important;
    color: oklch(0.50 0.22 295) !important;
    font-weight: 800 !important;
    border-left: 2px solid oklch(0.55 0.24 295 / 0.5) !important;
  }
}

/* ── 6. FAQ ACCORDION FIX — reliable max-height approach ── */
.faq-list-wide .faq-a {
  display: block !important;
  overflow: hidden !important;
  max-height: 0 !important;
  transition: max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.faq-list-wide .faq-item.open .faq-a {
  max-height: 500px !important;
  transition: max-height 0.5s ease-in-out !important;
}
.faq-list-wide .faq-a > div {
  overflow: visible !important;
  min-height: unset !important;
  padding: 12px 8px 28px !important;
}

/* ── 7. FOOTER — handled by .site-footer rules above ── */

/* ── 8. FINAL CTA MOBILE ── */
@media (max-width: 680px) {
  .final-cta-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    text-align: center !important;
  }
  /* Hide side nav columns on mobile — they duplicate the footer */
  .final-cta-grid .final-col { display: none !important; }
  /* Button div: full-width centered */
  .final-cta-grid > div:nth-child(2) {
    grid-column: 1 !important;
    order: 0 !important;
    padding-top: 0 !important;
    width: 100% !important;
  }
  .final-cta-grid > div:nth-child(2) a.btn-violet {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 18px 24px !important;
    text-align: center !important;
  }
}

/* =====================================================================
   BOOK PAGE — mobile grid fix
   ===================================================================== */
@media (max-width: 720px) {
  .book-grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
}

/* =====================================================================
   PROOF PAGE — mobile fixes
   ===================================================================== */

/* Video card zone height */
.proof-video-zone { height: 360px; }

/* Hero 3-col → 2-col → 1-col */
@media (max-width: 720px) {
  .proof-hero-grid { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .proof-hero-section { padding-top: 56px !important; padding-bottom: 36px !important; }
}
@media (max-width: 540px) {
  .proof-hero-grid { grid-template-columns: 1fr !important; }
  .proof-video-zone { height: 260px !important; }
  .proof-hero-section { padding-top: 40px !important; }
}

/* Results card grid — force 1-col below 640px */
@media (max-width: 640px) {
  .proof-results-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
}

/* Objection grid — prevent overflow on small screens */
@media (max-width: 640px) {
  .proof-objection-grid { grid-template-columns: 1fr !important; }
}

/* Scarcity closer — tighten padding on mobile */
@media (max-width: 640px) {
  .proof-scarcity-inner { padding: 28px 24px !important; flex-direction: column !important; align-items: flex-start !important; }
  .proof-scarcity-inner a { width: 100% !important; text-align: center !important; justify-content: center !important; }
}

/* Niche tabs label */
@media (max-width: 480px) {
  .proof-niche-label { font-size: 12px !important; }
}

/* =====================================================================
   NICHE PAGES — verified results table (clinics + ecom)
   ===================================================================== */
@media (max-width: 640px) {
  .proof-table-hdr { display: none !important; }
  .proof-table-row {
    grid-template-columns: 1fr 1fr !important;
    row-gap: 4px !important;
    padding: 14px 16px !important;
  }
  .proof-table-row > div:first-child { grid-column: 1 / -1; }
  .proof-table-row > div:nth-child(2) { font-size: 12px !important; }
  .proof-table-row > div:nth-child(3) { font-size: 12px !important; text-align: right; }
}

/* =====================================================================
   HOME-SERVICES — hero overflow fix
   ===================================================================== */
@media (max-width: 640px) {
  .hs-hero-section { overflow-x: hidden !important; }
  .hs-hero-section .hero-grid { max-width: 100% !important; overflow: hidden !important; }
}

/* =====================================================================
   AGENCIES PAGE — full mobile responsive
   ===================================================================== */
@media (max-width: 860px) {
  /* Nav: hide links on mobile */
  .ag-nav-links { display: none !important; }

  /* Hero: stack left/right columns */
  .ag-hero-wrap { flex-direction: column !important; gap: 40px !important; padding-top: 100px !important; padding-bottom: 60px !important; }
  .ag-hero-right { display: none !important; }

  /* Stats: 2 cols */
  .ag-stats-grid { grid-template-columns: 1fr 1fr !important; }
  .ag-stats-grid > div { border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.08) !important; }

  /* Villain: 1 col */
  .ag-villain-grid { grid-template-columns: 1fr !important; gap: 32px !important; }

  /* Three systems: 1 col */
  .ag-systems-grid { grid-template-columns: 1fr !important; }

  /* What you don't do: 1 col */
  .ag-wyntd-grid { grid-template-columns: 1fr !important; }

  /* Founder: 1 col */
  .ag-founder-grid { grid-template-columns: 1fr !important; gap: 40px !important; }

  /* Testimonials: 1 col */
  .ag-testimonials-grid { grid-template-columns: 1fr !important; }

  /* Comparison: 1 col */
  .ag-comparison-grid { grid-template-columns: 1fr !important; }

  /* ROI calc grid: 1 col */
  .ag-calc-grid { grid-template-columns: 1fr !important; }
}

/* =====================================================================
   PRICING PAGE — social proof toast mobile
   ===================================================================== */
@media (max-width: 480px) {
  .pricing-toast { max-width: 240px !important; bottom: 16px !important; left: 16px !important; }
}

/* =====================================================================
   CLINIC 2-COL — Guarantee + Founder grid
   ===================================================================== */
.clinic-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 860px) {
  .clinic-2col { grid-template-columns: 1fr; gap: 40px; }
}

/* =====================================================================
   CLINIC CASE STUDIES — light theme 3-col grid
   ===================================================================== */
.clinic-cases-grid {
  display: grid;
  grid-template-columns: 240px 1fr 240px;
  gap: 24px;
  align-items: start;
  max-width: 1240px;
  margin: 0 auto;
}
.clinic-cases-list { display: flex; flex-direction: column; gap: 4px; }
.cases-mobile-tabs { display: none; }

@media (max-width: 960px) {
  .clinic-cases-grid { grid-template-columns: 1fr; }
  .clinic-cases-list { display: none; }
  .clinic-cases-metric { order: -1; }
  .cases-mobile-tabs { display: flex !important; }
}

/* BigCaseCard */
.case-card-split {
  display: flex;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid var(--line-2);
  background: var(--bg);
  min-height: 460px;
  max-width: 1100px;
  margin: 0 auto;
}
.case-card-media {
  position: relative;
  flex: 0 0 42%;
  min-height: 460px;
  overflow: hidden;
}
.case-card-content {
  flex: 1;
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.case-niche-tabs {
  display: flex;
  gap: 8px;
  padding-bottom: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 700px) {
  .case-card-split { flex-direction: column; min-height: auto; }
  .case-card-media { height: 380px; min-height: 380px; flex: none; }
  .case-card-content { padding: 28px 24px; }
  .case-niche-tabs { flex-wrap: wrap; justify-content: center; overflow-x: auto; scrollbar-width: none; }
}

/* =====================================================================
   PROMISE CARD — guarantee section responsive
   ===================================================================== */
@media (max-width: 900px) {
  .promise-card { grid-template-columns: 1fr !important; padding: 40px 28px !important; border-radius: 24px !important; }
  .promise-left { display: none !important; }
}

/* MidCTA — desktop hidden, mobile only */
.midcta-mobile-only { display: none !important; }
@media (max-width: 700px) {
  .midcta-mobile-only { display: block !important; }
}

/* Trades grid — 2×2 on mobile */
@media (max-width: 700px) {
  .trades-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .trade-card { padding: 14px 12px !important; }
}
