/* personalny.eu - css v1.0.0 */

/* global */

:root {
    /* brand colors */
    --brand-01: #0914d8;
    --brand-02: #044bd9;
    --brand-03: #0460d9;
    --low-emphasis-1: #a1b4ff;
    --low-emphasis-2: #d5ddff;
    --low-emphasis-3: #e6ecff;

    /* blacks */
    --black: #000000;
    --gray-1: #1c1c1c;
    --gray-2: #3b3b3b;
    --gray-3: #616161;
    --gray-4: #929292;
    --gray-5: #d3d3d2;
    --off-white-0: #efefef;
    --off-white-1: #eeeeee;
    --off-white-2: #f8f8f8;
    --off-white-blue: #f6f7fb;
    --white: #ffffff;

    /* accents */
    --success: #3fc084;
    --error: #ee5959;
    --info: #53a0fe;
    --warning: #f9805b;

    /* accents low opacity */
    --success-10: rgba(63, 192, 132, 0.1);
    --error-10: rgba(238, 89, 89, 0.1);
    --info-10: rgba(83, 160, 254, 0.1);
    --warning-10: rgba(249, 128, 91, 0.1);

    /* promotion */
    --promotion-green: #aff5a9;

    /* gradients */
    --brand-gradient: linear-gradient(
        55deg,
        hsl(220deg 72% 83%) 0%,
        hsl(220deg 72% 84%) 1%,
        hsl(220deg 71% 85%) 2%,
        hsl(220deg 71% 86%) 3%,
        hsl(220deg 70% 87%) 4%,
        hsl(220deg 69% 88%) 6%,
        hsl(221deg 69% 89%) 8%,
        hsl(221deg 67% 90%) 11%,
        hsl(221deg 66% 91%) 14%,
        hsl(221deg 65% 92%) 18%,
        hsl(220deg 63% 93%) 23%,
        hsl(220deg 62% 93%) 31%,
        hsl(220deg 59% 94%) 42%,
        hsl(220deg 56% 95%) 56%,
        hsl(220deg 50% 96%) 67%,
        hsl(220deg 42% 97%) 74%,
        hsl(220deg 27% 98%) 79%,
        hsl(220deg 52% 96%) 84%,
        hsl(220deg 61% 94%) 87%,
        hsl(220deg 65% 92%) 90%,
        hsl(220deg 68% 90%) 93%,
        hsl(220deg 70% 89%) 95%,
        hsl(220deg 71% 87%) 97%,
        hsl(220deg 72% 85%) 98%,
        hsl(220deg 72% 83%) 100%
    );
    --bg-overlay: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.5) 100%
    );
    --gradient-pro: linear-gradient(
        160deg,
        var(--brand-02) 0%,
        #457ff3 15%,
        var(--brand-02) 30%
    );

    /* hovers (30% darker main colors */
    --hover-brand-01: #060e97;
    --hover-brand-02: #033498;
    --hover-brand-03: #034398;
    --hover-low-emphasis-1: #2450ff;
    --hover-low-emphasis-2: #c1c9ff;
    --hover-low-emphasis-3: #dbe1ff;

    --hover-off-white-blue: #e1e3ea;

    --scrollbar-width: 0px;
}

/* typography */

@font-face {
    font-family: "personalny-font";
    src: url("/assets/fonts/Personalny/personalny-font.eot");
    src:
        url("/assets/fonts/Personalny/personalny-font.eot?#iefix")
            format("embedded-opentype"),
        url("/assets/fonts/Personalny/personalny-font.woff2") format("woff2"),
        url("/assets/fonts/Personalny/personalny-font.woff") format("woff"),
        url("/assets/fonts/Personalny/personalny-font.ttf") format("truetype"),
        url("/assets/fonts/Personalny/personalny-font.svg#personalny-font")
            format("svg");
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

/* poppins-100 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 100;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-100italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 100;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-100italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-200 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 200;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-200italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 200;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-200italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-300 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 300;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-300italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 300;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-300italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-regular - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 400;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-regular.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 400;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-500 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 500;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-500italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 500;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-500italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-600 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 600;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-600italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 600;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-600italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-700 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 700;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-700italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 700;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-700italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-800 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 800;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-800italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 800;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-800italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-900 - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: normal;
    font-weight: 900;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900.svg#Poppins")
            format("svg"); /* Legacy iOS */
}
/* poppins-900italic - latin_latin-ext */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: "Poppins";
    font-style: italic;
    font-weight: 900;
    src: url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.eot"); /* IE9 Compat Modes */
    src:
        url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.eot?#iefix")
            format("embedded-opentype"),
        /* IE6-IE8 */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.woff2")
            format("woff2"),
        /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.woff")
            format("woff"),
        /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.ttf")
            format("truetype"),
        /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
            url("/assets/fonts/Poppins/poppins-v24-latin_latin-ext-900italic.svg#Poppins")
            format("svg"); /* Legacy iOS */
}

body,
html {
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: var(--gray-3);
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-style: normal;
}

.z-1 {
    z-index: 1;
    position: relative;
}

.p-mobile-only {
    display: none !important;
}

.p-desktop-only {
    display: block !important;
}

/* link cleaner */
a {
    color: inherit;
    text-decoration: none;
    font-weight: inherit;
    line-height: inherit;
    transition: all 0.3s ease;
}

h1,
.t-size-h1 {
    font-weight: 600;
    font-size: 56px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

h2,
.t-size-h2 {
    font-weight: 600;
    font-size: 48px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

h3,
.t-size-h3 {
    font-weight: 600;
    font-size: 36px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

h4,
.t-size-h4 {
    font-weight: 600;
    font-size: 24px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

h5,
.t-size-h5 {
    font-weight: 600;
    font-size: 17px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

h6,
.t-size-h6 {
    font-weight: 600;
    font-size: 17px;
    line-height: 1.2em;
    letter-spacing: -0.02em;
    color: var(--gray-1);
}

p,
.t-body {
    font-weight: 400;
    font-size: 16px;
    color: var(--gray-2);
    line-height: 1.5em;
}

p a {
    color: var(--brand-02);
    text-decoration: none;
}

b,
strong,
.t-bold {
    font-weight: 600;
}

.t-bigger {
    font-weight: 400;
    font-size: 17px;
    color: var(--gray-2);
    line-height: 1.3em;
}

.t-bigger-bold {
    font-weight: 600;
    font-size: 17px;
    color: var(--gray-2);
    line-height: 1.3em;
}

.t-caption {
    font-weight: 400;
    font-size: 14px;
    color: var(--gray-3);
    line-height: 1.3em;
}

.t-caption-bold {
    font-weight: 600;
    font-size: 14px;
    color: var(--gray-4);
    line-height: 1.3em;
}

.t-small {
    font-weight: 400;
    font-size: 12px;
    color: var(--gray-4);
    line-height: 1.2em;
}

.t-center {
    text-align: center;
}

/* screen-reader */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* colors */
.c-brand-01 {
    color: var(--brand-01);
}

.c-brand-02 {
    color: var(--brand-02);
}

.c-brand-03 {
    color: var(--brand-03);
}

.c-gray-1 {
    color: var(--gray-1);
}

.c-gray-2 {
    color: var(--gray-2);
}

.c-gray-3 {
    color: var(--gray-3);
}

.c-gray-4 {
    color: var(--gray-4);
}

.c-gray-5 {
    color: var(--gray-5);
}

.c-white {
    color: var(--white);
}

.c-low-emphasis-1 {
    color: var(--low-emphasis-1);
}

.c-low-emphasis-2 {
    color: var(--low-emphasis-2);
}

.c-success {
    color: var(--success);
}

.c-error {
    color: var(--error);
}

.c-info {
    color: var(--info);
}

.c-warning {
    color: var(--warning);
}

/* effects */
.p-border-shine {
    position: relative;
    border: 1px solid transparent;
}

.p-border-shine::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    padding: 1px;
    background: conic-gradient(
        from var(--gradient-angle),
        transparent 0deg,
        transparent 70deg,
        var(--low-emphasis-2) 85deg,
        var(--brand-01) 100deg,
        var(--low-emphasis-2) 115deg,
        transparent 130deg,
        transparent 360deg
    );
    -webkit-mask:
        linear-gradient(var(--white) 0 0) content-box,
        linear-gradient(var(--white) 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(var(--white) 0 0) content-box,
        linear-gradient(var(--white) 0 0);
    mask-composite: exclude;
    pointer-events: none;
    animation: border-shine-rotate 3s linear infinite;
    transition: background 800ms ease-out;
}

.p-border-shine:hover::before {
    background: conic-gradient(
        from var(--gradient-angle),
        var(--low-emphasis-1) 0deg,
        var(--brand-01) 30deg,
        var(--brand-02) 180deg,
        var(--brand-01) 330deg,
        var(--low-emphasis-1) 360deg
    );
}

@keyframes border-shine-rotate {
    0% {
        --gradient-angle: 0deg;
    }
    25% {
        --gradient-angle: 120deg;
    }
    50% {
        --gradient-angle: 180deg;
    }
    75% {
        --gradient-angle: 300deg;
    }
    100% {
        --gradient-angle: 360deg;
    }
}

@property --gradient-angle {
    syntax: "<angle>";
    initial-value: 0deg;
    inherits: false;
}

/* buttons */
button {
    appearance: none;
    -webkit-appearance: none;
    border-radius: 0;
    text-align: inherit;
    background: none;
    box-shadow: none;
    padding: 0;
    cursor: pointer;
    border: none;
    color: inherit;
    font: inherit;
}

.p-button {
    height: 54px;
    padding: 12px 32px;
    border-radius: 64px;
    display: inline-flex;
    background: var(--brand-02);
    color: var(--white);
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid transparent;
    line-height: 1;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
    white-space: nowrap;
}
.p-button:hover {
    background: var(--hover-brand-02);
}

.p-button-brand {
    background: var(--brand-01);
}
.p-button-brand:hover {
    background: var(--hover-brand-01);
}

.p-button-secondary {
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    color: var(--brand-02);
}
.p-button-secondary:hover {
    background: var(--white);
    border-color: var(--brand-02);
}

.p-button-tertiary {
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    color: var(--gray-1);
    font-size: 14px;
    font-weight: 400;
}
.p-button-tertiary:hover {
    background: var(--white);
    border-color: var(--brand-02);
}

.p-button-tertiary-blue {
    background: var(--brand-02);
    border: 1px solid var(--brand-02);
    color: var(--white);
    font-size: 14px;
    font-weight: 400;
}
.p-button-tertiary-blue:hover {
    background: var(--hover-brand-02);
    border-color: var(--hover-brand-02);
}

.p-button-tertiary-blue .p-icon {
    fill: var(--low-emphasis-1);
}

.p-button-off-white-2 {
    background: var(--off-white-2);
    color: var(--gray-1);
}
.p-button-off-white-2:hover {
    background: var(--off-white-0);
}

.p-button-white {
    background: var(--white);
    color: var(--gray-1);
}
.p-button-white:hover {
    background: var(--off-white-2);
}

.p-button-white-outline {
    background: transparent;
    border: 1px solid var(--white);
    color: var(--white);
}
.p-button-white-outline:hover {
    background: var(--white);
    color: var(--gray-1);
}
.p-button-white-outline:hover .p-icon {
    fill: var(--gray-1);
}

.p-button-small {
    padding: 8px 16px;
    font-size: 14px;
}

.p-button-glow {
    background: linear-gradient(
        98deg,
        var(--brand-01) 20%,
        var(--brand-02) 50%,
        var(--brand-01) 80%
    );
}

.p-button-active-plan {
    background: rgba(63, 192, 132, 0.1);
    border: rgba(63, 192, 132, 0.11);
    color: var(--success);
}

.p-active-symbol {
    width: 10px;
    height: 10px;
    background: var(--success);
    border-radius: 50%;
    display: inline-block;
}

.p-button-rounded {
    border-radius: 64px;
}

.p-button-text-small {
    color: var(--brand-03);
    font-size: 14px;
    line-height: 1em;
}

.p-button-form-search {
    background: none;
    border: none;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.p-button-w-100 {
    width: 100%;
    text-align: center;
    justify-content: center;
}

.p-button-flex {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* Button loading state */
.p-button[disabled] {
    opacity: 0.7;
    cursor: not-allowed;
    pointer-events: none;
}

.p-button.is-loading {
    opacity: 0.85;
    cursor: wait;
    pointer-events: none;
}

.p-button.is-loading .p-button-text {
    display: none !important;
}

.p-button.is-loading .p-button-loading {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
}

.p-button-loading {
    display: none;
    align-items: center;
    gap: 8px;
}

.p-button-loading[hidden] {
    display: none !important;
}

/* Spinner animation */
.p-spinner {
    width: 20px;
    height: 20px;
    animation: p-spin 1s linear infinite;
}

.p-spinner circle {
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-dasharray: 60;
    stroke-dashoffset: 45;
}

@keyframes p-spin {
    100% {
        transform: rotate(360deg);
    }
}

/* Prevent double-click */
.p-button.is-submitting {
    pointer-events: none;
    opacity: 0.75;
}

/* tabs-nav */
.p-tabs-nav-wrap {
    text-align: center;
}

.p-tabs-nav {
    border-radius: 64px;
    display: inline-flex;
    background: var(--white);
    gap: 8px;
    padding: 4px;
}

.p-tabs-nav-item {
    color: var(--gray-3);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    line-height: 1;
    height: 48px;
    padding: 12px 32px;
    border-radius: 64px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.p-tabs-nav-item:hover {
    color: var(--gray-1);
}

.p-tabs-nav-item.p-tabs-nav-item-active {
    background: var(--brand-02);
    color: var(--white);
}

/* tags */
.p-tags {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.p-tag-item {
    background: var(--off-white-blue);
    border-radius: 6px;
    padding: 8px 16px;
    text-decoration: none;
    color: var(--gray-2);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.3em;
}
.p-tag-item:hover {
    background: var(--hover-off-white-blue);
}

.p-tag-item-round {
    border-radius: 64px;
}

.p-tag-item-brand-02 {
    color: var(--brand-02);
}

.p-tag-item-blue {
    background: var(--low-emphasis-3);
    color: var(--brand-01);
}

.p-tag-item.p-border-shine:hover {
    background: var(--white);
}

/* status tag */
.p-status-tag {
    font-weight: 400;
    font-size: 14px;
    line-height: 1.3em;
    background: var(--off-white-0);
    padding: 4px 16px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
}

.p-status-tag::before {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 8px;
    flex-shrink: 0;
    background: var(--gray-4);
}

.p-status-tag-success {
    color: var(--success);
    background: var(--success-10);
}
.p-status-tag-success::before {
    background: var(--success);
}

.p-status-tag-error {
    color: var(--error);
    background: var(--error-10);
}
.p-status-tag-error::before {
    background: var(--error);
}

.p-status-tag-info {
    color: var(--info);
    background: var(--info-10);
}
.p-status-tag-info::before {
    background: var(--info);
}

.p-status-tag-warning {
    color: var(--warning);
    background: var(--warning-10);
}
.p-status-tag-warning::before {
    background: var(--warning);
}

/* badge */
.p-badges-wrap {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.p-badge-small {
    display: inline-block;
    background: var(--brand-02);
    color: var(--white);
    font-weight: 600;
    font-size: 14px;
    padding: 2px 4px;
    border-radius: 4px;
    line-height: 1.35;
}
.p-badge-brand-01 {
    background: var(--brand-01);
}
.p-badge-brand-02 {
    background: var(--brand-02);
}
.p-badge-off-white-1 {
    background: var(--off-white-1);
    color: var(--brand-02);
}

.p-dashboard-badge-wrapper {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* table */
.p-table-wrap {
    overflow-x: auto;
    padding: 24px 48px;
}

.p-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 600px;
    text-align: left;
}

.p-table-header p {
    font-weight: 400;
    font-size: 14px;
    color: var(--gray-4);
    line-height: 1.3em;
}

.p-table-header th {
    padding: 12px;
    border-bottom: 1px solid var(--off-white-0);
}

.p-table-body td {
    padding: 12px;
}

.p-table-body tr {
    border-bottom: 1px solid var(--off-white-0);
}

.p-table-body tr:last-child {
    border-bottom: none;
}

.p-table-body td p {
    font-weight: 400;
    font-size: 14px;
    color: var(--gray-1);
    line-height: 1.3em;
}

/* icons */
.p-icon {
    display: block;
    width: 32px;
    height: 32px;
    fill: var(--brand-01);
    flex-shrink: 0;
}

.p-icon-brand-02 {
    fill: var(--brand-02);
}

.p-icon-tertiary {
    fill: var(--low-emphasis-2);
}

.p-icon-white {
    fill: var(--white);
}

.p-icon-gray-1 {
    fill: var(--gray-1);
}

.p-icon-gray-2 {
    fill: var(--gray-2);
}

.p-icon-gray-3 {
    fill: var(--gray-3);
}

.p-icon-gray-4 {
    fill: var(--gray-4);
}

.p-icon-success {
    fill: var(--success);
}

.p-icon-warning {
    fill: var(--warning);
}

.p-icon-info {
    fill: var(--info);
}

.p-icon-error {
    fill: var(--error);
}

.p-icon-row {
    display: grid;
    grid-template-columns: 32px 1fr;
    gap: 16px;
    align-items: center;
}

.p-icon-circle-small {
    height: 48px;
    width: 48px;
    padding: 12px;
    border-radius: 64px;
    background: var(--white);
    fill: var(--black);
    overflow: visible;
}
.p-icon-circle-small-white {
    height: 48px;
    width: 48px;
    padding: 12px;
    border-radius: 64px;
    background: var(--white);
}

.p-icon-circle {
    height: 68px;
    width: 68px;
    padding: 16px;
    border-radius: 64px;
    background: var(--low-emphasis-3);
}

.p-icon-circle-gray-1 {
    background: var(--gray-1);
    fill: var(--white);
}

.p-icon-20 {
    width: 20px;
    height: 20px;
}

.p-icon-24 {
    width: 24px;
    height: 24px;
}

.p-icon-48 {
    width: 48px;
    height: 48px;
}

.p-icon-64 {
    width: 64px;
    height: 64px;
}

.p-icon-payment {
    height: 32px;
    width: 48px;
}

.p-icon-spinner-wrap {
    display: inline-block;
    animation: spin 1000ms infinite linear;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* forms */
.form-container form,
.p-dashboard-form-wrapper {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 24px;
}

.form-group,
.form-check {
    grid-column: span 12;
}

.form-group-3 {
    grid-column: span 3;
}

.form-group-4 {
    grid-column: span 4;
}

.form-group-6 {
    grid-column: span 6;
}

.form-group-9 {
    grid-column: span 9;
}

.form-group label {
    display: block;
    font-weight: 600;
    font-size: 14px;
    line-height: 1.3em;
    color: var(--gray-2);
    padding-left: 16px;
    margin-bottom: 8px;
}

.form-check label {
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: var(--gray-3);
    font-size: 14px;
    margin-bottom: 0;
}

.form-check label a {
    color: var(--brand-02);
    text-decoration: none;
}

.form-input {
    width: 100%;
    padding: 16px 24px;
    border-radius: 12px;
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: var(--gray-2);
    font-size: 16px;
    border: 1px solid var(--low-emphasis-2);
    transition:
        border-color 200ms,
        box-shadow 200ms;
}

.form-input::placeholder {
    color: var(--gray-4);
}

.form-input:focus {
    outline: none;
    border-color: var(--brand-02);
    box-shadow: 0 0 0 4px var(--low-emphasis-2);
    /* Subtelny podświetlony efekt */
}

.form-input-wrap {
    position: relative;
}

.form-input-suffix {
    position: absolute;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
}

.form-helper {
    padding-left: 16px;
    margin-top: 8px;
    display: block;
}

.form-input-shadow {
    border: none;
    box-shadow: 0px 2px 15px rgba(64, 97, 164, 0.2);
}

.form-input-shadow:focus {
    box-shadow: 0px 2px 15px rgba(64, 97, 164, 0.4);
}

.form-input-rounded {
    border-radius: 20px;
}
.form-wrap-alt .form-input {
    background: var(--off-white-1);
    border: 1px solid var(--off-white-1);
}

.form-wrap-alt .form-check-input,
.form-wrap-alt .form-checkbox-input:checked,
.form-checkbox-alt .form-check-input,
.form-checkbox-alt .form-check-input:checked {
    border: 1px solid transparent;
    background: var(--off-white-1);
}

/* sort / filter */
.p-trainer-search-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.p-trainer-search-actions-select-button {
    padding: 12px 24px;
    border-radius: 24px;
    background: var(--white);
    color: var(--gray-3);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid var(--low-emphasis-3);
    line-height: 1;
    align-items: center;
    gap: 16px;
    cursor: pointer;
    position: relative;
    z-index: 3;
}

.p-trainer-search-actions-select-button-current {
    display: inline-flex;
    gap: 8px;
    align-items: center;
}

.p-trainer-search-actions-select-button-current .p-icon {
    transition: transform 0.15s ease;
}

.p-trainer-search-actions-select-button.is-open
    .p-trainer-search-actions-select-button-current
    .p-icon {
    transform: rotate(180deg);
}

.p-trainer-search-actions-select-button-header {
    display: flex;
    gap: 16px;
    align-items: center;
}
.p-trainer-search-actions-select-button-options {
    margin-top: 16px;
    margin-bottom: 8px;
    padding-right: 24px;
    gap: 16px;
    display: none;
    flex-direction: column;
    background: var(--white);
    align-items: flex-end;
}
.p-trainer-search-actions-select-button-option {
    text-align: center;
    cursor: pointer;
}

/* Filters */
.p-filters-box {
    padding: 24px;
    background: var(--white);
    border: 1px solid var(--low-emphasis-3);
    border-radius: 24px;
}

.p-filters-box .form-check label {
    padding-left: 0;
}

.p-filters-toggle .p-icon {
    display: none;
}

.p-filters-header {
    display: flex;
    justify-content: space-between;
}

.p-filter-group-label {
    margin-bottom: 16px;
    display: block;
    white-space: nowrap;
}

.p-filter-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.p-filter-tag {
    display: inline-flex;
    padding: 4px 16px;
    border: 1px solid var(--low-emphasis-3);
    border-radius: 64px;
    align-items: center;
    background: var(--white);
}

.p-filter-tag:hover {
    cursor: pointer;
    border-color: var(--low-emphasis-2);
}

.p-filter-tag.is-active {
    background: var(--low-emphasis-3);
    border-color: var(--low-emphasis-2);
}

.p-filter-separator {
    height: 1px;
    background: var(--off-white-0);
    margin: 24px 0;
}

.p-filters-actions {
    margin-top: 32px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.p-filters-toggle {
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: space-between;
}

.p-button-filter-count {
    font-weight: 400;
}

.p-trainer-search-actions-filter-button.is-open {
    background: var(--brand-02);
    color: var(--white);
}

.p-trainer-search-actions-filter-button.is-open
    .p-trainer-search-actions-select-button-value {
    color: var(--white);
}

.p-trainer-search-actions-filter-button.is-open .p-icon {
    fill: var(--white);
}

/* password-toggle */
.p-password-toggle-wrap {
    position: relative;
}

.p-toggle-password {
    position: absolute;
    right: 24px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    top: 50%;
    transform: translateY(-50%);
}

/* form-search-big */
.p-search-big .form-input {
    padding: 24px;
    border-radius: 64px;
}

/* form-checkbox */
.form-check {
    display: flex;
    align-items: center;
    gap: 16px;
}

.form-check-input {
    appearance: none;
    -webkit-appearance: none;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: 1px solid var(--low-emphasis-2);
    display: inline-block;
    position: relative;
    cursor: pointer;
    background-color: var(--white);
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.form-check-input:checked {
    border-color: var(--low-emphasis-2);
    background-color: var(--white);
}

.form-check-input:checked::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"><path d="M18.7085 7.20986C18.6155 7.11613 18.5049 7.04174 18.3831 6.99097C18.2612 6.9402 18.1305 6.91406 17.9985 6.91406C17.8665 6.91406 17.7358 6.9402 17.6139 6.99097C17.492 7.04174 17.3814 7.11613 17.2885 7.20986L9.83848 14.6699L6.70848 11.5299C6.61196 11.4366 6.49802 11.3633 6.37317 11.3141C6.24831 11.2649 6.11499 11.2408 5.98081 11.2431C5.84663 11.2454 5.71422 11.2741 5.59114 11.3276C5.46806 11.3811 5.35672 11.4583 5.26348 11.5549C5.17025 11.6514 5.09693 11.7653 5.04773 11.8902C4.99852 12.015 4.97439 12.1484 4.97672 12.2825C4.97904 12.4167 5.00776 12.5491 5.06126 12.6722C5.11475 12.7953 5.19196 12.9066 5.28848 12.9999L9.12848 16.8399C9.22145 16.9336 9.33205 17.008 9.45391 17.0588C9.57577 17.1095 9.70647 17.1357 9.83848 17.1357C9.9705 17.1357 10.1012 17.1095 10.2231 17.0588C10.3449 17.008 10.4555 16.9336 10.5485 16.8399L18.7085 8.67986C18.81 8.58622 18.891 8.47257 18.9464 8.34607C19.0018 8.21957 19.0304 8.08296 19.0304 7.94486C19.0304 7.80676 19.0018 7.67015 18.9464 7.54365C18.891 7.41715 18.81 7.3035 18.7085 7.20986Z" fill="%23044BD9" stroke="%23044BD9"/></svg>')
        no-repeat center center;
    background-size: contain;
}

.form-check-no-padding label {
    padding-left: 0;
}

/* form-radio */
.form-radio {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.form-radio label {
    font-family: "Poppins", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: var(--gray-3);
    font-size: 14px;
    margin-top: 10px;
}

.form-radio label a {
    color: var(--brand-02);
    text-decoration: none;
}

.form-radio-input {
    appearance: none;
    -webkit-appearance: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    /* Różnica: radio ma okrągły kształt */
    border: 1px solid var(--low-emphasis-2);
    display: inline-block;
    position: relative;
    cursor: pointer;
    background-color: var(--white);
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.form-radio-input:checked {
    border-color: var(--low-emphasis-2);
    background-color: var(--white);
}

.form-radio-input:checked::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"><circle cx="12" cy="12" r="6" fill="%23044BD9"/></svg>')
        no-repeat center center;
    background-size: contain;
}

/* form-errors */
.form-input.form-input-error {
    border-color: var(--error);
    background-color: #ffe6e6;
}

.form-text-error {
    color: var(--error);
    font-size: 14px;
    margin-top: 8px;
}

/* form-labels */
.form-optional-label {
    color: var(--gray-4);
    font-size: 14px;
    margin-left: 8px;
    font-weight: 500;
}

/* pagination */
.p-pagination-list {
    display: flex;
    justify-content: center;
    align-items: center;
    list-style: none;
    padding: 12px;
    margin: 0;
    gap: 8px;
}

.p-pagination-item .p-pagination-link,
.p-pagination-ellipsis {
    width: 48px;
    height: 48px;
    border-radius: 64px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 400;
    font-size: 14px;
    color: var(--gray-1);
    line-height: 1em;
    cursor: pointer;
}

.p-pagination-item:not(.disabled, .active) .p-pagination-link:hover {
    color: var(--gray-1);
    transition:
        background-color 200ms,
        color 200ms;
}

.p-pagination-item.active .p-pagination-link {
    background: var(--white);
    border: 1px solid var(--low-emphasis-3);
    color: var(--gray-1);
    font-size: 17px;
    font-weight: 600;
}
.p-pagination-item-next {
    background: var(--gray-1);
}
.p-pagination-item-next .p-icon {
    fill: var(--white);
}

/* flash-messages alerts */
.p-flash-messages {
    position: fixed;
    top: 24px;
    z-index: 999;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 640px;
    padding-left: 24px;
    padding-right: 24px;
    width: 100%;
}

.p-alert {
    display: flex;
    align-items: center;
    padding: 24px;
    border-radius: 16px;
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    gap: 16px;
    animation: alertSlideIn 0.3s ease;
    transition:
        opacity 0.3s ease,
        transform 0.3s ease;
}

.p-alert.is-hiding {
    opacity: 0;
    transform: translateY(-10px);
}

@keyframes alertSlideIn {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.p-alert-success {
    background: var(--success);
    border: 1px solid var(--success);
}

.p-alert-error {
    background: var(--error);
    border: 1px solid var(--error);
}

.p-alert-warning {
    background: var(--warning);
    border: 1px solid var(--warning);
}

.p-alert-info {
    background: var(--info);
    border: 1px solid var(--info);
}

.p-alert-content {
    color: var(--white);
}

.p-alert-inline-box {
    display: inline-flex;
    align-items: center;
    padding: 16px 24px;
    border-radius: 12px;
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    gap: 16px;
}

.p-alert-inline-box-success {
    background: var(--success);
    border: 1px solid var(--success);
}

.p-alert-inline-box-error {
    background: var(--error);
    border: 1px solid var(--error);
}

.p-alert-inline-box-warning {
    background: var(--warning);
    border: 1px solid var(--warning);
}

.p-alert-inline-box-info {
    background: var(--info);
    border: 1px solid var(--info);
}

/* --- modal (global component) --- */
.p-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 2000;
    overflow: auto;
    display: none;
    padding: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.p-modal-dialog {
    background: var(--white);
    color: var(--gray-2);
    border-radius: 20px;
    width: 100%;
    margin: 24px auto;
    max-height: calc(100vh - 128px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.p-modal-md {
    max-width: 640px;
}

.p-modal-lg {
    max-width: 840px;
}

.p-modal-xl {
    max-width: 1024px;
}

.p-modal-header {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 24px 32px;
}

.p-modal-header .t-size-h4 {
    margin: 0;
    color: var(--brand-02);
    text-align: center;
    width: 100%;
}

.p-modal-body {
    padding: 0 32px;
    overflow: auto;
    /* in case content is tall, scroll this area */
    /* display: flex; */
    align-items: center;
    justify-content: center;
}

.p-modal-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 24px 32px;
}

/* close button */
.p-modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 40px;
    background: transparent;
}

.p-modal-close:hover {
    background: var(--low-emphasis-3);
}

.p-modal-body img {
    max-width: 100%;
    max-height: 70vh;
    /* keep footer visible */
    height: auto;
    display: block;
    margin: 0 auto;
}

/* 3DS Modal */
/* #secure-3ds-modal {
    padding: 24px;
}
#secure-3ds-modal .p-modal-header {
    display: none;
}
#secure-3ds-modal .p-modal-body {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}
#secure-3ds-modal iframe {
    width: 100%;
    min-height: 500px;
    border: none;
    border-radius: 4px;
} */

/* 3DS Modal - mobile fix */
/* @media screen and (max-width: 768px) {
    #secure-3ds-modal {
        padding: 0;
        align-items: flex-start;
    }
    #secure-3ds-modal .p-modal-dialog {
        max-height: 100vh;
        max-height: 100dvh;
        height: 100%;
        margin: 0;
        border-radius: 0;
    }
    #secure-3ds-modal .p-modal-body {
        flex: 1;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        padding: 0;
    }
    #secure-3ds-modal iframe {
        height: 100%;
        min-height: unset;
    }
    #secure-3ds-modal .p-modal-footer {
        padding: 12px 16px;
        flex-wrap: wrap;
    }
} */

/* --- CropperJS (avatar modal) --- */
.p-avatar-cropper-wrap {
    border-radius: 12px;
    overflow: hidden;
    width: 100%;
    max-height: 70vh;
    /* constrain cropper area */
    display: flex;
    align-items: center;
    justify-content: center;
}

.cropper-dashed,
.cropper-center {
    display: none !important;
}

.cropper-container {
    border-radius: 16px;
    overflow: hidden;
}

.cropper-view-box {
    outline: 2px solid var(--brand-02) !important;
    outline-offset: 0;
}

.cropper-line {
    background-color: transparent !important;
}

.cropper-point {
    background-color: var(--brand-02) !important;
}

.cropper-line {
    opacity: 0.9;
}

.cropper-point {
    display: none !important;
}

.cropper-face {
    background: transparent !important;
}

/* layout */
.container {
    max-width: 1600px;
    margin: 0 auto;
    padding-left: 24px;
    padding-right: 24px;
}

.grid-12 {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.grid-c-10-o-1 {
    grid-column: 2 / span 10;
}

/* shadow-box */
.shadow-box {
    background: var(--white);
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.06);
    border-radius: 12px;
}

/* swiper */

/* swiper-nav */
.p-swiper-nav-wrap {
    display: flex;
    gap: 16px;
}

.p-swiper-nav {
    border-radius: 64px;
    background: var(--gray-1);
    padding: 12px;
    flex-shrink: 0;
    cursor: pointer;
    transition: all 200ms ease;
    box-shadow: none;
    outline: none;
}
.p-swiper-nav:hover {
    background: var(--gray-2);
}
.p-swiper-nav .p-icon {
    fill: var(--white);
    transition: all 200ms ease;
}
.p-swiper-nav.swiper-button-disabled {
    background: var(--off-white-blue);
}
.p-swiper-nav.swiper-button-disabled .p-icon {
    fill: var(--gray-1);
}

/* header */
.p-header {
    padding-top: 32px;
    padding-bottom: 32px;
    align-items: center;
    display: grid;
    grid-template-columns: minmax(0, 3fr) minmax(0, 4fr) minmax(0, 3fr);
    z-index: 9;
    position: relative;
}

.p-logo {
    width: 248px;
    height: auto;
}

.p-sygnet-logo {
    height: 48px;
    width: auto;
}

/* header avatar */
.p-header-avatar-wrap {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    overflow: hidden;
    border: 1px solid var(--low-emphasis-2);
    padding: 4px;
    display: flex;
}

.p-header-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.p-header-avatar-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.p-header-avatar-name {
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #666883 0%, #17171d 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.p-header-avatar-initial {
    line-height: 1;
}

/* Sticky mobile header */
.p-mobile-sticky-header {
    position: fixed;
    width: 100%;
    bottom: 0;
    z-index: 10;
    background: var(--white);
    border-top: 1px solid var(--low-emphasis-3);
    padding-top: 8px;
    padding-bottom: 8px;
}

.p-mobile-sticky-header-bar {
    position: relative;
    z-index: 2;
}

.p-mobile-sticky-header-nav-list {
    padding: 0;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.p-mobile-sticky-header-nav-avatar {
    width: 32px;
    height: 32px;
    padding: 2px;
}

/* Hamburger toggle button */
.p-mobile-sticky-header-hamburger {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    color: var(--gray-2);
    transition: color 0.2s ease;
}

.p-mobile-sticky-header-hamburger:hover {
    color: var(--brand-01);
}

.p-mobile-sticky-header-hamburger .p-icon-hamburger {
    display: block;
}

.p-mobile-sticky-header-hamburger .p-icon-close {
    display: none;
}

.p-mobile-sticky-header.is-menu-open
    .p-mobile-sticky-header-hamburger
    .p-icon-hamburger {
    display: none;
}

.p-mobile-sticky-header.is-menu-open
    .p-mobile-sticky-header-hamburger
    .p-icon-close {
    display: block;
}

/* Mobile menu panel */
.p-mobile-sticky-header-menu {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--white);
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
    padding: 48px 24px;
    margin-bottom: 57px; /* przestrzeń na sticky bar */
    transform: translateY(100%);
    opacity: 0;
    visibility: hidden;
    transition:
        transform 0.3s ease,
        opacity 0.3s ease,
        visibility 0.3s ease;
    z-index: 1;
    max-height: 70vh;
    overflow-y: auto;
}

.p-mobile-sticky-header.is-menu-open .p-mobile-sticky-header-menu {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
}

/* Overlay behind menu */
.p-mobile-sticky-header-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0;
    visibility: hidden;
    transition:
        opacity 0.3s ease,
        visibility 0.3s ease;
    z-index: 9;
}

.p-mobile-sticky-header.is-menu-open ~ .p-mobile-sticky-header-overlay,
body.is-mobile-menu-open .p-mobile-sticky-header-overlay {
    opacity: 1;
    visibility: visible;
}

.p-mobile-sticky-header-menu-nav {
    overflow: scroll;
}

.p-mobile-sticky-header-menu-nav-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    padding-left: 0;
}
.p-mobile-sticky-header-menu-nav-url:not(.p-button) {
    font-weight: 600;
    color: var(--gray-3);
}

.p-mobile-sticky-dashboard-footer {
    width: 100%;
    text-align: center;
    margin-top: 24px;
}

/* footer */
.p-footer {
    margin-top: 80px;
    z-index: 9;
    position: relative;
}
.p-footer-main {
    background: var(--gray-1);
    margin-left: 24px;
    margin-right: 24px;
    padding-top: 80px;
    padding-bottom: 80px;
    border-radius: 32px;
}
.p-footer-row {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 0 24px;
}
.p-footer-col-6 {
    grid-column: span 6;
}
.p-footer-col-4 {
    grid-column: span 4;
}

.p-footer-logo {
    width: 200px;
    height: auto;
}

.p-footer-social {
    display: flex;
    align-items: center;
    gap: 32px;
    justify-content: flex-end;
}
.p-footer-nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 24px;
    align-items: baseline;
}
.p-footer-nav-list-vertical {
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

.p-footer-row--links-main {
    margin-top: 48px;
}

.p-footer-nav-secondary .p-footer-nav-list {
    justify-content: flex-end;
}

.p-footer-separator {
    border-color: var(--gray-4);
    margin: 64px 0;
    grid-column: span 12;
    opacity: 0.2;
}

.p-footer-text-low {
    color: var(--gray-4);
    opacity: 0.4;
}

.p-footer-row--links-locations {
    gap: 0 48px;
}

.p-footer-nav-trainers-locations {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0 24px;
}

.p-footer-nav-item {
    line-height: 1;
}

.p-footer-bottom {
    padding-top: 24px;
    padding-bottom: 24px;
}

/* cookies */
#cookies-policy.p-cookie-consent .cookies__alert {
    width: 400px;
    border: 1px solid var(--off-white-0);
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.06);
    border-radius: 24px;
}

#cookies-policy.p-cookie-consent .cookies__wrapper,
#cookies-policy.p-cookie-consent .cookies__btn--customize {
    padding: 24px 32px;
}

.p-cookie_icon {
    margin-bottom: 8px;
}

.p-cookies__title {
    margin-bottom: 16px;
}

.p-cookies__intro {
    margin-bottom: 24px;
    color: var(--gray-2);
}

#cookies-policy.p-cookie-consent .cookies__actions {
    gap: 8px;
}

#cookies-policy.p-cookie-consent .cookies__btn--customize {
    border-top: 1px solid var(--off-white-0);
}

#cookies-policy.p-cookie-consent.cookies--show .cookies__btn--customize {
    border-bottom: 1px solid var(--off-white-0);
}

#cookies-policy.p-cookie-consent .cookies__section {
    padding: 0 32px;
}
#cookies-policy.p-cookie-consent .cookies__box {
    padding: 24px 0 16px;
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: space-between;
}

#cookies-policy.p-cookie-consent .cookies__details {
    color: var(--low-emphasis-1);
    margin-bottom: 24px;
    margin-top: 16px;
}

#cookies-policy.p-cookie-consent .cookies__details:focus,
#cookies-policy.p-cookie-consent .cookies__details:hover {
    color: var(--brand-02);
}

#cookies-policy.p-cookie-consent .cookies__save {
    padding: 24px 32px 32px;
}

.p-cookies__definitions {
    margin-top: 24px;
}

.p-cookies__cookie-header {
    display: flex;
    gap: 8px;
}

.p-cookies__cookie {
    margin-top: 8px;
}

.p-cookies__description {
    margin-top: 4px;
}

#cookies-policy.p-cookie-consent .cookies__box:after {
    width: 56px;
    height: 32px;
    border-radius: 64px;
    margin: 0;
    position: relative;
    background: var(--off-white-0);
}

#cookies-policy.p-cookie-consent .cookies__box:before {
    width: 24px;
    height: 24px;
    margin: 0;
    right: 28px;
    transform: translateY(-12px);
    opacity: 0.5;
    top: 28px;
}

#cookies-policy.p-cookie-consent
    .cookies__category
    input:checked
    + .cookies__box:after {
    background: var(--off-white-0);
}

#cookies-policy.p-cookie-consent
    .cookies__category
    input:checked
    + .cookies__box:before {
    transform: none;
    right: 4px;
    background: var(--brand-02);
}

/* nav */
.p-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none;
    gap: 32px;
    padding: 0;
    margin: 0;
}

.p-nav-item {
    margin: 0;
    padding: 0;
}

.p-nav-url {
    color: var(--gray-3);
    text-decoration: none;
    font-weight: 600;
}

.p-nav-url:hover {
    color: var(--gray-1);
}

.p-nav-buttons {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: flex-end;
}

/* -- pagination -- */
.p-pagination {
    width: 100%;
    grid-column: span 12;
    text-align: center;
    margin-top: 16px;
}

.p-pagination .pagination {
    display: inline-flex;
    margin: 0 auto;
    justify-content: center;
    align-items: center;
    gap: 8px;
    list-style: none;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.06);
    padding: 8px;
    border-radius: 12px;
}

.p-pagination .page-item {
    display: inline-block;
    width: 56px;
    height: 48px;
    text-align: center;
    line-height: 48px;
    border-radius: 12px;
}

.p-pagination .page-link {
    font-weight: 600;
    font-size: 17px;
    color: var(--gray-4);
}

.p-pagination .page-item.active {
    background: var(--brand-02);
}

.p-pagination .page-item.active .page-link {
    color: var(--white);
}

.p-pagination .page-item.disabled {
    display: none;
}

/* --- ads sections --- */
.p-ads-section {
    max-width: 1280px;
    margin: 80px auto;
    width: 100%;
    background: var(--off-white-2);
    padding: 32px 24px 16px 24px;
    border-radius: 16px;
    grid-column: 1/-1;
}

.p-ads-wrap {
    text-align: center;
}

.ad-link {
    display: inline-block;
}

.ad-image {
    max-width: 100%;
    max-height: 200px;
    object-fit: contain;
    margin: 0 auto;
}

.p-ad-caption {
    margin-top: 16px;
    text-align: center;
    color: var(--gray-3);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.2em;
}

.p-ad-placeholder {
    background: var(--off-white-2);
    padding-top: 64px;
    padding-bottom: 64px;
    max-width: 768px;
    border-radius: 12px;
    margin: 0 auto;
    background: var(--off-white-1);
}

/* --- trainer --- */

/* trainer header */
.p-header-trainer {
    grid-template-columns: 1fr 2fr;
}
.p-header-trainer .p-nav-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 32px;
}

.p-logo-trainer {
    display: flex;
    gap: 16px;
    align-items: center;
}
.p-trainer-subdomain {
    font-family: "personalny-font", sans-serif;
    font-style: italic;
    font-weight: 500;
    font-size: 48px;
    color: var(--brand-02);
}
.p-logo-trainer-powered-by {
    display: flex;
    gap: 8px;
    align-items: center;
    white-space: nowrap;
}
.p-logo-trainer-powered-by-image {
    width: auto;
    height: 16px;
}

/* trainer-hero */
.p-trainer-hero {
    margin-bottom: 80px;
}

.p-trainer-hero-inner {
    padding-left: 0;
    padding-right: 0;
}
.p-trainer-hero-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-template-rows: auto auto;
    row-gap: 24px;
}

.p-trainer-hero-bg {
    grid-column: 1 / -1;
    grid-row: 1 / 2;
    position: relative;
    border-radius: 32px;
    overflow: hidden;
    width: calc(100vw - var(--scrollbar-width) - 48px);
    left: 50%;
    transform: translateX(-50%);
}

.p-trainer-hero-content {
    grid-column: 6 / 12;
    grid-row: 1 / 2;
    padding-left: 80px;
    padding-top: 64px;
    padding-bottom: 24px;
    z-index: 2;
    display: flex;
    flex-direction: column;
}

.p-trainer-hero-bg .p-bg-blobs {
    background: var(--off-white-blue);
}

.p-blobs--trainer-hero {
    --blobs-size: 90%;
    --blobs-anchor-x: 90%;
    --blobs-anchor-y: 30%;
    --blobs-rotate: 15deg;
    --blobs-scale-y: 0.7;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

.p-trainer-hero-content-details {
    margin-top: auto;
}

.p-trainer-short-description {
    margin-top: 32px;
    margin-bottom: 32px;
}

/* trainer-profile-photo */
.p-trainer-hero-avatar {
    grid-column: 2 / 6;
    grid-row: 1 / 3;
    /* align-self: end; */
    z-index: 3;
    padding-top: 80px;
}
.p-trainer-profile-photo-wrap {
    position: relative;
}

.p-trainer-profile-photo-img {
    aspect-ratio: 4 / 5;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 32px;
}

/* trainer-rating-badge */
.p-trainer-rating-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px 12px 16px;
    background: rgba(34, 30, 31, 0.8);
    backdrop-filter: blur(12px);
    border-radius: 64px;
}

.p-trainer-profile-photo .p-trainer-rating-badge {
    position: absolute;
    bottom: 16px;
    left: 16px;
}

/* trainer-socials */
.p-trainer-social-links {
    display: flex;
    gap: 16px;
    justify-content: flex-end;
    margin-bottom: 32px;
}

.p-trainer-social-item-icon {
    width: 32px;
    height: 32px;
}

/* p-trainer-meta */
.p-trainer-hero-meta-wrap {
    grid-column: 6 / 12;
    grid-row: 2 / 3;
    z-index: 2;
    padding-left: 80px;
}
.p-trainer-meta {
    position: relative;
}
.p-trainer-meta-gym {
    margin-top: 16px;
}
.p-trainer-meta-pill {
    padding: 12px 24px;
    height: 54px;
    border-radius: 64px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--low-emphasis-3);
}
.p-trainer-meta-pill-gym {
    padding: 4px 24px;
}
.p-trainer-location-wrap {
    position: relative;
    padding-left: 80px;
    margin-left: -80px;
}
.p-trainer-location-wrap::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 80px;
    height: 100%;
    background: linear-gradient(to left, transparent, var(--white));
    z-index: 2;
    pointer-events: none;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}
.p-trainer-location-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 20%;
    height: 100%;
    background: linear-gradient(to right, transparent, var(--white));
    z-index: 1;
    pointer-events: none;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}
.p-trainer-location-wrap .swiper-slide {
    width: auto;
}

/* trainer others */
.p-trainer-contact-button {
    position: absolute;
    right: 16px;
    bottom: 48px;
}

.p-trainer-hero-content-header {
    padding-bottom: 24px;
    margin-bottom: 24px;
    border-bottom: 1px solid var(--low-emphasis-2);
}

.p-trainer-hero-content-header .p-logo-trainer {
    justify-content: center;
    flex-direction: column;
    gap: 0;
}

/* p-trainer-services */
.p-trainer-services-wrap {
    margin-bottom: 80px;
}

.p-trainer-services-loop {
    margin-top: 48px;
    display: flex;
    gap: 16px;
}

.p-trainer-services-item {
    flex: 1;
    padding: 24px 32px;
    text-align: center;
}

.p-trainer-services-item-icon {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 16px;
    width: 90px;
    height: 90px;
}

.p-trainer-services-item p {
    font-weight: 600;
}

/* p-trainer-about */
.p-trainer-about-wrap .grid-12 {
    gap: 80px;
}

.p-trainer-about h3 {
    margin-bottom: 48px;
}

.p-trainer-about .t-bigger {
    font-size: 16px;
    line-height: 1.5em;
}

.p-trainer-about {
    grid-column: 2 / span 6;
}

/* p-trainer-reviews-box */
.p-trainer-reviews-box {
    grid-column: span 4;
}

.p-trainer-reviews-box-header {
    margin-bottom: 32px;
    display: flex;
    justify-content: space-between;
}

.swiper-reviews .swiper-slide {
    height: auto;
}

.p-trainer-reviews-box-item {
    height: 100%;
}

/* p-trainer-reviews-box-item */
.p-trainer-reviews-box-item {
    padding: 32px;
    border-radius: 16px;
    background: var(--off-white-blue);
}

.p-trainer-reviews-box-item-header {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
}

.p-trainer-reviews-box-item-author {
    margin-bottom: 4px;
}

.p-trainer-reviews-box-item-review p {
    color: var(--gray-2);
}

.p-trainer-reviews-box-item-header-rating {
    display: flex;
    align-items: center;
    gap: 8px;
}

.p-trainer-reviews-box-swiper-nav {
    margin-top: 32px;
}

/* reviews-box-basic */
.p-trainer-reviews-box-basic {
    grid-column: 2 / span 10;
}

/* reviews form */
.p-review-rating-stars {
    display: flex;
    gap: 8px;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
}

.p-review-success {
    display: flex;
    font-weight: 600;
    gap: 16px;
    text-align: center;
    flex-direction: column;
    align-items: center;
    padding: 24px 0;
}

.p-review-success[hidden] {
    display: none;
}

.p-review-success h4 {
    margin: 0;
}

.p-review-success p {
    margin: 0;
    color: var(--gray-6);
}

.p-review-header-success {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.p-review-header-success[hidden] {
    display: none;
}

[data-review-title-form][hidden] {
    display: none;
}

/* p-trainer-gallery */
.p-trainer-gallery-wrap {
    margin-top: 80px;
}

.p-trainer-gallery {
    gap: 16px;
}

.p-trainer-gallery-column {
    grid-column: 2 / 12;
}

.p-trainer-gallery-item {
    grid-column: span 2;
    position: relative;
    border-radius: 32px;
    overflow: hidden;
    background: var(--gray-1);
}

.p-trainer-gallery-image {
    aspect-ratio: 4 / 5;
    object-fit: cover;
    width: 100%;
    height: auto;
    border-radius: 32px;
    transition: all 200ms ease;
}
.p-trainer-gallery-image:hover {
    opacity: 0.3;
}

/* p-trainer-pricing */
.p-trainer-pricing-wrap {
    margin-top: 80px;
    padding-top: 80px;
    margin-left: 24px;
    margin-right: 24px;
    padding-bottom: 80px;
    border-radius: 32px;
    background: var(--off-white-blue);
    position: relative;
}

.p-blobs--trainer-pricing {
    --blobs-size: 90%;
    --blobs-anchor-x: 80%;
    --blobs-anchor-y: 95%;
    --blobs-rotate: 180deg;
    --blobs-scale-y: 0.7;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

.p-trainer-pricing h3 {
    text-align: center;
    margin-bottom: 48px;
}

.p-trainer-pricing .p-tabs-nav-wrap {
    margin-bottom: 48px;
}

.p-trainer-pricing-swiper-nav {
    margin-top: 48px;
    justify-content: center;
}

/* pricing-card */
.p-pricing-card {
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    border-radius: 32px;
    padding: 48px 32px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    height: auto;
    gap: 24px;
}

.p-pricing-card-price {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 16px;
}

.p-pricing-card-description {
    max-width: 100%;
}

.p-pricing-card-icon-box {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* p-trainer-transformations */
.p-trainer-transformations-wrap {
    margin-top: 80px;
}

.p-trainer-transformations-wrap h3 {
    margin-bottom: 48px;
}

.p-trainer-transformation-item {
    display: grid;
    align-items: center;
    gap: 48px;
    grid-template-columns: 8fr 4fr;
}

.p-trainer-transformation-photos {
    display: flex;
    gap: 24px;
}

.p-trainer-transformation-photo-before,
.p-trainer-transformation-photo-after {
    flex: 1;
    position: relative;
}

.p-trainer-transformation-photo-before-image,
.p-trainer-transformation-photo-after-image {
    border-radius: 32px;
    aspect-ratio: 3 / 4;
    object-fit: cover;
}

.p-trainer-transformation-photo-after-badge,
.p-trainer-transformation-photo-before-badge {
    padding: 12px 24px;
    background: rgba(34, 30, 31, 0.8);
    backdrop-filter: blur(12px);
    border-radius: 64px;
    position: absolute;
    bottom: 16px;
    left: 16px;
}

.p-trainer-transformation-content-age {
    margin-bottom: 24px;
}

.p-trainer-transformation-details-weight-wrap {
    margin-top: 24px;
}

.p-trainer-transformation-details-weight {
    display: flex;
    gap: 4px;
    align-items: center;
    margin-top: 4px;
}
.p-trainer-transformation-details-goal {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    margin-top: 8px;
}

.p-trainer-transformation {
    display: flex;
    align-items: center;
    gap: 48px;
}

.p-trainer-transformations {
    overflow: hidden;
    flex: 1;
    min-width: 0;
}

.p-trainer-transformations .swiper-slide {
    width: 100%;
    height: auto;
}

/* p-trainer-contact */
.p-trainer-contact-wrap {
    margin-top: 80px;
}

.p-trainer-contact {
    grid-column: 2 / span 4;
}

.p-trainer-contact h3 {
    margin-bottom: 48px;
}

.p-trainer-contact-details {
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-trainer-contact-details:not(:first-child) {
    margin-top: 24px;
}

.p-trainer-contact-details .p-icon {
    border: 1px solid var(--low-emphasis-3);
    padding: 8px;
    width: 48px;
    height: 48px;
    border-radius: 12px;
}

.p-trainer-contact-details a {
    text-decoration: none;
}

/* p-trainer-contact-form */
.p-trainer-contact-form {
    grid-column: span 6;
}

/* gym-cards */
.p-gym-cards-container {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 48px;
    align-items: flex-start;
}

.p-gym-short-card {
    padding: 16px 32px 16px 16px;
    border: 1px solid var(--low-emphasis-3);
    background: var(--white);
    border-radius: 20px;
    width: 100%;
    display: block;
}

.p-gym-short-card-header {
    display: flex;
    gap: 12px;
}

.p-gym-short-card-info {
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}
.p-gym-short-card-info p {
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.p-gym-short-card-address-wrap {
    padding-left: 48px;
}

/* gym-full-card */
.p-gym-full-card-item {
    padding: 24px;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 16px;
    width: 100%;
    display: flex;
    gap: 48px;
    justify-content: space-between;
    align-items: center;
    background: var(--white);
}

.p-gym-full-card-header {
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-gym-full-card-address-wrap {
    padding-left: 48px;
}

.p-gym-full-card-address,
.p-gym-full-card-address-line-2 {
    font-size: 14px;
    color: var(--gray-3);
}

.p-gym-full-card-header .p-icon {
    flex: 0 0 32px;
}

.p-gym-full-card-links {
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-gym-full-card-link-item {
    display: inline-block;
    flex-shrink: 0;
}

/* city card short */
.p-city-short-card {
    padding: 24px;
    border: 1px solid var(--low-emphasis-3);
    background: var(--white);
    border-radius: 16px;
    width: 100%;
    display: flex;
    gap: 16px;
    align-items: center;
}

/* p-trainer-contact-simple */
.p-trainer-simple-contact {
    grid-column: 2 / span 10;
}

.p-trainer-simple-contact h3 {
    text-align: center;
}

.p-trainer-simple-contact .p-trainer-contact-details-wrap {
    display: flex;
    justify-content: center;
    gap: 24px;
}

.p-trainer-simple-contact .p-trainer-contact-details:not(:first-child) {
    margin-top: 0;
}

.p-trainer-simple-contact .p-gym-cards-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
}
.p-trainer-simple-contact .p-gym-short-card,
.p-trainer-contact .p-gym-short-card {
    width: auto;
}

/* --- auth --- */

/* auth layout */
.p-auth-body {
    background: var(--gray-1);
    padding-left: 24px;
    padding-right: 24px;
}

.p-auth-header {
    max-width: 640px;
    margin: 64px auto;
}

.p-auth-header .p-logo {
    margin: 0 auto;
}

.p-auth-main {
    background: var(--white);
    border-radius: 16px;
    max-width: 640px;
    margin: 0 auto;
    padding: 48px 80px;
}

.p-auth-main h4 {
    margin-bottom: 32px;
}

.p-auth-back {
    text-align: center;
    margin-top: 24px;
}

.p-auth-form-footer {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--low-emphasis-2);
}

.p-auth-footer {
    max-width: 640px;
    margin: 64px auto 0 auto;
}

.p-auth-form-footer p:not(:first-child) {
    margin-top: 16px;
}

/* --- dashboard --- */
.p-dashboard-page-wrapper {
    position: relative;
}
.p-dashboard-page-wrapper .p-bg-blobs {
    z-index: -1;
}
.p-blobs--dashboard {
    --blobs-size: 900px;
    --blobs-anchor-x: 45%;
    --blobs-anchor-y: 650px;
    --blobs-rotate: 0deg;
    --blobs-scale-y: 1;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

.p-dashboard-main-wrap {
    margin-top: 48px;
}

/* header */
.p-dashboard-header-nav {
    display: flex;
    justify-content: space-between;
    padding-top: 24px;
    padding-bottom: 24px;
}

.p-dashboard-header-nav-title {
    display: flex;
    gap: 48px;
    align-items: center;
}

.p-dashboard-header-account-details {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 24px;
    align-items: center;
    margin-bottom: 24px;
    margin-top: 24px;
}

.p-dashboard-header-account-details-type {
    display: flex;
    gap: 24px;
    align-items: center;
    grid-column: 1 / 2;
}

.p-dashboard-header-account-details-register-date {
    grid-column: 3 / 4;
}

.p-dashboard-header-account-next-payment {
    padding-bottom: 24px;
}

.p-dashboard-header-nav-buttons-wrap {
    display: flex;
    gap: 8px;
}

/* footer */
.p-dashboard-page-wrapper .p-footer-social .p-icon {
    fill: var(--gray-2);
}

/* nav */
.p-dashboard-side-menu {
    grid-column: span 3;
    padding-top: 24px;
}

.p-dashboard-nav-title {
    margin-bottom: 24px;
}

.p-dashboard-nav-title:not(:first-child) {
    margin-top: 48px;
}

.p-dashboard-nav-wrap {
    padding-right: 24px;
}

.p-dashboard-nav {
    display: flex;
    flex-direction: column;
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.p-dashboard-nav .p-dashboard-nav-url {
    display: flex;
    padding: 8px 16px;
    gap: 16px;
    align-items: center;
    text-decoration: none;
    color: var(--gray-3);
    font-weight: 600;
    border-radius: 8px;
    transition: all 200ms ease;
}

.p-dashboard-nav .p-dashboard-nav-url:hover {
    background: var(--off-white-blue);
}

.p-dashboard-nav .p-dashboard-nav-url-current {
    background: var(--low-emphasis-3);
    color: var(--gray-1);
}

.p-dashboard-nav .p-dashboard-nav-url-disabled {
    color: var(--gray-4);
}

.p-dashboard-nav .p-dashboard-nav-url-disabled .p-icon {
    fill: var(--gray-4);
}

/* content */
.p-dashboard-main-content {
    padding: 64px;
    border-radius: 32px;
    background: var(--white);
    grid-column: span 7;
}

.p-dashboard-section-title {
    margin-bottom: 48px;
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-dashboard-section-title--icon {
    display: flex;
    align-items: center;
    gap: 16px;
}

.p-dashboard-title-inline {
    display: flex;
    align-items: center;
    gap: 16px;
}

/* dashboard-forms */
.p-dashboard-subdomain-actions {
    margin-top: 16px;
    display: flex;
    gap: 24px;
}

.p-dashboard-action-icon {
    display: inline-flex;
    gap: 4px;
    align-items: center;
    font-weight: 600;
    text-decoration: none;
    color: var(--brand-02);
}

.p-dashboard-avatar-preview-wrap {
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-dashboard-avatar-preview-actions {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.p-dashboard-avatar-preview {
    border-radius: 16px;
    aspect-ratio: 4 / 5;
    width: 128px;
    height: auto;
    object-fit: cover;
}

.p-dashboard-avatar-preview-actions-icon {
    background: var(--low-emphasis-3);
    border-radius: 64px;
    display: inline-block;
    padding: 8px;
}

.p-dashboard-form-colab-form {
    display: flex;
    gap: 24px;
    align-items: center;
}

.p-dashboard-form-colab-form .form-check label {
    padding-left: 0;
    margin-bottom: 0;
}

.p-textarea-no-resize textarea {
    resize: none;
}

/* dashboard-services */
.p-dashboard-services-loop {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 24px;
}

.p-dashboard-service-item {
    display: inline-flex;
    gap: 16px;
    padding: 8px 16px;
    border: 1px solid var(--brand-02);
    border-radius: 16px;
    max-width: 240px;
    align-items: center;
    opacity: 0.5;
}

.p-dashboard-service-item:hover {
    cursor: pointer;
    opacity: 0.85;
}

.p-dashboard-service-item.selected {
    opacity: 1;
}

.p-dashboard-service-icon {
    width: 45px;
    height: 45px;
}

/* p-dashboard-gym-card */
.p-dashboard-gym-item {
    padding: 24px;
    border: 1px solid var(--low-emphasis-2);
    display: inline-block;
    border-radius: 16px;
}

.p-dashboard-gym-item-header {
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-dashboard-gym-item-remove {
    margin-left: auto;
    align-self: flex-start;
    background: none;
    outline: none;
    border: none;
    padding: 0;
}

.p-dashboard-gym-item-address-wrap {
    padding-left: 48px;
}

.p-dashboard-gyms-list {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.p-dashboard-gym-button {
    margin-top: 24px;
}

.p-dashboard-gyms-search {
    margin-top: 24px;
    margin-bottom: 24px;
}

.p-dashboard-gyms-list-search-results .p-dashboard-gym-item {
    padding-right: 48px;
    cursor: pointer;
}

.p-dashboard-gym-item-search.gym-added {
    opacity: 0.5;
}

.p-dashboard-gyms-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
}

.p-dashboard-gym-item-wrapper {
    position: relative;
}

.p-dashboard-gym-item-wrapper .p-gym-short-card {
    padding-right: 48px;
}

.p-dashboard-gym-item-wrapper .p-dashboard-gym-item-remove {
    position: absolute;
    top: 16px;
    right: 16px;
}

/* p-dashboard-gym-add-new-card */
.p-dashboard-gym-add-new-card {
    padding: 30px 24px;
    border: var(--brand-02);
    background: var(--brand-02);
    display: inline-block;
    width: 280px;
    border-radius: 16px;
    text-align: center;
    text-decoration: none;
}

.p-dashboard-gym-add-new-card-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 8px;
}

.p-dashboard-gym-add-new-card-cta p {
    color: var(--white);
}

.p-dashboard-gym-add-new-card-cta svg {
    fill: var(--low-emphasis-2);
}

.p-dashboard-gym-add-new-card-title {
    color: var(--low-emphasis-1);
}

.p-dashboard-form-gyms-add .p-dashboard-gym-card-wrapper .p-gym-short-card {
    cursor: pointer;
}

/* p-dashboard-gallery */
.p-dashboard-gallery-loop {
    display: flex;
    gap: 16px;
}

.p-dashboard-gallery-item {
    position: relative;
    flex: 0 1 128px;
    border-radius: 12px;
}

.p-dashboard-gallery-image {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 12px;
}

.p-dashboard-gallery-item-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    background: var(--white);
    border-radius: 64px;
}

/* p-dashboard-pricing */
.p-dashboard-pricing-tabs {
    margin-top: 24px;
    margin-bottom: 24px;
}

.p-tabs-nav-wrap-dashboard .p-tabs-nav {
    background: var(--off-white-2);
}

.p-dashboard-pricing-cards {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.p-dashboard-pricing-card-item {
    padding: 24px;
    border-radius: 16px;
    border: 1px solid var(--low-emphasis-2);
    width: 320px;
}

.p-dashboard-pricing-card-meta {
    margin-top: 16px;
    display: flex;
    gap: 16px;
    align-items: center;
}

.p-dashboard-pricing-card-description {
    display: -webkit-box;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.p-dashboard-pricing-card-price {
    margin-right: auto;
    color: var(--brand-02);
}

.p-dashboard-pricing-card-edit {
    color: var(--gray-4);
    font-weight: 600;
    text-decoration: none;
}

.p-dashboard-pricing-card-delete {
    color: var(--error);
    font-weight: 600;
    text-decoration: none;
    background: none;
    padding: 0;
    border: none;
    outline: none;
}

.p-dashboard-pricing-card-title {
    margin-bottom: 16px;
}

/* p-dashboard-info */
.p-dashboard-form-info {
    display: flex;
    gap: 16px;
    align-items: center;
}

/* p-dashboard-transformations */
.p-dashboard-transformations-list {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.p-dashboard-transformation-item {
    padding: 24px;
    border-radius: 12px;
    border: 1px solid var(--low-emphasis-2);
    display: inline-block;
    border-radius: 16px;
    min-width: 240px;
}

.p-dashboard-transformation-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.p-dashboard-transformation-actions {
    margin-top: 16px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 16px;
}

#delete-photo-before,
#delete-photo-after {
    border: none;
    background: var(--low-emphasis-3);
    border-radius: 64px;
    display: inline-block;
    padding: 8px;
}

/* dashboard subscriptions */
.p-dashboard-current-plan {
    padding: 16px 48px;
    background: var(--off-white-2);
    border-radius: 12px;
    margin-top: 24px;
}

.p-dashboard-current-plan-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
}

.p-dashboard-current-plan-name {
    font-family: "personalny-font", sans-serif;
    font-style: italic;
    font-weight: 500;
    font-size: 56px;
    color: var(--gray-2);
    font-weight: 500;
    line-height: 1.2em;
}

.p-dashboard-current-plan-price {
    margin-top: -8px;
}

.p-dashboard-current-plan-change {
    text-decoration: none;
    color: var(--brand-02);
    font-weight: 600;
}

.p-dashboard-current-plan--pro {
    background: linear-gradient(
        125deg,
        var(--brand-02),
        #457ff3,
        var(--brand-02)
    );
}

.p-dashboard-current-plan--elite {
    background: linear-gradient(
        125deg,
        var(--brand-01),
        #457ff3,
        var(--brand-01)
    );
}

.p-dashboard-current-plan--pro .p-dashboard-current-plan-name,
.p-dashboard-current-plan--pro .p-dashboard-current-plan-price,
.p-dashboard-current-plan--elite .p-dashboard-current-plan-name,
.p-dashboard-current-plan--elite .p-dashboard-current-plan-price {
    color: var(--white);
}

.p-dashboard-current-plan--pro .p-dashboard-current-plan-change,
.p-dashboard-current-plan--elite .p-dashboard-current-plan-change {
    color: var(--low-emphasis-2);
}

.p-dashboard-current-plan-footer {
    margin-top: 16px;
    padding-left: 48px;
}

.p-dashboard-current-plan-footer-item {
    display: flex;
    gap: 48px;
}

.p-dashboard-action-buttons {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--off-white-1);
}

.p-dashboard-action-buttons-title {
    padding-left: 16px;
}

.p-dashboard-action-button-item {
    margin-top: 24px;
    padding: 16px 48px;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 12px;
    background: var(--white);
    display: flex;
    align-items: center;
    gap: 32px;
}

.p-dashboard-action-button-item-action {
    margin-left: auto;
}

.p-dashboard-action-button-item-link {
    text-decoration: none;
    color: var(--brand-02);
    font-weight: 600;
    height: 32px;
    display: inline-block;
    line-height: 32px;
}

/* dashboard subscriptions change */
.p-dashboard-plan-change-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
    margin-top: 24px;
}

.p-dashboard-plan-change-item {
    padding: 24px;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    align-items: center;
    text-align: center;
}

.p-dashboard-plan-change-name {
    font-size: 40px;
}

.p-dashboard-plan-change-cta {
    margin-top: auto;
    width: 100%;
}

.p-dashboard-plan-change-grid .p-button {
    padding: 16px;
    width: 100%;
    justify-content: center;
}

/* dashboard cards */
.p-dashboard-card-change {
    margin-top: 24px;
}

.p-info-secure-block {
    display: flex;
    gap: 16px;
    margin-top: 24px;
}

.p-dashboard-card-change-form {
    margin-top: 24px;
}

.p-dashboard-card-change-details {
    margin-top: 24px;
    padding: 16px;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 12px;
    display: flex;
    gap: 16px;
    align-items: center;
}

/* dashboard payments */
.p-dashboard-payments {
    margin-top: 24px;
}

/* dashboard subscription cancel */
.p-dashboard-cancel-subscription {
    margin-top: 24px;
}

/* dashboard account */
.p-dashboard-account {
    margin-top: 24px;
}

/* dashboard disabled features */
.p-dashboard-disabled-feature {
    filter: grayscale(100%);
    opacity: 0.5;
}

/* Breadcrumbs */
.p-breadcrumbs {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
}

.p-breadcrumbs a {
    color: var(--gray-1);
    text-decoration: none;
}

.p-breadcrumbs-item,
.p-breadcrumbs-separator {
    font-size: 12px;
    white-space: nowrap;
}

.p-breadcrumbs-item {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 50ch;
}

.p-breadcrumbs-current {
    max-width: 70ch;
}

/* Search Component */
.p-search-component-wrap {
    position: relative;
    max-width: 768px;
    margin: 0 auto;
}

.p-search-component-wrap {
    position: relative;
}

.p-search-component-wrap .form-input {
    padding-left: 32px;
    padding-right: 96px;
    padding-top: 24px;
    padding-bottom: 24px;
}

.p-search-component-wrap .p-button-form-search {
    position: absolute;
    right: 24px;
    top: 0;
    height: 100%;
}
.p-search-component-submit {
    flex-shrink: 0;
}
.p-search-component-separator {
    height: 32px;
    width: 1px;
    background: var(--low-emphasis-2);
    z-index: 1;
}

/* Search Inline */
.p-search-component-inline {
    display: flex;
    align-items: center;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 20px;
    transition: border-color 0.15s ease;
}

.p-search-component-inline:focus-within {
    border-color: var(--brand-02);
    box-shadow: 0 0 0 4px rgba(69, 127, 243, 0.2);
}

.p-search-component-inline .form-input {
    border: none;
    box-shadow: none;
    padding-right: 24px;
    border-radius: 20px;
}
.p-search-component-inline .form-input:disabled {
    background: var(--white);
}
.p-search-component-inline .p-search-component-submit {
    padding: 16px 24px;
}
.p-search-component-inline .p-search-suggest {
    top: 100%;
}

/* Search */
.p-search-page {
    overflow-x: hidden;
    position: relative;
}
.p-search-page .p-bg-blobs {
    border-radius: 0;
}
.p-blobs--search {
    --blobs-size: 40%;
    --blobs-anchor-x: 95%;
    --blobs-anchor-y: 400px;
    --blobs-rotate: 0deg;
    --blobs-scale-y: 0.8;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

.p-search-hero {
    margin-top: 48px;
}

.p-search-hero-results {
    text-align: center;
    margin-top: 24px;
}

.p-search-content-wrap {
    padding-top: 48px;
    padding-bottom: 48px;
    margin-top: 32px;
    margin-left: 24px;
    margin-right: 24px;
    background: var(--off-white-blue);
    border-radius: 32px;
    position: relative;
    z-index: 1;
}

.p-search-content-grid {
    display: grid;
    grid-template-columns: 1fr 3fr;
    gap: 48px;
}

.p-search-content-main {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.p-search-content-top-bar {
    margin-bottom: 48px;
    margin-left: -24px;
    margin-right: -24px;
    padding-left: 24px;
    padding-right: 24px;
    overflow-x: hidden;
}

.p-search-content-sidebar {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.p-search-content-sidebar .p-ads-section {
    margin: 0;
}

.p-search-cta-section {
    margin-top: 80px;
    margin-bottom: 80px;
}
.p-search-cta-container {
    text-align: center;
    max-width: 768px;
    margin-left: auto;
    margin-right: auto;
}
.p-search-cta-container .p-tags {
    justify-content: center;
    margin-bottom: 48px;
}

/* Search Top - Cities (index view) */
/* .p-search-top-cities {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 16px;
} */
.p-search-top-city-item {
    padding: 32px;
    display: inline-flex;
    flex: 1 0 0;
    gap: 8px;
    align-items: center;
    text-align: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 20px;
    background: var(--white);
    border: 1px solid var(--low-emphasis-3);
}

/* Search Top - Gyms */
/* .p-search-top-gyms {
    display: flex;
    gap: 16px;
    overflow: hidden;
} */
.p-search-top-gyms .p-gym-short-card {
    flex: 1 1 0;
    min-width: 0;
    overflow: hidden;
}
.p-search-top-gyms-all {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 32px;
    background: var(--white);
    border-radius: 20px;
    border: 1px solid var(--low-emphasis-3);
    height: auto;
}

/* Search Top - Gym Selected */
.p-search-top-gym-selected {
    display: grid;
    grid-template-columns: 3fr 9fr;
    gap: 48px;
}
.p-search-top-gym-selected-content {
    display: flex;
    gap: 24px;
}
.p-search-top-gym-selected-details {
    display: flex;
    gap: 16px;
}
.p-search-top-gym-selected-actions {
    margin-left: auto;
}

/* Search - City&Gyms Index */
.p-search-content-index {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.p-search-content-index .p-gym-short-card .p-icon {
    width: 48px;
    height: 48px;
}

/* trainer card */
.p-trainer-list {
    display: grid;
    grid-template-columns: repeat(10, minmax(0, 1fr));
    gap: 24px;
}

.p-trainer-card {
    grid-column: span 2;
    border-radius: 32px;
    background: var(--off-white-2);
    display: flex;
    flex-direction: column;
    gap: 16px;
    overflow: hidden;
    aspect-ratio: 4 / 5;
    cursor: pointer;
}

/* .p-trainer-card:hover .p-trainer-card-photo {
    transform: scale(1.1);
    transition: transform 0.3s ease;
} */

.p-trainer-card-inner {
    position: relative;
    height: 100%;
}

.p-trainer-card-photo {
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    transition: transform 0.3s ease;
}

.p-trainer-card-photo-img {
    aspect-ratio: 4 / 5;
    object-fit: cover;
    width: 100%;
}

.p-trainer-card-content {
    z-index: 1;
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    pointer-events: none;
}

.p-trainer-card-details-wrap {
    padding: 16px;
    background: var(--bg-overlay);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    height: 100%;
}

.p-trainer-card-details {
    pointer-events: all;
    max-width: 100%;
}

.p-trainer-card-title {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    font-size: 20px;
    line-height: 1.3em;
    margin-bottom: 4px;
}

.p-trainer-card-city {
    line-height: 1;
}

.p-trainer-card-details-rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 8px;
    margin-top: auto;
}

.p-trainer-card-details-rating .p-icon {
    width: 24px;
    height: 24px;
}

.p-trainer-card-rating-value {
    color: var(--white);
    line-height: 1em;
}

.p-trainer-card-account-level-badge {
    padding: 8px 16px;
    background: var(--off-white-1);
    border-radius: 16px;
    display: inline-block;
}

.p-icon-account-badge-level-text {
    font-family: "personalny-font", sans-serif;
    font-style: italic;
    font-weight: 500;
    font-size: 18px;
    line-height: 1em;
    text-transform: capitalize;
    color: var(--white);
}

.p-trainer-card-account-level-elite {
    background: var(--brand-01);
}

.p-trainer-card-account-level-pro {
    background: var(--off-white-1);
}
.p-trainer-card-account-level-pro .p-icon-account-badge-level-text {
    color: var(--brand-02);
}

.p-icon-account-badge {
    width: 40px;
    height: 16px;
    object-fit: contain;
}

/* Trainer Card - Extended */
.p-trainer-card-extended {
    background: var(--white);
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    border-radius: 32px;
    box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.06);
    overflow: hidden;
}
.p-trainer-card-extended .p-trainer-card {
    grid-column: auto;
}

.p-trainer-card-extended-content {
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    min-width: 0;
    overflow: hidden;
}
.p-trainer-card-extended-services .p-tag-item {
    font-weight: 400;
    color: var(--gray-1);
}
.p-trainer-card-extended-services .p-tag-item:hover {
    background: var(--off-white-blue);
}
.p-trainer-card-extended-footer {
    margin-top: auto;
    display: flex;
    gap: 8px;
    padding-top: 24px;
    border-top: 1px solid var(--low-emphasis-3);
    min-width: 0;
}
.p-trainer-card-extended-pill {
    padding: 4px 24px 4px 16px;
    height: 44px;
    border-radius: 64px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--low-emphasis-3);
    min-width: 0;
    overflow: hidden;
}
.p-trainer-card-extended-pill-more {
    background: var(--off-white-blue);
    padding: 4px 16px;
    text-decoration: underline;
    flex-shrink: 0;
}

.p-trainer-card-extended-gym-details {
    min-width: 0;
    overflow: hidden;
}

.p-trainer-card-extended-gym-details p {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.p-trainer-card-extended-bio p {
    word-break: break-word;
}

/* search no results */
.p-search-hero-no-results {
    display: flex;
    gap: 24px;
    align-items: center;
    justify-content: center;
    padding: 32px;
    border-radius: 16px;
    background: var(--white);
    border: 1px solid var(--low-emphasis-2);
    flex: 1;
}

.p-trainer-search-wrap .p-search-hero-city-gyms .p-search-hero-no-results {
    margin-bottom: 48px;
}

.p-trainer-search-wrap .p-gyms-search-title {
    margin-top: 48px;
    margin-bottom: 48px;
}

/* Search No Results Card */
.p-search-no-results {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-radius: 32px;
    overflow: hidden;
    background: var(--gray-1);
    margin-bottom: 32px;
}

.p-search-no-results-content {
    padding: 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
    grid-row: 1 / 2;
    grid-column: 1 / 2;
    z-index: 1;
}

.p-search-no-results-title {
    color: var(--white);
}

.p-search-no-results-button {
    margin-top: 16px;
    align-self: flex-start;
}

.p-search-no-results-image {
    position: relative;
    overflow: hidden;
    grid-row: 1 / 2;
    grid-column: 1 / 3;
    z-index: 0;
}

.p-search-no-results-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.p-gym-full-card-list {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 24px;
}

.p-gym-full-card-list .p-gym-full-card-item {
    grid-column: span 6;
}

/* homepage */
.p-homepage-hero {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-homepage-hero-title-wrap {
    text-align: center;
    margin-bottom: 32px;
    margin-left: auto;
    margin-right: auto;
    max-width: 768px;
}

.p-homepage-hero-title {
    margin-bottom: 16px;
}

.p-hero-phrase {
    white-space: nowrap;
}

.p-homepage-hero-search-wrap {
    position: relative;
    max-width: 768px;
    margin: 0 auto;
}

.p-homepage-hero-search {
    position: relative;
}

.p-homepage-hero-search .form-input {
    padding-left: 32px;
    padding-right: 96px;
    padding-top: 24px;
    padding-bottom: 24px;
}

.p-homepage-hero-search .p-button-form-search {
    position: absolute;
    right: 24px;
    top: 0;
    height: 100%;
}

.p-homepage-hero-tags {
    max-width: 768px;
    margin: 16px auto 0 auto;
}

.p-homepage-hero-tags .p-tags {
    justify-content: center;
}

.p-homepage-hero-title-tag {
    margin-bottom: 24px;
}

.p-homepage-hero-title-tag .p-tags {
    justify-content: center;
}

.p-homepage-hero-title-tag .p-tag-item,
.p-landing-hero .p-tag-item {
    padding: 6px 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 64px;
}
.p-landing-hero .p-tag-item {
    background: var(--white);
}

.p-homepage-container {
    position: relative;
}

.p-homepage-hero-icon-left {
    position: absolute;
    top: 95%;
    left: 5%;
    transform: translateY(-50%);
    max-width: 256px;
    z-index: -1;
}

.p-homepage-hero-icon-right {
    position: absolute;
    top: 15%;
    right: 5%;
    transform: translateY(-50%);
    max-width: 128px;
    filter: blur(5px);
    z-index: -1;
}

.p-homepage-hero-icon-right img {
    rotate: 120deg;
}

.p-homepage-hero-trainers {
    position: relative;
}

.p-homepage-hero-trainers-swiper {
    margin-left: -24px;
    margin-right: -24px;
    padding-left: 24px;
    padding-right: 24px;
}

.p-homepage-trainers-heading {
    text-align: center;
    margin-bottom: 48px;
}

.p-homepage-blog {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-homepage-blog-heading {
    text-align: center;
    margin-bottom: 48px;
}

.p-homepage-blog-button {
    margin-top: 48px;
    margin-left: auto;
    margin-right: auto;
}

/* search-suggest */
.p-search-suggest {
    position: absolute;
    width: 100%;
    margin-top: 8px;
    border: 1px solid var(--low-emphasis-2);
    border-radius: 12px;
    background: var(--white);
    z-index: 5;
    text-align: left;
}

.p-search-suggest-inner {
    padding: 32px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.p-search-suggest-heading {
    margin-bottom: 8px;
}

.p-search-suggest-item-result {
    font-weight: 400;
}

.p-hl {
    font-weight: 600;
}

.p-search-suggest-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.p-search-suggest-item {
    display: inline-flex;
    gap: 16px;
    align-items: center;
    padding: 4px 8px;
}

.p-search-suggest-item:hover {
    background: var(--off-white-2);
    border-radius: 4px;
    cursor: pointer;
}

.p-search-suggest-item:hover .p-icon {
    fill: var(--brand-01);
}

.p-search-suggest-item-label,
.p-search-suggest-sub {
    display: block;
}

.p-search-suggest-sub {
    font-size: 10px;
    line-height: 1.2em;
}

.p-search-suggest-city,
.p-search-suggest-gym {
    padding: 4px 0;
}

.autocomplete-wrapper {
    position: relative;
}

/* homepage info */
.p-homepage-info {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-homepage-info-heading {
    text-align: center;
    margin-bottom: 32px;
    max-width: 768px;
    margin-left: auto;
    margin-right: auto;
}

.p-homepage-info-features {
    display: flex;
    margin-top: 48px;
}

.p-homepage-features-swiper {
    margin-left: -24px;
    margin-right: -24px;
    padding-left: 24px;
    padding-right: 24px;
}

.p-homepage-info-features .swiper-slide {
    height: auto;
    align-self: stretch;
}

.p-homepage-info-feature {
    padding: 96px 32px 48px 32px;
    border-radius: 24px;
    background: var(--off-white-blue);
    height: 100%;
}

.p-homepage-info-feature-img-wrap {
    background: var(--gray-1);
    border-radius: 64px;
    padding: 16px;
    margin-bottom: 16px;
    border-radius: 80px;
    display: inline-block;
}

.p-homepage-info-feature-img {
    fill: var(--white);
    width: 40px;
    height: 40px;
}

.p-homepage-info-feature-title {
    margin-bottom: 8px;
    max-width: 24ch;
}

/* homepage cta box */
.p-homepage-cta {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-homepage-cta-inner {
    display: flex;
    align-items: center;
}

.p-homepage-cta-content {
    max-width: 640px;
}

.p-homepage-cta-heading {
    margin-bottom: 16px;
}

.p-homepage-cta-subtitle {
    margin-bottom: 32px;
    margin-top: 24px;
}

.p-homepage-cta-buttons-wrap {
    margin-top: 64px;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.p-homepage-cta-image-wrap {
    width: 100%;
    min-width: 60%;
    position: relative;
    overflow-x: hidden;
}
.p-homepage-cta-image {
    width: 130%;
    height: auto;
    max-width: unset;
}

.p-homepage-cta-image-box {
    background: var(--off-white-blue);
    border-radius: 32px;
    width: 70%;
    height: 90%;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}
.p-homepage-cta-image-box-inner {
    width: 100%;
    height: 100%;
    position: relative;
}
.p-blobs--homepage-cta {
    --blobs-size: 160%;
    --blobs-anchor-x: 70%;
    --blobs-anchor-y: 95%;
    --blobs-rotate: -10deg;
    --blobs-scale-y: 0.7;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

/* blog */
.p-blog-hero {
    background: var(--gray-1);
    border-radius: 32px;
    margin-left: 24px;
    margin-right: 24px;
    margin-bottom: 48px;
    text-align: center;
}

.p-blog-hero-item-wrap {
    border-radius: 16px;
    overflow: hidden;
    position: relative;
}

.p-blog-hero-item-media {
    position: relative;
    width: 100%;
    height: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.p-blog-hero-item-image {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 3 / 2;
    height: 700px;
    border-radius: 32px;
}

.p-blog-hero-item-media-link {
    grid-column: 2;
}

.p-blog-hero-item-image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        245deg,
        rgba(0, 0, 0, 0) 35%,
        rgba(0, 0, 0, 0.4) 65%
    );
    z-index: 0;
}

.p-blog-hero-item-content {
    position: absolute;
    inset: 0;
    width: 100%;
    z-index: 1;
    display: flex;
    flex-direction: column;
    text-align: left;
    padding-bottom: 80px;
    padding-top: 80px;
    pointer-events: none;
    justify-content: center;
}

.p-blog-hero-item-content-inner {
    max-width: calc(50% - 64px);
}

.p-blog-hero-item-container {
    width: 100%;
}

.p-blog-hero-item-category {
    margin-bottom: 16px;
    pointer-events: all;
}

.p-blog-hero-item-title {
    margin-bottom: 16px;
    pointer-events: all;
}

.p-blog-hero-item-excerpt {
    margin-bottom: 48px;
}

.p-blog-hero-item-read-more {
    pointer-events: all;
}

.p-blog-hero-post-swiper-pagination-wrap {
    position: absolute;
    z-index: 2;
    width: 100%;
    left: 0;
    right: 0;
    bottom: 48px;
}

.p-blog-hero-post-swiper-pagination {
    text-align: left;
    display: flex;
    gap: 16px;
}

.p-blog-hero-post-swiper-pagination .swiper-pagination-bullet {
    background: var(--low-emphasis-2);
    margin: 0 !important;
    width: 128px;
    height: 2px;
    border-radius: 12px;
    opacity: 1;
}

.p-blog-hero-post-swiper-pagination .swiper-pagination-bullet-active {
    background: var(--brand-02);
}

/* blog categories */
.p-blog-categories {
    margin-top: 32px;
    margin-bottom: 32px;
}

.p-blog-categories-list {
    display: flex;
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.p-blog-categories-item.swiper-slide {
    width: auto;
}

.p-blog-categories-label {
    color: var(--gray-3);
    background: var(--off-white-2);
    padding: 16px 32px;
    border-radius: 12px;
    display: inline-block;
    transition: all 200ms ease;
    white-space: nowrap;
}

.p-blog-categories-label:hover {
    cursor: pointer;
    background: var(--off-white-1);
}

.p-blog-categories-label-active {
    background: var(--gray-1);
    color: var(--white);
}

.p-blog-categories-label-active:hover {
    background: var(--gray-2);
}

/* blog grid */
.p-blog-grid-inner {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 32px;
}

.p-blog-intro {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-blog-intro .container {
    max-width: 1280px;
}

.p-blog-intro-header {
    text-align: center;
    margin-bottom: 48px;
}

.p-blog-intro-title {
    margin-bottom: 24px;
}

/* post card */
.p-post-card {
    display: flex;
    flex-direction: column;
}

.p-post-card-media {
    border-radius: 24px;
    overflow: hidden;
}

.p-post-card-image {
    width: 100%;
    height: auto;
    aspect-ratio: 5 / 3;
    object-fit: cover;
}

.p-post-card-content {
    padding: 24px 32px 32px;
    flex: 1;
}

.p-post-card-category {
    margin-bottom: 8px;
}

.p-post-card-title {
    margin-bottom: 16px;
}

.p-post-card-excerpt {
    margin-bottom: 32px;
    color: var(--gray-2);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.p-post-card-read-more:hover {
    text-decoration: underline;
}

/* post single */
.p-post-single-container {
    max-width: 960px;
}

.p-post-single-media {
    margin-bottom: 48px;
    margin-left: 24px;
    margin-right: 24px;
}
.p-post-single-media-inner {
    width: 100%;
}

.p-post-single-featured-image {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 1;
    object-fit: cover;
    border-radius: 32px;
    max-height: 600px;
    max-width: 1600px;
    margin: 0 auto;
}

.p-post-single-category {
    margin-bottom: 24px;
}

.p-post-single-title {
    margin-bottom: 32px;
}

.p-post-single-lead {
    color: var(--gray-2);
    font-size: 24px;
    font-weight: 600;
}

.p-post-single-header {
    margin-bottom: 80px;
}

.p-post-single-breadcrumbs .p-breadcrumbs {
    margin-top: 0;
}

.p-post-single-meta-wrap {
    display: flex;
    gap: 32px;
    justify-content: space-between;
    margin-bottom: 32px;
}

.p-post-single-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    color: var(--gray-3);
    font-size: 12px;
}

.p-post-single-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.p-post-single-share {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    margin-top: 24px;
}

.p-post-single-share-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.p-post-single-share-button,
.p-post-single-share-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 999px;
    padding: 10px 18px;
    border: 1px solid var(--low-emphasis-2);
    background: var(--white);
    color: var(--gray-2);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition:
        border-color 200ms,
        color 200ms;
}

.p-post-single-share-button {
    cursor: pointer;
}

.p-post-single-share-button:hover,
.p-post-single-share-link:hover {
    border-color: var(--brand-02);
    color: var(--brand-02);
}

.p-post-single-share-button svg,
.p-post-single-share-link svg {
    width: 16px;
    height: 16px;
}

.p-post-single-share-button-native[hidden] {
    display: none;
}

/* post single body */
.p-post-single-body {
    color: var(--gray-2);
}

.p-post-single-body > *:first-child {
    margin-top: 0;
}

.p-post-single-body img {
    width: 100%;
    height: auto;
    border-radius: 16px;
}

.p-post-single-body p {
    margin-bottom: 16px;
}

.p-post-single-body p + p {
    margin-top: -8px;
}
.p-post-single-body p + ol,
.p-post-single-body p + ul {
    margin-top: -8px;
}

.p-post-single-body h2,
.p-post-single-body h3,
.p-post-single-body h4 {
    margin-top: 48px;
    margin-bottom: 16px;
}

.p-post-single-body h2 {
    font-size: 28px;
}

.p-post-single-body h3 {
    font-size: 24px;
}

.p-post-single-body h4 {
    font-size: 20px;
}

.p-post-single-body .t-caption {
    font-weight: 400;
    font-size: 14px;
    line-height: 1.3em;
}

/* lists */
.p-post-single-body ul,
.p-post-single-body ol,
.p-static-content ul,
.p-static-content ol {
    margin-bottom: 16px;
    padding-left: 0;
    list-style: none;
}

.p-post-single-body ul li,
.p-post-single-body ol li,
.p-static-content ul li,
.p-static-content ol li {
    margin-bottom: 8px;
    padding-left: 24px;
    position: relative;
}

.p-post-single-body ul li:last-child,
.p-post-single-body ol li:last-child,
.p-static-content ul li:last-child,
.p-static-content ol li:last-child {
    margin-bottom: 0;
}

.p-post-single-body li[data-list="bullet"]::before,
.p-static-content ul > li::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--brand-02);
    position: absolute;
    left: 6px;
    top: 0.7em;
}

.p-post-single-body ol li::before,
.p-static-content ol > li::before {
    position: absolute;
    left: 0;
    color: var(--brand-02);
    font-weight: 600;
}

/* reset list */
.p-static-content ul,
.p-static-content ol {
    margin-bottom: 24px;
    padding-left: 0;
    list-style: none;
}

/* elementy list */
.p-static-content ul li,
.p-static-content ol li {
    margin-bottom: 8px;
    padding-left: 24px;
    position: relative;
}

.p-static-content ul li:last-child,
.p-static-content ol li:last-child {
    margin-bottom: 0;
}

/* ol - counter */

/* każdy ol resetuje "item" */
.p-static-content ol {
    counter-reset: item;
}

/* każdy li w ol zwiększa licznik */
.p-static-content ol li {
    counter-increment: item;
}

/* generowanie pełnej ścieżki: 1, 1.1, 1.1.1 ... */
.p-static-content ol li::before {
    content: counters(item, ".") ".";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--brand-02);
    font-weight: 600;
}

.p-legal-article ol li[data-paragraph]::before {
    content: attr(data-paragraph) "." counters(item, ".");
}

/* ul */

.p-static-content ul,
.p-static-content ul li {
    counter-reset: none;
    counter-increment: none;
}

.p-static-content ul > li::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--brand-02);
    position: absolute;
    left: 6px;
    top: 0.7em;
}

/* poziom 1 */

/* poziom 2 */
.p-static-content ul ul li,
.p-static-content ol ol li {
    padding-left: 32px;
}

/* poziom 3 */
.p-static-content ul ul ul li,
.p-static-content ol ol ol li {
    padding-left: 48px;
}

/* poziom 4 — opcjonalnie */
.p-static-content ul ul ul ul li,
.p-static-content ol ol ol ol li {
    padding-left: 64px;
}

/* legal levels */
.p-legal-article ol li {
    padding-left: 32px;
}
.p-legal-article ol ol li {
    padding-left: 48px;
}
.p-legal-article ol ol ol li {
    padding-left: 64px;
}
.p-legal-article ol ol ol ol li {
    padding-left: 80px;
}

/* post table of contents */
.p-post-single-toc {
    background: var(--off-white-2);
    border-radius: 16px;
    padding: 32px;
    margin-top: 24px;
}

.p-post-single-toc-label {
    margin-bottom: 16px;
}

.p-post-single-toc-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.p-post-single-toc-item {
    font-size: 14px;
}

.p-post-single-toc-item-number {
    font-weight: 600;
    margin-right: 8px;
    color: var(--brand-02);
}

.p-post-single-toc-item a {
    color: var(--gray-2);
    text-decoration: none;
}

.p-post-single-toc-item a:hover {
    color: var(--brand-02);
}

.p-post-single-toc-item-level-1 {
    margin-left: 0;
}

.p-post-single-toc-item-level-2 {
    margin-left: 16px;
}

.p-post-single-toc-item-level-3 {
    margin-left: 32px;
}

/* post related */
.p-post-related {
    margin-top: 80px;
    margin-bottom: 80px;
}

.p-post-related-title {
    margin-bottom: 48px;
}

/* plan cards */
.p-plan-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0 24px;
    justify-content: center;
    max-width: 1280px;
    margin: 0 auto;
    /* grid-template-rows: auto auto auto auto auto 1fr auto; */
}

.p-plan-card {
    border: 1px solid var(--low-emphasis-2);
    border-radius: 20px;
    padding: 32px;
    background: var(--white);
    position: relative;
}

.p-plan-card-title-wrap {
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: space-between;
}

.p-plan-card-title {
    font-family: "personalny-font", sans-serif;
    font-style: italic;
    font-weight: 500;
    font-size: 40px;
}

.p-plan-card--pro .p-plan-card-title {
    color: var(--brand-02);
}

.p-plan-card--highlighted {
    background: var(--gradient-pro);
}

.p-plan-card--highlighted .p-plan-card-title {
    color: var(--white);
}

.p-plan-card--highlighted .p-plan-card-price-amount,
.p-plan-card--highlighted .p-plan-card-price-period,
.p-plan-card--highlighted .p-plan-card-description,
.p-plan-card--highlighted .p-plan-feature-title,
.p-plan-card--highlighted .p-plan-feature-description,
.p-plan-card--highlighted .p-plan-feature-list li {
    color: var(--white);
}

.p-plan-card--highlighted .p-button {
    color: var(--brand-02);
    background: var(--white);
}

.p-plan-card-trial-badge {
    /* position: absolute;
    top: 24px; */
    color: var(--brand-02);
    font-size: 13px;
    background: var(--promotion-green);
    padding: 4px 16px;
    border-radius: 64px;
}

.p-plan-card--highlighted .p-icon {
    fill: var(--promotion-green);
}

.p-plan-card-price {
    display: flex;
    gap: 8px;
    align-items: baseline;
    margin-bottom: 24px;
}

.p-plan-card-price--yearly {
    display: none;
}

.p-plan-card-price-amount {
    font-weight: 600;
    font-size: 48px;
    line-height: 1.3em;
    color: var(--gray-2);
}

.p-plan-card-price-free {
    font-weight: 600;
    font-size: 36px;
    line-height: calc(48px * 1.35);
    color: var(--gray-2);
}

.p-plan-card-description,
.p-plan-feature-description,
.p-plan-card-price-period {
    font-weight: 400;
    font-size: 14px;
    color: var(--gray-2);
    line-height: 1.3em;
    text-align: left;
}

.p-plan-card-description {
    margin-bottom: 24px;
    color: var(--gray-4);
}

/* .p-plan-feature-title {
    margin-bottom: 8px;
    font-weight: 600;
    font-size: 17px;
    line-height: 1.3em;
    color: var(--gray-3);
}

.p-plan-feature {
    margin-bottom: 24px;
} */

.p-plan-feature-list {
    margin-bottom: 24px;
    padding-left: 0;
    list-style: none;
}

.p-plan-feature-list li {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    color: var(--gray-2);
    font-size: 14px;
    line-height: 1.3em;
    text-align: left;
}

.p-plan-cta-wrap {
    margin-bottom: 24px;
}

.p-plan-feature-list li:last-child {
    margin-bottom: 0;
}

.p-plan-cards-billing-cycle {
    margin-bottom: 48px;
}

.p-plan-cards-wrapper {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

/* newsletter */
.p-newsletter {
    margin-top: 128px;
    margin-bottom: 128px;
    text-align: center;
}

.p-newsletter-title {
    max-width: 768px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 48px;
}

.p-newsletter-icon-wrap {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 24px;
    display: inline-block;
    padding: 16px;
    border-radius: 64px;
    background: var(--gray-1);
}

.p-newsletter-form-wrap {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

.p-newsletter-form-wrap .form-check {
    text-align: left;
    margin-top: 24px;
}

.p-newsletter-form-wrap .p-newsletter-privacy-label {
    font-weight: 400;
    font-size: 12px;
    color: var(--gray-3);
    line-height: 1.2em;
    margin-top: 0;
}

/* newsletter pages */
.p-newsletter-status-container {
    max-width: 1024px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 80px;
    margin-bottom: 128px;
    text-align: center;
    padding: 80px 24px;
    background: var(--off-white-blue);
    border-radius: 32px;
    position: relative;
    overflow: hidden;
}

.p-newsletter-status-content {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

.p-newsletter-status-image-icon {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 24px;
    max-width: 456px;
    width: 100%;
}

.p-blobs--newsletter {
    --blobs-size: 100%;
    --blobs-anchor-x: 90%;
    --blobs-anchor-y: 30%;
    --blobs-rotate: -270deg;
    --blobs-scale-y: 1;
    --blobs-scale-x: 1;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

/* static page */
.p-static-container {
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
}

.p-static-hero {
    margin-bottom: 80px;
    margin-left: 24px;
    margin-right: 24px;
    background: var(--off-white-blue);
    border-radius: 32px;
    padding: 80px;
    position: relative;
}

.p-static-hero-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

.p-static-body ul,
.p-static-body ol {
    margin-top: 8px;
    margin-bottom: 8px;
}

.p-static-body ul li,
.p-static-body ol li {
    margin-bottom: 4px;
}

/* blobs */
.p-bg-blobs {
    position: absolute;
    inset: 0;
    overflow: hidden;
    border-radius: 32px;
    pointer-events: none;
}

/* wrapper na preset */
.p-blobs-wrap {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

/* płótno blobów – to co skalujesz i kotwisz */
.p-blobs-canvas {
    position: absolute;

    /* rozmiar płótna */
    width: var(--blobs-size, 100%);
    aspect-ratio: var(--blobs-ar, 1 / 1);

    /* gdzie ma leżeć środek */
    top: var(--blobs-anchor-y, 50%);
    left: var(--blobs-anchor-x, 50%);

    /* najpierw środek w anchor, potem skalowanie i obrót od środka,
       na końcu drobna korekta przesunięcia */
    transform: translate(-50%, -50%) rotate(var(--blobs-rotate, 0deg))
        scaleX(var(--blobs-scale-x, 1)) scaleY(var(--blobs-scale-y, 1))
        translate(var(--blobs-shift-x, 0), var(--blobs-shift-y, 0));

    transform-origin: center center;
    opacity: 0.9;
}

/* w środku jak wcześniej */
.p-blobs-group {
    position: relative;
    width: 100%;
    height: 100%;
}

.p-blob {
    position: absolute;
    display: block;
    max-width: none;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    will-change: transform;
}

.p-blob--1 {
    width: 60%;
    top: 30%;
    left: 10%;
    animation-name: blob-drift-left;
    animation-duration: 4s;
}

.p-blob--2 {
    width: 100%;
    top: 0;
    left: 0;
    animation-name: blob-drift-center;
    animation-duration: 8s;
}

.p-blob--3 {
    width: 80%;
    top: -15%;
    left: 30%;
    animation-name: blob-drift-right;
    animation-duration: 6s;
}

/* animacje jak wcześniej */
@keyframes blob-drift-left {
    0% {
        transform: translate3d(-1%, 1%, 0) scale(0.97) rotate(-18deg);
    }
    35% {
        transform: translate3d(0%, -1%, 0) scale(1.04) rotate(-6deg);
    }
    70% {
        transform: translate3d(-1%, 0%, 0) scale(1.05) rotate(14deg);
    }
    100% {
        transform: translate3d(0%, 1%, 0) scale(0.96) rotate(-12deg);
    }
}

@keyframes blob-drift-center {
    0% {
        transform: translate3d(-1%, -1%, 0) scale(1.02) rotate(-6deg);
    }
    30% {
        transform: translate3d(0%, 1%, 0) scale(1.08) rotate(10deg);
    }
    55% {
        transform: translate3d(1%, -1%, 0) scale(1.03) rotate(-12deg);
    }
    85% {
        transform: translate3d(0%, 1%, 0) scale(1.07) rotate(16deg);
    }
    100% {
        transform: translate3d(1%, 0%, 0) scale(1.04) rotate(-4deg);
    }
}

@keyframes blob-drift-right {
    0% {
        transform: translate3d(1%, -1%, 0) scale(1.01) rotate(4deg);
    }
    30% {
        transform: translate3d(0%, 0%, 0) scale(1.05) rotate(-6deg);
    }
    60% {
        transform: translate3d(-1%, 0%, 0) scale(1.02) rotate(-18deg);
    }
    100% {
        transform: translate3d(0%, 1%, 0) scale(1.01) rotate(12deg);
    }
}

/* wyłączenie zaznaczania itp. */
.p-bg-blobs,
.p-blobs-wrap,
.p-blob,
.p-blob img {
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}

/* wariant dla hero – zamiast transform ustawiasz zmienne */
.p-blobs--static-hero {
    --blobs-size: 50%;
    --blobs-anchor-x: 100%;
    --blobs-anchor-y: 30%;
    --blobs-rotate: 0deg;
    --blobs-scale-y: 0.7;
    --blobs-scale-x: 2.5;
    --blobs-shift-x: 0%;
    --blobs-shift-y: 0%;
}

/* contact page */

.p-contact-page-details {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
    margin-top: 80px;
}

.p-contact-page-details-section h3 {
    margin-top: 0;
}

/* Demo */
.p-demo-plan-bar {
    position: fixed;
    bottom: 32px;
    left: 50%;
    transform: translate(-50%);
    z-index: 9;
    background: var(--brand-01);
    padding: 24px 32px;
    border-radius: 64px;
}

.p-demo-plan-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 48px;
}

.p-demo-plan-actions {
    display: flex;
    gap: 8px;
}

.p-demo-plan-chip {
    color: var(--white);
    text-decoration: none;
    padding: 8px 32px;
    border-radius: 64px;
    border: 1px solid var(--brand-03);
    transition: all 0.2s ease;
    font-family: "personalny-font", sans-serif;
    font-style: italic;
    font-weight: 500;
    font-size: 18px;
    line-height: 1;
}

.p-demo-plan-chip:hover {
    background: var(--white);
    color: var(--brand-01);
    border-color: var(--brand-01);
}

.p-demo-plan-chip.is-active {
    background: var(--white);
    border-color: var(--white);
    color: var(--brand-01);
}

/* FAQ */
.p-faq-accordion {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 48px;
    max-width: 1024px;
    margin-left: auto;
    margin-right: auto;
}

.p-faq-item {
    background: var(--white);
    border: 1px solid var(--low-emphasis-3);
    border-radius: 32px;
    overflow: hidden;
    transition:
        border-color 0.2s ease,
        background 0.2s ease;
}

.p-faq-item:hover {
    border-color: var(--low-emphasis-2);
}

.p-faq-item.is-open {
    border-color: var(--low-emphasis-2);
    background: var(--off-white-blue);
}

/* Question Button */
.p-faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
    padding: 32px 48px;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
}

.p-faq-question:hover .p-faq-question:focus,
.p-faq-question:focus-visible {
    outline: none;
}

.p-faq-question-text {
    flex: 1;
}

/* Icon */

/* Icon visibility toggle */
.p-faq-icon-open {
    display: none;
}

.p-faq-item.is-open .p-faq-icon-closed {
    display: none;
}

.p-faq-item.is-open .p-faq-icon-open {
    display: block;
}

/* Answer Panel */
.p-faq-answer {
    overflow: hidden;
    transition: height 0.3s ease;
}

.p-faq-answer[hidden] {
    display: block;
    height: 0;
    visibility: hidden;
}

.p-faq-answer:not([hidden]) {
    visibility: visible;
}

.p-faq-answer-inner {
    padding: 0 48px 32px;
    font-size: 16px;
    line-height: 1.6;
    color: var(--gray-2);
}

.p-faq-answer-inner p {
    margin: 0 0 12px 0;
}

.p-faq-answer-inner p:last-child {
    margin-bottom: 0;
}

.p-faq-answer-inner a {
    color: var(--brand-02);
    text-decoration: underline;
}

.p-faq-answer-inner a:hover {
    color: var(--brand-01);
}

.p-faq-answer-inner ul,
.p-faq-answer-inner ol {
    margin: 12px 0;
    padding-left: 24px;
}

.p-faq-answer-inner li {
    margin-bottom: 8px;
}
