/*
  font-family: 'Work Sans', sans-serif;
  gold: #a79132

*/
/*LINK LOCAL AULA*/
.grey-link {
  color: #8b8b8b !important;
}

@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600&display=swap");
html,
body {
  font-family: "Poppins", sans-serif;
  color: #222222;
  font-weight: 400;
}
h1,
h2,
h3,
h4,
h5 {
  font-weight: 600;
}
b,
strong {
  font-weight: 600;
}
button,
button:hover,
input,
input:hover,
input:focus,
button:focus,
a:hover,
a:focus {
  text-decoration: none;
  outline: none;
  box-shadow: none;
}
.form-control:focus {
  box-shadow: none;
}
.gosmall {
  font-size: 12px;
}
.btn.focus,
.btn:focus {
  outline: 0;
  box-shadow: none;
}
input[type="date"]::-webkit-inner-spin-button,
input[type="date"]::-webkit-calendar-picker-indicator {
  display: none;
  -webkit-appearance: none;
}
input[type="time"]::-webkit-calendar-picker-indicator {
  background: none;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

::placeholder {
  color: #f3f3f3;
  opacity: 1;
}

:-ms-input-placeholder {
  color: #f3f3f3;
}

::-ms-input-placeholder {
  color: #f3f3f3;
}
.mt-10px {
  margin-top: 10px;
}
.col-md-20 {
  -ms-flex: 0 0 20%;
  flex: 0 0 20%;
  max-width: 20%;
}
.pt-80 {
  padding-top: 80px;
}
.mb-50 {
  margin-bottom: 50px;
}

/*NAVBAR*/
.mainnav {
  z-index: 9;
}
.nav-item .nav-link.buttn {
  background: #ee8135;
  color: white;
  padding: 12px 35px;
  border-radius: 100px;
}
.nav-item .nav-link {
  color: white;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
.nav-item .nav-link {
}
.mainnav .dropdown-menu {
  background-color: #ee8135;
  border: none;
}
.mainnav .dropdown-menu .dropdown-item {
  color: white;
}
.dropdown-item:focus,
.dropdown-item:hover {
  background-color: inherit;
}
/*NAVBAR*/

/*HOME*/
#hero {
  /*    background-image: url('../img/hero.jpg');*/
  background-size: cover;
  background-position: center;
  position: relative;
  padding: 340px 0 220px 0;
}
#hero video.fullscreen {
  position: absolute;
  z-index: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#hero h1 {
  letter-spacing: 2px;
  font-weight: 400;
  font-size: 3rem;
  color: white;
  line-height: 1;
}
#hero h4 {
  font-weight: 400;
  color: white;
  font-size: 1.1em;
  margin-bottom: 30px;
}
#hero h5 {
  font-size: 1em;
}
#hero h5 a.fazmarc {
  background: #ee8135;
  display: inline-block;
  font-weight: 400;
  line-height: 1.5;
  color: white;
  padding: 12px 25px;
  border-radius: 100px;
}
#hero h5 a.verserv {
  font-weight: 400;
  margin-left: 15px;
  display: inline-block;
  color: white;
}
#hero .scrollnow {
  position: absolute;
  right: 40px;
  color: white;
  transform: rotate(90deg);
  transform-origin: 0 0;
  bottom: 15%;
}
#hero .scrollnow:before {
  position: absolute;
  content: "";
  width: 100px;
  height: 2px;
  top: 12px;
  background: white;
  left: 50px;
}
/*HOME*/

#mainclasses {/*
  display: flex;
  justify-content: space-between;
  width: 100%;
  overflow-x: hidden;*/
}
#mainclasses .classbox {
  position: relative;
  flex: 0.25;
  height: 25rem;
}
#mainclasses .classbox .classimg {
  height: 100%;
  /*max-width: 100%;*/
  width: 100%;
  object-fit: cover;
}
#mainclasses .classbox .classinfo p {
  margin-bottom: 0;
}
#mainclasses .classbox .classinfo {
  color: white;
  background-color: #33333355;
  pointer-events: none;
  position: absolute;
  padding: 20px;
  border-radius: 5px;
  z-index: 2;
  left: 20px;
  bottom: 20px;
}
#mainclasses .classbox .classinfo h3 {
  background: linear-gradient(to right, #fff11d, #e98c30, #e06444, #3a62a9);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 700;
  width: 100%;
}
#mainclasses .classbox .classinfo .price {
  margin-bottom: 0;
}

/*ABOUT*/
#about {
  padding: 120px 0;
}
#about img {
  border-radius: 10px;
}
#about h1 {
  font-weight: 400;
  font-size: 1.5rem;
  color: #333;
  line-height: 1;
}
#about p {
  color: #666;
  text-align: justify;
  margin-bottom: 2rem;
}
#about a {
  background: #ee8135;
  color: white;
  padding: 12px 35px;
  border-radius: 100px;
}
#about a:hover {
  background: #ee8135;
}

/*BOXES*/
#boxesrow .row {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
}
#boxesrow .row .classbox-text,
#boxesrow .row .classimg {
  flex: 0 0 25%;
}
#boxesrow .row .classbox-text {
  background-color: black;
  color: white;
  padding-top: 6rem !important;
  padding: 2rem;
  height: 320px;
}
#boxesrow .row .classbox-text h3 {
  color: white;
  font-weight: 700;
  width: 100%;
  font-size: 1.3rem;
  margin-bottom: 0;
}
#boxesrow .row .classbox-text .price,
#boxesrow .row .classbox-text .days {
  margin-top: 1rem;
}
#boxesrow .row .classbox-text.c1 h3 {
  color: #111;
}
#boxesrow .row .classbox-text.c1 {
  background-color: #fede14;
  color: #111;
}
#boxesrow .row .classbox-text.c2 {
  background-color: #e98c30;
}
#boxesrow .row .classbox-text.c3 {
  background-color: #e06444;
}
#boxesrow .row .classbox-text.c4 {
  background-color: #3a62a9;
}
#boxesrow .row .classimg {
  width: 100%;
  height: 320px;
  object-fit: cover;
}

/*TESTIMONIALS*/
#testimonials {
  background-color: #222;
  padding: 120px 0;
  display: flex;
  flex-direction: column;
  position: relative;
  justify-content: flex-end;
}
#testimonials .svg-bg {
  left: 0;
  bottom: 0;
  width: 80%;
  pointer-events: none;
  opacity: 0.2;
  height: auto;
  position: absolute;
}
#testimonials .owl-dots {
  display: none;
}
#testimonials h1 {
  letter-spacing: 2px;
  font-weight: 400;
  font-size: 2rem;
  color: white;
  line-height: 1;
}
#testimonials .testimonial-carousel {
  text-align: center;
}
#testimonials .testimonial-carousel .testimonial-item p {
  font-style: italic;
  font-size: 1.1rem;
  color: white;
}
#testimonials .testimonial-carousel .testimonial-item cite {
  text-align: left;
  color: #ee8135;
  text-align: center;
}

.item.is-hidden {
  display: none;
}
/*PROF*/
#prof {
  padding: 120px 0;
  position: relative;
}
#prof .teacher-item {
  margin-bottom: 30px;
}
#prof h1 {
  letter-spacing: 2px;
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
}
#prof .teacher-carousel .teacher-item {
  position: relative;
}
#prof .photoprof {
  height: 250px;
  overflow: hidden;
  border-radius: 300px;
}
#prof .photoprof img {
  width: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
#prof .teacher-info h3 {
  font-weight: 400;
}
#prof .teacher-info p {
  opacity: 0.7;
}
#prof .teacher-info a {
  color: #ee8135;
  font-weight: 400;
}

#prof .teacher-carousel .teacher-item .teacher-image .teacher-info {
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  padding: 1rem;
  color: #fff;
  opacity: 0;
  transition: left 0.3s ease, opacity 0.3s ease;
  text-align: center;
}
#prof .teacher-carousel .teacher-item .teacher-image .teacher-info h3 {
  margin: 0;
}
#prof .teacher-carousel .teacher-item .teacher-image .teacher-info p {
  margin: 1rem 0;
}
#prof .teacher-carousel .teacher-item .teacher-image .btn-luel {
  position: absolute;
  color: white;
  bottom: 1rem;
  display: flex;
  justify-content: center;
  font-weight: 700;
  padding: 0.5rem 1.5rem;
  left: 50%;
  font-size: 1rem;
  transform: translateX(-50%);
}
#prof .teacher-carousel .teacher-item .teacher-image .btn-luel:hover {
  text-decoration: none;
}
#prof .teacher-carousel .teacher-item:hover .teacher-image img {
  transform: translateX(-5px);
}
#prof .teacher-carousel .teacher-item:hover .teacher-info {
  left: -5px;
  opacity: 1;
}
/*INSTAROW*/
/*HORARIO*/
#hero-horario {
  padding: 120px 0;
  background-image: url("../img/horario.jpg");
  object-position: center;
  background-position: 0 20%;
  background-size: cover;
  background-repeat: no-repeat;
}
/*GRID HORARIO*/
#horario {
  padding: 120px 0;
}
#horario h1 {
  letter-spacing: 2px;
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
}

#horario .dia_semana {
  font-size: 1.1rem;
  padding: 12px 0;
  border-bottom: 1px solid #888;
  margin-bottom: 20px;
}

#horario .class_detail{
	padding: 10px 10px;
}

#horario .class_detail h3 {
  font-size: 0.8rem;
  margin-bottom: 5px;
  display: block;
  width: 100%;
}
#horario .class_detail span {
  font-size: 0.7em;
  letter-spacing: 1px;
  display: inline-block;
  margin-right: 5px;
  top: 1px;
  padding: 6px;
  border-radius: 10px;
  position: relative;
  color: white;
  font-weight: 400;
  background: black;
}
#horario .class_detail span.intermedio {
  background: #6dc1ab;
}
#horario .class_detail p {
  margin-bottom: 0;
  font-size: 14px;
}
#horario .class_detail p a {
  color: #ee8135;
  text-decoration: underline;
}

#schedule_details {
/*  background: #f7f7f7;*/
  padding: 40px 0;
}
#schedule_details p {
  margin-bottom: 0;
}

#schedule_details span {
  font-size: 0.6em;
  letter-spacing: 1px;
  display: inline-block;
  margin-right: 5px;
  top: 1px;
  padding: 6px;
  border-radius: 10px;
  position: relative;
  color: white;
  font-weight: 400;
  background: black;
}

#schedule_details span.plus3, #horario h3 span.plus3 {
  background: #9b59b6;
}
#schedule_details span.plus4, #horario h3 span.plus4 {
  background: #f39434;
}
#schedule_details span.plus5, #horario h3 span.plus5 {
  background: #6dc1ab;
}
/*
#schedule_details span.quatroaos6, #horario h3 span.quatroaos6 {
  background: #f39434;
}
#schedule_details span.tresaos10, #horario h3 span.tresaos10 {
  background: #2ecc71;
}*/

#schedule_details span.plus6, #horario h3 span.plus6 {
  background: #3498db;
}
#schedule_details span.plus9, #horario h3 span.plus9 {
  background: #f0dc1a;
}

#schedule_details span.plus14, #horario h3 span.plus14 {
  background: #2ecc71;
}

#schedule_details span.adultos, #horario h3 span.adultos {
  background: #e74c3c;
}
#filters ul li {
  cursor: pointer;
}

/*MODALIDADE*/
#hero-modalidade {
  padding: 120px 0;
  background-image: url("../img/hiphop.jpg");
  object-position: center;
  background-position: 0 50%;
  background-size: cover;
  background-repeat: no-repeat;
}
#modalidade {
  padding: 120px 0;
}
#modalidade h1 {
  letter-spacing: 2px;
  margin-bottom: 10px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
}
#modalidade .professors p {
  font-size: 14px;
}
#modalidade .professors img {
  border-radius: 400px;
}
#modalidade p {
  color: #777;
  text-align: justify;
}
#modalidade p span {
  color: #ee8135;
}
#modalidade .modalidadeimg {
  border-radius: 10px;
}

#modalidade .prices .wrap {
  padding: 30px;
  border: 1px solid #e4e4e4;
  border-radius: 10px;
}
#modalidade .prices .wrap h2 {
  margin-bottom: 10px;
  margin-top: 0;
}
#modalidade .prices .wrap h3 {
  font-size: 14px;
}
#modalidade .prices .wrap h3 del {
  color: #8b8b8b;
}
#modalidade .prices .wrap h3 span {
  background: #e4ebe6;
  border-radius: 5px;
  color: #484848;
  padding: 8px 15px !important;
  display: inline-block;
  margin-left: 10px;
}
#modalidade .prices img {
  border-radius: 10px;
}
#modalidade .prices .wrap button.mymod {
  background: #00b894;
  border-radius: 100px;
  color: white;
  border: none;
  margin-top: 20px;
  width: 100%;
  padding: 10px 25px !important;
  display: inline-block;
  text-align: center;
}
#modalidade .prices .wrap h5 {
  color: #484848;
  font-size: 1.1em;
  margin-bottom: 15px;
}
#modalidade .prices .wrap p {
  color: #8b8b8b;
  font-size: 14px;
}
#modalidade .prices .wrap p a {
  color: #ee8135;
}

#modalidade img.teacher {
  position: relative;
  overflow: hidden;
  height: 80vh;
  max-width: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
  border-radius: 20px;
  border: 10px solid transparent;
  background: linear-gradient(to right, #fff11d, #e98c30, #e06444, #3a62a9)
    border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
}
#modalidade img.modalidadeimg {
  /* 
    height: 50vh;
    object-fit: cover;
  */
  width: 100%;
  
}
#modalidade .hipimg {
  height: 85vh;
  overflow: hidden;
}
#modalidade .professor {
  padding: 3rem 0;
}
/*CONTATOS*/
#hero-contatos {
  padding: 120px 0;
  background-image: url("../img/contatos.jpg");
  object-position: center;
  background-position: 0 35%;
  background-size: cover;
  background-repeat: no-repeat;
}
#inner-hero {
  padding-top: 120px;
}
#inner-hero h1 {
  letter-spacing: 2px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
  text-align: center;
}

#contacts_01 {
  padding: 80px 0 0px 0;
}

#contacts_01 i {
  color: #67a9ab;
}

#contacts_01 h5 {
  color: #333;
}

#contacts_01 p {
  color: #444;
}

#contacts_01 strong,
#contacts_01 a {
  color: #67a9ab;
}

#contacts_02 {
  padding: 120px 0;
}

#contacts_02 h2 {
  letter-spacing: 2px;
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
}

#contacts_02 h2 span {
  color: #67a9ab;
}

#contacts_02 input {
  background: #f3f3f3;
  border: 1px solid transparent;
  color: #444;
  padding: 15px;
  height: auto;
}

#contacts_02 input:focus {
  border: 1px solid #67a9ab;
  box-shadow: none;
}

#contacts_02 textarea {
  background: #f3f3f3;
  color: #444;
  border: 1px solid transparent;
  padding: 15px;
  height: 150px;
  resize: none;
}

#contacts_02 textarea:focus {
  box-shadow: none;
  border: 1px solid #67a9ab;
}

#contacts_02 label {
  color: #444;
  font-weight: 400;
}

#contacts_02 label.form-check-label {
  color: #444;
}

#contacts_02 label a,
#contacts_02 label span {
  color: #ee8135;
  font-size: 14px;
  font-weight: 400;
}

#contacts_02 button {
  display: inline-block;
  background: #ee8135;
  color: white;
  padding: 12px 35px;
  border-radius: 100px;
  border: none;
}

/*PREÇOS*/
#prices {
  padding: 120px 0;
}
#hero-prices {
  padding: 120px 0;
  background-image: url("../img/contatos.jpg");
  object-position: center;
  background-position: 0 35%;
  background-size: cover;
  background-repeat: no-repeat;
}
#prices h1 {
  letter-spacing: 2px;
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 2rem;
  color: #333;
  line-height: 1;
}
#prices .card-this {
  padding: 30px;
  margin-bottom: 20px;
  text-align: left;
  border-radius: 5px;
  border: none;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
#prices .card-images img {
  height: 200px;
  object-fit: cover;
  object-position: top;
  width: 100%;
  border-radius: 5px 5px 0 0;
}
#prices .card-this h4 {
  font-size: 1rem;
  color: #444;
  height: 40px;
}
#prices .card-this h4 span {
  color: #ee8135;
}
#prices .card-this p.days {
  color: #444;
}
#prices .card-this p.fee {
  color: #444;
}
#prices .card-this p.fee span {
  color: #ee8135;
}
#prices .disclai {
  font-weight: 500;
}
#prices .disclai span {
  color: #ee8135;
}
#prices .card-this p {
  color: #8b8b8b;
  font-size: 14px;
}

/*FOOTER*/
footer {
  background: #67a9ab;
  padding: 40px 0 0px 0;
  color: #f3f3f3;
}
footer h2 {
  font-size: 1.1rem;
}
footer .footrow p {
  margin-bottom: 0;
}
footer p small {
  color: #ccc;
}
footer .footrow a {
  color: #f3f3f3;
  transition: all 0.3s ease;
}
footer .footrow a:hover {
  text-decoration: none;
  color: #ccc;
}
footer .footrow i {
  color: #f3f3f3;
}
.minifoot,
.minifoot a {
  color: #f3f3f3;
}

footer .footrow .col-md-3 {
  min-height: 14.5rem;
}
/*MOBILE*/
@media (max-width: 900px) {
  .navbar-toggler i {
    font-size: 3rem;
    color: white;
  }
  #prof .photoprof {
    width: 250px;
    margin: 0 auto;
  }
  footer {
    text-align: center;
  }
  .navbar-collapse {
    padding-top: 20px;
    padding-bottom: 20px;
    background: white;
    text-align: center;
  }
  .mainnav .dropdown-menu .dropdown-item {
    text-align: center;
  }
  .navbar-collapse .nav-link {
    color: #444;
    text-shadow: none;
  }
  #hero h5 a.verserv {
    margin-top: 20px;
  }
  #mainclasses .classbox {
    flex: 0 0 50%;
    max-width: 50%;
    height: 20rem;
  }
  #mainclasses .classbox .classinfo {
    padding: 20px 20px;
    left:10px;
    width: calc(100% - 20px);
  }
  #mainclasses .classbox .classinfo h3 {
    font-size: 1.1rem;
  }
  #about h1 {
    margin-top: 20px;
  }
  footer .footrow .col-md-3 {
    min-height: auto;
    margin-bottom: 30px;
  }
  footer .minicopi .text-right {
    text-align: center!important;
    margin-bottom: 10px;
  }
  #boxesrow .row .classbox-text {
    height: 120px;
    padding-top: 2rem !important;
  }
  #boxesrow .row .classbox-text .days {
    margin-top: 0;
  }
}

.control {
  display: block;
  position: relative;
  padding-left: 30px;
  margin-bottom: 15px;
  cursor: pointer;
  font-size: 16px; }

.control input {
  position: absolute;
  z-index: -1;
  opacity: 0; }

.control-indicator {
  position: absolute;
  top: 2px;
  left: 0;
  height: 20px;
  width: 20px;
  border-radius: 4px;
  background: transparent; }

.control-indicator.plus3 {
	border: 2px solid #9b59b6;
}

.control input:checked ~ .control-indicator.plus3 {
  border: 2px solid #9b59b6;
  background: #fff; }


.control-indicator.plus4 {
	border: 2px solid #f39434;
}

.control input:checked ~ .control-indicator.plus4 {
  border: 2px solid #f39434;
  background: #fff; }

.control-indicator.plus5 {
	border: 2px solid #6dc1ab;
}

.control input:checked ~ .control-indicator.plus5 {
  border: 2px solid #6dc1ab;
  background: #fff; }

/*.control-indicator.quatroaos6 {
	border: 2px solid #f39434;
}

.control input:checked ~ .control-indicator.quatroaos6 {
  border: 2px solid #f39434;
  background: #fff; }

.control-indicator.tresaos10 {
	border: 2px solid #2ecc71;
}

.control input:checked ~ .control-indicator.tresaos10 {
  border: 2px solid #2ecc71;
  background: #fff; }
*/

.control-indicator.plus6 {
	border: 2px solid #3498db;
}

.control input:checked ~ .control-indicator.plus6 {
  border: 2px solid #3498db;
  background: #fff; }

.control-indicator.plus9 {
	border: 2px solid #f0dc1a;
}

.control input:checked ~ .control-indicator.plus9 {
  border: 2px solid #f0dc1a;
  background: #fff; }

.control-indicator.plus14 {
	border: 2px solid #2ecc71;
}

.control input:checked ~ .control-indicator.plus14 {
  border: 2px solid #2ecc71;
  background: #fff; }


.control-indicator.adultos {
	border: 2px solid #e74c3c;
}

.control input:checked ~ .control-indicator.adultos {
  border: 2px solid #e74c3c;
  background: #fff; }


/*.control-radio .control-indicator {
  border-radius: 50%; }*/

.control input:disabled ~ .control-indicator {
  background: #e6e6e6;
  opacity: 0.6;
  pointer-events: none;
  border: 2px solid #ccc; }

.control-indicator:after {
  font-family: 'icomoon';
  content: '\2713';
  position: absolute;
  display: none; }

.control input:checked ~ .control-indicator:after {
  display: block;
  color: #000; }

.control-checkbox .control-indicator:after {
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -52%);
  -ms-transform: translate(-50%, -52%);
  transform: translate(-50%, -52%); }

.control-checkbox input:disabled ~ .control-indicator:after {
  border-color: #7b7b7b; }

.control-checkbox input:disabled:checked ~ .control-indicator {
  background-color: #007bff;
  opacity: .2;
  border: 2px solid #007bff; }
  
  
/* ***** BEGIN ERRORS STYLE ***** */
.field-validation-error,
.field-validation-valid { /* Generic */
    color: #dc3545;
    font-weight: 500;
    font-size: 13px;
    margin-left: 2px;
    min-height: 20px;
    float: left;
    width: 100%;
    margin-top: 5px;
}

.input-validation-error,
.form-control.input-validation-error {
    border-color: #dc3545 !important;
}

.form-control.input-validation-error:focus {
        outline: 0;
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }
/* ***** END ERRORS STYLE ***** */


/* text, password, textarea */
#contacts_02 input[type=text].form-control.required:not(.input-validation-error):not(.ignore-required-highlight),
			 input[type=text][data-val-required].form-control:not(.input-validation-error):not(.ignore-required-highlight),
			 textarea.form-control.required:not(.input-validation-error):not(.ignore-required-highlight),
			 textarea[data-val-required].form-control:not(.input-validation-error):not(.ignore-required-highlight) {
    border-left-color: #ffc107;
    border-left-width: 2px;
}

.check-box-required-error {
	border: 2px solid #e74c3c;
}

.no-border {
  border: 0;
}



