.banner-form-wrap input.invalid {
  border: 2px solid #dc3545; /* red border */
}

.banner-form-wrap input.valid {
  border: 2px solid #28a745; /* green border */
}

.banner-form-wrap .error-msg {
    position: absolute;
    left: 0px;
    bottom: 0;
  color: #dc3545;
  font-size: 10px;
  margin-top: 4px;
  display: block;
  background: #fff;
    padding: 0 10px;
}

    .video-container {
        position: relative;
        height: auto;
    }
    iframe#myvideo {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100% !important;
    display: block;
    opacity: 0;
}
.video-container.playVideo iframe#myvideo {
    opacity: 1;
}
.banner-form-wrap {
    /*justify-content: center;*/
    display: flex;
    align-items: end;
    margin: 30px auto;
}
.banner-form-wrap input::placeholder {
    color: #fff;
    opacity: 0.7;
}
.banner-form-wrap input {
    height: 40px;
    border-radius: 5px;
    background-color: #000000;
    border: 1px solid #ffffff;
    text-transform: none;
    letter-spacing: 0.5px;
    color: #fff;
    font-family: 'gotham_mediumregular';
}
    #play-button {
    z-index: 2;
}
#pause-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80px;
    height: 80px;
    background: url(/wp-content/themes/tonehouse-bootstrap/images/pause-button.svg) no-repeat;
    background-size: contain;
    cursor: pointer;
    z-index: 2;
    display: none;
}
.video-container.playVideo #play-button {
    display: none;
}
.video-container.playVideo #pause-button {
    display: block;
}
#homeModal button.close {
    position: relative;
    background-color: #F8F9FA;
    border-radius: 3px;
    font-size: 50px;
    font-weight: 400;
    text-align: right;
    box-shadow: 0 1px 3px 0 rgba(35,35,41,0.2);
    overflow: hidden;
    padding: 0 10px;
    margin-bottom: 20px;
    transform: translate3d(0, 0, 0);
    width: 100%;
    z-index: 20;
}
.modal-content {
    height: 100vh;
    overflow-y: scroll;
}
#homeModal h1.healcode-registration-promo-text {
    padding: 0;
    width: 100%;
    margin-bottom: 0;
}

/*
.new-athlete-page h1,
.new-athlete-page h2,
.new-athlete-page h3 {
  font-weight: bold;
} */
 
.athlete_banner h1 {
    font-size: 48px;
    padding-bottom: 0;
    font-family: 'gotham_boldregular';
}
.athlete_banner h3 {
    margin-bottom: 20px;
}
.banner-content p {
    text-align: left;
    /*width: 80%;*/
    margin: 0 auto;
    font-size: 20px;
}
.image-content-wrap {
    position: absolute; 
    bottom: 20px;
    left: 20px;
    right: 20px; 
    background: rgba(0,0,0,0.7); 
    padding: 20px; 
    color: #fff; 
    min-height: 185px;
    text-align: center;
    margin: 0 auto;
}
.image-with-content img {
    width: 100%;
}
.image-with-content {
    padding: 40px 0;
    background: #fff;
}
.map-section {
    position: relative;
}
.map-section iframe {
    width: 100% !important;
}
.map-section h2 {
    text-align: left;
    background: #000;
    position: absolute;
    left: 0;
    padding: 10px;
    font-size: 30px;
    text-transform: uppercase;
    font-weight: 400;
    color: #fff;
    padding-left: 30px;
    font-family: 'gotham_lightregular';
    text-align: center; 
    margin-bottom: 30px;
}
.image-content-wrap h3 {
    font-size: 36px;
    text-transform: uppercase;
}
/* Container card */
.social-proof-item {
  background: #fff;
    border-radius: 0;
    padding: 20px;
    height: 100%;
    min-height: 250px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    border: 5px solid #dbff5b;
    position: relative;
    margin: 0 15px;
}
.social-proof-item:after {
    content: "";
    background: transparent;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    border: solid #808080;
    border-width: 0px 5px 5px 0px;
    left: 18px;
    top: 18px;
}
/* Header section */
.social-user-head {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.social-user-head img {
  width: 32px !important;
  height: 32px;
  border-radius: 50%;
  margin-right: 10px;
  object-fit: cover;
}

.social-user-head h4 {
  margin: 0;
  font-size: 16px;
  color: #000;
  font-family: 'gotham_mediumregular';
}

/* Rating stars */
.social-rating {
  font-size: 16px;
  color: #ffb400; /* Gold/yellow for stars */
  margin-bottom: 10px;
  letter-spacing: 2px;
}

.owl-social-proof .owl-stage {
    margin: 0 auto;
    display: flex;
    align-items: stretch;
    margin: 0 auto;
    padding: 20px 0;
    padding: 20px 0;
}
/* Review text */
.social-description p {
  margin: 0;
  font-size: 14px;
  color: #333;
  line-height: 1.5;
}
.social-proofs {
    padding: 60px 0;
    background: #000;
}
.social-proofs h2 {
    margin-bottom: 20px;
    margin-top: 0;
    color: #fff;
}
/* Responsive tweaks */
@media (max-width: 768px) {
    .form-section select {
    background-position: calc(100% - 18px) center !important;
}
  .social-proof-item {
    padding: 15px;
  }

  .social-user-head h4 {
    font-size: 14px;
  }

  .social-description p {
    font-size: 13px;
  }
}


.logos-section .row {
    display: flex;
    justify-content: center;
    align-items: center;
}
.logos-section .row > div {
    display: inline-flex;
    align-items: center;
}
.img-wrap {
    display: inline-block;
    margin: 0 20px;
}
.logos-section h2 {
    position: relative;
    text-align: center;
    color: #fff;
    text-transform: uppercase;
    font-weight: 400;
    padding-right: 40px;
    margin-right: 20px;
    font-family: 'gotham_lightregular';
}
.logos-section h2:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -30px;
    width: 2px;
    height: 100px;
    background-image: linear-gradient(90deg, #7f7f7f 0%, #f7f5f5 39%, #9f9f9f 62%, #dfdfe1 75%, #7f7f7f 100%);
}
/*.mb_only {
    display: none;
}*/
.img-content-wrapper {
    position: relative;
}
.btn-primary:hover {
    color: #fff;
    background: #286090;
    border-color: #204d74;
}
/*.new-athlete-page .banner-content .wpcf7-response-output {
    display: none !important;
}*/
.logos-section {
    padding: 60px 0; 
    background: #111; 
    color: #fff;
}

@media(max-width: 992px){
/*  .mb_only {
        display: block;
    }
    .desktop_only {
        display: none;
    }*/
    .logos-section .row {
        flex-wrap: wrap;
    }
    .logos-section h2 {
        margin-right: 0;
        margin-bottom: 50px;
        padding: 0;
    }
    .logos-section h2:after {
        right: 30px;
        bottom: -20px;
        margin: 0 auto;
        width: 100px;
        height: 2px;
    }
    .map-section h2 {
        font-size: 20px;
    }
    .image-content-wrap h3 {
        font-size: 24px;
    }
    .athlete_banner .banner-content {
        padding-bottom: 30px;
    }
    .img-content-wrapper {
        margin-bottom: 20px;
    } 
    .athlete_banner h1 {
        font-size: 40px;
        padding-top: 30px;
    }
    .owl-nav-custom {
    color: #fff;
    font-size: 28px;
    background: rgba(0, 0, 0, 0.4);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9;
  }

  .left-arrow {
    left: -12px;
  }

  .right-arrow {
    right: -12px;
  }

  .owl-carousel .owl-nav {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none; /* nav buttons won't block item click */
  }

  .owl-carousel .owl-nav span {
    pointer-events: all;
  }

  .social-proof-item-wrapper {
    position: relative;
  }
  .social-proof-item {
    width: 80%;
    margin: 0 auto;
  }
  .owl-social-proof.owl-carousel .owl-nav button.owl-next,
  .owl-social-proof.owl-carousel .owl-nav button.owl-prev {
    position: unset;
  }

}


/* */
.athlete_banner .h-100 {
    height: 100%;
}
.athlete_banner-in {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 5%;
}
.athlete_banner .banner-content h3 {
    font-weight: 600;
    font-style: italic;
    text-align: left;
}
.banner-form-wrap div {
    padding-left: 0;
}
.athlete_banner-in .btn {
    text-transform: uppercase;
    background: #fff;
    padding: 10px 30px;
    font-family: 'gotham_boldregular';
    color: #000;
}
.athlete_banner-in .btn:hover {
    background: #DBFF5B;
    border-color: #DBFF5B;
}
.page-template-template-newathlete-2025 .wpcf7-response-output.alert.alert-warning {
    color: #fff;
    position: absolute;
    bottom: 35px;
    left: 0;
}
ul#menu-main-menu-new .dropdown-toggle::after {
    font-size: 0;
}
.navbar-top-login .container, .navbar-top-login .container .row {
       width: 100%;
    display: block !important;
    max-width: 100%;
}
.navbar-top-login .container .row > .col-sm-5.col-sm-push-7 {
  
    left: 0;
    width: 100%;
}
.navbar-top-login .container .row > .col-sm-5.col-sm-push-7 {
    display: flex;
    justify-content: end;
    align-items: center;
}
    .multi-step-container .form-control {
        height: 50px;
        background: #fff;
        border: 1px solid #AEAEAE;
        padding: 10px 20px;
        border-radius: 0;
        margin: 0;
        font-size: 12px;
        font-family: 'gotham_lightregular';
        text-transform: none !important;
        color: #000;
    }
    .toggle-password {
            position: absolute;
        right: 25px;
        top: 12px;
        cursor: pointer;
        font-size: 16px;
        z-index: 10;
        color: #919191;
    }
    #home-social-container {
        display: none;
    }
    .form-group.wpcf7-acceptance {
        display: inline-block;
        margin-top: 4px;
        margin-bottom: 0;
    }
    .form-group.wpcf7-acceptance span {
        font-family: 'gotham_mediumregular';
        font-size: 14px;
    }
    .acceptance-wrapper .checkbox {
        margin: 0;
    }
    .acceptance-wrapper {
        display: flex;
        align-items: center;
        margin-bottom: 20px;
    }
    .multi-step-container .btn {
        color: #000;
        background: #EDEDED;
        height: 40px;
        font-size: 16px;
        border-radius: 10px;
        display: flex;
        align-items: center;
        font-family: 'gotham_boldregular';
    }
    .multi-step-container .btn.wpcf7-submit {
        background: #DBFF5B;
    }
    .multi-step-container {
        font-family: 'gotham_regular';
    }
    .multi-step-container .form-left img {
        margin-bottom: 20px;
        width: 100%;
    }
    .form-left h2 {
        font-size: 30px;
        line-height: 1.3;
        padding-bottom: 0;
        font-family: 'gotham_boldregular';
    }
    .left-content {
        margin-top: 30px;
    }
.top-pass-section {
    border: 1px solid #ccc; 
    padding: 15px; 
    margin-bottom: 20px; 
    font-weight: bold;
}
.top-pass-section p {
    font-size: 18px;
    margin-bottom: 0;
}
.form-right {
    flex: 1; 
    padding: 40px; 
    background: #fff;
}
.form-section input.invalid, .form-section select.invalid {
    border: 2px solid #dc3545;
}
.form-section input.valid, .form-section select.valid {
    border: 2px solid #28a745;
}
.form-section .error-msg {
    position: absolute;
    right: 10px;
    bottom: 0px;
    color: #dc3545;
    font-size: 11px;
    display: block;
}
.form-section select {
    background-image: url('/wp-content/uploads/2025/10/Vector-82.png') !important;
    background-repeat: no-repeat !important;
    background-position: 96% center !important;
    background-size: 10px !important;
}
ul#menu-main-menu-new .dropdown-toggle::after {
    font-size: 0;
}
.navbar-top-login .container, .navbar-top-login .container .row {
       width: 100%;
    display: block !important;
    max-width: 100%;
}
.navbar-top-login .container .row > .col-sm-5.col-sm-push-7 {
  
    left: 0;
    width: 100%;
}
.navbar-top-login .container .row > .col-sm-5.col-sm-push-7 {
    display: flex;
    justify-content: end;
    align-items: center;
}
    .multi-step-container .form-control {
        height: 50px;
        background: #fff;
        border: 1px solid #AEAEAE;
        padding: 10px 20px;
        border-radius: 0;
        margin: 0;
        font-size: 12px;
        font-family: 'gotham_lightregular';
        text-transform: none !important;
        color: #000;
    }
    .toggle-password {
            position: absolute;
        right: 15px;
        top: 50%;
        transform: translateY(-50%);
        cursor: pointer;
        font-size: 16px;
        z-index: 10;
        color: #919191;
    }
    #home-social-container {
        display: none;
    }
    .form-group.wpcf7-acceptance {
        display: inline-block;
        margin-top: 4px;
        margin-bottom: 0;
    }
    .form-group.wpcf7-acceptance span {
        font-family: 'gotham_mediumregular';
        font-size: 14px;
    }
    .acceptance-wrapper .checkbox {
        margin: 0;
    }
    .acceptance-wrapper {
        display: flex;
        align-items: center;
        margin-bottom: 20px;
    }
    .multi-step-container .btn {
        color: #000;
        background: #EDEDED;
        height: 40px;
        font-size: 16px;
        border-radius: 10px;
        display: flex;
        align-items: center;
        font-family: 'gotham_boldregular';
    }
    .multi-step-container .btn.wpcf7-submit {
        background: #DBFF5B;
    }
    .multi-step-container {
        font-family: 'gotham_regular';
    }
    .multi-step-container .form-left img {
        margin-bottom: 20px;
        width: 100%;
    }
    .form-left h2 {
        font-size: 30px;
        line-height: 1.3;
        padding-bottom: 0;
        font-family: 'gotham_boldregular';
    }
    .left-content {
        margin-top: 30px;
    }

    .ui-datepicker {
        background: #f0f8ff;   
        border: 1px solid #333;
        font-family: Arial, sans-serif;
    }

    .ui-datepicker-header {
        background: #007bff;
        color: #fff;
    }

    .ui-datepicker td a {
        color: #007bff;
    }

    .ui-datepicker td a:hover {
        background: #0056b3;
        color: #fff;           
    }
.top-pass-section p {
    font-size: 18px;
    margin-bottom: 0;
}
.form-right {
    flex: 1; 
    padding: 40px; 
    background: #fff;
}
.multi-step-container #profile .wpcf7-response-output {
    display: none !important;
}
.form-section input.invalid, .form-section select.invalid {
    border: 2px solid #dc3545;
}
.form-section input.valid, .form-section select.valid {
    border: 2px solid #28a745;
}
.form-section .error-msg {
    position: absolute;
    right: 10px;
    bottom: 0px;
    color: #dc3545;
    font-size: 11px;
    display: block;
}
.form-section select {
    background-image: url('/wp-content/uploads/2025/10/Vector-82.png') !important;
    background-repeat: no-repeat !important;
    background-position: calc(100% - 8px) center !important;
    background-size: 10px !important;
}
.multi-step-container .form-group.state .form-control, 
.multi-step-container .form-group.how-hear .form-control,
.multi-step-container .form-group.gender .form-control {
    background-position: calc(100% - 16px) center !important;
}
p.form-txt {
    font-family: 'gotham_mediumregular';
    font-size: 14px;
    color: #aeaeae;
    font-weight: 500;
    line-height: 30px;
}
.same-address-wrapper {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
    font-size: 14px;
    color: #AEAEAE;
}
.same-address-wrapper div.checkbox.same-address {
    margin: 0;
}
.same-address-wrapper > .form-group {
    margin-bottom: 0px;
    line-height: 1;
}
/* Full form overlay */
.cf7-form-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.95);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cf7-overlay-content {
  text-align: center;
}

.cf7-overlay-text {
  margin-top: 12px;
  font-size: 16px;
  color: #333;
  font-weight: 500;
}

/* Spinner styling */
.cf7-custom-spinner {
  display: inline-block;
  width: 32px;
  height: 32px;
  border: 3px solid #ccc;
  border-top: 3px solid #0073aa; /* your theme accent color */
  border-radius: 50%;
  animation: cf7-spin 0.8s linear infinite;
}

@keyframes cf7-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Ensure the form container is positioned so overlay can sit on top */
#wpcf7-f6757-o1 form {
  position: relative;
}

    .multi-step-container  .tab-content {
    border: 1px solid #eee;
    background: #fff;
    border-top: none;
    padding: 0;
    border-radius: 0 0 8px 8px;
}
    .multi-step-container .acceptance-wrapper {
    align-items: self-start;
}
        .multi-step-container .form-left {
    padding: 20px ! IMPORTANT;
}
    .banner-form-wrap {
    flex-wrap: wrap;
}
}
.multi-step-container .wpcf7-form .wpcf7-response-output,
.new-athlete-page .wpcf7-form .wpcf7-response-output {
    display: none;
}
.multi-step-container .wpcf7-form.invalid .wpcf7-response-output,
.new-athlete-page .wpcf7-form.invalid .wpcf7-response-output {
    display: block;
}.alert-warning{
        background-color: transparent;
    border-color: transparent;
}
/* new css */
.form-left h2 {
    color: #DAFF5A;
}
.multi-step-container .left-content p {
    font-family: 'gotham_lightregular';
        font-size: 20px;
    line-height: 30px;
}
.multi-step-container .left-content p em {
    font-size: 20px;
    line-height: 30px;
    font-family: 'gotham_mediumregular';
        margin-bottom: 20px;
    display: block;
}
.multi-step-container {
    font-family: 'gotham_mediumregular' !important;
}
.top-pass-section {
    background: #F4F4F4;
    border: 0 !important;
    font-size: 22px;
    color: #656565;
    font-family: 'gotham_lightregular';
}
.top-pass-section span {
    color: #000;
    font-family: 'gotham_mediumregular';
    font-weight: 400;
}
.multi-step-container .nav-tabs .nav-link {
    font-size: 16px;
    font-family: 'gotham_lightregular';
}
.multi-step-container .form-control {
    font-size: 16px !important;
    box-shadow: none !important;
}
.multi-step-container .acceptance-wrapper {
    font-size: 14px;
    color: #AEAEAE;
}
.multi-step-container .btn {
    border: 0px;
    font-weight: 900;
}
.multi-step-container .btn.wpcf7-submit:hover {
    background: #EDEDED;
}
.multi-step-container .btn:hover {
    background: #DBFF5B;
}
.banner-form-wrap input {
    border-radius: 5px !important;
}
#profilePaymentTabContent {
    border: 0;
    padding: 0;
}
@media only screen and (max-width:992px)
{
    .form-right {
    padding: 20px !important;
}
    .top-pass-section span {
    float: none !important;
}
    .top-pass-section {
    display: flex
;
    justify-content: space-between;
                flex-wrap: wrap;
}
    .multi-step-container  .tab-content {
    border: 1px solid #eee;
    background: #fff;
    border-top: none;
    padding: 0;
    border-radius: 0 0 8px 8px;
}
    .multi-step-container .acceptance-wrapper {
    align-items: self-start;
}
        .multi-step-container .form-left {
    padding: 20px ! IMPORTANT;
}
    .banner-form-wrap {
    flex-wrap: wrap;
}
}
.multi-step-container .wpcf7-form .wpcf7-response-output,
.new-athlete-page .wpcf7-form .wpcf7-response-output {
    display: none;
}
.multi-step-container .wpcf7-form.invalid .wpcf7-response-output,
.new-athlete-page .wpcf7-form.invalid .wpcf7-response-output {
    display: block;
}
.athlete_banner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #0000005e;
}
.multi-step-container .form-group.dob .form-control {
    padding-right: 12px;
}