@charset "UTF-8";
/*
Theme Name: FEMILITE 3.6 - Subskrypcje
Author: studiobrothers.pl
Version: 1.0
Requires PHP: 7.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: s
*/
/* =WordPress Core
-------------------------------------------------------------- */
/* Text meant only for screen readers. */
.alignnone {
  margin: 5px 20px 20px 0;
}

.aligncenter {
  display: block;
  margin: 5px auto 5px auto;
}

div.aligncenter {
  display: block;
  margin: 5px auto 5px auto;
}

.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}

.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}

a img.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}
a img.alignnone {
  margin: 5px 20px 20px 0;
}
a img.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}
a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption {
  background: #fff;
  border: 1px solid #f0f0f0;
  max-width: 96%;
  padding: 5px 3px 10px;
  text-align: center;
}
.wp-caption img {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 98.5%;
  padding: 0;
  width: auto;
}
.wp-caption p.wp-caption-text {
  font-size: 11px;
  line-height: 17px;
  margin: 0;
  padding: 0 4px 5px;
}

.wp-caption.alignnone {
  margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
  margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
  margin: 5px 0 20px 20px;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}
.screen-reader-text:focus {
  background-color: #eee;
  clip: auto !important;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 1em;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

.wp-block-columns {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px 15px;
  align-items: center !important;
}
.wp-block-columns.flex-start {
  align-items: flex-start !important;
}
.wp-block-columns .wp-block-column {
  flex: 1;
  padding: 15px;
}
.wp-block-columns .wp-block-column figure.wp-block-image:not(.normal) img {
  width: 100%;
}

.wp-block-separator {
  border-color: #D9251C;
  opacity: 0.1;
  margin-bottom: 30px;
}



.femi-team__nav .splide-arrow {
    position: relative;
    right: 0;
    margin: 0 !important;
}

.femi-team__nav {
    gap: 17px;
}

.femi-team__nav .femi-team__count {
    font-size: 1.25em;
    color: #DE832B;
    display: flex;
    letter-spacing: 0.3em;
}

.femi-team__nav {
    margin-top: 4em;
        margin-bottom: -3em;
}

.program-femilite__top {
    display: grid;
    grid-template-columns: 50em 13em;
    justify-content: space-between;
}

.program-femilite__top h2 {
  margin-bottom: 1em;
}

.program-femilite__top svg {
    width: 100%;
    height: auto;
}

.program-femilite__slider {
    display: grid;
    grid-template-columns: repeat(5,1fr);
    text-align: center;
    gap: 1em;
    margin-top: 4em;
}

.program-femilite__slider > div {background: #F2F9F3;border-radius: 1em;padding: 0.5em;}

.program-femilite__slider > div h3 {
    font-size: 1.2em;
    font-weight: 500;
    margin: 0.5em;
}

.program-femilite__slider > div p {
    font-size: 0.875em;
    padding-bottom: 0.5em;
}


.program-femilite__slider > div > div {
    position: relative;
}

.program-femilite__slider > div > div .splide__arrows button {
    position: relative;
    width: 1.5em;
    height: 1.5em;
    background-size: 0.5em;
    margin: 0;
    bottom: 0;
    opacity: 1;
    border: 1px solid #ffcd9d;
}

.program-femilite__slider > div > div .splide__arrows {
    padding: 0 0.7em;
    margin-top: -2em;
    position: relative;
    top: -1em;
    margin-bottom: 0.6em;
}

.program-femilite__slider > div h5 {
    font-size: 0.785rem;
    background: rgba(255,255,255,0.9);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    bottom: 4.4em;
    color: #014550;
    font-weight: 500;
    height: 3.5em;
    display: flex;
    align-items: center;
    justify-content: center;
}

.program-femilite__person img {
    border-radius: 1em;
    margin-bottom: 1em;
    aspect-ratio: 1 / 1.28;
    width: 100%;
}

.program-femilite__slider > div > div .splide__arrows button.splide__arrow.splide__arrow--next {
    background-image: url(/wp-content/uploads/2025/06/arrow-orange-22.svg);
}

@media(max-width: 768px) {
  .program-femilite__top svg {
    display: none;
  }

  .program-femilite__top {
    grid-template-columns: 1fr;
  }

  .program-femilite__slider > div {
    width: 49%;
}

  .program-femilite__slider {
    display: flex
;
    grid-template-columns: repeat(2, 1fr);
    text-align: center;
    gap: 1em;
    margin-top: 4em;
    justify-content: center;
    flex-wrap: wrap;
  }
}




.program-femilite__slider > div > div .splide__arrows svg path {
    fill: transparent !important;
}

.program-femilite__slider > div > div .splide__arrows svg {
    filter: brightness(0) invert(1);
    width: 0.7em;
}

.program-femilite__slider > div > div .splide__arrow {background: #df832b;background-image: unset !important;border-color: #df832b !important;}

@media(max-width: 768px) {


  .program-femilite__slider > div > div .splide__arrows {
    top: -1.5em;
  }

.program-femilite__slider {
    flex-wrap: nowrap;
    overflow: scroll;
    justify-content: left;
    width: auto;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    
    /* Snap scrolling (opcjonalne) */
    scroll-snap-type: x mandatory;
}

.program-femilite__slider > div {
    flex: 0 0 43%; /* Stała szerokość */
    min-width: 43%;
    scroll-snap-align: start;
}


        .program-femilite__slider::-webkit-scrollbar {
            height: 10px;
            margin-top: 20px;
        }

        .program-femilite__slider::-webkit-scrollbar-track {
            background: rgb(242 249 243);
            border-radius: 15px;
        }

        .program-femilite__slider::-webkit-scrollbar-thumb {
            background: #ffdab7;
            border-radius: 15px;
            border: 1px solid transparent;
            background-clip: content-box;
            transition: all 0.3s ease;
        }

      



.program-femilite__slider {
    padding-bottom: 20px;
}

}

@media(max-width: 567px) {



.program-femilite__slider > div {
    flex: 0 0 80%; /* Stała szerokość */
    min-width: 80%;
}


}




.page-template-page-home4 canvas#myChart,
.home canvas#myChart {
    width: 100% !important;
    height: auto !important;
}



.p_spacing p {
    margin-bottom: 1em;
}

.splide_femi-team {
    margin-bottom: -12em;
}

@media(max-width: 768px){
    .team_ceo_left_column {
    max-width: 100% !important;
}

.team_ceo_text_wrap {
    max-width: 100% !important;
}

.team_ceo_image_wrap {
    margin-left: auto;
    margin-right: auto;
}

.splide_femi-team {
    margin-bottom: -5em;
}
}

.program-femilite__slider > div p {
    min-height: 12em;
}

.program-femilite__slider > div span {
    background: #D1F1D5;
    display: block;
    border-radius: 0 0 0.9em 0.9em;
    font-weight: 500;
    font-size: 0.7em;
    padding: 0.8em 1.5em;
    line-height: 1.4;
}

@media(max-width: 768px){
    .program-femilite__slider > div p {
    min-height: 30vw;
}
}

.page-template-page-harmonogram-video  .db_materials_outer_list_wrap > div {
    display: block !important;
}

@media(min-width: 992px){
    .recipe-info h4 {
    font-size: 0.71em !important;
    min-height: 4em!important;
}
}

.db_materials_dd_list_item p {
    margin-bottom: 1em;
}


@media(max-width: 768px) {
  .account_main_flex {
    grid-row-gap: 1em !important;
  }
}


.account_menu__wrap-mobile {
    color: #fff;
    background: #014550;
    display: none;
    width: 100%;
    padding: 12px;
    border-radius: 6px;
    font-size: 13px;
}


@media(max-width: 768px) {
  .account_main_flex {
    grid-row-gap: 1em !important;
  }

  .account-menu-wrapper .account_menu_wrap{
    width: 100%;
    display: none;
}

.account-menu-wrapper .account_menu_wrap.show {
  display: flex !important;
}

.account_menu__wrap-mobile {
  display: block;
}


}



.month-nav-item:not(.disabled) .month-icon::before { content: "📅"; }

.quiz_form_flex:not(.is--disease) {
  max-width: 50em !important;
}

.filter-container ~ table * {
  font-size: 12px !important;
}

/* Filary Programu Sekcja */
.fillar-femilite__header {
  text-align: center;
  margin-bottom: 3rem;
}

.fillar-femilite__header p {
  max-width: 38em;
  margin: 40px auto 20px;
}
.fillar-femilite__header h2 {
  margin-bottom: 1rem;
}

.fillar-femilite__flex {
  display: grid;
  grid-template-columns: 30rem 1fr;
  gap: 3rem;
  align-items: flex-start;
  align-items: center;
}

.fillar-femilite__video-column {
  position: sticky;
  top: 2rem;
}

.fillar-femilite__video-container {
  position: relative;
  border-radius: var(--border-15px);
  overflow: hidden;
  aspect-ratio: 9/16;
  max-width: 24em;
  margin: 0 auto;
}

.fillar-femilite__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.fillar-femilite__video.active {
  opacity: 1;
}

.fillar-femilite__tabs-column {
  flex: 1;
}

.fillar-femilite__tab-toggle {
  align-items: center;
}

.fillar-femilite__tab-number {
  font-weight: 600;
  color: var(--site-colors--orange02);
  margin-right: 0.5rem;
  min-width: 1.5em;
}

.fillar-femilite__mobile-video {
  display: none;
  margin-top: 1rem;
}

.fillar-femilite__mobile-video-player {
  width: 100%;
  border-radius: var(--border-15px);
  aspect-ratio: 16/9;
}





.fillar-femilite__tab.w--open-tab .faq_arrow {
  transform: rotate(180deg);
}

/* Smooth transitions for tab interactions */
.fillar-femilite__tab .faq_dropdown_toggle {
  transition: background-color 0.3s ease, border-bottom-color 0.3s ease;
}

.fillar-femilite__tab .faq_arrow {
  transition: transform 0.3s ease;
}

/* User's custom tab animations - using w--open-tab class */

/* Mobile responsiveness */
@media screen and (max-width: 991px) {
  .fillar-femilite__flex {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  .fillar-femilite__video-column {
    display: none;
  }
  
  .fillar-femilite__mobile-video {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .fillar-femilite__header {
    margin-bottom: 2rem;
  }
  
  .fillar-femilite__mobile-video-player {
    /* aspect-ratio: 9/16; */
    aspect-ratio: auto;
        max-width: 300px;
        margin: 0 auto;
        display: block
  }
}

.faq_dropdown.fillar-femilite__tab.w--open-tab {
  background: #f2f9f3 !important;
}

.faq_dropdown.fillar-femilite__tab {
  transition: all .5s;
}

/* fadeIn/fadeOut will handle display - removing CSS display:none */

.fillar-femilite__tabs-column .faqs_list_wrap {
  align-items: flex-start;
}

.fillar-femilite__tabs-column .faqs_list_wrap > a {
  margin-top: 1em;
  gap: 0.3em;
}

.fillar-femilite__tab .faq_dropdown_toggle .is--faq-question {
  font-weight: 600;
}

@media(max-width: 768px) {
  .fillar-femilite__tabs-column .faqs_list_wrap > a {
    margin: 30px auto 0;
}
}

.page-template-page-oferta .fillar-femilite__tabs-column .faqs_list_wrap > a {
  display: none;
}

.home p#breadcrumbs {
  display: none;
}

@media(max-width: 768px) {
  .container.is--hero {
    padding-top: 3em;
  }
}

.info-alert-box {
  margin-top: 2em;
  background: #e60c0c;
  display: block;
  padding: 1em;
  border-radius: 0.4em;
  color: #fff;
  font-size: 1em;
  text-align: center;
}


.doctor-info {
  display: grid;
  grid-template-columns: 17em 1fr;
  gap: 2em;
}

.doctor-info .doctor-info__data > img {
  width: 100%;
  height: 22em;
  object-fit: cover;
  border-radius: 1em;
}

.doctor-info .doctor-info__data .name {
  background: #C5FACB;
  border-radius: 500px;
  width: 15em;
  height: 15em;
  position: absolute;
  bottom: -7.5em;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 0.875em;
}

.doctor-info .doctor-info__data {
  position: relative;
}

.doctor-info .doctor-info__data .name span {
  font-weight: 600;
  display: block;
  margin-bottom: 0.7em;
}

.doctor-info  .doctor-info__text {
  color: #014550;
  padding-top: 1.5em;
  border-top: 0.1em solid #C5FACB;
}

.doctor-info  .doctor-info__text .description {
  opacity: 0.8;
  margin-top: 1em;
  line-height: 1.5;
}

@media(max-width: 768px) {
  .doctor-info {
    grid-template-columns: 1fr;
    text-align: center;
}

.doctor-info .doctor-info__text {
    margin-top: 7em;
    max-width: 30em;
    margin-left: auto;
    margin-right: auto;
}

.doctor-info .doctor-info__data > img {
    max-width: 20em;
    margin: 0 auto;
    display: block;
    height: 28em;
}
}

.doctor-info .doctor-info__text .description p {
    margin-bottom: 1em;
}

.db_contact_wrap_outer__supportinfo {
  display: grid;
  grid-template-columns: 1fr 18em;
  align-items: flex-start;
  gap: 1.25em;
  margin-top: 1em;
}



.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image {
  text-align: center;
  position: sticky;
  top: 1em;
}

.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image span {
  width: 11em;
  height: 11em;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #C5FACB;
  padding: 1em;
  border-radius: 200em;
  position: absolute;
  bottom: -5.5em;
  left: 50%;
  transform: translate(-50%, 0);
}

.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image span strong {
  font-size: 1em;
}

.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image span p {
  font-size: 0.875em;
  margin-top: 0.4em;
}

.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image img {
  border-radius: 1em;
}

.support-message.expert .message-content p {
  margin-bottom: 0.8em;
}

.support-message.expert.welcome-message {
    position: relative;
    padding-left: 5em;
}

.support-message.expert.welcome-message:before {
    content: '';
    width: 4em;
    height: 4em;
    display: block;
    background: url(https://femilite.pl/wp-content/uploads/2024/07/Frame-50985.jpg);
    background-size: cover;
    border-radius: 100em;
    position: absolute;
    left: 0;
    top: 0;
}

/* KOMUNIKATOR EXPERT/USER  */

.page-template-page-komunikator-user div#messages-container {
  border-radius: 1em !important;
  padding: 1em !important;
  margin-bottom: 1.25em !important;
  background: #f2f9f3 !important;
}

.page-template-page-komunikator-user .item.expert .content {
  background: #fff !important;
  margin-right: auto !important;
  padding: 1em !important;
  font-size: 0.75em !important;
  border-radius: 0 0.8em 0.8em 0.8em !important;
  margin-top: 0 !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.expert {
  background: transparent !important;
  width: 100% !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item .top .name {
  width: auto !important;
  font-size: 0.75em !important;
  margin-bottom: 0 !important;
  opacity: 0.8 !important;
  margin-left: 0 !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item .top .date {
  margin-left: 1em !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.user {
  border: 0 !important;
  padding: 1em !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  align-items: flex-end !important;
}

.page-template-page-komunikator-user .item.user .content {
  background: #c5facb !important;
  color: #014550 !important;
  padding: 1em !important;
  font-size: 0.75em !important;
  border-radius: 0.8em 0em 0.8em 0.8em !important;
}

.page-template-page-komunikator-user div#messages-container {
  padding: 0 !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item {
  margin-bottom: 0 !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item .content {
  margin-top: 1em !important;
  margin-left: 0 !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.user .top .thumb {
  display: none !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.expert .top .thumb {
  margin-right: 1em !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.expert .top {
  margin-bottom: 1em !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.user .top {
  justify-content: flex-end !important;
}

.page-template-page-komunikator-user .chat-user-page .messages-list .list .item.user .content {
  margin-right: 0 !important;
  width: fit-content !important;
}


@media(max-width: 768px) {
  .db_contact_wrap_outer__supportinfo {
    display: flex;
    flex-direction: column-reverse;
}

.db_contact_wrap_outer__supportinfo .db_contact_wrap_outer__supportinfo_image {
    position: relative;
    top: 0;
    margin-bottom: 2em;
    max-width: 20em;
    margin: 0 auto 6em;
}
}

.new-message-form textarea {
  border: 1px solid #c5facb;
  border-radius: 0.5em;
  height: 12em;
  resize: none;
}

.conversations-list {
  margin-top: 1.25em;
}

.conversation-item {
  background: #fff;
  border: 0.0625em solid #ddd;
  border-radius: 0.5em;
  padding: 0.9375em;
  margin-bottom: 0.9375em;
}

.conversation-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5em;
}

.conversation-link {
  text-decoration: none;
  color: #014550;
  font-size: 1em;
}

.conversation-link:hover {
  text-decoration: underline;
}

.unread-badge {
  background: #e74c3c;
  color: white;
  padding: 0.125em 0.5em;
  border-radius: 0.75em;
  font-size: 0.75em;
  margin-left: 0.5em;
}

.last-message-date {
  color: #666;
  font-size: 0.75em;
}

.last-message-preview {
  color: #666;
  font-size: 0.875em;
  line-height: 1.4;
}

.no-conversations {
  text-align: center;
  padding: 2.5em;
  color: #666;
}



.conversations-list h4 {
  font-size: 1.5em;
  margin-bottom: 1em;
}

@media(min-width: 768px){
  .account-menu-wrapper {
  width: 19em;
}
}

@media(max-width: 767px){
  .account-menu-wrapper {
  width: 100%;
max-width: 100%;
}

  
.account_menu_wrap {
  width: 100% !important;
  max-width: 100% !important;
}
div#messages-container *,
div#support-messages * {
    font-size: 12px;
}

  
}


/* Komunikator Taby  */

.expert-tabs.comunicator-tabs button {
  padding: 0.5em 0.9em;
  font-size: 0.95em;
  border-radius: 100px;
}

.expert-tabs.comunicator-tabs {
  margin-top: 1em;
}

.expert-tabs.comunicator-tabs button.active {
  background: #014550;
  color: #fff;
}

.page-template-page-komunikator-user div#ankieta-content h4,
.page-template-page-komunikator-user div#pomiary-content h4,
.page-template-page-komunikator-user div#notatki-content h4 {
  margin: 1em 0;
  font-size: 1.25em;
  font-weight: 500;
}

.page-template-page-komunikator-user div#notatki-content .add-note-form {
  padding: 0 !important;
  background: transparent !important;
}



.page-template-page-komunikator-user div#notatki-content .add-note-form h5 {
  font-size: 1em;
  margin: 0 0 1em 0;
}

.page-template-page-komunikator-user div#notatki-content .add-note-form button {
  background: #014550 !important;
  border-radius: 100px !important;
}

.page-template-page-komunikator-user div#notatki-content .add-note-form textarea {
  border-radius: 0.5em !important;
  border-color: #06dd8e !important;
  resize: none;
  min-height: 12em;
}

.support-message .message-content p {
  margin-bottom: 1em;
}

.support-message .message-content {
  text-align: left;
}

.support-messages-container {
  display: flex;
  flex-direction: column-reverse;
}

.voice-message-container {
  padding: 0;
  background: transparent;
  border: 0;
}

.voice-record-button {
  background: #014550;
}

span#transcription-status {
  display: none;
}

div#transcription-text {
  margin-top: 10px;
}

/* * NOWE - Style dla wyboru daty jadłospisu w meal-plan-box */ */
.meal-plan-date-section {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

.date-selector {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 1.25em;
    margin-top: 1.25em;
}

.date-label {
    font-size: 13px;
    font-weight: 500;
    color: #666;
    margin: 0;
    white-space: nowrap;
}

.date-input {
    padding: 8px 12px;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    font-size: 13px;
    font-family: inherit;
    background: white;
    color: #014550;
    transition: all 0.3s ease;
    min-width: 140px;
}

.date-input:focus {
    outline: none;
    border-color: #04DD8F;
    box-shadow: 0 0 0 2px rgba(4, 221, 143, 0.1);
}

.date-input:hover {
    border-color: #04DD8F;
}

/* Responsive dla mobile */
@media (max-width: 768px) {
    .meal-plan-date-section {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    
    .date-selector {
        width: 100%;
        justify-content: space-between;
    }
    
    .date-input {
        flex: 1;
        min-width: auto;
    }
}

/* Opinie  */

section.opinion-femilite {
  background: #fff;
}

section.opinion-femilite h2 {
  color: #014550;
}

/*OPINIE*/
.opinion-femilite {
  padding: 5rem 0;
  background: #f8f9fa;
}



/* Usunięto custom style h2 - używamy istniejących .team_top_tag_text */

.google-rating {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
}

.google-logo {
  font-size: 2rem;
  font-weight: bold;
  color: #4285f4;
}

.google-logo .g-blue { color: #4285f4; }
.google-logo .g-red { color: #ea4335; }
.google-logo .g-yellow { color: #fbbc05; }
.google-logo .g-green { color: #34a853; }

.google-rating-info {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.google-stars {
  color: #014550;
  font-weight: 500;
  font-size: 1.2rem;
}

.google-rating-text {
  font-size: 1.1rem;
  color: #014550;
}

/* Style dla Splide slidera opinii */
.opinions_splide {
  max-width: 100%;
  margin: 0 auto;
}


section.opinion-femilite .container {
  padding-top: 0;
  padding-bottom: 0;
}

/* .opinions_splide .splide__list {
  display: flex;
  align-items: stretch;
} */

.opinions_splide .splide__slide {
  height: auto;
  display: flex;
  align-items: stretch;
}

.opinion-femilite .splide__list {
  height: auto !important;
}

.opinion_slide_wrap {
  background: white;
    border-radius: 0.75rem;
    padding: 1.875rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    position: relative;
    width: 100%;
    /* height: 100%; */
    display: flex
;
    flex-direction: column;
    border: 0.0625rem solid #DFE2DF;
}

.opinion_slide_wrap:hover {
  border-color: #FFDAB7;
}

/* Custom arrows dla Splide */
.opinions_custom_arrow_left,
.opinions_custom_arrow_right {
  border: 0.0625rem solid var(--site-colors--orange02-2);
  background-color: var(--site-colors--orange02-2);
  color: var(--site-colors--orange01);
  border-radius: 50em;
  justify-content: center;
  align-items: center;
  width: 2.63em;
  height: 2.63em;
  font-size: 1em;
  transition: background-color .2s, color .2s;
  display: flex;
  cursor: pointer;
  border: none;
}

.opinions_custom_arrow_left:hover {
  background-color: var(--site-colors--orange01);
  color: var(--site-colors--orange02);
}

.opinions_custom_arrow_right:hover {
  background-color: var(--site-colors--orange01);
  color: var(--site-colors--orange02);
}

.opinion-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 1.25rem;
  flex-direction: column;
  gap: 0.625rem;
}

.opinion-author {
  display: flex;
  flex-direction: column;
}

.opinion-name {
  font-weight: 500;
  font-size: 1.1rem;
  color: #333;
  margin-bottom: 0.3125rem;
}

.opinion-time {
  font-size: 0.9rem;
  color: #888;
}

.opinion-rating {
  display: flex;
  align-items: center;
  gap: 0.3125rem;
}

.opinion-stars {
  color: #ffc107;
  font-size: 1.1rem;
}

.google-icon {
  width: 1.25rem;
  height: 1.25rem;
  margin-left: 0.3125rem;
}

.opinion-content {
  font-size: .9em;
  line-height: 1.6;
  color: #014550;
}

/* Usunięto custom slider controls - używamy Webflow slidera */

/* Pasek postępu dla slidera opinii */
.opinion-progress-bar {
  width: 100%;
  height: 0.25rem;
  background: #f2f9f3;
  border-radius: 0.125rem;
  margin-top: 1.875rem;
  overflow: hidden;
}

.opinion-progress-fill {
  height: 100%;
  background: #FFDAB7;
    border-radius: 0.125rem;
  width: 0%;
  transition: width 0.3s ease;
}

/* Responsive - 3 slajdy na desktop, 2 na tablet, 1 na mobile */
@media (max-width: 1024px) {
  .opinion_slide {
    width: 50%;
  }
}

@media (max-width: 768px) {
  .opinion-femilite {
    padding: 3.75rem 0;
  }
  
  .opinion_slide {
    width: 100%;
  }
  
  .opinion_slide_wrap {
    padding: 1.25rem;
    margin: 0 0.3125rem;
  }
  
  .google-rating {
  }
  
  .google-rating-info {
  }
}

@media (max-width: 480px) {
  .opinion-femilite .container {
    padding: 0 0.9375rem;
  }
  
  .opinion_slide_wrap {
    padding: 0.9375rem;
  }
}

.opinions_slider_arrows {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 3em;
  gap: 1em;
}

.opinions_slider_arrows button.opinions_custom_arrow_left {transform: rotate(180deg);}

.opinion-femilite__top {
  display: grid;
  grid-template-columns: 33em 1fr;
  gap: 6em;
  max-width: 81.5em;
  margin: 5em auto 4em;
  align-items: center;
	text-decoration: none;
}

.opinion-femilite__top .google-rating {
  border: 1px solid #DFE2DF;
  border-radius: 0.5em;
  padding: 1.5em 1em;
}

.opinion-femilite__top h3 {
  font-size: 1.5em;
  line-height: 1.7;
}

@media(max-width: 768px){
  .opinion-femilite__top {
  grid-template-columns: 1fr;
  max-width: 500px;
  text-align: center;
  gap: 30px;
}
	
	.opinion-content {
    font-size: 1em;
}

.opinion-name {
    font-size: 1.3em;
}

.opinion-time {
    font-size: 0.9em;
}

.opinion-stars {
    font-size: 1em;
}

.google-icon {
    width: 1.2em;
    height: auto;
}
	.google-logo svg {
    width: 1.6em;
}

.google-stars {
    font-size: 1.3em;
}

.google-rating-text {
        font-size: 1.3em;

}
	
}

.home_process_right_column {
    min-height: auto !important;
}

.mobile-links-header {
  margin-right: 1em;
}

@media(min-width: 992px){
  
.mobile-links-header {
  display: none;
}
}
.account-menu-access-popup,
.popupwait.mobile-access-popup {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: #f3f9f4;
  z-index: 99999999;
}

.mobile-tabs-bottom {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-top: 1px solid #e0e0e0;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 8px 0;
  z-index: 1000;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
}

.mobile-tab-item {
  flex: 1;
  text-align: center;
  padding: 4px;
}

.mobile-tab-item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: #666;
  transition: color 0.3s ease;
}

.mobile-tab-item.active a {
  color: #06dd90;
}

.mobile-tab-item.mobile-tab-disabled a {
  opacity: 0.5;
}

.mobile-tab-item.mobile-tab-disabled .mobile-tab-icon img {
  filter: grayscale(1) opacity(0.5);
}

.mobile-tab-icon {
  width: 32px;
  height: 32px;
  margin: 0 auto 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-tab-icon img {
  width: 24px;
  height: 24px;
  filter: grayscale(1);
  transition: filter 0.3s ease;
}

.mobile-tab-item.active .mobile-tab-icon img {
  filter: none;
}

.mobile-tab-label {
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
}

/* Ukryj na desktop */
@media (min-width: 768px) {
  .mobile-tabs-bottom {
      display: none;
  }
}

/* Dodaj padding na dole body żeby nie zakrywać treści */
@media (max-width: 767px) {
  body {
      padding-bottom: 70px;
  }
}


.mobile-tab-item:nth-child(3) .mobile-tab-icon {
  background: #014550;
  border-radius: 200px;
  margin-top: -18px;
  width: 50px;
  height: 50px;
  position: relative;
  top: -6px;
  text-transform: uppercase;
}

.mobile-tab-item:nth-child(3) .mobile-tab-icon img {
  filter: brightness(0) invert(1);
}

/* Mobilne zakładki na dole */
/* Blokowanie interakcji z sekcjami placeholder dla kontynuacji */
.showpopup-kontynuacja .db_materials_dd_toggle {
    pointer-events: none;
    cursor: default;
}

.showpopup-kontynuacja {
    cursor: pointer;
}

.mobile-tabs-bottom {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    border-top: 1px solid #e0e0e0;
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 8px 0;
    z-index: 1000;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
}

.mobile-tab-item {
    flex: 1;
    text-align: center;
    padding: 4px;
}

.mobile-tab-item a {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    color: #666;
    transition: color 0.3s ease;
}

.mobile-tab-item.active a {
    color: #06dd90;
}

.mobile-tab-item.mobile-tab-disabled a {
    opacity: 0.5;
}

.mobile-tab-item.mobile-tab-disabled .mobile-tab-icon img {
    filter: grayscale(1) opacity(0.5);
}

.mobile-tab-icon {
    width: 32px;
    height: 32px;
    margin: 0 auto 4px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mobile-tab-icon img {
    width: 24px;
    height: 24px;
    filter: grayscale(1);
    transition: filter 0.3s ease;
}

.mobile-tab-item.active .mobile-tab-icon img {
    filter: none;
}

.mobile-tab-label {
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
}

/* Ukryj na desktop */
@media (min-width: 768px) {
    .mobile-tabs-bottom {
        display: none;
    }
}

/* Dodaj padding na dole body żeby nie zakrywać treści */
@media (max-width: 767px) {
    body {
        padding-bottom: 70px;
    }
}


/* FORM MEDFILE  */.show-medfile-register-iframe, .add-to-cart-femimed {
  display: none;
}
.show-medfile-register-iframe[data-slot], .add-to-cart-femimed[data-slot] {
  display: block;
}

.doc_calendar_time_card.active {
  background: #c5facb;
}
.doc_calendar_time_card .slot-selector {
  cursor: pointer;
}

.after-choose-slot {
  display: none;
  padding-bottom: 2.6875em;
}
.after-choose-slot iframe {
  width: 100%;
  height: 1150px;
  border: 0;
}

.medfile-noresults {
  padding: 10px;
  background: #c5facb;
  border-left: 6px solid #014550;
}

.doc-not-available {
  border-radius: 25px;
  background: #c5facb;
  margin: 20px 0;
  padding: 15px;
  border-left: 32px solid #014550;
}

.medfile-noresults.calendar-noresults {
  background: #fff;
  border: 0;
  padding: 30px 30px 50px;
  margin-top: -60px;
  text-align: center;
  font-size: 1vw;
  line-height: 1.6;
}

.medfile-booking-form-container__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.medfile-booking-form-container__top img {
  width: 7em;
  height: auto;
}

form#medfile-booking-form label {
  font-weight: 500;
  margin-bottom: 0.7em;
}

form#medfile-booking-form .form-row {
  margin-bottom: 0;
}

/* Style dla formularza Medfile - ZASTĘPUJE KALENDARZ */
#medfile-booking-form-container {
  background: white;
  border-radius: 0.625rem;
  padding: 1.875rem;
  margin: 1.25rem 0;
  border: 0.0625rem solid #ddd;
  width: calc(100% - 1.875rem);
  margin-left: 0.9375rem;
}

#medfile-booking-form-container h3 {
  margin-top: 0;
  color: #04dd8f;
  text-align: center;
}

.form-row {
  display: flex;
  gap: 0.9375rem;
  margin-bottom: 0.9375rem;
}

.form-field {
  flex: 1;
  margin-bottom: 0.9375rem;
}

.form-field label {
  display: block;
  margin-bottom: 0.3125rem;
  font-weight: bold;
  color: #014550;
}

.form-field input,
.form-field textarea {
  width: 100%;
  padding: 0.625rem;
  border: 0.0625rem solid #ddd;
  border-radius: 0.3125rem;
  font-size: 0.875rem;
}

.form-field input:focus,
.form-field textarea:focus {
  border-color: #04DD8F;
  outline: none;
}

.form-checkboxes {
  margin: 1.25rem 0;
}

.checkbox-field {
  display: flex;
  align-items: center;
  margin-bottom: 0.625rem;
}

.checkbox-field input {
  margin-right: 0.625rem;
  width: auto;
}

.form-buttons {
  display: flex;
  gap: 0.9375rem;
  justify-content: center;
  margin-top: 1.5625rem;
}

.button-secondary {
  background: #f5f5f5;
  color: #666;
  border: 0.0625rem solid #ddd;
  padding: 0.75rem 1.5625rem;
  border-radius: 0.3125rem;
  cursor: pointer;
}

.button-primary {
  background: #014550;
  color: #fff;
  border: none;
  padding: 0.75rem 1.5625rem;
  border-radius: 0.3125rem;
  cursor: pointer;
  font-weight: 400;
  transition: all 0.3s ease;
}

.button-primary:hover {
  background: #03c27d;
}

.button-primary:disabled {
  background: #ccc;
  cursor: not-allowed;
}

#booking-messages {
  margin-top: 0.9375rem;
  padding: 0.625rem;
  border-radius: 0.3125rem;
}

#booking-messages.success {
  background: #d4edda;
  color: #155724;
  border: 0.0625rem solid #c3e6cb;
}

#booking-messages.error {
  background: #f8d7da;
  color: #721c24;
  border: 0.0625rem solid #f5c6cb;
}

.cancel-visit-btn {
  background: #ff4444;
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
  transition: background-color 0.3s;
  text-align: center;
  display: block;
  margin: 0 auto;
}
.cancel-visit-btn:hover {
  background: #cc0000;
}

@media (max-width: 48rem) {
  .form-row {
      flex-direction: column;
      gap: 0;
  }
  
  #medfile-booking-form-container {
      padding: 1.25rem;
      margin: 0.625rem 0;
  }
}

a.patient-visit-btn {
  background: #024550;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
  transition: background-color 0.3s;
  text-align: center;
  display: block;
  margin: 0 auto;
  color: #fff;
  text-decoration: none;
}

.visit_buttons_wrap {
  display: flex;
  gap: 0.4em;
}

a.patient-visit-btn:hover {
  background: #04dd8f;
}
/* END FORM MEDFILE  */

.page-template-page-formularz-wydarzenie .ml-form-embedWrapper {
  width: 100% !important;
  max-width: 690px !important;
  background: #fff !important;
  margin: 3rem 0 5rem !important;
}

.page-template-page-formularz-wydarzenie .ml-form-embedWrapper * {
  font-family: stolzl, sans-serif !important;
}

.page-template-page-formularz-wydarzenie .ml-form-embedContent p, .page-template-page-formularz-wydarzenie .ml-form-embedContent p * {
  font-size: 1rem !important;
  color: #104550 !important;
}

.page-template-page-formularz-wydarzenie .ml-form-embedContent h2, .page-template-page-formularz-wydarzenie .ml-form-embedContent h3, .page-template-page-formularz-wydarzenie .ml-form-embedContent h4,.page-template-page-formularz-wydarzenie .ml-form-embedContent h5 {
  font-size: 1.75rem !important;
  font-weight: 500 !important;
  text-align: center !important;
}

.page-template-page-formularz-wydarzenie .ml-form-embedWrapper .ml-form-embedBody .ml-form-checkboxRow label p {
  display: block !important;
  width: 100% !important;
}

.page-template-page-formularz-wydarzenie .ml-form-checkboxRow label.checkbox {
  width: 100%;
  height: auto;
  background: transparent;
}

.page-template-page-formularz-wydarzenie .ml-form-embedWrapper .ml-form-embedBody .ml-form-embedSubmit button {
  border-radius: 100px !important;
}

.event_hero_flex {
  padding-top: 5.9375em;
  padding-bottom: 4.0625em;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.event_hero_image_wrap {
  border-radius: var(--border-15px);
  overflow: hidden;
}

.event_hero_content_wrap {
  justify-content: center;
  align-items: center;
  padding: 3.75em;
  display: flex;
}

.event_hero_image {
  aspect-ratio: 1.48;
  width: 100%;
  max-width: 42.625em;
  height: 100%;
}

.event_details {
  grid-column-gap: 1.8125em;
  grid-row-gap: 1.8125em;
  text-align: center;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  max-width: 63.625em;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 2em;
  display: flex;
}

.event_details_line_separater {
  background-color: var(--site-colors--green01);
  width: 100%;
  max-width: 6.25em;
  height: 1px;
}

.event_details_time {
  flex-flow: column;
  align-items: center;
  display: flex;
}

@media(max-width: 576px){
  .event_hero_flex {
    grid-template-columns: 1fr;
}

  .event_details p {
    max-width: 55rem;
}

.event_hero_image {
    width: 100%;
    height: auto;
    aspect-ratio: unset;
    max-width: 100%;
}

  .event_hero_content_wrap {
    padding: 1rem 0 !important;
    text-align: center;
}
}



.event_details p {
    max-width: 55rem;
}

@media(min-width: 992px){
  .db_workshop__live-content {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1em;
  font-size: 0.8em !important;
}
}

/* FEMISTACJA  */

section.femistacja-podcasts video {
  width: 100%;
  height: auto;
  transform: scale(1.1);
  position: relative;
  left: -2em;
}

section.femistacja-podcasts {
  position: relative;
  overflow: hidden;
}

section.femistacja-podcasts .container {
  position: absolute;
  bottom: 4.5em;
  right: 4.5em;
  display: flex;
  flex-direction: column;
  max-width: 34em;
  align-items: self-start;
  z-index: 1;
  padding: 0;
}

section.femistacja-podcasts h2 {
  color: #FFDAB7;
  font-weight: 500;
  font-size: 2em;
}

section.femistacja-podcasts svg {
  width: 19em;
  height: auto;
  margin-bottom: 3em;
}

section.femistacja-podcasts .container a svg {
  width: 2em;
  height: auto;
  margin: 0;
}

section.femistacja-podcasts .container a {
  display: flex;
  align-items: center;
  gap: 2em;
  padding: 0.6em 1em;

}

section.femistacja-podcasts .container p {
  font-size: 1.25em;
  color: #fff;
  font-weight: 500;
  margin: 2em 0 3em;
}

section.femistacja-podcasts .container a {
  background: #FFDAB7;
  /* display: inline-block; */
  text-decoration: none;
  font-weight: 500;
  padding: 0.6em 1em;
  border-radius: 100rem;
  transition: all .5s;
}

section.femistacja-podcasts .container a svg path {
  transition: all .5s;;
}

section.femistacja-podcasts .container a:hover {
  background-color: #014550;
  color: #fff;
}
section.femistacja-podcasts .container a:hover svg path {
  fill: #fff;
  stroke : #fff;
}
.femistacja-podcasts__container:before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(290deg, #024550, transparent);
  z-index: 1;
}

@media(max-width: 768px) {
  section.femistacja-podcasts video {
      left: 0;
      transform: scale(1);
  }


section.femistacja-podcasts .container {
  position: relative;
  text-align: center;
  max-width: 80%;
  align-items: center;
  padding: 3em 0 4em;
  bottom: 0;
  right: 0;
}

.femistacja-podcasts__container {
  background: #024550;
}



section.femistacja-podcasts h2 {
  font-size: 5vw;
}

section.femistacja-podcasts svg {
  width: 61vw;
}
}


.femistacja-podcasts__container {
  position: relative;
}

.femistacja-podcasts__container {
  max-width: 87em;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 1em;
}

section.femistacja-podcasts {
  background: #fff;
  padding: 0 1em 5em;
}

.hero_flex.hero_flex__new {
  padding-left: 0;
}

@media(min-width: 768px){
  .hero_flex.hero_flex__new .hero_content_wrap {
    max-width: 50vw;
    width: 100%;
    } 
}

.hero_flex.hero_flex__new .hero_content_wrap  .hero_heading_wrap {
  max-width: 100%;
}

.hero_flex.hero_flex__new .hero_image_wrap {
  max-width: 38.13em;
}


.prl-counter-section {
    background: #f3f9f3;
    position: relative;
    overflow: hidden;
}

.prl-counter-section::before {
}

.prl-counter-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
}

.prl-counter-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 2em;
    justify-content: space-between;
    width: 100%;
}

.prl-counter-display {
    display: flex;
    align-items: center;
    gap: 15px;
    position: relative;
}

.prl-counter-display::before {
    content: '';
    position: absolute;
    top: 8px;
    left: 8px;
    right: 8px;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}

.prl-counter-plus {
    font-size: 36px;
    font-weight: bold;
    color: var(--site-colors--green01); /* Jaśniejszy zielony */
     /* Silniejszy blask */
    font-family: 'Courier New', monospace;
}

/* Odometer.js customization for PRL style */
.prl-counter-odometer {
    font-size: 48px !important;
    font-weight: bold !important;
    color: #00FF00 !important;
    text-shadow: 0 0 15px rgba(0, 255, 0, 0.8) !important;
    font-family: 'Courier New', monospace !important;
    background: #000 !important;
    padding: 15px 20px !important;
    border-radius: 8px !important;
    border: 2px solid #333 !important;
    box-shadow: 
        inset 0 2px 5px rgba(0,255,0,0.2),
        0 2px 10px rgba(0,0,0,0.5) !important;
    width: 300px !important;
    text-align: center !important;
    display: inline-block !important;
    letter-spacing: 8px !important;
}

/* Wymuś stałą szerokość dla każdej cyfry */
.prl-counter-odometer .odometer-digit {
    width: 40px !important;
    display: inline-block !important;
    text-align: center !important;
}


.prl-counter-label {
    text-align: left;
    color: #014550;
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 1.6em;
    line-height: 1.2;
    font-weight: 500;
    width: 9em;
    min-height: 5em;
}

.counter-main-text {transition: all .5s;}

.counter-sub-text {
    transition: all 0.5s ease;
}

/* Animacja rolowania cyfr - MECHANICZNE ROLKI */
@keyframes mechanicalRoll {
    0% { 
        transform: scale(1);
        opacity: 1;
    }
    50% { 
        transform: scale(1.1);
        opacity: 0.7;
    }
    100% { 
        transform: scale(1);
        opacity: 1;
    }
}

.digit-roller {
    background: #024550;
    color: var(--site-colors--green01);
    font-size: 3.6em;
    font-weight: 400;
    width: 1.3em;
    height: 2.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 3px solid #2a4a2a;
    position: relative;
    overflow: hidden;
    transition: all 0.1s ease;
}

.digit-value {
    position: relative;
    z-index: 2;
    line-height: 1;
}

/* Usunięto maskę - cyfry były przecinane poziomą linią */

/* Usunięto maskę - cyfry były za słabo widoczne */

/* Proste przełączanie cyfr - bez 3D */
.digit-roller .digit-cylinder {
    position: absolute;
    width: 100%;
    height: 100%;
    transition: opacity 0.3s ease;
}

.digit-roller .digit-face {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 56px; /* Większe cyfry */
    font-weight: bold;
    color: #00FF00; /* Jaśniejszy zielony */
    text-shadow: 0 0 15px rgba(0, 255, 0, 0.8); /* Silniejszy blask */
    background: rgba(0,0,0,0.9); /* Ciemniejsze tło */
    border: 1px solid #333; /* Subtelna ramka */
    opacity: 0; /* Ukryte domyślnie */
}

/* Tylko pierwsza cyfra (0) jest widoczna na starcie */
.digit-roller .digit-face:nth-child(1) { opacity: 1; }

.digit-rolling {
    animation: mechanicalRoll 0.05s ease-in-out;
}

/* Animacja zmiany tekstu */
@keyframes textFade {
    0% { opacity: 1; transform: translateY(0); }
    50% { opacity: 0; transform: translateY(-10px); }
    100% { opacity: 1; transform: translateY(0); }
}

.text-changing {
    animation: textFade 1s ease-in-out;
}

/* Responsive */
@media (max-width: 768px) {
    .prl-counter-display {
        padding: 15px 20px;
        gap: 8px;
    }
    
    .prl-counter-plus {
        font-size: 28px;
    }
    
    .digit-roller {
        font-size: 29px;
        width: 44px;
        height: 59px;
    }
    
    .counter-main-text {
        font-size: 20px;
    }
    
    .counter-sub-text {
        font-size: 14px;
    }
    
    .prl-counter-left-text {
        font-size: 16px;
        text-align: center;
    }
}

/* PRL COUNTER - TYLKO ANIMACJA */
.prl-counter-odometer {
    transition: opacity 0.3s ease !important;
}

.prl-counter-odometer .odometer-digit {
    transition: opacity 0.3s ease !important;
}

/* Ukryj niepotrzebne cyfry - zawsze pokazuj 5 */
.prl-counter-odometer .odometer-digit:nth-child(n+6) {
    display: none !important;
}

/* Animacja zmiany tekstu */
@keyframes textFade {
    0% { opacity: 1; transform: translateY(0); }
    50% { opacity: 0; transform: translateY(-20px); }
    100% { opacity: 1; transform: translateY(0); }
}

.text-changing {
    animation: textFade 0.8s ease-in-out;
}

/* ===================================
   Femilite Offers Home - Main Styles
   =================================== */

/* Base container */
.femilite__offers-home > div {
  position: relative;
  padding-bottom: 0;
}

/* Background decoration for desktop */
@media (min-width: 768px) {
  .femilite__offers-home::before {
      /* content: '';
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      width: 50%;
      height: 100%;
      background: #FFE6CE;
      z-index: 1; */
  }
}

/* ===================================
 Column Text Right Section
 =================================== */

.femilite__offers-home .column-text-right {
  padding-left: 3em;
  padding-right: 0;
  position: relative;
}

.femilite__offers-home .column-text-right > a.button {
  margin: 0 auto;
  position: relative;
  display: inline-block;
  clear: both;
  left: 50%;
  transform: translate(-50%, 0);
}

/* Background decoration for mobile */
@media (max-width: 767px) {
  .femilite__offers-home__new .home_values_grid > div {
    padding: 1.25em !important;
}

.femilite__offers-home__new > div {
  padding-top: 0;
}

  .femilite__offers-home .column-text-right::before {
      /* content: '';
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: -1rem;
      width: calc(100% + 2rem);
      height: 100%;
      background: #FFE6CE; */
  }
}

.femilite__offers-home__new .home_values_grid > div {
  padding: 2em;
  background: #FFE6CE;
  border-radius: 1em;
}



.femilite__offers-home__new .home_values_grid > div:nth-child(1) {
  background: #EAFFEC;
}

.femilite__offers-home__new {
  background: #fff;
}

.femilite__offers-home__new .home_values_grid {
  gap: 2em;
}

@media(min-width: 768px) {
  .femilite__offers-home__new .home_values_grid > div:nth-child(2) {
  padding-left: 4rem !important;
  padding-right: 4em !important;
}
}


/* Heading */
.femilite__offers-home .column-text-right h3 {
  position: relative;
  max-width: 30em;
  margin: 0 auto 2em;
  font-size: 1.5em;
  font-weight: 500;
  text-align: center;
}

.femilite__offers-home .column-text-right h3 strong {
  color: var(--site-colors--orange01);
  font-weight: 500;
}

/* ===================================
 Single Item Cards
 =================================== */

.femilite__offers-home .columnt-text-right__single {
  position: relative;
  margin: 2.4em 0;
}

.femilite__offers-home .columnt-text-right__single:last-child {
  margin-bottom: 0;
}

/* Step badge */
.femilite__offers-home .columnt-text-right__single .step {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  margin-top: -1.25em;
  padding: 0.35em 0.63em;
  background-color: var(--site-colors--orange02-2);
  color: var(--site-colors--orange01);
  text-align: center;
  border-radius: 50em;
}

/* Text container */
.femilite__offers-home .columnt-text-right__single .text {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-top: 0.56em;
  padding: 2em 1.3em 1.5em;
  border: 1px solid var(--site-colors--orange02);
  border-radius: var(--border-15px);
  text-align: left;
  grid-column-gap: 0.63em;
  grid-row-gap: 0.63em;
}

.femilite__offers-home .columnt-text-right__single .text h4 {
  font-size: 1.125em;
  font-weight: 500;
}

.femilite__offers-home .columnt-text-right__single .text p {
  max-width: 74%;
  font-size: 0.875em;
  color: #014550;
}

/* Image */
.femilite__offers-home .columnt-text-right__single .image {
  position: absolute;
  top: 50%;
  right: -4em;
  width: 13em;
  height: auto;
  transform: translate(0, -50%);
}

/* ===================================
 Odd Items (Alternate Layout)
 =================================== */

.femilite__offers-home .columnt-text-right__single:nth-child(odd) {
  display: flex;
  justify-content: flex-end;
}

.femilite__offers-home .columnt-text-right__single:nth-child(odd) .step {
  right: 0;
  left: unset;
}

.femilite__offers-home .columnt-text-right__single:nth-child(odd) .image {
  right: unset;
  left: -4em;
}

.femilite__offers-home .columnt-text-right__single:nth-child(odd) .text {
  display: flex;
  align-items: flex-end;
}

.femilite__offers-home .columnt-text-right__single:nth-child(odd) .text * {
  width: calc(100% - 7.2em);
  justify-content: flex-end;
}

.femilite__offers-home .columnt-text-right__single:nth-child(odd) .text p {
  max-width: calc(100% - 9.3em);
}

/* ===================================
 Responsive: Tablet
 =================================== */

@media (max-width: 992px) {
  .femilite__offers-home .column-text-right {
      padding-right: 1.5em;
  }
}

/* ===================================
 Responsive: Mobile
 =================================== */

@media (max-width: 767px) {
  .femilite__offers-home .column-text-right h3 {
      max-width: 21rem;
  }

  .femilite__offers-home .columnt-text-right__single .text {
      padding: 1em;
  }

  .femilite__offers-home .columnt-text-right__single .text p {
      max-width: calc(100% - 14.7em);
  }

  .femilite__offers-home .columnt-text-right__single .image {
      right: 0;
  }

  /* Odd items adjustments */
  .femilite__offers-home .columnt-text-right__single:nth-child(odd) .image {
      left: 0;
  }

  .femilite__offers-home .columnt-text-right__single:nth-child(odd) .text * {
      width: calc(100% - 11.2em);
  }

  .femilite__offers-home .columnt-text-right__single:nth-child(odd) .text p {
      max-width: calc(100% - 14.7em);
  }

.femilite__offers-home .home_values_grid {grid-template-columns: 1fr;grid-template-rows: 1fr;}
}



.container.container-video__femilite {
  padding-top: 0;
 
}

.container-video__femilite .video-container {
  border-radius: 1em;
  overflow: hidden;
  position: relative;
}

.video-container > div > button {
  background: #fff;
  opacity: 1;
}



.video-container > div > button  svg {
  fill: var(--site-colors--dark);
}

.video-container > div > button:hover {
  background: #f3f9f3 !important;
}

.container-video__femilite .ceo_image_gfx {
  top: 50%;
  transform: translate(-50%, -50%);
  right: 0;
  margin: unset;
  left: unset;
  z-index: 1;
}

.container-video__femilite .ceo_image_gfx p {
  font-size: 0.76em !important;
  margin: 0.875em;
}

/* video  */

.container-video__femilite .video-container {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  overflow: hidden;
  border-radius: 12px;
}

/* Tło video */
.container-video__femilite .background-video-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.container-video__femilite #background-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Przycisk play na wierzchu */
.container-video__femilite .video-cover-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  background: rgb(2 69 80);
  border: none;
  border-radius: 50%;
  width: 80px;
  height: 80px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

@media(max-width: 576px){

.container-video__femilite .video-cover-button {
  width: 35px;
  height: 36px;
}

.container-video__femilite .video-cover-button svg {
  width: 16px;
}
}

.container-video__femilite .plyr--video .plyr__control:hover {
  background: #045a68;
}
.container-video__femilite .video-cover-button:hover {
  background: rgba(0, 0, 0, 0.9);
  transform: translate(-50%, -50%) scale(1.1);
}

.container-video__femilite .video-cover-icon {
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Plyr wrapper */
.container-video__femilite .plyr-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
}

.container-video__femilite .plyr-wrapper .plyr {
  width: 100%;
  height: 100%;
}

.container-video__femilite .plyr-wrapper .plyr__video-wrapper {
  height: 100%;
}

.container-video__femilite .plyr__control--overlaid {
background: #024550;
}

.container-video__femilite .plyr--full-ui input[type=range] {
color: #f3f9f3;
}

.container-video__femilite .plyr--stopped .plyr__controls {
  opacity: 0;
  pointer-events: none;
}

/* Pokaż tylko duży przycisk play */
.container-video__femilite .plyr--stopped .plyr__control--overlaid {
  opacity: 1;
  pointer-events: all;
}


.container-video__femilite .ceo_image_gfx {
    transition: all .5s;
    opacity: 1;
}

.video-container.play-video ~  .ceo_image_gfx {
    opacity: 0;
}

@media(max-width: 576px) {
  .container-video__femilite .ceo_image_gfx {
  top: 4em;
  font-size: 1.43em;
  right: -1em;
}
}

.page-template-page-home4 .container.is--hero {
  padding-top: 2em;
}

.page-template-page-home4 .hero_flex.is--new {
  padding-bottom: 1em;;
}

.page-template-page-home4 .section.is--home-process {
  background: #fff;
}

.page-template-page-home4  section.section.is--home-process > div {
  background: #ffe6ce;
  border-radius: 1em;
  max-width: 86.4rem;
  padding: 3em 1em;
  width: calc(100% - 3em);
}

@media(max-width: 768px){
  .page-template-page-home4   section.section.is--home-process > div {
  padding: 2em;
}
}

@media(max-width: 576px){
  .page-template-page-home4  section.section.is--home-process > div {
  padding: 1em;
}
}

.page-template-page-home4 .home_values_wrap._2 {
  margin-bottom: 4em !important;
}

section.femistacja-podcasts video {
  pointer-events: none;
}


.femilite__offers-home .columnt-text-right__single .image img {
  width: 100% !important;
  height: auto !important;
}

/* // Subskcypcje  */

.offer_packages_grid__new h3 ~ p {
  margin-top: 2em;
  max-width: 43em;
  margin-left: auto;
  margin-right: auto;
}

.offer_packages_grid__new {
  max-width: 71.5em;
  margin-left: auto;
  margin-top: 6rem;
  margin-right: auto;
}

.offer_packages_grid__new  .offer_package_card_content_wrap__table {
  text-align: left;
  background: #F2F9F3;
  position: relative;
  margin-top: 3em;
  padding: 2em;
}

.offer_packages_grid__new > div {
  padding: 2em 0 0;
  border-radius: 1em;
  overflow: hidden;
  border: 0;
}

.offer_packages_grid__new > div h3, .offer_packages_grid__new > div h3 ~ p {
  padding: 0 1em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table > h3 {
  text-align: center;
  padding: 0 1em;
  margin-bottom: 2em;
  margin-top: 0.5em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section {
  max-width: 53em;
  margin-left: auto;
  margin-right: auto;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-section-title {
  font-size: 1.5em;
  font-weight: 600;
  margin-bottom: 1.25em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item {
  display: grid;
  grid-template-columns: 1fr 18em;
  margin-bottom: 1em;
  gap: 1em;
}

@media(max-width: 767px) {
  .offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item {
    grid-template-columns: 1fr 17em;
}
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item .package-item-value {
  text-align: center;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 1em;
  height: 55px;
  font-weight: 400;
  font-size: 1em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item .package-item-text {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item .package-item-text .info-icon {
  width: 1.5em;
  height: 1.5em;
  border: 1px solid #024550;
  display: flex;
  align-items: center;
  justify-content: center;
  font-style: normal;
  border-radius: 100px;
  position: relative;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section {
  margin-bottom: 2em;
  border-bottom: 1px solid #C5FACB;
  padding-bottom: 2em;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}

.offer_packages_grid__new .offer_package_card_content_wrap__table .package-content-section .package-item .package-item-text .package-item-title {
  font-weight: 400;
}


.offer_packages_grid__new .offer_package_card_content_wrap__table:not(.is-show) {
  height: 80rem;
  position: relative;
  transition: all 0.5s;
}


.offer_packages_grid__new .offer_package_card_content_wrap__table:not(.is-show):before {
  background: linear-gradient(0deg, #f3f9f3, transparent);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 30rem;
  z-index: 9;
  content: '';
}

.offer_packages_grid__new > div .button.is--show-table {
  position: absolute;
  bottom: 0;
  z-index: 21;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: 50px;
}

.subscription-info-banner.text_center_align {
  max-width: 80em;
  margin-left: auto;
  margin-right: auto;
}

/* SEKCJA KARTY KREDYTOWEJ */
.payment-method-section {
  margin-bottom: 40px;
  padding: 2em;
  background: #fff;
  border-radius: 1em;
}

.payment-header h2 {
  font-size: 24px;
  color: #024550;
  margin-bottom: 20px;
  font-weight: 400;
}

.payment-header h2 strong {
  font-weight: 600;
}

.payment-card-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
}

.card-details {
  display: flex;
  align-items: center;
  gap: 15px;
}

.card-icon img {
  width: 50px;
  height: 32px;
}

.card-number {
  font-size: 18px;
  font-weight: 600;
  color: #333;
}

.card-actions {
  display: flex;
  gap: 15px;
}

.btn-update, .btn-remove {
  padding: 8px 20px;
  border-radius: 20px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  border: none;
}

.btn-update {
  background: #024550;
  color: var(--site-colors--green01);
}

.btn-remove {
  background: transparent;
  color: #024550;
  border: 1px solid #024550;
}

/* NASTĘPNA PŁATNOŚĆ */
.next-payment-section {
  margin-bottom: 40px;
}

.payment-card {
  background: #FFE6CE;
  padding: 40px 30px 50px 30px;
  border-radius: 15px;
  display: flex;
  position: relative;
  flex-direction: column;
  gap: 2em;
}

.payment-card h3 {
  font-size: 20px;
  color: #014550;
  margin: 0;
  font-weight: 400;
}

.payment-card h3 strong {
  font-weight: 600;
}

.payment-date {
  font-size: 32px;
  font-weight: 700;
  color: #DE832B;
}

.payment-arrow {
  font-size: 24px;
  color: #e65100;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

/* HISTORIA ZAMÓWIEŃ */
.orders-history-section h2 {
  font-size: 24px;
  color: #014550;
  margin-bottom: 30px;
  font-weight: 400;
}

.orders-history-section h2 strong {
  font-weight: 600;
}

.orders-table {
  background: white;
  border-radius: 8px;
  overflow: hidden;
}

.table-header {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  padding: 15px 20px;
  font-weight: 600;
  color: #024550;
  font-size: 14px;
  text-transform: uppercase;
  border-bottom: 1px solid #014550;
  text-align: center;
}

.table-row {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  padding: 20px;
  border-bottom: 1px solid #04DD8F;
  align-items: center;
  text-align: center;
}

.table-row:last-child {
  border-bottom: none;
}

.table-row.pending {
  background: #fff8e1;
}

.table-row.future {
}

.table-row.completed {
  background: white;
}

.col-date {
  color: #333;
  font-weight: 400;
}

.table-row.pending .col-date {
  color: #ff9800;
}

.table-row.future .col-date {
  font-weight: 400;
  color: #DE832B;
}

.col-type {
  font-weight: 400;
  color: #333;
}

.table-row.pending .col-type {
  color: #ff9800;
}

.table-row.future .col-type {
  font-weight: 400;
  color: #DE832B;
}

.col-amount {
  color: #333;
  font-weight: 400;
  text-align: right;
}

.payment-card:before {
  content: '!';
  font-size: 9em;
  color: #FFCD9D;
  position: absolute;
  top: 50%;
  right: 2rem;
  transform: translate(0, -50%);
}

/* RESPONSYWNOŚĆ */
@media (max-width: 768px) {
  .payment-card-info {
      flex-direction: column;
      gap: 20px;
      align-items: flex-start;
  }
  
  .payment-card {
      flex-direction: column;
      /* text-align: center; */
      gap: 15px;
  }
  
  .payment-arrow {
      position: static;
      transform: none;
  }
  
  .table-header,
  .table-row {
      grid-template-columns: 1fr;
      gap: 10px;
  }
  
  .table-header {
      display: none;
  }
  
  .table-row {
      border-left: 4px solid #e9ecef;
      padding-left: 16px;
  }
  
  .table-row.pending {
      border-left-color: #ff9800;
  }
  
  .col-date::before {
      content: "DATA: ";
      font-weight: 600;
      color: #000;
  }
  
  .col-type::before {
      content: "ROZLICZENIE: ";
      font-weight: 600;
      color: #000;
  }
  
  .col-amount::before {
      content: "KWOTA: ";
      font-weight: 600;
      color: #000;
  }
  
  .col-amount {
      text-align: left;
  }
}

@media(max-width: 991px){
  .orders-table .table-row {
  text-align: left;
  border-left: revert-layer;
  padding: 15px 0;
  gap: 6px;
  border-bottom: 1px solid silver;
  font-size: 13px;
}

.orders-history-section h2 {
  margin-bottom: 10px;
}
}

.orders-history-section {
  background: #fff;
  padding: 2em;
  border-radius: 10px;
}



.table-header > div {
  font-weight: 600;
}

@media(min-width: 992px) {
  .payment-method-section__flex {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3em;
}

.payment-method-section__flex.w-100 {
  grid-template-columns: 1fr;
}


}

.payment-method-section__flex.w-100 > div {
  background: #f25656;
}

.payment-method-section__flex.w-100 > div {
  color: #fff;
}



.info-icon:hover::after {
  content: attr(data-tooltip);
    position: absolute;
    bottom: 155%;
    left: 50%;
    transform: translateX(-50%);
    background: #024550;
    color: white;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: normal;
    width: 20em;
    white-space: normal;
    text-align: center;
}

.info-icon:hover::before {
  content: "";
  position: absolute;
  bottom: 82%;
  left: 50%;
  transform: translateX(-50%);
  border: 9px solid transparent;
  border-top-color: #024550;
  z-index: 1000;
}

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


.femi-restriction-alert {
    max-width: 60rem;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 1em;
    background: #ce4e4e;
    color: #fff;
    padding: 2em;
    border-radius: 1em;
    align-items: center;
}

.femi-restriction-alert > a {
  background: #fff;
  color: #104550;
}

.femi-restriction-alert h3 {
    font-size: 1.5em;
    font-weight: 500;
}

.page-template-page-femimed-kontynuacja .payment_option_card {
  cursor: pointer;
}

.page-template-page-femimed-kontynuacja .payment_option_card .dot_icon {
  position: relative;
}

.page-template-page-femimed-kontynuacja .payment_option_card .dot_icon:before {
  content: '';
  width: 1.3em;
  height: 1.3em;
  background: #ffe6ce;
  border-radius: 100px;
  transition: all .5s;
}

.page-template-page-femimed-kontynuacja .payment_option_card.is--active  .dot_icon:before {
  box-shadow: inset 0 0 0px 7px #024550;
}

.basket_accepted_cards_grid a {
    border: 2px solid #cccccc;
    padding: 8px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.basket_accepted_cards_grid .method-loading {
  display: none !important;
}

.basket_accepted_cards_grid a.active-method {border-color: #04dd8f;}

@media(min-width: 992px){
    .basket_accepted_cards_grid {
    grid-template-columns: repeat(4, 1fr);
}
}

.payment_option_wrap_femi180 {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  max-width: 60em;
  margin-left: auto;
  margin-right: auto;
}

.payment_option_wrap_femi180 > div {
  background: #ffe6ce;
  position: relative;
  padding-left: 1em;
  padding-right: 1em;
}

.payment_option_wrap_femi180 > div .payment-option-badge {
  position: absolute;
  top: -1.3em;
  border-radius: 100px;
  font-size: 0.875em;
  border: .15em solid #fff;
  padding: 0.5em 0.9em;
}

.payment_option_wrap_femi180 > div .payment-option-badge.badge-disabled {
  background: red;
  color: #fff;
}

.payment_option_wrap_femi180  .payment-option-badge-title {
  margin-top: 0.5em;
}

.payment-option-badge.badge-promo {
  background: #C5FACB;
}

.payment_option_wrap_femi180 > div .payment_option_card_heading > .payment-option-badge-title {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1em;
}

.payment_option_wrap_femi180 > div .payment_option_card_heading .payment-option-badge-title:before {
   content: '';
   width: 1.3em;
   height: 1.3em;
   background: #fff;
   border-radius: 100px;
   transition: all .5s;
}



 

.payment_option_wrap_femi180 > div.is--active .payment-option-badge-title:before {
  box-shadow: inset 0 0 0px 7px #024550;
}

.prl-counter-section .container {
    padding-top: 0;
}

.prl-counter-left-text {
    text-align: left;
    color: #014550;
    flex-direction: column;
    justify-content: center;
    font-size: 1.3em;
    line-height: 1.2;
    font-weight: 400;
    width: 13em;
    font-size: 2em;
}

.prl-counter-display-wrap {
    display: flex;
    align-items: center;
    gap: 4em;
}

.prl-counter-left-text span {
  font-weight: 500;
}

@media(max-width: 768px){
  .prl-counter-item {
  flex-direction: column;
  gap: 1em;
}

.prl-counter-display-wrap {
  flex-direction: column;
  text-align: center;
  gap: 0;
}

.prl-counter-left-text {
  text-align: center;
}

.prl-counter-label {
  text-align: center;
}

.prl-counter-display {
  position: relative;
  left: -0.8em;
}
}

.hidden-element {
  display: none  !important;
}

@media(min-width: 768px){
  .page-template-page-zamowienie   .basket_flex {
     align-items: flex-start;
 }
 
 .page-template-page-zamowienie .basket_flex .basket_flex_left_column.is--femi {
     position: sticky;
     top: 4rem;
 }
 
 .page-template-page-zamowienie .is--overflow-hiden {
     overflow: unset;
 }
 
 .page-template-page-zamowienie .section.is--overflow-hidden {
     overflow: unset;
 }
 }

 .form_field_wrap__text--info {
  padding: 1em;
  margin-bottom: 2em;
  border-radius: 0.5em;
  background: #104550;
  color: #fff;
  margin-top: 1em;
  line-height: 1.4;
}

@media(min-width: 768px){
  .form_field_wrap__flex-femilite {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 1em;
}

.basket_form_block {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.basket_flex .input_field {
  font-size: 0.875em;
}
}



.basket_form_checkboxes_flex.is--femi.div-has-agreements {
  padding-bottom: 1em;
}

.basket_flex {
  grid-column-gap: 1em !important;
  grid-row-gap: 1em !important;
}

.basket_flex_left_column.is--form, .basket_flex_left_column.is--femi {
  max-width: 43em !important;
}

.subscription-info-banner {
  background: #104550;
  color: #fff;
  padding: 2em;
  border-radius: 1em;
  font-size: 1em !important;
}

.subscription-info-banner * {
  font-size: 1em !important;
}

/* Walidacja pól adresowych dla subskrypcji */
.error-field {
  border: 2px solid #ef4444 !important;
  background-color: #fef2f2 !important;
  animation: shake 0.3s ease-in-out;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-10px); }
  75% { transform: translateX(10px); }
}

/* MODAL U PACJENTA  */


div#modal-u-pacjenta,
div#modal-przeslane-pliki {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99999999999999999;
  background: rgba(0,0,0,0.5);
  overflow: scroll;
  transition: all .5s;
  opacity: 0;
  pointer-events: none;
}

div#modal-u-pacjenta.show,
div#modal-przeslane-pliki.show {
  opacity: 1;
  pointer-events: all;
}

.modal-upacjenta .modal-container {
  max-width: 62.5em;
  background: #fff;
  border-radius: 32px !important;
  margin: 20px auto;
  position: relative;
  overflow: hidden;
  padding: 3.75em;
}

.modal-upacjenta .modal-container:before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 50%;
  background: linear-gradient(180deg, rgba(255, 249, 243, 0) 0%, #FFF9F3 87.98%, #FFEEDD 96.15%);
  z-index: 0;
}

.modal-upacjenta .modal-container > * {
  z-index: 1;
  position: relative;
}

.modal-upacjenta h2.modal-title {
  text-align: center;
  font-size: 2.25em;
  color: #181D27;
}

.modal-upacjenta p.modal-subtitle {
  text-align: center;
  margin: 1.5em;
  font-size: 1.25em;
  color: #181D27;
}

.modal-upacjenta .info-badges {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5em;
  margin-bottom: 2.5em;
}

.modal-upacjenta .info-badges .info-badge {
  background: #FFEEDD;
  padding: 0.75em 1.25em;
  border-radius: 100px;
  color: #181D27;
  font-weight: 500;
  font-size: 0.870em;
} 

.modal-upacjenta  .tests-grid {
  opacity: 1;
  border-radius: 1.5em;
  padding: 1.5em;
  gap: 48px;
  border-width: 1px;
  border: 1px solid #E9EAEB;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.modal-upacjenta  .tests-grid .test-column {
  display: flex;
  flex-direction: column;
}


.modal-upacjenta  .tests-grid .test-column .test-item {
  margin: 0.25em 0;
  padding: 0.25em 0;
  display: flex;
  gap: 0.75em;
  border-bottom: 1px solid #E9EAEB;
}

.modal-upacjenta  .tests-grid .test-column .test-item span.test-check svg {
  width: 1.25em;
  height: auto;
}

@media(max-width: 768px){
.modal-upacjenta    .tests-grid {
        grid-template-columns: 1fr;
        gap: 0;
  }
}

.modal-upacjenta  .option-card {
  border-radius: 1.5em;
  padding: 1.5em;
  background: #fff;
  box-shadow: 0px 4px 6px -2px #0A0D1208;
  box-shadow: 0px 12px 16px -4px #0A0D1214;
}

.modal-upacjenta .test-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5em;
  margin-top: 2.5em;
}

.modal-upacjenta .test-options .option-icon svg {
  width: 2em;
}

.modal-upacjenta  h3.option-title {
  font-size: 1.25em;
  color: #181D27;
  font-weight: 500;
  margin: 0.75em 0 1em;
}



.modal-upacjenta .bottom-notice {
  background: #FFEEDD;
  color: #D97826;
  font-weight: 500;
  display: flex;
  align-items: center;
  padding: 1em;
  border-radius: 0.5em;
  margin-top: 1.25em;
  gap: 0.5em;
  font-weight: 400;
}

.modal-upacjenta .bottom-notice svg {
  width: 2em;
}

.modal-upacjenta span.notice-icon svg {
  width: 1.25em;
  height: auto;
  position: relative;
  top: -0.07em;
}

.modal-upacjenta span.notice-icon {
  display: flex;
  align-items: center;
  gap: 0;
}

.modal-upacjenta button.modal-close {
  width: 2em;
  height: 2em;
  border-radius: 100px;
  background: #014550;
  color: #fff;
  font-size: 1.6em;
  padding: 0 !important;
  line-height: 1;
  position: absolute !important;
  top: 0.75em;
  right: 0.75em;
  cursor: pointer;
  transition: all .5s;
}

.modal-upacjenta button.modal-close:hover {
  background: #ffeedd;
  color: #024550;
}

.modal-upacjenta span.badge-text {
  font-weight: 400;
}


.modal-upacjenta  a.option-button {
  display: inline-block;
}

.modal-upacjenta  a.option-link {
  display: inline-block;
  margin: 1em 0 2em;
  color: #717680;
  font-size: 0.89em;
}

.modal-upacjenta  p.option-description {
  font-size: 0.89em;
}

.modal-upacjenta  a.option-button.option-button-primary {
  background: #FFED64;
  text-decoration: none;
  color: #181D27;
  font-weight: 500;
  padding: 0.8em 1.5em;
  border-radius: 100px;
  border: 0.15em solid #FFED64;
  transition: all .5s;
}

.modal-upacjenta  a.option-button.option-button-primary:hover {
  color: #181D27;
  background: #fff;
  border-color: #181D27;
}

.modal-upacjenta  a.option-button.option-button-secondary {
  background: #fff;
  text-decoration: none;
  color: #181D27;
  font-weight: 500;
  padding: 0.8em 1.5em;
  border-radius: 100px;
  border: 0.15em solid #181D27;
  transition: all .5s;
}

.modal-upacjenta a.option-button.option-button-secondary:hover {
  background: #181D27;
  color: #fff;
}

.modal-upacjenta em:after {
  content: '';
  width: 100%;
  height: 40%;
  background: #ABF3D8;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
}

.modal-upacjenta em {
  position: relative;
}

@media(max-width: 768px){
  .modal-upacjenta .modal-container {
    padding: 70px 20px 20px 20px;
    max-width: 100%;
    margin: 0;
    border-radius: 0 !important;
    min-height: 100vh;
}

.modal-upacjenta .test-options {
    grid-template-columns: 1fr;
}

.modal-upacjenta a.option-link {
    display: block;
}
}


.uploaded-file-item {
  border: 1px solid #ededed;
  border-radius: 0.7em;
  margin-bottom: 1em;
  padding: 1em;
  background: #fff;
}

.uploaded-file-item .file-name {
  font-weight: 600;
}

.uploaded-file-item .file-info {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}

.uploaded-file-item .file-actions {
  display: flex;
  gap: 1em;
}



.info_footer_left_column__upacjenta img {
  width: 11em;
  margin-left: 0;
  position: relative;
  top: -1px;
  height: 5.2em;
  background: #fff;
  border-radius: 1em;
  object-fit: contain;
  padding: 0 1em;
  margin-top: 2.5em;
}