/**
 * Table of Contents:
 *
 * 1.0 - Basic Structure
 * 2.0 - Media Queries
 * ---------------------------------------
 -------------------------------------
 */

@import url('https://fonts.googleapis.com/css2?family=Baloo+Tamma+2:wght@400..800&family=Heebo:wght@100..900&display=swap');

:root {
  --color-primary: #010101;
  --color-warning: #ffd800;
  --bg-primary: #A8E1FF ;
  --bg-white: #fbfbfb;
}

/* Default */
html {
  font-size: 16px;
}
body {
  font-family: "Heebo", sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--color-primary);
}

h1 , h2 , h3 , h4 , h5 , h6 {
  font-family: "Baloo Tamma 2", sans-serif;
}

h1{
  font-size: clamp(2.25rem, 2.25rem + ((1vw - 0.2rem) * 2.5), 3.75rem);
  text-align: center;
  font-weight: 400;
}

h2 {
  font-size: 2.25rem;
}

h3{
  font-size: 1.75rem;
}

h4,
.h4{
  font-size: 1.5rem;
}

h5 {
  font-size: 1.25rem;
}

h2 ,h3 , h4 ,h5 ,h6 {
  font-weight: 500;
}


.figure,
img {
	width: 100%;
  height: auto;
}

.cover {
  border-radius: 1.5rem;
  aspect-ratio: 1;
  object-fit: cover;
}
.cover-2 {
  border-top-right-radius: 1.5rem;
  border-bottom-right-radius: 1.5rem;
  object-fit: cover;
  height: 100%;
  width: 100%;
}

.logo {
  width: 2.625rem;
  height: 2.625rem;
}

.ilustration {
  width: 5rem;
  height: 5rem;
  margin-bottom: 1.5rem;
}

.icon{
  width: 1.25rem;
  height: 1.25rem;
}

ul {
	margin: 0;
	padding: 0;
}
ul li {
	list-style: none;
}
/* Link */
a {
  display: inline-block;
}
a,
a:hover {
  display: inline-block;
  text-decoration: none;
}

/* Btn */
.btn {
  font-weight: 600;
  padding: 0.85rem 1.5rem;
  border-radius: 32px;
  font-size: 1.1rem;
}
.btn-primary {                                                        
  background-color: var(--color-warning);
  border-color: var(--color-warning);
  color: var(--color-primary);
}
.btn-outline-primary {
  background-color: transparent;
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.btn:hover,
.btn:focus-visible,
.btn-check:focus + .btn,
.btn:focus,
.btn:first-child:active,
:not(.btn-check) + .btn:active,
.btn:first-child:active:focus-visible,
:not(.btn-check) + .btn:active:focus-visible {
  box-shadow: none;
  transition: 0.25s ease-in;
}
.btn:hover.btn-primary,
.btn:focus-visible.btn-primary,
.btn-check:focus + .btn.btn-primary,
.btn:focus.btn-primary,
.btn:first-child:active.btn-primary,
:not(.btn-check) + .btn:active.btn-primary {
  background-color: #185810d0;
  border-color: #185810d0;
  color: #fff;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus-visible,
.btn-check:focus + .btn.btn-outline-primary,
.btn-outline-primary:first-child:active,
:not(.btn-check) + .btn:active.btn-outline-primary {
  background-color: #5a5c5e35;
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* Définition des styles pour les inputs et les formulaires */
input, textarea, select {
  padding: 0.75rem 1.5rem !important;
  border-radius: 14px !important;
  transition:all 0.3s;
}

input:focus, textarea:focus, select:focus {
  border-color: inherit;
  border: inherit;

}
input:focus , textarea:focus , select:focus , input:hover , textarea:hover , select:hover {
    outline: none !important; 
    border: 1px solid rgba(255, 255, 255, 0.3);
}

input::placeholder ,textarea::placeholder, select::placeholder{
    color:#94A0AC !important; 
}

label {
  font-weight: 600;
  color: var(--color-secondary);
}

/* Text and background */
.liste{
  padding: 0.5rem 1rem; 
}
.liste li{
  list-style-type: disc;
}

body.body-blur > *:not(.modal):not(.modal-backdrop) {
  filter: blur(5px);
  pointer-events: none;
  transition: filter 0.3s ease-in-out;
}

/**
  * 1.0 Basic Structure
  * ----------------------------------------------------------------------------
  */
/* Navbar */
nav.navbar{
  padding: 2rem 0;
}
.navbar-nav .nav-item {
  margin-right: 1rem;
}
.navbar-nav .nav-item:last-child {
  margin-right: 0;
}

/* Banner */
.banner ,.discover ,.formations{
  padding: 5rem 0;
}
.banner {
  background: linear-gradient(to bottom, var(--bg-primary) 0%, var(--bg-white) 100%);
}

/* Discover */
.discover ,.explore-stats ,.formations , .explores-item , .about , .emplod {
  background-color: var(--bg-primary);
}

.banner-about-1 {
  height: 13rem;
}

.banner-about-2 {
  height: clamp(10rem, 24rem, 24rem);
}

.banner-about-1 img , .banner-about-2 img{
  height: 100%;
  width: 100%;
  object-fit: cover;
  border-radius: 32px;
}

.after::before {
  position: relative;
  content: url("assets/images/info.svg");
  left: -3rem;
  top: 3rem;
}


/* Subscription Plan Styles */
.plan-card {
    border: 2px solid #e9ecef;
    padding: 1.5rem;
    border-radius: 0.75rem;
    text-align: center;
    position: relative;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.plan-card:hover {
    border-color: #424950;
}

.plan-card.popular {
    border-color: var(--color-primary);
    box-shadow: 0 0 15px rgba(1, 1, 1, 0.1);
}

.popular-badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-warning);
    color: var(--color-primary);
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 0.8rem;
    font-weight: bold;
}

.plan-card input[type="radio"] {
    display: none; /* Radios are hidden, selection is handled by clicking the card */
}

.plan-price {
    font-size: 2rem;
    font-weight: bold;
}

.plan-features {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
}

.plan-features li {
    margin-bottom: 0.5rem;
}





/* Footer */

/**
  * 2.0 Media Queries
  * ----------------------------------------------------------------------------
  */

/* Media Queries */
@media (max-width: 600.98px) {
}

@media (min-width: 601px) and (max-width: 782.98px) {
}

@media (min-width: 783px) {
}

/* X-Small devices (portrait phones, less than 576px) */
@media (max-width: 575.98px) {
}

/* Small devices (landscape phones, 576px, up to 768px) */
@media (min-width: 576px) and (max-width: 767.98px) {
}
@media (min-width: 768px) {
}

/* Medium devices (tablets, 768px, up to 992px) */
@media (min-width: 768px) and (max-width: 991.98px) {
  
}

/* Large devices (desktops, 992px, up to 1200px) */
@media (min-width: 992px) and (max-width: 1199.98px) {
}

/* Large devices (desktops, 992px) */
@media (min-width: 992px) {
  /* Default */
  html {
    font-size: 20px;
  }

  h1{
    font-size: 3.375rem;
    line-height: 4.375rem;
  }
  
  h2 {
    font-size: 2.75rem;
  }
  
  h3{
    font-size: 2rem;
  }

  h4 {
    font-size: 1.75rem;
  }
  /* Banner */
  .banner {
    padding: 8rem 0;
  }
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (min-width: 1400px) {
}

