/* ============================================================
   Garage FMA Autos - Feuille de styles
   Extrait de fma-autos.html (CSS auparavant en ligne)
   ============================================================ */

:root{--primary:#1A2B4A;--accent:#E8502A;--light:#F5F3EE;--mid:#E0DDD6;--text:#1A2B4A;--muted:#6B7280;--white:#FFFFFF;--radius:12px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;font-size:16px;line-height:1.65;color:var(--text);background:var(--white);padding-top:68px;}
h1,h2,h3,h4{font-family:'Syne',sans-serif;line-height:1.15;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(255,255,255,0.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--mid);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:68px;}
.nav-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.7rem;color:var(--primary);letter-spacing:-0.02em;text-decoration:none;}
.nav-logo span{color:var(--accent);}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{position:relative;text-decoration:none;color:var(--muted);font-size:0.9rem;font-weight:500;transition:color 0.2s;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:right;transition:transform 0.28s cubic-bezier(0.22,0.61,0.36,1);}
.nav-links a:hover{color:var(--accent);}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left;}
.nav-right{display:flex;align-items:center;gap:0.75rem;}

/* Bouton hamburger (mobile) */
.nav-burger{display:none;width:42px;height:42px;border:none;background:transparent;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0;}
.nav-burger span{display:block;width:24px;height:2px;background:var(--primary);border-radius:2px;transition:transform 0.3s,opacity 0.2s;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Panneau mobile déroulant */
.mobile-menu{position:fixed;top:68px;right:0;width:min(78vw,300px);background:#ffffff;backdrop-filter:blur(12px);border-left:1px solid var(--mid);box-shadow:-8px 0 32px rgba(26,43,74,0.12);display:flex;flex-direction:column;padding:1rem 0;transform:translateX(105%);transition:transform 0.35s cubic-bezier(0.22,0.61,0.36,1);z-index:199;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{padding:1rem 1.75rem;color:var(--primary);text-decoration:none;font-family:'Syne',sans-serif;font-weight:600;font-size:1.05rem;border-bottom:1px solid var(--mid);transition:background 0.2s,padding-left 0.2s;}
.mobile-menu a:hover{background:var(--light);padding-left:2.1rem;color:var(--accent);}
.mobile-menu-backdrop{position:fixed;inset:68px 0 0 0;background:rgba(26,43,74,0.35);opacity:0;visibility:hidden;transition:opacity 0.35s,visibility 0.35s;z-index:198;}
.mobile-menu-backdrop.open{opacity:1;visibility:visible;}
.nav-cta{background:var(--accent);color:white;border:none;border-radius:8px;padding:0.55rem 1.2rem;font-family:'Syne',sans-serif;font-weight:600;font-size:0.9rem;cursor:pointer;text-decoration:none;transition:background 0.2s,transform 0.15s;display:inline-flex;align-items:center;white-space:nowrap;}
.nav-cta:hover{background:#c73f1e;transform:translateY(-1px);}

/* HERO */
.hero{min-height:calc(100vh - 68px);background:var(--primary);display:flex;flex-direction:column;position:relative;overflow:hidden;padding-top:2rem;}
.hero-photo{position:absolute;inset:0;opacity:0.5;overflow:hidden;pointer-events:none;}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(232,80,42,0.18) 0%,transparent 60%),radial-gradient(ellipse at 10% 80%,rgba(232,80,42,0.10) 0%,transparent 50%);pointer-events:none;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(26,43,74,0.78) 35%,rgba(26,43,74,0.3) 100%);pointer-events:none;}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;}
.hero-content{position:relative;z-index:2;flex:1;display:flex;align-items:center;padding:0.5rem 5%;max-width:1200px;margin:0 auto;width:100%;gap:4rem;}
.hero-text{flex:1;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,80,42,0.15);border:1px solid rgba(232,80,42,0.3);color:#F5A58E;border-radius:100px;padding:0.35rem 1rem;font-size:0.8rem;font-weight:500;margin-bottom:1.5rem;letter-spacing:0.04em;text-transform:uppercase;}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
.hero-title{font-size:clamp(2.8rem,5.5vw,4.5rem);font-weight:800;color:white;letter-spacing:-0.03em;margin-bottom:1.25rem;}
.hero-title .accent{color:var(--accent);}
.hero-subtitle{color:rgba(255,255,255,0.65);font-size:1.1rem;max-width:480px;margin-bottom:2.5rem;font-weight:300;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;}
.btn-primary{background:var(--accent);color:white;border:none;padding:0.85rem 1.8rem;border-radius:10px;font-family:'Syne',sans-serif;font-weight:600;font-size:1rem;cursor:pointer;text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;}
.btn-primary:hover{background:#c73f1e;transform:translateY(-2px);}
.btn-outline{background:transparent;color:white;border:1px solid rgba(255,255,255,0.3);padding:0.85rem 1.8rem;border-radius:10px;font-family:'Syne',sans-serif;font-weight:600;font-size:1rem;cursor:pointer;text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;}
.btn-outline:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.6);}
.hero-visual{flex:1;display:flex;justify-content:center;align-items:center;}
.hero-card-stack{position:relative;width:320px;height:360px;}
.hero-card{position:absolute;border:1px solid rgba(255,255,255,0.12);border-radius:16px;padding:1.5rem;}
.hero-card-main{width:280px;top:40px;left:20px;background:rgba(255,255,255,0.1);backdrop-filter:blur(6px);}
.hero-card-back{width:260px;top:10px;left:35px;opacity:0.4;transform:rotate(2deg);background:rgba(255,255,255,0.05);}
.stat-row{display:flex;gap:1.5rem;}
.stat{text-align:center;}
.stat-num{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:white;display:block;}
.stat-label{font-size:0.75rem;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.05em;}
.hero-card-icon{font-size:2rem;margin-bottom:1rem;}
.hero-card-title{font-family:'Syne',sans-serif;color:white;font-size:0.95rem;font-weight:600;margin-bottom:0.5rem;}
.hero-card-text{font-size:0.8rem;color:rgba(255,255,255,0.5);}
.hero-bottom{position:relative;z-index:2;margin-top:1.25rem;background:rgba(255,255,255,0.05);border-top:1px solid rgba(255,255,255,0.08);padding:1.2rem 5%;}
.hero-bottom-inner{max-width:1200px;margin:0 auto;display:flex;gap:3rem;align-items:center;flex-wrap:wrap;}
.hero-bottom-item{display:flex;align-items:center;gap:10px;}
.hero-bottom-icon{width:28px;height:28px;background:rgba(232,80,42,0.2);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:0.85rem;}
.hero-bottom-text{font-size:0.85rem;color:rgba(255,255,255,0.7);}

/* BANDEAUX PROMO / EVENEMENT */
@keyframes bannerSlideDown{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
@keyframes bannerDotPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.8);opacity:0.3;}}
@keyframes bannerSweep{0%{left:-40%;}60%,100%{left:110%;}}
.banners-wrap{margin-top:0;}
.info-banner{display:none;padding:0.8rem 5%;text-align:center;font-size:0.92rem;font-weight:500;position:relative;overflow:hidden;}
.info-banner.promo-active{display:flex;align-items:center;justify-content:center;gap:8px;background:#FFF7ED;border-bottom:2px solid #F59E0B;color:#92400E;animation:bannerSlideDown 0.45s cubic-bezier(0.34,1.3,0.64,1) both;}
.info-banner.event-active{display:flex;align-items:center;justify-content:center;gap:8px;background:#EFF6FF;border-bottom:2px solid #3B82F6;color:#1E3A8A;animation:bannerSlideDown 0.45s cubic-bezier(0.34,1.3,0.64,1) both;}
.info-banner::after{content:'';position:absolute;top:0;bottom:0;width:35%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.5),transparent);animation:bannerSweep 3.5s ease-in-out infinite 1s;pointer-events:none;}
.info-banner .banner-text{font-weight:700;}
.banner-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0;animation:bannerDotPulse 1.6s ease-in-out infinite;}
.info-banner.promo-active .banner-dot{background:#F59E0B;}
.info-banner.event-active .banner-dot{background:#3B82F6;}

/* SECTIONS */
section{padding:5rem 5%;}
/* Décalage des ancres pour ne pas passer sous la nav fixe (68px) */
#services,#about,#contact,#horaires{scroll-margin-top:84px;}
.section-inner{max-width:1200px;margin:0 auto;}
.section-tag{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--accent);margin-bottom:0.8rem;}
.section-title{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;color:var(--primary);letter-spacing:-0.02em;margin-bottom:1rem;}
.section-subtitle{color:var(--muted);max-width:520px;font-size:1rem;line-height:1.7;margin-bottom:3rem;}

/* SERVICES */
.services{background:var(--light);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;}
.service-card{position:relative;overflow:hidden;background:linear-gradient(160deg,#ffffff 0%,#fbfaf8 100%);border-radius:var(--radius);padding:1.5rem;border:1px solid var(--mid);transition:transform 0.3s cubic-bezier(0.22,0.61,0.36,1),box-shadow 0.3s,border-color 0.3s;box-shadow:0 2px 8px rgba(26,43,74,0.05);}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),#ff8a5c);transform:scaleX(0);transform-origin:left;transition:transform 0.35s cubic-bezier(0.22,0.61,0.36,1);}
.service-card:hover{transform:translateY(-6px);border-color:rgba(232,80,42,0.45);box-shadow:0 18px 36px rgba(26,43,74,0.12),0 8px 20px rgba(232,80,42,0.14);}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{width:52px;height:52px;border-radius:12px;background:rgba(232,80,42,0.08);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border:1px solid rgba(232,80,42,0.12);transition:background 0.3s,transform 0.3s,box-shadow 0.3s;}
.service-card:hover .service-icon{background:rgba(232,80,42,0.16);transform:scale(1.08) rotate(-3deg);box-shadow:0 6px 16px rgba(232,80,42,0.22);}
.service-title{font-family:'Syne',sans-serif;font-weight:700;font-size:0.95rem;color:var(--primary);margin-bottom:0.4rem;}
.service-desc{font-size:0.85rem;color:var(--muted);line-height:1.55;}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-main-box{background:var(--primary);border-radius:20px;padding:2.5rem;color:white;position:relative;overflow:hidden;}
.about-main-box::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(232,80,42,0.3);}
.big-number{font-family:'Syne',sans-serif;font-size:3rem;font-weight:800;color:var(--accent);display:block;line-height:1.1;margin-bottom:0.3rem;}
.big-label{font-size:0.9rem;color:rgba(255,255,255,0.6);margin-bottom:1.5rem;}
.about-chip{display:inline-block;background:rgba(255,255,255,0.12);border-radius:6px;padding:0.4rem 0.8rem;font-size:0.8rem;margin:0.25rem;color:rgba(255,255,255,0.8);}
.about-mini-cards{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem;margin-top:1rem;}
.about-mini{background:var(--light);border-radius:var(--radius);padding:1rem;border:1px solid var(--mid);}
.about-mini .mini-num{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:var(--primary);}
.about-mini .mini-label{font-size:0.75rem;color:var(--muted);}
.about-text p{color:var(--muted);line-height:1.8;margin-bottom:1.2rem;}
.about-text strong{color:var(--primary);font-weight:500;}
.certif-row{display:flex;gap:0.75rem;flex-wrap:wrap;margin-top:2rem;}
.certif-badge{display:flex;align-items:center;gap:8px;background:var(--light);border:1px solid var(--mid);border-radius:8px;padding:0.5rem 1rem;font-size:0.82rem;font-weight:500;color:var(--primary);}
.certif-badge::before{content:'✓';color:#16a34a;font-weight:700;}

/* PROCESS */
.process{background:var(--primary);}
.process .section-title{color:white;}
.process .section-subtitle{color:rgba(255,255,255,0.5);}
.process .section-tag{color:#F5A58E;}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.step-card{text-align:center;padding:1.5rem 1rem;}
.step-num{width:72px;height:72px;border-radius:50%;background:rgba(232,80,42,0.15);border:1px solid rgba(232,80,42,0.3);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;transition:background 0.3s,border-color 0.3s,transform 0.3s,box-shadow 0.3s;}
.step-card{text-align:center;padding:1.5rem 1rem;transition:transform 0.3s cubic-bezier(0.22,0.61,0.36,1);}
.step-card:hover{transform:translateY(-6px);}
.step-card:hover .step-num{background:rgba(232,80,42,0.3);border-color:rgba(232,80,42,0.7);transform:scale(1.06);box-shadow:0 0 0 6px rgba(232,80,42,0.08),0 8px 24px rgba(232,80,42,0.28);}
.step-title{font-family:'Syne',sans-serif;color:white;font-weight:700;margin-bottom:0.5rem;}
.step-desc{font-size:0.85rem;color:rgba(255,255,255,0.5);line-height:1.6;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;}
.hours-card{background:var(--primary);border-radius:16px;padding:2rem;color:white;box-shadow:0 8px 32px rgba(26,43,74,0.18);}
.hours-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;color:white;margin-bottom:1.5rem;}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:0.65rem 0;border-bottom:1px solid rgba(255,255,255,0.08);}
.hours-row:last-child{border-bottom:none;}
.hours-day{font-size:0.9rem;color:rgba(255,255,255,0.6);}
.hours-time{font-size:0.9rem;font-weight:500;color:white;}
.hours-closed{color:rgba(255,255,255,0.3);font-style:italic;font-weight:400;}
/* Encart événement sous les horaires (congés, fermetures exceptionnelles) — masqué par défaut */
.hours-event{display:none;align-items:flex-start;gap:0.7rem;margin-top:1rem;padding:0.95rem 1.15rem;background:#FFF7ED;border:1px solid #FED7AA;border-left:4px solid #F59E0B;border-radius:12px;box-shadow:0 4px 14px rgba(245,158,11,0.12);}
.hours-event.show{display:flex;}
.hours-event-ico{font-size:1.15rem;line-height:1.4;flex-shrink:0;}
.hours-event-text{font-size:0.9rem;color:#92400E;font-weight:600;line-height:1.5;}
.contact-info{display:flex;flex-direction:column;gap:1.25rem;}
.contact-item{position:relative;overflow:hidden;display:flex;gap:1rem;align-items:flex-start;background:linear-gradient(160deg,#ffffff 0%,var(--light) 100%);border-radius:12px;padding:1.1rem 1.25rem;border:1px solid var(--mid);transition:box-shadow 0.3s,transform 0.3s,border-color 0.3s;}
.contact-item::before{content:'';position:absolute;top:0;bottom:0;left:0;width:3px;background:linear-gradient(180deg,var(--accent),#ff8a5c);transform:scaleY(0);transform-origin:top;transition:transform 0.32s cubic-bezier(0.22,0.61,0.36,1);}
.contact-item:hover{border-color:rgba(232,80,42,0.35);box-shadow:0 10px 24px rgba(26,43,74,0.10),0 4px 12px rgba(232,80,42,0.10);transform:translateX(4px);}
.contact-item:hover::before{transform:scaleY(1);}
.contact-ico{width:40px;height:40px;flex-shrink:0;background:rgba(232,80,42,0.12);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background 0.3s,transform 0.3s;}
.contact-item:hover .contact-ico{background:rgba(232,80,42,0.2);transform:scale(1.08);}
.contact-label{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:0.25rem;font-weight:600;}
.contact-value{font-weight:500;color:var(--primary);font-size:0.95rem;}
.contact-value a{color:var(--accent);text-decoration:none;}

/* FORMULAIRE DE CONTACT */
.form-card{margin-top:2.5rem;background:linear-gradient(160deg,#ffffff 0%,var(--light) 100%);border:1px solid var(--mid);border-radius:16px;padding:2rem;box-shadow:0 8px 28px rgba(26,43,74,0.07);}
.form-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.3rem;color:var(--primary);margin-bottom:0.4rem;}
.form-intro{color:var(--muted);font-size:0.92rem;margin-bottom:1.5rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-field{display:flex;flex-direction:column;margin-bottom:1rem;}
.form-field label{font-size:0.82rem;font-weight:600;color:var(--primary);margin-bottom:0.4rem;}
.form-field input,.form-field select,.form-field textarea{border:1px solid var(--mid);border-radius:10px;padding:0.7rem 0.9rem;font-family:'DM Sans',sans-serif;font-size:0.95rem;color:var(--text);background:#fff;transition:border-color 0.2s,box-shadow 0.2s;width:100%;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,80,42,0.12);}
.form-field textarea{resize:vertical;min-height:110px;}
.form-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-consent{display:flex;align-items:flex-start;gap:0.6rem;margin:0.3rem 0 1.3rem;font-size:0.82rem;color:var(--muted);line-height:1.5;cursor:pointer;}
.form-consent input{margin-top:0.15rem;flex-shrink:0;accent-color:var(--accent);width:16px;height:16px;}
.form-submit{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:0.85rem 2rem;font-family:'Syne',sans-serif;font-weight:700;font-size:1rem;cursor:pointer;transition:background 0.2s,transform 0.15s;}
.form-submit:hover{background:#c73f1e;transform:translateY(-1px);}
.form-submit:disabled{opacity:0.6;cursor:not-allowed;transform:none;}
.form-feedback{margin-top:1rem;font-size:0.9rem;font-weight:500;display:none;padding:0.8rem 1rem;border-radius:10px;}
.form-feedback.show{display:block;}
.form-feedback.ok{display:block;background:#ECFDF5;color:#065F46;border:1px solid #A7F3D0;}
.form-feedback.error{display:block;background:#FEF2F2;color:#991B1B;border:1px solid #FECACA;}

/* MAP */
.map-section{background:var(--light);padding:3rem 5%;}
.map-wrap{border-radius:16px;overflow:hidden;border:1px solid var(--mid);height:300px;background:var(--mid);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;color:var(--muted);}

/* ATELIER */
.atelier-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;}

/* FOOTER */
footer{background:var(--primary);padding:2.5rem 5%;color:rgba(255,255,255,0.5);font-size:0.85rem;}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.footer-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.1rem;color:white;}
.footer-logo span{color:var(--accent);}
.footer-legal-btn{background:none;border:none;color:rgba(255,255,255,0.45);cursor:pointer;font-size:0.85rem;font-family:'DM Sans',sans-serif;text-decoration:underline;padding:0;transition:color 0.2s;}
.footer-legal-btn:hover{color:rgba(255,255,255,0.8);}

/* MENTIONS LÉGALES */
#legal-modal{display:none;position:fixed;inset:0;z-index:1100;background:rgba(10,15,25,0.75);backdrop-filter:blur(4px);overflow-y:auto;padding:2rem 1rem;}
#legal-modal.open{display:flex;align-items:flex-start;justify-content:center;}
.legal-box{background:white;border-radius:16px;padding:2.5rem;max-width:680px;width:100%;margin:auto;position:relative;box-shadow:0 24px 64px rgba(0,0,0,0.35);}
.legal-close{position:absolute;top:1.25rem;right:1.25rem;background:var(--light);border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--muted);transition:background 0.2s;}
.legal-close:hover{background:var(--mid);color:var(--primary);}
.legal-title{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;color:var(--primary);margin-bottom:0.25rem;padding-right:2.5rem;}
.legal-subtitle{font-size:0.82rem;color:var(--muted);margin-bottom:2rem;}
.legal-section{margin-bottom:1.75rem;}
.legal-section h3{font-family:'Syne',sans-serif;font-size:0.92rem;font-weight:700;color:var(--primary);margin-bottom:0.75rem;text-transform:uppercase;letter-spacing:0.05em;display:flex;align-items:center;gap:8px;}
.legal-section h3::before{content:'';display:inline-block;width:14px;height:3px;background:var(--accent);border-radius:2px;flex-shrink:0;}
.legal-section p{font-size:0.88rem;color:var(--muted);line-height:1.75;margin-bottom:0.5rem;}
.legal-section ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:0.35rem;}
.legal-section ul li{font-size:0.88rem;color:var(--muted);line-height:1.6;}
.legal-dots{color:var(--accent);font-style:italic;opacity:0.8;}
.legal-divider{border:none;border-top:1px solid var(--mid);margin:0 0 1.75rem;}

/* ===== INTERFACE ADMIN ===== */
#admin-panel{display:none;position:fixed;inset:0;z-index:1000;background:rgba(10,15,25,0.7);backdrop-filter:blur(4px);overflow-y:auto;padding:2rem 1rem;}
#admin-panel.open{display:flex;align-items:flex-start;justify-content:center;}
.admin-modal{background:white;border-radius:20px;width:100%;max-width:720px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.35);margin:auto;}
.admin-header{background:var(--primary);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;}
.admin-header h2{font-family:'Syne',sans-serif;color:white;font-size:1.2rem;font-weight:700;}
.admin-close{background:rgba(255,255,255,0.1);border:none;color:white;width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background 0.2s;}
.admin-close:hover{background:rgba(255,255,255,0.2);}
.admin-tabs{display:flex;border-bottom:1px solid var(--mid);background:var(--light);}
.admin-tab{padding:0.85rem 1.5rem;font-size:0.88rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);transition:all 0.2s;border-bottom:2px solid transparent;font-family:'Syne',sans-serif;}
.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.admin-body{padding:2rem;}
.admin-section{display:none;}
.admin-section.active{display:block;}
/* Statistiques */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.7rem;margin-bottom:1.6rem;}
.stat-card{background:var(--light);border:1px solid var(--mid);border-radius:10px;padding:0.9rem 0.5rem;text-align:center;}
.stat-card-num{display:block;font-family:'Syne',sans-serif;font-size:1.55rem;font-weight:800;color:var(--accent);line-height:1.1;}
.stat-card-label{display:block;font-size:0.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.03em;margin-top:0.35rem;}
.stats-chart-title{font-size:0.85rem;font-weight:600;color:var(--text);margin-bottom:0.9rem;font-family:'Syne',sans-serif;}
.stats-chart{display:flex;align-items:stretch;gap:5px;height:150px;margin-bottom:0.5rem;}
.stats-bar-wrap{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;height:100%;}
.stats-bar-track{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;min-height:0;}
.stats-bar{position:relative;width:100%;max-width:24px;background:var(--accent);border-radius:4px 4px 0 0;min-height:2px;}
.stats-bar-cnt{position:absolute;top:-15px;left:50%;transform:translateX(-50%);font-size:0.62rem;color:var(--accent);font-weight:700;}
.stats-bar-day{font-size:0.58rem;color:var(--muted);margin-top:5px;white-space:nowrap;}
.admin-field{margin-bottom:1.25rem;}
.admin-field label{display:block;font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:0.5rem;}
.admin-field input,.admin-field textarea,.admin-field select{width:100%;border:1px solid var(--mid);border-radius:8px;padding:0.65rem 0.9rem;font-family:'DM Sans',sans-serif;font-size:0.95rem;color:var(--text);transition:border-color 0.2s;background:white;}
.admin-field input:focus,.admin-field textarea:focus,.admin-field select:focus{outline:none;border-color:var(--accent);}
.admin-field textarea{resize:vertical;min-height:80px;}
.admin-hours-grid{display:grid;grid-template-columns:100px 1fr 1fr;gap:0.5rem;align-items:center;margin-bottom:0.5rem;}
.admin-hours-grid span{font-size:0.88rem;font-weight:500;color:var(--text);}
.admin-hours-grid input{padding:0.5rem 0.7rem;font-size:0.88rem;}
.admin-hours-grid .closed-label{font-size:0.82rem;color:var(--muted);font-style:italic;}
.admin-toggle{display:flex;align-items:center;gap:10px;margin-bottom:1.25rem;}
.admin-toggle label{font-size:0.88rem;font-weight:500;color:var(--text);cursor:pointer;}
.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;inset:0;background:#ccc;border-radius:24px;cursor:pointer;transition:0.3s;}
.toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:white;border-radius:50%;transition:0.3s;}
.toggle-switch input:checked+.toggle-slider{background:var(--accent);}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(20px);}
.admin-save-btn{background:var(--accent);color:white;border:none;border-radius:10px;padding:0.8rem 2rem;font-family:'Syne',sans-serif;font-weight:700;font-size:0.95rem;cursor:pointer;transition:all 0.2s;width:100%;margin-top:0.5rem;}
.admin-save-btn:hover{background:#c73f1e;transform:translateY(-1px);}
.admin-saved-msg{text-align:center;color:#16a34a;font-size:0.85rem;font-weight:500;margin-top:0.75rem;opacity:0;transition:opacity 0.3s;}
.admin-saved-msg.show{opacity:1;}
.admin-pin-screen{padding:2rem;text-align:center;}
.admin-pin-screen p{color:var(--muted);margin-bottom:1.5rem;}
.admin-pin-screen input{width:140px;text-align:center;letter-spacing:0.3em;font-size:1.3rem;border:2px solid var(--mid);border-radius:10px;padding:0.7rem;font-family:'Syne',sans-serif;}
.admin-pin-screen input:focus{outline:none;border-color:var(--accent);}
.admin-pin-error{color:var(--accent);font-size:0.85rem;margin-top:0.5rem;}
.admin-pin-btn{background:var(--primary);color:white;border:none;border-radius:10px;padding:0.75rem 2rem;font-family:'Syne',sans-serif;font-weight:700;cursor:pointer;margin-top:1rem;transition:background 0.2s;}
.admin-pin-btn:hover{background:#0f1e36;}
.section-hint{font-size:0.82rem;color:var(--muted);background:var(--light);border-radius:8px;padding:0.6rem 0.9rem;margin-bottom:1.5rem;border-left:3px solid var(--mid);}

/* ANIM */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
/* Carte du hero : arrive depuis la droite au chargement (desktop ; .hero-visual est masquée sur mobile) */
.hero-visual{opacity:0;transform:translateX(110px);animation:heroSlideRight 0.9s cubic-bezier(0.22,0.61,0.36,1) 0.35s forwards;}
@keyframes heroSlideRight{to{opacity:1;transform:translateX(0);}}
@media(prefers-reduced-motion:reduce){.hero-visual{opacity:1;transform:none;animation:none;}}
.hero-text>*{animation:fadeUp 0.7s ease both;}
.hero-text>*:nth-child(1){animation-delay:0.1s;}
.hero-text>*:nth-child(2){animation-delay:0.2s;}
.hero-text>*:nth-child(3){animation-delay:0.3s;}
.hero-text>*:nth-child(4){animation-delay:0.4s;}

/* RÉVÉLATION AU DÉFILEMENT (ajoutée via JS uniquement → contenu visible si JS désactivé) */
.reveal{opacity:0;transform:translateY(22px) scale(0.99);transition:opacity 0.6s cubic-bezier(0.22,0.61,0.36,1),transform 0.6s cubic-bezier(0.22,0.61,0.36,1);will-change:opacity,transform;}
.reveal.is-visible{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important;}
}

/* RESPONSIVE */
@media(max-width:900px){
  .hero{padding-top:0.5rem;}
  .hero-content{flex-direction:column;text-align:center;padding:1.5rem 5% 3rem;}
  .hero-subtitle{margin-left:auto;margin-right:auto;}
  .hero-actions{justify-content:center;}
  .hero-visual{display:none;}
  .about-grid{grid-template-columns:1fr;}
  .about-visual{min-width:0;width:100%;}
  .process-steps{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .nav-burger{display:flex;}
}
@media(max-width:600px){
  .process-steps{grid-template-columns:1fr;}
  section{padding:3.5rem 5%;}
  .form-row{grid-template-columns:1fr;gap:0;}
  .form-card{padding:1.4rem;}
  .form-submit{width:100%;}
  .admin-tabs{flex-wrap:wrap;}
  .admin-hours-grid{grid-template-columns:80px 1fr 1fr;}
  /* Statistiques : libellés compacts pour faire tenir toutes les barres */
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .stats-chart{gap:3px;}
  .stats-bar-day{font-size:0.5rem;margin-top:4px;}
  .stats-bar-day .lbl-sfx{display:none;}
  .stats-bar-cnt{font-size:0.55rem;}
  /* Atelier */
  .atelier-grid{grid-template-columns:1fr;gap:2rem;}
  /* Hero */
  .hero-title{font-size:clamp(1.5rem,7.5vw,2.2rem);}
  .hero-subtitle{font-size:1rem;}
  /* À propos */
  .about-main-box{padding:1.25rem;width:100%;box-sizing:border-box;}
  .big-number{font-size:2.2rem;}
  .about-chip{font-size:0.75rem;padding:0.3rem 0.6rem;margin:0.2rem;}
  .about-text p{word-break:break-word;overflow-wrap:break-word;}
  .certif-row{gap:0.5rem;}
  .certif-badge{font-size:0.78rem;padding:0.4rem 0.75rem;}
  /* Nav compacte : tout doit tenir, burger compris, sans débordement */
  nav{padding:0 0.85rem;}
  .nav-logo{font-size:1.2rem;white-space:nowrap;}
  .nav-right{gap:0.4rem;}
  .nav-cta{padding:0.45rem 0.7rem;font-size:0.78rem;}
  .nav-cta svg{margin-right:4px;}
  .nav-burger{width:34px;height:34px;}
}
