/* =========================
   RESET
========================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Roboto',sans-serif;
}

html{
    scroll-behavior:smooth;
}

body{
    background:#ffffff;
    color:#222;
    overflow-x:hidden;
}

img{
    width:100%;
    display:block;
}

a{
    text-decoration:none;
}

ul{
    list-style:none;
}


/* =========================
   NAVBAR MOBILE
========================= */

@media(max-width:991px){

    .desktop-cta{
        display:none;
    }

    .navbar{
        position:relative;
    }

    .menu-toggle{
        display:flex !important;
        align-items:center;
        justify-content:center;
        width:42px;
        height:42px;
        border-radius:50%;
        background:var(--primary);
        color:#fff;
        font-size:20px;
        cursor:pointer;
        z-index:9999;
        position:relative;
    }

    .menu-toggle i{
        color:#fff;
        font-size:20px;
        pointer-events:none;
    }

    .nav-links{
        position:absolute;
        top:75px;
        right:6%;
        width:280px;
        background:#fff;
        border-radius:24px;
        padding:24px;
        box-shadow:0 20px 55px rgba(0,0,0,.14);

        opacity:0;
        visibility:hidden;
        transform:translateY(15px);
        pointer-events:none;

        display:flex;
        flex-direction:column;
        align-items:flex-start;
        gap:18px;

        z-index:3000;
        transition:.3s ease;
    }

    .nav-links.active{
        opacity:1;
        visibility:visible;
        transform:translateY(0);
        pointer-events:auto;
    }

    .nav-links a{
        color:var(--dark);
    }

    .mobile-cta{
        display:block;
        width:100%;
    }

    .mobile-cta .nav-btn{
        display:block;
        width:100%;
        text-align:center;
    }
}

@media(max-width:480px){
    .nav-links{
        width:90%;
        right:5%;
    }
}
/*  MOBILE NAV */

@media(max-width:991px){

    .navbar{
        position:relative;
    }

    .menu-toggle{
        display:flex !important;
        align-items:center;
        justify-content:center;
        width:42px;
        height:42px;
        border-radius:50%;
        background:var(--primary);
        color:#fff;
        font-size:20px;
        cursor:pointer;
        z-index:5000;
        position:relative;
    }

    .nav-links{
        position:absolute;
        top:75px;
        right:6%;
        width:280px;
        background:#fff;
        border-radius:24px;
        padding:24px;
        box-shadow:0 20px 55px rgba(0,0,0,.14);

        display:none;
        flex-direction:column;
        align-items:flex-start;
        gap:18px;

        z-index:3000;
    }

    .nav-links.active{
        display:flex;
    }

    .nav-links a{
        color:var(--dark);
    }

    .desktop-cta{
        display:none;
    }

    .mobile-cta{
        display:block;
        width:100%;
    }

    .mobile-cta .nav-btn{
        display:block;
        width:100%;
        text-align:center;
    }
}

@media(max-width:480px){

    .nav-links{
        width:90%;
        right:5%;
    }
}
/* =========================
   COLORS
========================= */

:root{

    --primary:#d72638;
    --primary-dark:#b71c2c;
    --primary-light:#ff6b7c;

    --accent:#fff1f3;

    --dark:#181818;
    --gray:#6f6f6f;
    --light:#ffffff;

    --shadow:
    0 15px 40px rgba(215,38,56,.12);

}

/* =========================
   HEADER
========================= */

.site-header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:1000;

    backdrop-filter:blur(15px);

    background:
    rgba(255,255,255,.88);

    border-bottom:
    1px solid rgba(0,0,0,.05);

    transition:.35s ease;
}

.navbar{
    max-width:1300px;
    margin:auto;

    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:18px 6%;
}

.logo{
    font-size:28px;
    font-weight:900;
    color:var(--dark);

    display:flex;
    align-items:center;
    gap:10px;
}

.logo span{
    color:var(--primary);
}

.logo i{
    color:var(--primary);
}

.nav-links{
    display:flex;
    gap:30px;
}

.nav-links a{
    color:var(--dark);
    font-weight:600;
    position:relative;
}

.nav-links a::after{
    content:"";

    position:absolute;
    left:0;
    bottom:-6px;

    width:0;
    height:2px;

    background:var(--primary);

    transition:.3s;
}

.nav-links a:hover::after{
    width:100%;
}

.nav-btn{
    background:
    linear-gradient(
    135deg,
    var(--primary),
    var(--primary-light));

    color:#fff;

    padding:13px 24px;

    border-radius:50px;

    font-weight:700;

    transition:.35s ease;
}

.nav-btn:hover{
    transform:translateY(-3px);
}

.menu-toggle{
    display:none;
    font-size:26px;
    cursor:pointer;
    color:var(--primary);
}

.mobile-cta{
    display:none;
}

/* =========================
   HERO
========================= */

.hero{
    min-height:100vh;

    position:relative;

    overflow:hidden;

    display:flex;
    align-items:center;

    padding:150px 6% 90px;

    background:
    linear-gradient(
    135deg,
    #fff,
    #fff6f7,
    #ffe6ea);
}

.hero-content{
    max-width:1300px;
    width:100%;

    margin:auto;

    display:grid;
    grid-template-columns:
    1.1fr .9fr;

    gap:70px;

    align-items:center;

    position:relative;
    z-index:3;
}

/* decorative circles */

.hero-circle{
    position:absolute;
    border-radius:50%;
    filter:blur(10px);
}

.circle-one{
    width:300px;
    height:300px;

    background:
    rgba(255,107,124,.12);

    top:-100px;
    right:-100px;
}

.circle-two{
    width:240px;
    height:240px;

    background:
    rgba(215,38,56,.08);

    bottom:40px;
    left:-70px;
}


/* =========================
   HERO MOBILE
========================= */

@media(max-width:768px){

    .hero{
        min-height:auto;
        padding:120px 6% 60px;
        display:block;
    }

    .hero-content{
        display:flex;
        flex-direction:column;
        gap:35px;
        text-align:center;
    }

    .hero-text{
        order:1;
    }

    .hero-visual{
        order:2;
        display:flex !important;
        justify-content:center;
        align-items:center;
        min-height:auto !important;
        width:100%;
    }

    .car-card{
        display:block !important;
        width:100%;
        max-width:330px;
        height:380px !important;
        border-radius:28px;
        overflow:hidden;
    }

    .car-card img{
        display:block !important;
        width:100% !important;
        height:100% !important;
        object-fit:cover !important;
    }

    .hero-stats{
        justify-content:center;
        gap:15px;
    }

    .hero-stats div{
        min-width:120px;
    }

    .floating-card{
        position:relative;
        margin:12px auto;
        width:100%;
        max-width:300px;
    }
}

@media(max-width:480px){

    .hero{
        padding:110px 5% 50px;
    }

    .hero-text h1{
        font-size:30px;
        line-height:1.15;
    }

    .hero-text p{
        font-size:14px;
        line-height:1.7;
    }

    .hero-buttons{
        flex-direction:column;
    }

    .hero-stats{
        flex-direction:column;
        align-items:center;
    }

    .hero-stats div{
        width:100%;
        max-width:230px;
        text-align:center;
    }

    .car-card{
        max-width:280px;
        height:320px !important;
    }
}
/* road */

.road-line{
    position:absolute;
    left:0;
    bottom:0;

    width:100%;
    height:8px;

    background:
    repeating-linear-gradient(
    to right,
    var(--dark) 0 40px,
    transparent 40px 80px);

    opacity:.08;
}

/* text */

.hero-badge{
    display:inline-flex;
    align-items:center;
    gap:10px;

    padding:12px 18px;

    border-radius:50px;

    background:
    rgba(255,255,255,.8);

    border:
    1px solid rgba(215,38,56,.12);

    color:var(--primary);

    font-weight:700;

    margin-bottom:25px;
}

.hero-text h1{
    font-size:clamp(2.8rem,5vw,4.8rem);
    line-height:1.1;

    color:var(--dark);

    margin-bottom:25px;
}

.hero-text p{
    color:var(--gray);

    line-height:1.8;

    font-size:17px;

    margin-bottom:35px;
}

/* buttons */

.hero-buttons{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}

.btn-primary{
    background:
    linear-gradient(
    135deg,
    var(--primary),
    var(--primary-light));

    color:#fff;

    padding:16px 30px;

    border-radius:50px;

    font-weight:700;

    transition:.35s ease;
}

.btn-primary:hover{
    transform:translateY(-4px);
}

.btn-secondary{
    background:#fff;

    border:
    1px solid rgba(215,38,56,.15);

    color:var(--dark);

    padding:16px 30px;

    border-radius:50px;

    font-weight:700;

    transition:.35s ease;
}

.btn-secondary:hover{
    border-color:var(--primary);
}

/* stats */

.hero-stats{
    display:flex;
    flex-wrap:wrap;
    gap:35px;

    margin-top:40px;
}

.hero-stats div{
    display:flex;
    flex-direction:column;
}

.hero-stats strong{
    color:var(--primary);
    font-size:22px;
    font-weight:900;
}

.hero-stats span{
    color:var(--gray);
    font-size:14px;
}

/* =========================
   HERO VISUAL + FLOATING CARDS
========================= */

.hero-visual{
    position:relative;
    min-height:560px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.car-card{
    width:min(440px,100%);
    height:560px;
    border-radius:42px;
    overflow:hidden;
    box-shadow:0 35px 90px rgba(215,38,56,.18);
    border:10px solid rgba(255,255,255,.75);
    position:relative;
}

.car-card img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.car-card::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.35),transparent 55%);
}

.floating-card{
    position:absolute;
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(14px);
    border:1px solid rgba(215,38,56,.12);
    border-radius:22px;
    padding:16px 18px;
    display:flex;
    align-items:center;
    gap:12px;
    box-shadow:var(--shadow);
    animation:floatCard 4s ease-in-out infinite;
}

.floating-card i{
    width:45px;
    height:45px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
}

.floating-card strong{
    color:var(--dark);
    display:block;
    font-size:14px;
}

.floating-card span{
    color:var(--gray);
    font-size:12px;
}

.card-top{
    top:70px;
    left:0;
}

.card-bottom{
    right:0;
    bottom:80px;
    animation-delay:1s;
}

@keyframes floatCard{
    0%,100%{
        transform:translateY(0);
    }
    50%{
        transform:translateY(-12px);
    }
}



/* =========================
   TRUST BAR
========================= */

.trust-bar{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
    padding:35px 6%;
    background:#fff;
    box-shadow:0 10px 35px rgba(0,0,0,.04);
}

.trust-item{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    color:var(--dark);
    font-weight:700;
    text-align:center;
}

.trust-item i{
    color:var(--primary);
    font-size:20px;
}

/* =========================
   GENERAL SECTIONS
========================= */

section{
    padding:100px 6%;
}

.section-heading{
    max-width:780px;
    margin:0 auto 60px;
    text-align:center;
}

.section-heading span,
.why-text span,
.registration-text span,
.contact-info span{
    color:var(--primary);
    text-transform:uppercase;
    font-size:13px;
    font-weight:900;
    letter-spacing:1.8px;
    display:inline-block;
    margin-bottom:12px;
}

.section-heading h2,
.why-text h2,
.registration-text h2,
.contact-info h2{
    color:var(--dark);
    font-size:clamp(30px,4vw,48px);
    line-height:1.15;
    margin-bottom:16px;
}

.section-heading p,
.why-text p,
.registration-text p,
.contact-info p{
    color:var(--gray);
    line-height:1.8;
}

/* =========================
   FORMATIONS
========================= */

.formations-section{
    background:#fff;
}

.formations-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

.formation-card{
    background:linear-gradient(180deg,#fff,var(--accent));
    border:1px solid rgba(215,38,56,.1);
    border-radius:30px;
    padding:36px 28px;
    text-align:center;
    box-shadow:var(--shadow);
    transition:.35s ease;
}

.formation-card:hover{
    transform:translateY(-10px);
}

.formation-card.featured{
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff;
}

.formation-card i{
    width:68px;
    height:68px;
    margin:0 auto 20px;
    border-radius:50%;
    background:#fff;
    color:var(--primary);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
    box-shadow:0 10px 30px rgba(215,38,56,.12);
}

.formation-card.featured i{
    background:rgba(255,255,255,.18);
    color:#fff;
}

.formation-card h3{
    margin-bottom:12px;
    font-size:20px;
}

.formation-card p{
    color:var(--gray);
    line-height:1.8;
    font-size:14px;
}

.formation-card.featured p{
    color:#fff;
}

/* =========================
   LICENSE TYPES
========================= */

.license-section{
    background:var(--accent);
}

.license-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

.license-card{
    background:#fff;
    border-radius:30px;
    padding:34px 26px;
    box-shadow:var(--shadow);
    border:1px solid rgba(215,38,56,.1);
    transition:.35s ease;
}

.license-card:hover{
    transform:translateY(-10px);
}

.license-icon{
    width:80px;
    height:80px;

    margin:0 auto 20px;

    border-radius:24px;

    background:linear-gradient(
    135deg,
    var(--primary),
    var(--primary-light));

    display:flex;
    align-items:center;
    justify-content:center;

    color:#fff;

    font-size:30px;

    box-shadow:
    0 12px 30px rgba(215,38,56,.25);
}

.license-card h3{
    color:var(--dark);
    margin-bottom:12px;
}

.license-card p{
    color:var(--gray);
    line-height:1.8;
    margin-bottom:18px;
    font-size:14px;
}

.license-card ul{
    display:grid;
    gap:10px;
}

.license-card li{
    color:var(--gray);
    font-size:14px;
}

.license-card li i{
    color:var(--primary);
    margin-right:8px;
}

/* =========================
   RESPONSIVE II
========================= */

@media(max-width:1024px){

    .hero-content{
        grid-template-columns:1fr;
        text-align:center;
    }

    .hero-text p{
        margin-left:auto;
        margin-right:auto;
    }

    .hero-buttons,
    .hero-stats{
        justify-content:center;
    }

    .hero-visual{
        max-width:520px;
        margin:auto;
    }

    .formations-grid,
    .license-grid{
        grid-template-columns:1fr 1fr;
    }

    .trust-bar{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:768px){

    section{
        padding:80px 6%;
    }

    .hero{
        padding:125px 6% 70px;
    }

    .hero-text h1{
        font-size:36px;
    }

    .hero-text p{
        font-size:15px;
    }

    .hero-visual{
        min-height:440px;
    }

    .car-card{
        max-width:330px;
        height:390px;
        border-radius:30px;
    }

    .floating-card{
        position:relative;
        margin:14px auto;
        max-width:300px;
        justify-content:center;
    }

    .card-top,
    .card-bottom{
        top:auto;
        right:auto;
        bottom:auto;
        left:auto;
    }

    .formations-grid,
    .license-grid{
        grid-template-columns:1fr;
    }
}

@media(max-width:480px){

    .hero{
        padding:115px 5% 60px;
    }

    .hero-text h1{
        font-size:30px;
    }

    .hero-badge{
        font-size:12px;
        line-height:1.5;
        text-align:center;
    }

    .btn-primary,
    .btn-secondary{
        width:100%;
        text-align:center;
        justify-content:center;
    }

    .trust-bar{
        grid-template-columns:1fr;
    }

    .car-card{
        max-width:290px;
        height:340px;
    }
}

/* =========================
   AUTOÉCOLE
   Why + Process + Instructors + Registration + Contact + Footer
========================= */

/* WHY SECTION */

.why-section{
    background:#fff;
}

.why-layout{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:55px;
    align-items:center;
}

.why-image{
    position:relative;
    height:560px;
    border-radius:38px;
    overflow:hidden;
    box-shadow:var(--shadow);
    border:10px solid rgba(255,255,255,.85);
}

.why-image img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.why-image::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.35),transparent 60%);
}

.why-badge{
    position:absolute;
    left:22px;
    bottom:22px;
    z-index:2;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(215,38,56,.12);
    border-radius:20px;
    padding:14px 18px;
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--dark);
    box-shadow:var(--shadow);
}

.why-badge i{
    color:var(--primary);
}

.why-points,
.registration-points{
    display:grid;
    gap:14px;
    margin:26px 0;
}

.why-points div,
.registration-points div{
    background:var(--accent);
    border:1px solid rgba(215,38,56,.1);
    border-radius:18px;
    padding:15px 16px;
    display:flex;
    align-items:center;
    gap:12px;
    color:var(--gray);
}

.why-points i,
.registration-points i{
    width:28px;
    height:28px;
    border-radius:50%;
    background:var(--primary);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:12px;
}

.section-btn{
    display:inline-flex;
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff;
    padding:15px 28px;
    border-radius:50px;
    font-weight:800;
    transition:.35s ease;
}

.section-btn:hover{
    transform:translateY(-3px);
}

/* PROCESS */

.process-section{
    background:var(--accent);
}

.process-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px;
}

.process-card{
    background:#fff;
    border:1px solid rgba(215,38,56,.1);
    border-radius:28px;
    padding:30px 24px;
    box-shadow:var(--shadow);
    transition:.35s ease;
}

.process-card:hover{
    transform:translateY(-10px);
}

.process-card span{
    width:60px;
    height:60px;

    display:flex;
    align-items:center;
    justify-content:center;

    margin:0 auto 18px;

    border-radius:50%;

    background:linear-gradient(
    135deg,
    var(--primary),
    var(--primary-light));

    color:#fff;

    font-weight:900;
    font-size:20px;

    box-shadow:
    0 10px 25px rgba(215,38,56,.25);
}

.process-card h3{
    color:var(--dark);
    margin-bottom:10px;
}

.process-card p{
    color:var(--gray);
    line-height:1.8;
    font-size:14px;
}

/* INSTRUCTORS */

.instructors-section{
    background:#fff;
}

.instructors-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

.instructor-card{
    background:#fff;
    border-radius:30px;
    overflow:hidden;
    box-shadow:var(--shadow);
    border:1px solid rgba(215,38,56,.1);
    text-align:center;
    transition:.35s ease;
}

.instructor-card:hover{
    transform:translateY(-10px);
}

.instructor-card img{
    height:300px;
    width:100%;
    object-fit:cover;
}

.instructor-card h3{
    color:var(--dark);
    margin:22px 20px 8px;
}

.instructor-card p{
    color:var(--gray);
    font-size:14px;
    line-height:1.7;
    padding:0 20px 26px;
}

/* REGISTRATION */

.registration-section{
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:#fff;
}

.registration-layout{
    display:grid;
    grid-template-columns:.95fr 1.05fr;
    gap:55px;
    align-items:center;
}

.registration-text span,
.registration-text h2{
    color:#fff;
}

.registration-text p{
    color:#ffe6ea;
}

.registration-points div{
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.16);
    color:#fff;
}

.registration-points i{
    background:#fff;
    color:var(--primary);
}

.registration-form{
    background:#fff;
    border-radius:34px;
    padding:35px;
    box-shadow:0 30px 80px rgba(0,0,0,.18);
    display:grid;
    gap:14px;
}

.registration-form h3{
    color:var(--dark);
    font-size:28px;
    margin-bottom:8px;
}

.registration-form input,
.registration-form select,
.registration-form textarea{
    width:100%;
    border:1px solid rgba(215,38,56,.14);
    border-radius:16px;
    padding:14px 15px;
    outline:none;
    color:var(--dark);
    font-size:14px;
    background:#fffafa;
}

.registration-form textarea{
    min-height:115px;
    resize:none;
}

.registration-form input:focus,
.registration-form select:focus,
.registration-form textarea:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(215,38,56,.08);
}

.registration-form button{
    border:none;
    background:#25D366;
    color:#fff;
    padding:15px 20px;
    border-radius:50px;
    cursor:pointer;
    font-weight:900;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    transition:.35s ease;
}

.registration-form button:hover{
    transform:translateY(-3px);
}

/* CONTACT */

.contact-section{
    background:#fff;
}

.contact-container{
    display:grid;
    grid-template-columns:.95fr 1.05fr;
    gap:45px;
    align-items:center;
}

.contact-items{
    display:grid;
    gap:15px;
    margin-top:28px;
}

.contact-item{
    background:var(--accent);
    border:1px solid rgba(215,38,56,.1);
    border-radius:22px;
    padding:18px;
    display:flex;
    align-items:center;
    gap:15px;
    box-shadow:0 12px 35px rgba(215,38,56,.08);
}

.contact-item i{
    width:52px;
    height:52px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
}

.contact-item strong{
    display:block;
    color:var(--dark);
    margin-bottom:4px;
}

.contact-item span{
    color:var(--gray);
    font-size:14px;
}

.contact-map{
    height:500px;
    border-radius:34px;
    overflow:hidden;
    box-shadow:var(--shadow);
    border:8px solid var(--accent);
}

.contact-map iframe{
    width:100%;
    height:100%;
    border:none;
}

/* FOOTER */

.footer{
    background:#161616;
    color:#fff;
    padding:80px 6% 25px;
}

.footer-container{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1fr;
    gap:40px;
    margin-bottom:45px;
}

.footer-logo{
    color:#fff;
    font-size:24px;
    font-weight:900;
    display:flex;
    align-items:center;
    gap:10px;
}

.footer-logo i,
.footer-logo span{
    color:var(--primary-light);
}

.footer-brand p{
    color:#cfcfcf;
    line-height:1.9;
    margin-top:18px;
}

.footer-links h4,
.footer-social h4{
    color:#fff;
    margin-bottom:18px;
}

.footer-links a,
.footer-social a{
    display:block;
    color:#cfcfcf;
    margin-bottom:12px;
    transition:.35s ease;
}

.footer-links a:hover,
.footer-social a:hover{
    color:var(--primary-light);
    transform:translateX(6px);
}

.footer-social i{
    width:22px;
    color:var(--primary-light);
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:22px;
    text-align:center;
}

.footer-bottom p{
    color:#aaa;
    font-size:13px;
}

/* REVEAL ANIMATION */

.reveal{
    opacity:0;
    transform:translateY(35px);
    transition:.8s ease;
}

.reveal.active{
    opacity:1;
    transform:translateY(0);
}

/* RESPONSIVE III */

@media(max-width:1024px){

    .why-layout,
    .registration-layout,
    .contact-container{
        grid-template-columns:1fr;
    }

    .why-text,
    .registration-text,
    .contact-info{
        text-align:center;
    }

    .why-points div,
    .registration-points div{
        justify-content:center;
    }

    .process-grid{
        grid-template-columns:1fr 1fr;
    }

    .instructors-grid{
        grid-template-columns:1fr 1fr;
    }

    .footer-container{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:768px){

    .why-image{
        height:360px;
        border-radius:28px;
    }

    .process-grid,
    .instructors-grid{
        grid-template-columns:1fr;
    }

    .instructor-card img{
        height:260px;
    }

    .registration-form{
        padding:26px 20px;
    }

    .contact-map{
        height:350px;
    }

    .footer-container{
        grid-template-columns:1fr;
        text-align:center;
    }

    .footer-logo{
        justify-content:center;
    }

    .footer-links a:hover,
    .footer-social a:hover{
        transform:none;
    }
}

@media(max-width:480px){

    .why-image{
        height:300px;
    }

    .why-badge{
        left:12px;
        right:12px;
        bottom:12px;
    }

    .why-points div,
    .registration-points div{
        flex-direction:column;
        text-align:center;
    }

    .contact-item{
        flex-direction:column;
        text-align:center;
    }

    .contact-map{
        height:300px;
    }

    .footer{
        padding:60px 5% 22px;
    }
}


/* HERO  - LAST Responsive */

@media(max-width:768px){

    .hero{
        min-height:auto !important;
        display:block !important;
        padding:120px 6% 60px !important;
    }

    .hero-content{
        display:flex !important;
        flex-direction:column !important;
        grid-template-columns:none !important;
        gap:35px !important;
        text-align:center !important;
    }

    .hero-text{
        order:1 !important;
    }

    .hero-visual{
        order:2 !important;
        display:flex !important;
        flex-direction:column !important;
        justify-content:center !important;
        align-items:center !important;
        width:100% !important;
        min-height:auto !important;
        max-width:100% !important;
        margin:0 auto !important;
    }

    .car-card{
        display:block !important;
        width:100% !important;
        max-width:330px !important;
        height:380px !important;
        border-radius:28px !important;
        overflow:hidden !important;
    }

    .car-card img{
        display:block !important;
        width:100% !important;
        height:100% !important;
        object-fit:cover !important;
    }

    .floating-card{
        position:relative !important;
        top:auto !important;
        left:auto !important;
        right:auto !important;
        bottom:auto !important;
        margin:14px auto !important;
        max-width:300px !important;
    }
}

@media(max-width:480px){

    .hero{
        padding:110px 5% 50px !important;
    }

    .hero-text h1{
        font-size:30px !important;
        line-height:1.15 !important;
    }

    .hero-text p{
        font-size:14px !important;
    }

    .hero-buttons{
        flex-direction:column !important;
    }

    .hero-stats{
        flex-direction:column !important;
        align-items:center !important;
    }

    .car-card{
        max-width:285px !important;
        height:330px !important;
    }
}


/* LICENSE ICON  */

.license-icon{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
}

.license-icon i{
    margin:0 !important;
    line-height:1 !important;
}

/* PROCESS NUMBER  */

.process-card span{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;

    margin:0 auto 18px !important;

    line-height:1 !important;
}






/*  FLOATING CARDS MOBILE */

@media(max-width:768px){

    .hero-visual{
        position:relative !important;
        width:100% !important;
        max-width:340px !important;
        min-height:390px !important;
        margin:0 auto !important;
        display:flex !important;
        align-items:center !important;
        justify-content:center !important;
    }

    .car-card{
        width:100% !important;
        max-width:320px !important;
        height:380px !important;
        position:relative !important;
    }

    .floating-card{
        position:absolute !important;
        z-index:20 !important;
        max-width:230px !important;
        padding:11px 13px !important;
        border-radius:18px !important;
        margin:0 !important;
    }

    .floating-card i{
        width:38px !important;
        height:38px !important;
        min-width:38px !important;
        font-size:14px !important;
    }

    .floating-card strong{
        font-size:12px !important;
    }

    .floating-card span{
        font-size:10px !important;
    }

    .card-top{
        top:18px !important;
        left:-8px !important;
        right:auto !important;
        bottom:auto !important;
    }

    .card-bottom{
        bottom:18px !important;
        right:-8px !important;
        left:auto !important;
        top:auto !important;
    }
}

@media(max-width:480px){

    .hero-visual{
        max-width:295px !important;
        min-height:335px !important;
    }

    .car-card{
        max-width:280px !important;
        height:330px !important;
    }

    .floating-card{
        max-width:205px !important;
        padding:10px 11px !important;
    }

    .card-top{
        top:12px !important;
        left:-4px !important;
    }

    .card-bottom{
        bottom:12px !important;
        right:-4px !important;
    }
}