/* cyrillic-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/3f49bd69-d8ae-49a8-9f64-d3e98744b78b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/1354c6c4-4612-43a7-9e2d-620259d6e307.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/f43bdec3-97fe-42bb-82d8-1eb0195b192d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/95607f42-1fc2-4008-a471-66c825316177.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/04286067-1a94-4691-8026-c076b600587b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/3f49bd69-d8ae-49a8-9f64-d3e98744b78b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/1354c6c4-4612-43a7-9e2d-620259d6e307.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/f43bdec3-97fe-42bb-82d8-1eb0195b192d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/95607f42-1fc2-4008-a471-66c825316177.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/04286067-1a94-4691-8026-c076b600587b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/3f49bd69-d8ae-49a8-9f64-d3e98744b78b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/1354c6c4-4612-43a7-9e2d-620259d6e307.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/f43bdec3-97fe-42bb-82d8-1eb0195b192d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/95607f42-1fc2-4008-a471-66c825316177.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/04286067-1a94-4691-8026-c076b600587b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/3f49bd69-d8ae-49a8-9f64-d3e98744b78b.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/1354c6c4-4612-43a7-9e2d-620259d6e307.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/f43bdec3-97fe-42bb-82d8-1eb0195b192d.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/95607f42-1fc2-4008-a471-66c825316177.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/04286067-1a94-4691-8026-c076b600587b.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 */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("assets/0688b28d-c46d-4834-9bad-76da850b3ce3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("assets/d04732b2-4845-47d8-913d-eb7aba7bf428.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: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("assets/4e1fe118-2701-4950-a2af-6d4cb1e1e57f.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: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("assets/78d1a42f-46f3-47ee-a457-f887ae107985.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 */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("assets/0688b28d-c46d-4834-9bad-76da850b3ce3.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("assets/d04732b2-4845-47d8-913d-eb7aba7bf428.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: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("assets/4e1fe118-2701-4950-a2af-6d4cb1e1e57f.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: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("assets/78d1a42f-46f3-47ee-a457-f887ae107985.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 */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/ba57ea77-b6ec-470d-b810-cf3be2401135.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/b105c7c6-d51f-4c0b-b90e-b13457192768.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: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/28d173b0-2476-49b5-9294-c49c75d9ee4b.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: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/b22b1218-7a18-4ede-8cc8-2eb708d73530.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 */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/ba57ea77-b6ec-470d-b810-cf3be2401135.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/b105c7c6-d51f-4c0b-b90e-b13457192768.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: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/28d173b0-2476-49b5-9294-c49c75d9ee4b.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: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/b22b1218-7a18-4ede-8cc8-2eb708d73530.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 */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("assets/ba57ea77-b6ec-470d-b810-cf3be2401135.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("assets/b105c7c6-d51f-4c0b-b90e-b13457192768.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: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("assets/28d173b0-2476-49b5-9294-c49c75d9ee4b.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: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("assets/b22b1218-7a18-4ede-8cc8-2eb708d73530.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


  :root {
    --bg: #52201d;
    --pink: #5BE2E6;
    --lime: #F1BF01;
    --cream: #FDF8EE;
    --purple: #3a1510;
    --dark2: #3d1a17;
    --glass: rgba(255,255,255,0.04);
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  html { scroll-behavior: smooth; }

  body {
    background: var(--bg);
    color: var(--cream);
    font-family: 'Playfair Display', serif;
    overflow-x: hidden;
  }

  .nav-logo-img { height: 36px; width: auto; display: block; mix-blend-mode: lighten; }

  /* NOISE */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
    opacity: 0.035;
    z-index: 9990;
    pointer-events: none;
  }

  /* NAV */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 40px;
    z-index: 100;
    backdrop-filter: blur(12px);
    background: rgba(82,32,29,0.7);
    border-bottom: 1px solid rgba(255,255,255,0.04);
  }
  .nav-logo {
    font-family: 'Oswald', sans-serif;
    font-weight: 900;
    font-size: 17px;
    letter-spacing: -0.5px;
    color: var(--cream);
  }
  .nav-logo span { color: var(--pink); }
  .nav-badge {
    background: var(--lime);
    color: #52201d;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 100px;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.5px;
  }

  /* HERO */
  .hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 140px 40px 80px;
    position: relative;
    overflow: hidden;
  }

  .hero-bg-blob {
    position: absolute;
    width: 600px; height: 600px;
    border-radius: 50%;
    filter: blur(120px);
    opacity: 0.18;
    pointer-events: none;
  }
  .blob1 { background: var(--pink); top: -100px; left: -100px; animation: blobMove 8s ease-in-out infinite alternate; }
  .blob2 { background: var(--purple); bottom: -200px; right: -50px; animation: blobMove 10s ease-in-out infinite alternate-reverse; }
  .blob3 { background: var(--lime); top: 40%; left: 40%; width: 300px; height: 300px; animation: blobMove 6s ease-in-out infinite alternate; }

  @keyframes blobMove {
    from { transform: translate(0, 0) scale(1); }
    to { transform: translate(40px, -30px) scale(1.1); }
  }

  .hero-tag {
    font-family: 'Playfair Display', serif;
    font-size: 20px;
    color: var(--lime);
    margin-bottom: 16px;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.2s forwards;
  }

  .hero-title {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(52px, 8vw, 110px);
    font-weight: 900;
    line-height: 0.95;
    letter-spacing: -3px;
    margin-bottom: 24px;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.4s forwards;
  }
  .hero-title .line2 {
    color: var(--pink);
    display: block;
    -webkit-text-stroke: 0px;
  }
  .hero-title .outline {
    -webkit-text-stroke: 2px var(--cream);
    color: transparent;
  }

  .hero-sub {
    font-size: 18px;
    color: rgba(253,248,238,0.6);
    max-width: 480px;
    line-height: 1.6;
    margin: 0 auto 48px;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.6s forwards;
    font-weight: 300;
  }

  .hero-cta-row {
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.8s forwards;
  }

  .btn-primary {
    background: var(--pink);
    color: white;
    font-family: 'Oswald', sans-serif;
    font-size: 13px;
    font-weight: 700;
    padding: 18px 36px;
    border: none;
    border-radius: 100px;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    letter-spacing: 0.3px;
    text-decoration: none;
    display: inline-block;
  }
  .btn-primary:hover {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 0 40px rgba(91,226,230,0.5);
  }

  .btn-ghost {
    background: transparent;
    color: var(--cream);
    font-family: 'Playfair Display', serif;
    font-size: 15px;
    font-weight: 500;
    padding: 18px 28px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 100px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    display: inline-block;
  }
  .btn-ghost:hover { border-color: var(--cream); background: rgba(255,255,255,0.05); }

  .hero-stats {
    position: absolute;
    bottom: 60px; right: 60px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    animation: fadeUp 0.8s ease 1s forwards;
  }
  .stat-item {
    font-family: 'Oswald', sans-serif;
    text-align: right;
  }
  .stat-num {
    font-size: 36px;
    font-weight: 900;
    color: var(--lime);
    line-height: 1;
  }
  .stat-label {
    font-size: 11px;
    color: rgba(253,248,238,0.4);
    font-family: 'Playfair Display', serif;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 1px;
  }

  /* HERO CAST — characters as centerpiece logo */
  .hero-cast {
    position: relative;
    width: min(680px, 92vw);
    height: 320px;
    margin: 0 auto 28px;
    opacity: 0;
    animation: fadeUp 1s ease 0.15s forwards;
  }
  .hero-cast .ch {
    position: absolute;
    bottom: 0;
    filter: drop-shadow(0 30px 40px rgba(0,0,0,0.5));
    transition: transform 0.4s ease;
  }
  .hero-cast .ch img { height: 100%; width: auto; display: block; }
  .hero-cast .ch.c1 { height: 240px; left: 2%;  transform: rotate(-6deg); z-index: 1; animation: bob 5s ease-in-out infinite; }
  .hero-cast .ch.c2 { height: 300px; left: 25%; z-index: 3; animation: bob 5s ease-in-out 0.4s infinite reverse; }
  .hero-cast .ch.c3 { height: 280px; left: 50%; transform: rotate(3deg); z-index: 2; animation: bob 5.5s ease-in-out 0.8s infinite; }
  .hero-cast .ch.c4 { height: 230px; right: 2%; transform: rotate(7deg); z-index: 1; animation: bob 6s ease-in-out 0.2s infinite reverse; }
  .hero-cast .ch:hover { transform: translateY(-12px) scale(1.04) rotate(0deg); z-index: 10; }
  @keyframes bob {
    0%, 100% { transform: translateY(0) rotate(var(--r, 0deg)); }
    50% { transform: translateY(-14px) rotate(var(--r, 0deg)); }
  }
  .hero-cast .ch.c1 { --r: -6deg; }
  .hero-cast .ch.c3 { --r: 3deg; }
  .hero-cast .ch.c4 { --r: 7deg; }

  /* HERO LOGO MARK */
  .hero-logomark {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin: 0 auto 8px;
    opacity: 0;
    animation: fadeUp 0.8s ease 0.3s forwards;
  }
  .hero-logomark .pill {
    font-family: 'Oswald', sans-serif;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--lime);
    border: 1px solid rgba(241,191,1,0.35);
    background: rgba(241,191,1,0.06);
    padding: 6px 14px;
    border-radius: 100px;
  }

  /* FLOATING EMOJIS */
  .float-em {
    position: absolute;
    font-size: 40px;
    animation: floatY 4s ease-in-out infinite;
    pointer-events: none;
    opacity: 0.6;
  }
  .fe1  { top: 18%;  right: 14%; animation-delay: 0s;    font-size: 44px; }
  .fe2  { top: 58%;  right: 6%;  animation-delay: 1.5s;  font-size: 30px; }
  .fe3  { top: 32%;  right: 24%; animation-delay: 0.7s;  font-size: 24px; }
  .fe4  { top: 14%;  left: 10%;  animation-delay: 0.3s;  font-size: 36px; }
  .fe5  { top: 48%;  left: 5%;   animation-delay: 1.1s;  font-size: 28px; }
  .fe6  { top: 72%;  left: 18%;  animation-delay: 0.5s;  font-size: 32px; }
  .fe7  { top: 26%;  left: 38%;  animation-delay: 2s;    font-size: 22px; }
  .fe8  { top: 78%;  right: 22%; animation-delay: 0.9s;  font-size: 26px; }
  .fe9  { top: 8%;   right: 38%; animation-delay: 1.7s;  font-size: 20px; }
  .fe10 { top: 64%;  right: 32%; animation-delay: 0.2s;  font-size: 24px; }
  .fe11 { top: 42%;  right: 38%; animation-delay: 1.3s;  font-size: 18px; }
  .fe12 { top: 88%;  left: 42%;  animation-delay: 0.6s;  font-size: 28px; }
  .fe13 { top: 12%;  left: 28%;  animation-delay: 2.2s;  font-size: 22px; }
  .fe14 { top: 86%;  left: 6%;   animation-delay: 1.8s;  font-size: 30px; }

  @keyframes floatY {
    0%, 100% { transform: translateY(0) rotate(-5deg); }
    50% { transform: translateY(-20px) rotate(5deg); }
  }

  /* SECTION DIVIDER */
  .section-label {
    font-family: 'Playfair Display', serif;
    font-size: 18px;
    color: var(--lime);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(241,191,1,0.2);
    max-width: 80px;
  }

  /* PROFILES SECTION */
  .profiles-section {
    padding: 80px 40px 120px;
  }
  .profiles-header {
    max-width: 600px;
    margin-bottom: 64px;
  }
  .profiles-title {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(36px, 5vw, 60px);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -2px;
    margin-bottom: 16px;
  }
  .profiles-subtitle {
    font-size: 16px;
    color: rgba(253,248,238,0.5);
    font-weight: 300;
    line-height: 1.6;
  }

  .cards-scroll {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    max-width: 1400px;
  }

  .profile-card {
    background: var(--dark2);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 24px;
    padding: 28px;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
    group: true;
  }
  .profile-card::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.3s ease;
    border-radius: inherit;
  }

  .card-fela::before { background: radial-gradient(circle at 80% 0%, rgba(34,197,94,0.12), transparent 60%); }
  .card-kasia::before { background: radial-gradient(circle at 80% 0%, rgba(251,146,60,0.12), transparent 60%); }
  .card-jagoda::before { background: radial-gradient(circle at 80% 0%, rgba(192,38,211,0.12), transparent 60%); }
  .card-jerzy::before { background: radial-gradient(circle at 80% 0%, rgba(239,68,68,0.12), transparent 60%); }
  .card-stefan::before { background: radial-gradient(circle at 80% 0%, rgba(249,115,22,0.16), transparent 60%); }

  .profile-card:hover::before { opacity: 1; }
  .profile-card:hover {
    transform: translateY(-6px);
    border-color: rgba(255,255,255,0.15);
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  }

  .card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
  }

  .card-avatar {
    width: 84px; height: 84px;
    border-radius: 22px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    font-size: 36px;
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
  }
  .card-avatar img {
    width: 130%;
    height: 130%;
    object-fit: cover;
    object-position: center top;
    position: absolute;
    top: -8%;
    left: 50%;
    transform: translateX(-50%);
  }
  .av-fela { background: radial-gradient(circle at 50% 30%, #1e4d2b, #0f2415); }
  .av-kasia { background: radial-gradient(circle at 50% 30%, #7c2d12, #2a0f06); }
  .av-jagoda { background: radial-gradient(circle at 50% 30%, #581c87, #1f0830); }
  .av-jerzy { background: radial-gradient(circle at 50% 30%, #7f1d1d, #2a0606); }
  .av-stefan { background: radial-gradient(circle at 50% 30%, #9a3412, #2a0e06); }

  .card-badge {
    font-size: 11px;
    font-weight: 700;
    padding: 5px 12px;
    border-radius: 100px;
    font-family: 'Oswald', sans-serif;
    letter-spacing: 0.3px;
  }
  .badge-online { background: rgba(34,197,94,0.15); color: #4ade80; border: 1px solid rgba(34,197,94,0.25); }
  .badge-popular { background: rgba(91,226,230,0.15); color: #5BE2E6; border: 1px solid rgba(91,226,230,0.25); }
  .badge-new { background: rgba(241,191,1,0.15); color: var(--lime); border: 1px solid rgba(241,191,1,0.25); }
  .badge-classic { background: rgba(251,146,60,0.15); color: #fb923c; border: 1px solid rgba(251,146,60,0.25); }
  .badge-rare { background: rgba(120,113,108,0.15); color: #a8a29e; border: 1px solid rgba(120,113,108,0.25); }

  .card-name {
    font-family: 'Oswald', sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.5px;
    margin-bottom: 4px;
    line-height: 1.1;
  }
  .card-age {
    font-size: 13px;
    color: rgba(253,248,238,0.4);
    font-weight: 300;
    margin-bottom: 14px;
  }
  .card-desc {
    font-size: 14px;
    line-height: 1.65;
    color: rgba(253,248,238,0.65);
    font-weight: 300;
    margin-bottom: 20px;
  }

  .card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 24px;
  }
  .tag {
    font-size: 11px;
    font-weight: 500;
    padding: 4px 10px;
    border-radius: 6px;
    background: rgba(255,255,255,0.06);
    color: rgba(253,248,238,0.6);
    border: 1px solid rgba(255,255,255,0.06);
  }

  .card-series {
    margin-top: 4px;
    margin-bottom: 18px;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
  }
  .series-label {
    font-family: 'Oswald', sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--lime);
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .series-label::before {
    content: '';
    width: 14px;
    height: 1px;
    background: var(--lime);
    opacity: 0.7;
  }
  .series-name {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-size: 14px;
    color: var(--cream);
    margin-bottom: 8px;
    letter-spacing: 0.2px;
  }
  .series-flavors {
    font-size: 11.5px;
    color: rgba(253,248,238,0.55);
    line-height: 1.55;
  }
  .series-flavors strong {
    color: rgba(253,248,238,0.85);
    font-weight: 500;
  }

  .card-actions {
    display: flex;
    gap: 10px;
  }
  .btn-match {
    flex: 1;
    background: var(--pink);
    color: white;
    border: none;
    border-radius: 12px;
    padding: 13px;
    font-family: 'Oswald', sans-serif;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s ease;
    letter-spacing: 0.3px;
  }
  .btn-match:hover { filter: brightness(1.15); transform: scale(1.02); }

  .btn-save {
    width: 46px; height: 46px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 18px;
  }
  .btn-save:hover { background: rgba(255,255,255,0.12); transform: scale(1.1); }

  .card-match-bar {
    margin-bottom: 18px;
  }
  .match-label {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    margin-bottom: 6px;
    color: rgba(253,248,238,0.4);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.8px;
  }
  .match-pct { color: var(--lime); font-weight: 700; font-family: 'Oswald', sans-serif; font-size: 12px; }
  .match-track {
    height: 3px;
    background: rgba(255,255,255,0.08);
    border-radius: 100px;
    overflow: hidden;
  }
  .match-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--pink), var(--lime));
    border-radius: 100px;
    transition: width 1s ease;
  }

  /* QUIZ SECTION */
  .quiz-section {
    padding: 80px 40px;
    background: var(--dark2);
    border-top: 1px solid rgba(255,255,255,0.05);
    border-bottom: 1px solid rgba(255,255,255,0.05);
  }
  .quiz-inner {
    max-width: 640px;
    margin: 0 auto;
    text-align: center;
  }
  .quiz-title {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(32px, 5vw, 52px);
    font-weight: 900;
    letter-spacing: -2px;
    line-height: 1.0;
    margin-bottom: 16px;
  }
  .quiz-title em { font-style: normal; color: var(--pink); }
  .quiz-sub {
    font-size: 16px;
    color: rgba(253,248,238,0.5);
    font-weight: 300;
    margin-bottom: 48px;
    line-height: 1.6;
  }

  .quiz-box {
    background: var(--bg);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 24px;
    padding: 36px;
    text-align: left;
  }
  .quiz-q {
    font-family: 'Oswald', sans-serif;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 8px;
    color: var(--lime);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
  }
  .quiz-question {
    font-size: 20px;
    font-weight: 500;
    margin-bottom: 28px;
    line-height: 1.4;
  }
  .quiz-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 28px;
  }
  .quiz-option {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 15px;
    color: rgba(253,248,238,0.7);
    user-select: none;
  }
  .quiz-option:hover {
    border-color: rgba(91,226,230,0.4);
    background: rgba(91,226,230,0.06);
    color: var(--cream);
  }
  .quiz-option.selected {
    border-color: var(--pink);
    background: rgba(91,226,230,0.1);
    color: var(--cream);
  }
  .option-dot {
    width: 20px; height: 20px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.2);
    flex-shrink: 0;
    transition: all 0.2s ease;
    display: flex; align-items: center; justify-content: center;
  }
  .quiz-option.selected .option-dot {
    background: var(--pink);
    border-color: var(--pink);
  }
  .quiz-option.selected .option-dot::after {
    content: '✓';
    font-size: 11px;
    color: white;
    font-weight: 700;
  }

  .quiz-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .quiz-progress {
    font-size: 13px;
    color: rgba(253,248,238,0.3);
    font-family: 'Oswald', sans-serif;
    font-size: 11px;
  }
  .btn-quiz-next {
    background: var(--lime);
    color: #52201d;
    border: none;
    border-radius: 100px;
    padding: 13px 28px;
    font-family: 'Oswald', sans-serif;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s ease;
    letter-spacing: 0.3px;
  }
  .btn-quiz-next:hover { transform: scale(1.05); box-shadow: 0 0 30px rgba(241,191,1,0.3); }

  /* RESULT CARD */
  .quiz-result {
    display: none;
    text-align: center;
  }
  .result-emoji { font-size: 72px; margin-bottom: 16px; animation: popIn 0.5s cubic-bezier(0.34, 1.56, 0.64, 1); }
  .result-title {
    font-family: 'Oswald', sans-serif;
    font-size: 28px;
    font-weight: 900;
    letter-spacing: -1px;
    margin-bottom: 8px;
  }
  .result-sub {
    font-size: 15px;
    color: rgba(253,248,238,0.6);
    margin-bottom: 28px;
    font-weight: 300;
    line-height: 1.6;
  }
  .result-vibe {
    display: inline-block;
    background: rgba(91,226,230,0.15);
    border: 1px solid rgba(91,226,230,0.3);
    color: var(--pink);
    padding: 8px 20px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 28px;
    font-family: 'Oswald', sans-serif;
    font-size: 11px;
    letter-spacing: 0.5px;
  }

  @keyframes popIn {
    from { transform: scale(0) rotate(-10deg); }
    to { transform: scale(1) rotate(0); }
  }

  /* MARQUEE */
  .marquee-section {
    padding: 40px 0;
    overflow: hidden;
    border-top: 1px solid rgba(255,255,255,0.05);
  }
  .marquee-track {
    display: flex;
    gap: 0;
    width: max-content;
    will-change: transform;
  }
  .marquee-item {
    white-space: nowrap;
    padding: 0 32px;
    font-family: 'Oswald', sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: rgba(253,248,238,0.25);
    display: flex;
    align-items: center;
    gap: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  .marquee-dot { color: var(--pink); font-size: 20px; }

  /* FOOTER CTA */
  .footer-cta {
    padding: 120px 40px;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .footer-cta-blob {
    position: absolute;
    width: 500px; height: 500px;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.12;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    background: var(--pink);
    animation: blobMove 6s ease-in-out infinite alternate;
  }
  .footer-eyebrow {
    font-family: 'Playfair Display', serif;
    font-size: 22px;
    color: var(--lime);
    margin-bottom: 20px;
  }
  .footer-title {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(40px, 7vw, 90px);
    font-weight: 900;
    letter-spacing: -3px;
    line-height: 0.95;
    margin-bottom: 32px;
  }
  .footer-title .outline { -webkit-text-stroke: 2px var(--cream); color: transparent; }
  .footer-sub {
    font-size: 16px;
    color: rgba(253,248,238,0.5);
    margin-bottom: 48px;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
    font-weight: 300;
    line-height: 1.6;
  }
  .footer-note {
    font-size: 12px;
    color: rgba(253,248,238,0.2);
    margin-top: 24px;
    font-style: italic;
  }
  .footer-bottom {
    margin-top: 80px;
    padding-top: 32px;
    border-top: 1px solid rgba(255,255,255,0.05);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    color: rgba(253,248,238,0.2);
  }

  /* ANIMATIONS */
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  }
  .reveal.visible {
    opacity: 1;
    transform: translateY(0);
  }

  /* SCROLLBAR */
  ::-webkit-scrollbar { width: 4px; }
  ::-webkit-scrollbar-track { background: var(--bg); }
  ::-webkit-scrollbar-thumb { background: var(--pink); border-radius: 100px; }

  /* ─── MOBILE ─────────────────────────────────────── */
  @media (max-width: 768px) {


    nav { padding: 14px 20px; }
    .nav-logo { font-size: 14px; }
    .nav-badge { font-size: 10px; padding: 3px 10px; }

    .hero {
      padding: 110px 20px 64px;
      min-height: 100svh;
    }
    .hero-title {
      font-size: clamp(44px, 13vw, 72px);
      letter-spacing: -2px;
      margin-bottom: 20px;
    }
    .hero-title .outline { -webkit-text-stroke: 1.5px var(--cream); }
    .hero-sub { font-size: 15px; margin-bottom: 36px; }
    .hero-cta-row { flex-direction: column; align-items: stretch; }
    .btn-primary, .btn-ghost { text-align: center; padding: 17px 24px; font-size: 13px; }
    .hero-stats { display: none; }
    .hero-cast { height: 220px; margin-bottom: 18px; }
    .hero-cast .ch.c1 { height: 160px; }
    .hero-cast .ch.c2 { height: 200px; }
    .hero-cast .ch.c3 { height: 188px; }
    .hero-cast .ch.c4 { height: 154px; }
    .float-em { display: none; }
    .blob1, .blob2, .blob3 { opacity: 0.1; }

    .marquee-item { font-size: 11px; padding: 0 20px; }

    .profiles-section { padding: 56px 0 80px; }
    .profiles-header { padding: 0 20px; margin-bottom: 40px; }
    .profiles-title { font-size: clamp(30px, 9vw, 44px); letter-spacing: -1.5px; }
    .profiles-subtitle { font-size: 14px; }

    /* KARTY — poziomy scroll ze snap */
    .cards-scroll {
      display: flex;
      flex-direction: row;
      overflow-x: auto;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      gap: 14px;
      padding: 8px 20px 24px;
      scrollbar-width: none;
      grid-template-columns: unset;
    }
    .cards-scroll::-webkit-scrollbar { display: none; }

    .profile-card {
      min-width: 82vw;
      max-width: 340px;
      flex-shrink: 0;
      scroll-snap-align: center;
      border-radius: 28px;
      padding: 24px;
    }
    .profile-card:last-child { margin-right: 20px; }
    .card-avatar { width: 56px; height: 56px; border-radius: 16px; font-size: 30px; }
    .card-name { font-size: 18px; }
    .card-desc { font-size: 13px; }

    .btn-match { padding: 15px; font-size: 12px; cursor: pointer; border-radius: 14px; }
    .btn-save { cursor: pointer; width: 50px; height: 50px; border-radius: 14px; }

    /* DOTS INDIKATOR */
    .scroll-dots {
      display: flex !important;
      justify-content: center;
      gap: 6px;
      padding: 4px 20px 20px;
    }
    .scroll-dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: rgba(255,255,255,0.15);
      transition: all 0.3s ease;
      flex-shrink: 0;
    }
    .scroll-dot.active {
      background: var(--pink);
      width: 20px;
      border-radius: 100px;
    }

    .quiz-section { padding: 56px 20px 64px; }
    .quiz-title { font-size: clamp(28px, 8vw, 44px); letter-spacing: -1.5px; }
    .quiz-sub { font-size: 14px; margin-bottom: 36px; }
    .quiz-box { padding: 24px 20px; border-radius: 20px; }
    .quiz-question { font-size: 17px; }
    .quiz-option { padding: 13px 16px; font-size: 14px; gap: 12px; border-radius: 12px; cursor: pointer; }
    .btn-quiz-next { padding: 13px 24px; cursor: pointer; }
    .result-emoji { font-size: 60px; }
    .result-title { font-size: 22px; }
    .result-sub { font-size: 14px; }

    .footer-cta { padding: 80px 20px 60px; }
    .footer-title { font-size: clamp(36px, 11vw, 60px); letter-spacing: -2px; }
    .footer-title .outline { -webkit-text-stroke: 1.5px var(--cream); }
    .footer-sub { font-size: 14px; margin-bottom: 36px; }
    .footer-bottom { flex-direction: column; gap: 10px; text-align: center; margin-top: 56px; }
    .btn-primary { padding: 18px 36px; }
    .section-label { font-size: 16px; }
  }

  /* SERIES SECTION */
  .series-section {
    padding: 100px 40px 120px;
    background:
      radial-gradient(ellipse 60% 40% at 80% 0%, rgba(255,107,143,0.05), transparent 60%),
      radial-gradient(ellipse 60% 40% at 0% 100%, rgba(184,255,77,0.04), transparent 60%);
  }
  .series-inner {
    max-width: 1200px;
    margin: 0 auto;
  }
  .series-section-header {
    text-align: center;
    margin-bottom: 80px;
  }
  .series-section-header .section-label {
    justify-content: center;
  }
  .series-section-title {
    font-family: 'Oswald', sans-serif;
    font-size: clamp(36px, 5vw, 60px);
    font-weight: 900;
    letter-spacing: -2px;
    text-transform: uppercase;
    margin-bottom: 16px;
    line-height: 1;
  }
  .series-section-title em {
    color: var(--pink);
    font-style: italic;
    font-family: 'Playfair Display', serif;
    font-weight: 400;
    text-transform: none;
    letter-spacing: -1px;
  }
  .series-section-sub {
    font-size: 16px;
    color: rgba(253,248,238,0.5);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.5;
  }

  .series-block {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 40px;
    padding: 48px 0;
    border-top: 1px solid rgba(255,255,255,0.07);
    align-items: start;
  }
  .series-block:last-child { border-bottom: 1px solid rgba(255,255,255,0.07); }

  .series-head {
    position: sticky;
    top: 100px;
  }
  .series-number {
    font-family: 'Oswald', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    color: rgba(253,248,238,0.4);
    margin-bottom: 12px;
  }
  .series-head h3 {
    font-family: 'Oswald', sans-serif;
    font-size: 44px;
    font-weight: 900;
    letter-spacing: -1.5px;
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .series-head .accent-bar {
    display: inline-block;
    width: 44px;
    height: 4px;
    border-radius: 2px;
    margin-bottom: 18px;
  }
  .series-head p {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-size: 17px;
    color: rgba(253,248,238,0.65);
    line-height: 1.5;
  }

  .series-fit .series-head h3 em { color: #4ade80;}
  .series-fit .accent-bar { color: #4ade80; background: #4ade80; }
  .series-sweet .series-head h3 em { color: #f0abfc;}
  .series-sweet .accent-bar { color: #f0abfc; background: #f0abfc; }
  .series-klasyka .series-head h3 em { color: #fca5a5;}
  .series-klasyka .accent-bar { color: #fca5a5; background: #fca5a5; }
  .series-street .series-head h3 em { color: #fdba74;}
  .series-street .accent-bar { color: #fdba74; background: #fdba74; }
  .series-head h3 em {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    text-transform: none;
    letter-spacing: -1px;
    display: block;
    font-size: 0.7em;
    margin-top: 4px;
  }

  .flavors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 16px;
  }
  .flavor-card {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px;
    padding: 0 0 22px;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
  }
  .flavor-thumb {
    width: 100%;
    aspect-ratio: 4 / 3;
    background: var(--thumb-bg, radial-gradient(circle at 50% 35%, #3a1815, #1a0a08));
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .flavor-thumb img {
    max-height: 88%;
    max-width: 78%;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(0,0,0,0.4));
  }
  .flavor-thumb .icon-emoji {
    font-size: 60px;
    filter: drop-shadow(0 6px 14px rgba(0,0,0,0.45));
  }
  .flavor-thumb .corner-tag {
    position: absolute;
    top: 10px; left: 10px;
    font-family: 'Oswald', sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: rgba(253,248,238,0.7);
    background: rgba(0,0,0,0.35);
    backdrop-filter: blur(8px);
    padding: 4px 8px;
    border-radius: 6px;
    text-transform: uppercase;
  }
  .flavor-body {
    padding: 18px 20px 0;
  }
  .flavor-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 2px;
    background: var(--accent, var(--pink));
    opacity: 0;
    transition: opacity 0.3s ease;
  }
  .flavor-card:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.12);
  }
  .flavor-card:hover::before { opacity: 1; }
  .flavor-card.is-hero {
    background: rgba(255,107,143,0.06);
    border-color: rgba(255,107,143,0.25);
  }
  .flavor-card.is-hero::before { opacity: 1; }
  .flavor-card.is-hero .flavor-meta { color: var(--pink); }

  .flavor-meta {
    font-family: 'Oswald', sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: rgba(253,248,238,0.4);
    text-transform: uppercase;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .flavor-name {
    font-family: 'Oswald', sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.3px;
    line-height: 1.1;
    margin-bottom: 8px;
  }
  .flavor-desc {
    font-size: 13px;
    color: rgba(253,248,238,0.55);
    line-height: 1.5;
  }

  @media (max-width: 900px) {
    .series-section { padding: 64px 20px 80px; }
    .series-section-header { margin-bottom: 48px; }
    .series-block {
      grid-template-columns: 1fr;
      gap: 24px;
      padding: 36px 0;
    }
    .series-head { position: static; }
    .series-head h3 { font-size: 32px; }
    .flavors-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
    .flavor-card { padding: 18px; }
    .flavor-name { font-size: 17px; }
  }

  @media (max-width: 380px) {
    .hero-title { font-size: 40px; }
    .profile-card { min-width: 88vw; }
  }

