/* ============================================================
   AUTO-ÉCOLE PASS'LIBERTÉ — THÈME WORDPRESS PROFESSIONNEL
   ============================================================ */

/* --- Variables --- */
:root {
    --blue: #0056b3;
    --blue-dark: #003d80;
    --blue-light: #e6f0fa;
    --accent: #e74c3c;
    --accent-dark: #c0392b;
    --accent-light: #fdecea;
    --orange: #f39c12;
    --green: #27ae60;
    --dark: #222222;
    --dark2: #333333;
    --text: #444444;
    --text-light: #777777;
    --text-muted: #999999;
    --bg: #ffffff;
    --bg-off: #f5f6f8;
    --bg-warm: #fdfbf7;
    --border: #e0e0e0;
    --shadow: 0 2px 15px rgba(0,0,0,0.07);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
    --radius: 6px;
    --radius-lg: 12px;
    --font: 'Open Sans', Arial, sans-serif;
    --font-head: 'Montserrat', Arial, sans-serif;
}

/* --- Reset --- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:140px; }
body { font-family:var(--font); font-size:15px; line-height:1.75; color:var(--text); background:var(--bg); }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:var(--blue); transition:all .25s; }
a:hover { color:var(--accent); }
ul { list-style:none; }

.container { max-width:1180px; margin:0 auto; padding:0 20px; }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
    background:var(--dark);
    color:rgba(255,255,255,.7);
    font-size:13px;
    padding:8px 0;
    border-bottom:3px solid var(--accent);
}
.topbar-inner {
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
}
.topbar-left { display:flex; gap:24px; }
.topbar-left span { display:flex; align-items:center; gap:6px; }
.topbar-left i { color:var(--accent); font-size:12px; }
.topbar-right { display:flex; align-items:center; gap:18px; }
.topbar-right a { color:rgba(255,255,255,.8); font-weight:600; }
.topbar-right a:hover { color:#fff; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
#header {
    background:#fff;
    position:sticky;
    top:0;
    z-index:999;
    box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.nav-container {
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:75px;
}

/* Logo */
.logo { display:flex; align-items:center; gap:10px; }
.logo-badge {
    width:48px; height:48px;
    background:var(--blue);
    color:#fff;
    font-family:var(--font-head);
    font-weight:900;
    font-size:16px;
    border-radius:var(--radius);
    display:flex; align-items:center; justify-content:center;
    letter-spacing:-1px;
}
.logo-badge.light { background:rgba(255,255,255,.15); }
.logo-text { display:flex; flex-direction:column; line-height:1.2; }
.logo-name {
    font-family:var(--font-head);
    font-weight:800;
    font-size:20px;
    color:var(--dark);
}
.logo-sub { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:2px; font-weight:600; }

/* Nav menu */
.nav-menu {
    display:flex;
    align-items:center;
    gap:2px;
}
.nav-menu li a {
    font-family:var(--font-head);
    font-weight:600;
    font-size:14px;
    color:var(--dark2);
    padding:8px 14px;
    border-radius:var(--radius);
    transition:all .25s;
}
.nav-menu li a:hover { color:var(--blue); background:var(--blue-light); }
.nav-btn {
    background:var(--accent) !important;
    color:#fff !important;
    border-radius:var(--radius) !important;
    padding:10px 22px !important;
}
.nav-btn:hover { background:var(--accent-dark) !important; }

/* Hamburger */
.hamburger {
    display:none;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
    padding:8px;
}
.hamburger span { width:24px; height:2.5px; background:var(--dark); border-radius:2px; transition:all .3s; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ============================================================
   BOUTONS
   ============================================================ */
.btn {
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-family:var(--font-head);
    font-weight:700;
    font-size:14px;
    padding:12px 28px;
    border-radius:var(--radius);
    border:2px solid transparent;
    cursor:pointer;
    transition:all .3s;
    text-align:center;
    justify-content:center;
}
.btn-accent { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-accent:hover { background:var(--accent-dark); border-color:var(--accent-dark); color:#fff; transform:translateY(-2px); box-shadow:0 6px 20px rgba(231,76,60,.35); }
.btn-primary { background:var(--blue); color:#fff; border-color:var(--blue); }
.btn-primary:hover { background:var(--blue-dark); border-color:var(--blue-dark); color:#fff; transform:translateY(-2px); }
.btn-white { background:#fff; color:var(--dark); border-color:#fff; }
.btn-white:hover { background:#f0f0f0; color:var(--dark); transform:translateY(-2px); }
.btn-outline-dark { background:transparent; color:var(--dark2); border-color:var(--border); }
.btn-outline-dark:hover { background:var(--dark); color:#fff; border-color:var(--dark); }
.btn-lg { padding:16px 36px; font-size:15px; }
.btn-sm { padding:10px 20px; font-size:13px; }
.btn-block { width:100%; }

/* ============================================================
   TITRES DE SECTION
   ============================================================ */
.section-label {
    display:inline-block;
    font-family:var(--font-head);
    font-weight:700;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:3px;
    color:var(--accent);
    margin-bottom:10px;
}
.section-heading {
    text-align:center;
    max-width:660px;
    margin:0 auto 55px;
}
.section-heading h2 {
    font-family:var(--font-head);
    font-weight:800;
    font-size:32px;
    color:var(--dark);
    margin-bottom:14px;
    line-height:1.25;
}
.section-heading p { color:var(--text-light); font-size:16px; }
.section-heading.light h2 { color:#fff; }
.section-heading.light p { color:rgba(255,255,255,.7); }
.section-heading.light .section-label { color:var(--orange); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
    position:relative;
    min-height:85vh;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}
.hero-bg {
    position:absolute; inset:0; z-index:0;
}
.hero-bg .hero-img {
    width:100%; height:100%;
    object-fit:cover;
    object-position:center 60%;
}
.hero-overlay {
    position:absolute; inset:0; z-index:1;
    background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.65) 100%);
}
.hero-content {
    position:relative; z-index:2;
    text-align:center;
    padding:100px 20px 140px;
    max-width:800px;
}
.hero-badge-top {
    display:inline-flex;
    align-items:center;
    gap:6px;
    background:rgba(255,255,255,.15);
    backdrop-filter:blur(8px);
    color:#ffd700;
    font-family:var(--font-head);
    font-weight:600;
    font-size:14px;
    padding:8px 20px;
    border-radius:50px;
    margin-bottom:28px;
    border:1px solid rgba(255,255,255,.15);
}
.hero-badge-top span { color:#fff; margin-left:4px; }
.hero h1 {
    font-family:var(--font-head);
    font-weight:900;
    font-size:52px;
    color:#fff;
    margin-bottom:20px;
    line-height:1.15;
    text-shadow:0 2px 15px rgba(0,0,0,.3);
}
.hero-subtitle {
    color:rgba(255,255,255,.85);
    font-size:17px;
    margin-bottom:35px;
    line-height:1.8;
}
.hero-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* Compteurs hero */
.hero-counters {
    position:absolute;
    bottom:0; left:0; right:0;
    z-index:3;
    background:var(--blue);
    display:flex;
}
.counter-item {
    flex:1;
    text-align:center;
    padding:22px 10px;
    border-right:1px solid rgba(255,255,255,.15);
}
.counter-item:last-child { border-right:none; }
.counter-num {
    font-family:var(--font-head);
    font-weight:900;
    font-size:32px;
    color:#fff;
}
.counter-suffix {
    font-family:var(--font-head);
    font-weight:700;
    font-size:22px;
    color:rgba(255,255,255,.7);
}
.counter-label {
    display:block;
    font-size:12px;
    color:rgba(255,255,255,.65);
    text-transform:uppercase;
    letter-spacing:1px;
    font-weight:600;
    margin-top:2px;
}

/* ============================================================
   AVANTAGES
   ============================================================ */
.advantages { padding:60px 0; background:var(--bg-off); }
.adv-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
}
.adv-item {
    text-align:center;
    padding:30px 20px;
}
.adv-icon {
    width:68px; height:68px;
    margin:0 auto 16px;
    background:var(--blue);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:24px;
}
.adv-item h3 {
    font-family:var(--font-head);
    font-size:16px;
    font-weight:700;
    color:var(--dark);
    margin-bottom:8px;
}
.adv-item p { font-size:13px; color:var(--text-light); }

/* ============================================================
   À PROPOS
   ============================================================ */
.about { padding:80px 0; background:var(--bg); }
.about-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
}
.about-photos { position:relative; }
.about-photo-main {
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-lg);
}
.about-photo-main img { width:100%; height:380px; object-fit:cover; }
.about-photo-small {
    position:absolute;
    bottom:-30px; right:-20px;
    width:200px;
}
.about-photo-small img {
    width:100%; height:150px;
    object-fit:cover;
    border-radius:var(--radius);
    border:4px solid #fff;
    box-shadow:var(--shadow);
}
.about-exp-badge {
    position:absolute;
    top:-15px; left:-15px;
    background:var(--accent);
    color:#fff;
    text-align:center;
    padding:12px 16px;
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}
.about-exp-badge strong { display:block; font-family:var(--font-head); font-size:26px; font-weight:900; line-height:1; }
.about-exp-badge span { font-size:11px; text-transform:uppercase; letter-spacing:1px; }

.about-text .section-label { margin-bottom:8px; }
.about-text h2 {
    font-family:var(--font-head);
    font-weight:800;
    font-size:28px;
    color:var(--dark);
    margin-bottom:20px;
    line-height:1.3;
}
.about-lead { font-size:16px; font-weight:600; color:var(--dark2); margin-bottom:14px; }
.about-text > p { margin-bottom:22px; }
.about-checks { margin-bottom:28px; }
.about-check {
    display:flex;
    align-items:center;
    gap:10px;
    padding:6px 0;
    font-weight:600;
    color:var(--dark2);
    font-size:14px;
}
.about-check i { color:var(--green); font-size:16px; }

/* ============================================================
   FORMATIONS
   ============================================================ */
.formations { padding:80px 0; background:var(--bg-off); }
.formations-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
}
.formation-card {
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow);
    transition:all .3s;
    position:relative;
}
.formation-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.formation-card.popular { border:2px solid var(--accent); }
.formation-popular {
    position:absolute; top:15px; right:15px; z-index:5;
    background:var(--accent);
    color:#fff;
    font-family:var(--font-head);
    font-weight:700;
    font-size:11px;
    padding:4px 12px;
    border-radius:50px;
    text-transform:uppercase;
    letter-spacing:.5px;
}
.formation-img {
    position:relative;
    height:200px;
    overflow:hidden;
}
.formation-img img {
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .5s;
}
.formation-card:hover .formation-img img { transform:scale(1.08); }
.formation-overlay {
    position:absolute; inset:0;
    background:rgba(0,0,0,.5);
    display:flex; align-items:center; justify-content:center;
    opacity:0;
    transition:opacity .3s;
}
.formation-card:hover .formation-overlay { opacity:1; }
.formation-body { padding:24px 20px; }
.formation-icon {
    width:46px; height:46px;
    background:var(--blue-light);
    color:var(--blue);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:18px;
    margin-bottom:14px;
    margin-top:-40px;
    position:relative;
    z-index:2;
    border:3px solid #fff;
    box-shadow:var(--shadow);
}
.formation-body h3 {
    font-family:var(--font-head);
    font-weight:700;
    font-size:17px;
    color:var(--dark);
    margin-bottom:10px;
}
.formation-body > p {
    font-size:13px;
    color:var(--text-light);
    margin-bottom:14px;
    line-height:1.7;
}
.formation-body ul li {
    display:flex; align-items:center; gap:8px;
    padding:4px 0;
    font-size:13px;
    color:var(--text);
}
.formation-body ul li i { color:var(--green); font-size:12px; }

/* ============================================================
   PARALLAX CTA
   ============================================================ */
.parallax-cta {
    position:relative;
    height:400px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}
.parallax-img {
    position:absolute; inset:0;
    width:100%; height:130%;
    object-fit:cover;
    object-position:center;
    /* on simule le parallaxe via JS ou via attachment */
}
.parallax-overlay {
    position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(0,86,179,.85), rgba(0,30,80,.9));
}
.parallax-content {
    position:relative; z-index:2;
    text-align:center;
    padding:0 20px;
}
.parallax-content h2 {
    font-family:var(--font-head);
    font-weight:900;
    font-size:38px;
    color:#fff;
    margin-bottom:14px;
}
.parallax-content p { color:rgba(255,255,255,.8); font-size:17px; margin-bottom:30px; }
.parallax-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   ÉQUIPE
   ============================================================ */
.team { padding:80px 0; background:var(--bg); }
.team-grid {
    display:flex;
    justify-content:center;
    gap:40px;
    flex-wrap:wrap;
}
.team-card {
    width:320px;
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow);
    transition:all .3s;
}
.team-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.team-photo {
    position:relative;
    height:350px;
    overflow:hidden;
}
.team-photo img {
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .5s;
}
.team-card:hover .team-photo img { transform:scale(1.05); }
.team-social {
    position:absolute;
    bottom:12px; right:12px;
    display:flex; gap:8px;
    opacity:0;
    transition:opacity .3s;
}
.team-card:hover .team-social { opacity:1; }
.team-social a {
    width:38px; height:38px;
    background:var(--accent);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:14px;
}
.team-social a:hover { background:var(--accent-dark); color:#fff; }
.team-info {
    padding:24px 20px;
    text-align:center;
}
.team-info h3 {
    font-family:var(--font-head);
    font-weight:700;
    font-size:19px;
    color:var(--dark);
    margin-bottom:4px;
}
.team-role {
    display:block;
    font-size:12px;
    color:var(--accent);
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:1px;
    margin-bottom:10px;
}
.team-info p { font-size:13px; color:var(--text-light); }

/* ============================================================
   GALERIE
   ============================================================ */
.gallery { padding:80px 0; background:var(--bg-off); }
.gallery-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    grid-auto-rows:220px;
    gap:12px;
}
.gallery-wide { grid-column:span 2; }
.gallery-item {
    position:relative;
    border-radius:var(--radius);
    overflow:hidden;
    cursor:pointer;
}
.gallery-item img {
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .5s;
}
.gallery-item:hover img { transform:scale(1.08); }
.gallery-caption {
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.5);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    font-family:var(--font-head);
    font-weight:600;
    font-size:14px;
    opacity:0;
    transition:opacity .3s;
}
.gallery-item:hover .gallery-caption { opacity:1; }

/* Lightbox */
.lightbox {
    position:fixed; inset:0;
    z-index:10000;
    background:rgba(0,0,0,.92);
    display:flex;
    align-items:center;
    justify-content:center;
    opacity:0;
    visibility:hidden;
    transition:all .3s;
}
.lightbox.active { opacity:1; visibility:visible; }
.lightbox img {
    max-width:90vw;
    max-height:85vh;
    border-radius:var(--radius);
    box-shadow:0 10px 60px rgba(0,0,0,.5);
}
.lightbox-close, .lightbox-prev, .lightbox-next {
    position:absolute;
    background:rgba(255,255,255,.1);
    color:#fff;
    border:none;
    border-radius:50%;
    width:50px; height:50px;
    display:flex; align-items:center; justify-content:center;
    font-size:20px;
    cursor:pointer;
    transition:background .3s;
}
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover { background:rgba(255,255,255,.25); }
.lightbox-close { top:20px; right:20px; }
.lightbox-prev { left:20px; top:50%; transform:translateY(-50%); }
.lightbox-next { right:20px; top:50%; transform:translateY(-50%); }

/* ============================================================
   ÉTAPES
   ============================================================ */
.steps {
    padding:80px 0;
    background:var(--dark);
}
.steps-grid {
    display:flex;
    align-items:flex-start;
    justify-content:center;
    gap:0;
    flex-wrap:wrap;
}
.step-item {
    flex:1;
    min-width:180px;
    max-width:240px;
    text-align:center;
    padding:0 15px;
    position:relative;
}
.step-num {
    font-family:var(--font-head);
    font-weight:900;
    font-size:42px;
    color:rgba(255,255,255,.08);
    line-height:1;
    margin-bottom:-8px;
}
.step-icon {
    width:64px; height:64px;
    margin:0 auto 16px;
    background:var(--accent);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:22px;
}
.step-item h3 {
    font-family:var(--font-head);
    font-weight:700;
    font-size:15px;
    color:#fff;
    margin-bottom:8px;
}
.step-item p { font-size:13px; color:rgba(255,255,255,.55); line-height:1.7; }
.step-arrow {
    display:flex; align-items:center;
    padding-top:60px;
    color:rgba(255,255,255,.2);
    font-size:20px;
}

/* ============================================================
   TARIFS
   ============================================================ */
.pricing { padding:80px 0; background:var(--bg); }
.pricing-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
    margin-bottom:30px;
}
.price-card {
    background:#fff;
    border:2px solid var(--border);
    border-radius:var(--radius-lg);
    padding:0;
    overflow:hidden;
    transition:all .3s;
    position:relative;
}
.price-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.price-card.featured {
    border-color:var(--accent);
    transform:scale(1.04);
}
.price-card.featured:hover { transform:scale(1.04) translateY(-6px); }
.price-ribbon {
    position:absolute; top:0; right:0;
    background:var(--accent);
    color:#fff;
    font-family:var(--font-head);
    font-weight:700;
    font-size:11px;
    padding:6px 18px;
    border-radius:0 0 0 var(--radius);
    text-transform:uppercase;
}
.price-head {
    padding:30px 24px 20px;
    text-align:center;
    border-bottom:1px solid var(--border);
}
.price-head h3 {
    font-family:var(--font-head);
    font-weight:800;
    font-size:20px;
    color:var(--dark);
    margin-bottom:4px;
}
.price-head p { font-size:13px; color:var(--text-muted); }
.price-amount {
    text-align:center;
    padding:24px;
}
.price-tag {
    font-family:var(--font-head);
    font-weight:800;
    font-size:22px;
    color:var(--blue);
}
.price-features {
    padding:0 24px 8px;
}
.price-features li {
    display:flex; align-items:center; gap:10px;
    padding:8px 0;
    font-size:14px;
    color:var(--text);
    border-bottom:1px solid #f5f5f5;
}
.price-features li:last-child { border-bottom:none; }
.price-features li i { color:var(--green); font-size:13px; }
.price-card .btn { margin:20px 24px 28px; width:calc(100% - 48px); }
.pricing-note {
    text-align:center;
    font-size:14px;
    color:var(--text-light);
}
.pricing-note i { color:var(--blue); }

/* ============================================================
   AVIS
   ============================================================ */
.reviews { padding:80px 0; background:var(--bg-off); }
.google-rating {
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:#fff;
    padding:8px 18px;
    border-radius:50px;
    box-shadow:var(--shadow);
    margin-top:16px;
    font-size:14px;
}
.google-stars { color:#fbbc04; font-size:14px; display:flex; gap:2px; }
.google-rating strong { color:var(--dark); }
.google-rating span { color:var(--text-muted); }

.reviews-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
    margin-bottom:36px;
}
.review-card {
    background:#fff;
    padding:28px 24px;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
    border-left:4px solid var(--blue);
    transition:all .3s;
}
.review-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.review-head {
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:14px;
}
.review-avatar {
    width:44px; height:44px;
    background:var(--blue);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-head);
    font-weight:700;
    font-size:14px;
    flex-shrink:0;
}
.review-head strong { font-size:15px; color:var(--dark); display:block; }
.review-stars { color:#fbbc04; font-size:12px; display:flex; gap:2px; }
.review-date {
    margin-left:auto;
    font-size:12px;
    color:var(--text-muted);
    white-space:nowrap;
}
.review-card p { font-size:14px; color:var(--text); line-height:1.75; font-style:italic; margin-bottom:12px; }
.review-tag {
    display:inline-block;
    background:var(--blue-light);
    color:var(--blue);
    font-size:12px;
    font-weight:600;
    padding:3px 10px;
    border-radius:50px;
}
.reviews-cta { text-align:center; }

/* ============================================================
   FAQ
   ============================================================ */
.faq { padding:80px 0; background:var(--bg); }
.faq-layout {
    display:grid;
    grid-template-columns:1fr 1.5fr;
    gap:60px;
    align-items:start;
}
.faq-left h2 {
    font-family:var(--font-head);
    font-weight:800;
    font-size:28px;
    color:var(--dark);
    margin-bottom:16px;
}
.faq-left p { color:var(--text-light); margin-bottom:24px; }
.faq-right { display:flex; flex-direction:column; gap:10px; }
.faq-item {
    border:1px solid var(--border);
    border-radius:var(--radius);
    overflow:hidden;
    transition:all .3s;
}
.faq-item:hover { border-color:var(--blue); }
.faq-item.active { border-color:var(--blue); box-shadow:0 2px 12px rgba(0,86,179,.1); }
.faq-q {
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:18px 20px;
    background:none;
    border:none;
    cursor:pointer;
    font-family:var(--font-head);
    font-weight:600;
    font-size:14px;
    color:var(--dark);
    text-align:left;
    gap:12px;
}
.faq-q:hover { color:var(--blue); }
.faq-q i { color:var(--blue); font-size:14px; transition:transform .3s; flex-shrink:0; }
.faq-item.active .faq-q i { transform:rotate(45deg); }
.faq-a {
    max-height:0;
    overflow:hidden;
    transition:max-height .4s ease;
}
.faq-item.active .faq-a { max-height:200px; }
.faq-a p { padding:0 20px 18px; font-size:14px; color:var(--text-light); line-height:1.75; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { padding:80px 0; background:var(--bg-off); }
.contact-grid {
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:40px;
}
.contact-form {
    background:#fff;
    padding:36px;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { margin-bottom:16px; }
.form-group label {
    display:block;
    font-family:var(--font-head);
    font-weight:600;
    font-size:13px;
    color:var(--dark2);
    margin-bottom:5px;
}
.form-group input, .form-group select, .form-group textarea {
    width:100%;
    padding:11px 14px;
    font-family:var(--font);
    font-size:14px;
    color:var(--text);
    background:var(--bg-off);
    border:1px solid var(--border);
    border-radius:var(--radius);
    transition:all .25s;
    outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    border-color:var(--blue);
    background:#fff;
    box-shadow:0 0 0 3px var(--blue-light);
}
.form-group textarea { resize:vertical; min-height:90px; }
.form-success {
    text-align:center;
    padding:50px 30px;
    background:#fff;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
}
.form-success i { font-size:48px; color:var(--green); margin-bottom:14px; }
.form-success h3 { font-family:var(--font-head); margin-bottom:8px; }
.form-success p { color:var(--text-light); }

.contact-sidebar { display:flex; flex-direction:column; gap:20px; }
.contact-info-card {
    background:#fff;
    padding:28px 24px;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
}
.contact-info-card h3 {
    font-family:var(--font-head);
    font-weight:700;
    font-size:18px;
    color:var(--dark);
    margin-bottom:20px;
    padding-bottom:14px;
    border-bottom:2px solid var(--accent);
}
.info-row {
    display:flex;
    gap:14px;
    padding:10px 0;
    align-items:flex-start;
}
.info-row > i {
    width:36px; height:36px;
    background:var(--blue-light);
    color:var(--blue);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:14px;
    flex-shrink:0;
    margin-top:2px;
}
.info-row strong { display:block; font-size:13px; color:var(--dark); margin-bottom:2px; font-family:var(--font-head); }
.info-row p { font-size:13px; color:var(--text-light); line-height:1.6; }
.info-row a { color:var(--blue); font-weight:600; }
.contact-map { border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
    background:var(--dark);
    color:rgba(255,255,255,.65);
    padding:60px 0 0;
}
.footer-grid {
    display:grid;
    grid-template-columns:1.6fr 1fr 1fr 1.3fr;
    gap:40px;
    padding-bottom:40px;
}
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.footer-logo .logo-name { color:#fff; }
.footer-logo .logo-sub { color:rgba(255,255,255,.4); }
.footer-about p { font-size:14px; line-height:1.7; margin-bottom:18px; }
.footer-social { display:flex; gap:10px; }
.footer-social a {
    width:38px; height:38px;
    background:rgba(255,255,255,.08);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:15px;
    transition:all .3s;
}
.footer-social a:hover { background:var(--accent); transform:translateY(-2px); }
.footer-col h4 { color:#fff; font-family:var(--font-head); font-weight:700; font-size:16px; margin-bottom:18px; }
.footer-col ul li { margin-bottom:8px; }
.footer-col ul li a { color:rgba(255,255,255,.55); font-size:14px; }
.footer-col ul li a:hover { color:#fff; padding-left:4px; }
.footer-contact li { display:flex; align-items:flex-start; gap:10px; margin-bottom:12px; font-size:13px; }
.footer-contact li i { color:var(--accent); margin-top:3px; }
.footer-contact a { color:rgba(255,255,255,.55); }
.footer-contact a:hover { color:#fff; }
.footer-bottom {
    border-top:1px solid rgba(255,255,255,.08);
    padding:20px 0;
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:12px;
    font-size:13px;
}
.footer-legal { display:flex; gap:20px; }
.footer-legal a { color:rgba(255,255,255,.4); font-size:13px; }
.footer-legal a:hover { color:#fff; }

/* ============================================================
   BACK TO TOP
   ============================================================ */
.back-to-top {
    position:fixed;
    bottom:24px; right:24px;
    width:46px; height:46px;
    background:var(--accent);
    color:#fff;
    border:none;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:16px;
    cursor:pointer;
    opacity:0; visibility:hidden;
    transform:translateY(20px);
    transition:all .3s;
    box-shadow:var(--shadow);
    z-index:998;
}
.back-to-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.back-to-top:hover { background:var(--accent-dark); transform:translateY(-3px); }

/* ============================================================
   ANIMATIONS SCROLL
   ============================================================ */
.reveal {
    opacity:0;
    transform:translateY(30px);
    transition:opacity .5s ease, transform .5s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
    .formations-grid { grid-template-columns:repeat(2,1fr); }
    .gallery-grid { grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
    .gallery-wide { grid-column:span 2; }
    .footer-grid { grid-template-columns:1fr 1fr; }
    .hero h1 { font-size:40px; }
}

@media (max-width:768px) {
    .topbar-left { display:none; }
    .nav-menu {
        position:fixed; top:0; right:-100%;
        width:80%; max-width:340px; height:100vh;
        background:#fff;
        flex-direction:column;
        padding:90px 28px 28px;
        box-shadow:var(--shadow-lg);
        transition:right .4s;
        z-index:999;
    }
    .nav-menu.active { right:0; }
    .nav-menu li { width:100%; }
    .nav-menu li a { font-size:15px; padding:12px 16px; width:100%; display:block; }
    .nav-btn { text-align:center !important; }
    .hamburger { display:flex; }

    .hero { min-height:70vh; }
    .hero h1 { font-size:30px; }
    .hero-subtitle { font-size:15px; }
    .hero-counters { flex-wrap:wrap; }
    .counter-item { flex:0 0 50%; border-bottom:1px solid rgba(255,255,255,.1); }
    .counter-num { font-size:26px; }

    .adv-grid { grid-template-columns:1fr 1fr; gap:16px; }
    .about-grid { grid-template-columns:1fr; gap:40px; }
    .about-photo-small { position:relative; bottom:auto; right:auto; width:160px; margin-top:-20px; margin-left:auto; }
    .formations-grid { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
    .team-grid { flex-direction:column; align-items:center; }
    .gallery-grid { grid-template-columns:1fr 1fr; grid-auto-rows:160px; }
    .gallery-wide { grid-column:span 1; }
    .step-arrow { display:none; }
    .steps-grid { flex-direction:column; align-items:center; gap:30px; }
    .step-item { max-width:100%; }
    .pricing-grid { grid-template-columns:1fr; max-width:380px; margin:0 auto 30px; }
    .price-card.featured { transform:none; }
    .reviews-grid { grid-template-columns:1fr; }
    .faq-layout { grid-template-columns:1fr; gap:30px; }
    .contact-grid { grid-template-columns:1fr; }
    .contact-form { padding:24px 18px; }
    .form-row { grid-template-columns:1fr; }
    .footer-grid { grid-template-columns:1fr; gap:30px; }
    .footer-bottom { flex-direction:column; text-align:center; }
    .parallax-content h2 { font-size:26px; }
}

@media (max-width:480px) {
    .container { padding:0 14px; }
    .hero h1 { font-size:26px; }
    .section-heading h2 { font-size:24px; }
    .hero-btns { flex-direction:column; align-items:center; }
    .parallax-btns { flex-direction:column; align-items:center; }
    .adv-grid { grid-template-columns:1fr; }
}
