/*
Theme Name: Le P'tit Mécanicien
Theme URI: https://www.le-ptit-mecanicien.fr
Author: Corentin
Description: Thème sur-mesure pour Le P'tit Mécanicien — Mécanicien automobile à domicile
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: leptitmecanicien
*/

/* ─── TOKENS ─── */
:root{
  --y:#F5E100;--yd:#c9b800;--k:#0a0a0a;--k2:#141414;--k3:#1e1e1e;
  --w:#ffffff;--g:#8a8a8a;--g2:#3a3a3a;
  --r:'Bebas Neue',sans-serif;--b:'Barlow',sans-serif;--bc:'Barlow Condensed',sans-serif;
}

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--b);background:var(--k);color:var(--w);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ─── TOPBAR ─── */
.topbar{background:var(--y);color:var(--k);text-align:center;padding:8px 16px;font-family:var(--bc);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.topbar a{color:var(--k);text-decoration:underline}

/* ─── HEADER ─── */
header.site-header{position:sticky;top:0;z-index:500;background:rgba(10,10,10,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--g2)}
.hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;max-width:1200px;margin:0 auto}
.logo-wrap{display:flex;align-items:center;gap:14px}
.logo-img-ring{width:80px;height:80px;border-radius:50%;border:2px solid var(--y);overflow:hidden;flex-shrink:0;background:var(--k2);display:flex;align-items:center;justify-content:center}
.logo-img-ring img{width:70px;height:70px;object-fit:contain;border-radius:50%}
.logo-text{line-height:1.1}
.logo-name{font-family:var(--r);font-size:22px;letter-spacing:1px;color:var(--w)}
.logo-sub{font-family:var(--bc);font-size:10px;letter-spacing:3px;color:var(--y);text-transform:uppercase;font-weight:700}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-family:var(--bc);font-weight:700;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;padding:8px 14px;color:var(--g);border-radius:4px;transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.current-menu-item{color:var(--w);background:var(--k3)}
.nav-cta{background:var(--y)!important;color:var(--k)!important;padding:9px 20px!important;border-radius:4px!important;font-weight:900!important}
.nav-cta:hover{background:var(--yd)!important;color:var(--k)!important}
.hamburger{display:none;background:none;border:none;color:var(--w);font-size:26px;cursor:pointer;padding:4px}

/* ─── HERO ─── */
.hero{min-height:92vh;display:grid;grid-template-columns:1fr 430px;gap:0;align-items:stretch;overflow:hidden;position:relative}
.hero::after{content:'';position:absolute;top:0;bottom:0;left:calc(100% - 430px - 60px);width:120px;background:var(--k);clip-path:polygon(60px 0,100% 0,100% 100%,0 100%);z-index:2;pointer-events:none}
.hero-left{background:var(--k);display:flex;flex-direction:column;justify-content:center;padding:80px 60px 80px 60px;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--bc);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--y);margin-bottom:20px}
.hero-eyebrow::before{content:'';display:block;width:32px;height:2px;background:var(--y)}
.hero-h1{font-family:var(--r);font-size:clamp(64px,8vw,110px);line-height:.92;letter-spacing:1px;margin-bottom:28px}
.hero-h1 .line-y{color:var(--y);display:block}
.hero-h1 .line-w{color:var(--w);display:block}
.hero-h1 .line-outline{-webkit-text-stroke:2px var(--g2);color:transparent;display:block;font-size:clamp(72px,9vw,120px)}
.hero-desc{font-size:17px;color:var(--g);max-width:500px;line-height:1.75;margin-bottom:36px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.btn-y{background:var(--y);color:var(--k);padding:15px 32px;font-family:var(--bc);font-weight:900;font-size:15px;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));transition:background .2s,transform .15s;display:inline-block}
.btn-y:hover{background:var(--yd);transform:translateY(-2px);color:var(--k)}
.btn-ghost{border:1.5px solid var(--g2);color:var(--w);padding:15px 32px;font-family:var(--bc);font-weight:700;font-size:15px;letter-spacing:1.5px;text-transform:uppercase;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));transition:border-color .2s,color .2s;display:inline-block}
.btn-ghost:hover{border-color:var(--y);color:var(--y)}
.hero-pills{display:flex;flex-wrap:wrap;gap:12px}
.pill{border:1px solid var(--g2);color:var(--g);padding:6px 14px;border-radius:2px;font-family:var(--bc);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.pill .dot{color:var(--y);margin-right:5px}

/* ─── HERO FORM ─── */
.hero-right{background:var(--k2);display:flex;flex-direction:column;justify-content:center;padding:60px 40px;position:relative;z-index:3;border-left:1px solid var(--g2)}
.form-heading{font-family:var(--r);font-size:32px;color:var(--w);letter-spacing:1px;margin-bottom:4px}
.form-sub{font-size:13px;color:var(--g);margin-bottom:28px;font-family:var(--bc);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.form-sub span{color:var(--y)}
.fg{margin-bottom:14px}
.fg label{display:block;font-family:var(--bc);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;background:var(--k3);border:1px solid var(--g2);color:var(--w);padding:12px 14px;font-family:var(--b);font-size:14px;outline:none;border-radius:0;transition:border-color .2s;-webkit-appearance:none}
.fg select option{background:var(--k3)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--y)}
.btn-submit-form{width:100%;background:var(--y);color:var(--k);border:none;padding:15px;font-family:var(--bc);font-size:15px;font-weight:900;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));margin-top:6px}
.btn-submit-form:hover{background:var(--yd);transform:translateY(-1px)}
.form-note{text-align:center;font-size:12px;color:var(--g2);margin-top:10px;font-family:var(--bc);letter-spacing:.5px;text-transform:uppercase}
.form-success{display:none;text-align:center;padding:32px 0}
.form-success .fs-icon{font-size:52px;margin-bottom:16px}
.form-success strong{font-family:var(--r);font-size:28px;letter-spacing:1px;color:var(--y)}
.form-success p{color:var(--g);font-size:14px;margin-top:8px}

/* ─── MARQUEE ─── */
.marquee-band{background:var(--y);padding:14px 0;overflow:hidden;white-space:nowrap}
.marquee-inner{display:inline-flex;animation:marquee 20s linear infinite}
.marquee-inner span{font-family:var(--r);font-size:20px;color:var(--k);letter-spacing:2px;padding:0 32px}
.marquee-inner span::after{content:'◆';margin-left:32px;font-size:10px;vertical-align:middle}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── STATS ─── */
.stats-band{background:var(--k2);border-top:1px solid var(--g2);border-bottom:1px solid var(--g2)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto}
.stat{padding:44px 32px;text-align:center;border-right:1px solid var(--g2);position:relative;overflow:hidden}
.stat:last-child{border-right:none}
.stat::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--y);transform:scaleX(0);transition:transform .3s}
.stat:hover::before{transform:scaleX(1)}
.stat-n{font-family:var(--r);font-size:60px;color:var(--y);line-height:1;margin-bottom:6px;letter-spacing:1px}
.stat-l{font-family:var(--bc);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--g);font-weight:700}

/* ─── SECTIONS ─── */
.section{padding:100px 0}
.section-alt{background:var(--k2)}
.eyebrow{font-family:var(--bc);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--y);display:flex;align-items:center;gap:12px;margin-bottom:16px}
.eyebrow::before{content:'';display:block;width:24px;height:2px;background:var(--y)}
.section-title{font-family:var(--r);font-size:clamp(42px,5vw,72px);line-height:.95;letter-spacing:1px;margin-bottom:16px}
.section-title .y{color:var(--y)}
.section-desc{font-size:16px;color:var(--g);max-width:560px;line-height:1.75;margin-bottom:56px}
.center .eyebrow{justify-content:center}
.center .section-title,.center .section-desc{text-align:center;margin-left:auto;margin-right:auto}

/* ─── SERVICES GRID ─── */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--g2)}
.svc{padding:32px 24px;border-right:1px solid var(--g2);border-bottom:1px solid var(--g2);position:relative;overflow:hidden;transition:background .2s;cursor:default}
.svc:nth-child(4n){border-right:none}
.svc:hover{background:var(--k2)}
.svc::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--y);transition:height .3s}
.svc:hover::before{height:100%}
.svc-num{font-family:var(--r);font-size:48px;color:var(--g2);line-height:1;margin-bottom:16px;transition:color .2s}
.svc:hover .svc-num{color:var(--y)}
.svc-icon-box{width:64px;height:64px;background:rgba(245,225,0,.08);border:1px solid rgba(245,225,0,.2);display:flex;align-items:center;justify-content:center;margin-bottom:16px;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));transition:background .2s}
.svc:hover .svc-icon-box{background:rgba(245,225,0,.15)}
.svc h3{font-family:var(--bc);font-size:18px;font-weight:900;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;color:var(--w)}
.svc p{font-size:13.5px;color:var(--g);line-height:1.6}

/* ─── ABOUT ─── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-main-box{border:1px solid var(--g2);aspect-ratio:1;position:relative;overflow:hidden}
.about-main-box img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%) contrast(1.05);transition:transform .5s ease}
.about-main-box:hover img{transform:scale(1.03)}
.about-main-box::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,transparent 60%,rgba(245,225,0,.08) 100%);pointer-events:none}
.about-sticker{position:absolute;bottom:-24px;right:-24px;background:var(--y);color:var(--k);width:110px;height:110px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-family:var(--bc);font-weight:900;padding:12px;border:4px solid var(--k);box-shadow:0 0 0 1px var(--y)}
.about-sticker .big{font-family:var(--r);font-size:32px;line-height:1;color:var(--k)}
.about-sticker .sm{font-size:11px;letter-spacing:1px;text-transform:uppercase;line-height:1.2;color:var(--k);font-weight:700}
.about-content .section-desc{margin-bottom:32px}
.about-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.about-list li{display:flex;align-items:flex-start;gap:14px;font-size:15px;color:var(--g);line-height:1.6}
.about-list li::before{content:'→';color:var(--y);font-weight:900;font-family:var(--bc);flex-shrink:0;margin-top:2px}

/* ─── ÉTAPES ─── */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--g2)}
.step-item{padding:40px 28px;border-right:1px solid var(--g2);position:relative}
.step-item:last-child{border-right:none}
.step-item::before{content:attr(data-n);font-family:var(--r);font-size:90px;color:var(--k3);position:absolute;top:16px;right:16px;line-height:1;z-index:0;transition:color .3s}
.step-item:hover::before{color:var(--g2)}
.step-bullet{width:52px;height:52px;background:var(--y);color:var(--k);font-family:var(--r);font-size:28px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;position:relative;z-index:1}
.step-item:nth-child(even) .step-bullet{background:var(--k3);color:var(--y);border:1px solid var(--y)}
.step-item h3{font-family:var(--bc);font-size:18px;font-weight:900;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;position:relative;z-index:1}
.step-item p{font-size:14px;color:var(--g);position:relative;z-index:1;line-height:1.65}

/* ─── AVIS ─── */
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.avis-card{background:var(--k2);border:1px solid var(--g2);padding:28px;position:relative;overflow:hidden;transition:border-color .2s}
.avis-card::before{content:'"';position:absolute;top:-20px;left:16px;font-family:var(--r);font-size:140px;color:var(--k3);line-height:1;z-index:0}
.avis-card:hover{border-color:var(--y)}
.stars{color:var(--y);font-size:16px;margin-bottom:14px;position:relative;z-index:1}
.avis-text{font-size:15px;color:var(--g);line-height:1.7;margin-bottom:20px;font-style:italic;position:relative;z-index:1}
.avis-author{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.av-circle{width:40px;height:40px;background:var(--y);color:var(--k);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--r);font-size:20px;flex-shrink:0}
.av-circle.alt{background:var(--k3);color:var(--y);border:1px solid var(--y)}
.avis-author strong{display:block;font-size:14px;font-weight:700;font-family:var(--bc);text-transform:uppercase;letter-spacing:.5px}
.avis-author span{font-size:12px;color:var(--g2)}

/* ─── CTA BANDE ─── */
.cta-bande{background:var(--y);padding:80px 0;position:relative;overflow:hidden}
.cta-bande::before{content:'DEVIS GRATUIT';position:absolute;font-family:var(--r);font-size:200px;color:rgba(0,0,0,.05);top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none}
.cta-inner{text-align:center;position:relative;z-index:1}
.cta-inner .section-title{color:var(--k)}
.cta-inner p{color:rgba(0,0,0,.6);font-size:17px;margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto}
.btn-dark{background:var(--k);color:var(--y);padding:16px 38px;font-family:var(--bc);font-weight:900;font-size:16px;letter-spacing:2px;text-transform:uppercase;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));display:inline-block;transition:background .2s,color .2s}
.btn-dark:hover{background:#1a1a1a;color:var(--w)}

/* ─── CONTACT ─── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.contact-list li{display:flex;align-items:flex-start;gap:18px;padding-bottom:20px;border-bottom:1px solid var(--g2)}
.contact-list li:last-child{border-bottom:none}
.c-icon-box{width:44px;height:44px;background:var(--y);color:var(--k);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px))}
.c-label{font-family:var(--bc);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g);font-weight:700;display:block;margin-bottom:3px}
.c-val{font-size:15px;color:var(--w)}
.contact-form{background:var(--k2);border:1px solid var(--g2);padding:36px}
.contact-form h3{font-family:var(--r);font-size:30px;letter-spacing:1px;margin-bottom:24px}
.cfg{margin-bottom:14px}
.cfg label{display:block;font-family:var(--bc);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:6px}
.cfg input,.cfg textarea{width:100%;background:var(--k3);border:1px solid var(--g2);color:var(--w);padding:12px 14px;font-family:var(--b);font-size:14px;outline:none;transition:border-color .2s}
.cfg input:focus,.cfg textarea:focus{border-color:var(--y)}
.btn-cf{width:100%;background:var(--y);color:var(--k);border:none;padding:14px;font-family:var(--bc);font-size:14px;font-weight:900;letter-spacing:2px;text-transform:uppercase;cursor:pointer;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));transition:background .2s}
.btn-cf:hover{background:var(--yd)}

/* ─── FOOTER ─── */
footer.site-footer{background:var(--k);border-top:1px solid var(--g2);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:56px;margin-bottom:48px}
.footer-brand{max-width:320px}
.footer-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.footer-logo-ring{width:48px;height:48px;border-radius:50%;border:2px solid var(--y);background:var(--k2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.footer-logo-ring img{width:44px;height:44px;object-fit:contain;border-radius:50%}
.footer-brand-name{font-family:var(--r);font-size:20px;letter-spacing:1px}
.footer-brand p{font-size:14px;color:var(--g);line-height:1.7}
footer h4{font-family:var(--bc);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--y);margin-bottom:18px}
footer ul{list-style:none}
footer ul li{margin-bottom:10px}
footer ul a{font-size:14px;color:var(--g);transition:color .2s}
footer ul a:hover{color:var(--y)}
.footer-bottom{border-top:1px solid var(--g2);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--g2);font-family:var(--bc);letter-spacing:.5px;text-transform:uppercase}

/* ─── PAGE PRESTATIONS ─── */
.page-hero{background:linear-gradient(160deg,#0d0d0d 0%,#1a1a2e 100%);padding:80px 0 60px;border-bottom:1px solid var(--g2)}
.page-hero h1{font-family:var(--r);font-size:clamp(52px,7vw,90px);line-height:.95;letter-spacing:1px;margin-bottom:16px}
.page-hero h1 .y{color:var(--y)}
.page-hero p{font-size:17px;color:var(--g);max-width:560px;line-height:1.75}
.svc-detail{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--g2);margin-bottom:2px}
.svc-detail:nth-child(even){direction:rtl}
.svc-detail:nth-child(even)>*{direction:ltr}
.svc-detail-img{overflow:hidden;aspect-ratio:16/9}
.svc-detail-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);transition:transform .5s,filter .4s}
.svc-detail:hover .svc-detail-img img{transform:scale(1.04);filter:grayscale(0%)}
.svc-detail-content{padding:40px;display:flex;flex-direction:column;justify-content:center;background:var(--k2);border-left:1px solid var(--g2)}
.svc-detail:nth-child(even) .svc-detail-content{border-left:none;border-right:1px solid var(--g2)}
.svc-tag{display:inline-block;font-family:var(--bc);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--y);border:1px solid rgba(245,225,0,.3);padding:4px 12px;margin-bottom:16px}
.svc-detail-content h2{font-family:var(--r);font-size:36px;letter-spacing:.5px;margin-bottom:12px}
.svc-detail-content p{font-size:15px;color:var(--g);line-height:1.75;margin-bottom:20px}
.svc-detail-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.svc-detail-list li{font-size:14px;color:var(--g);display:flex;align-items:center;gap:10px}
.svc-detail-list li::before{content:'→';color:var(--y);font-weight:900;font-family:var(--bc);flex-shrink:0}

/* ─── ANIMATIONS ─── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero::after{display:none}
  .hero-left{padding:60px 0 40px}
  .hero-right{border-left:none;border-top:1px solid var(--g2)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .svc:nth-child(2n){border-right:none}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .step-item:nth-child(2){border-right:none}
  .avis-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .svc-detail{grid-template-columns:1fr}
  .svc-detail:nth-child(even){direction:ltr}
  .svc-detail-content{border-left:none!important;border-right:none!important;border-top:1px solid var(--g2)}
}
@media(max-width:640px){
  .nav-links a:not(.nav-cta){display:none}
  .hamburger{display:block}
  .services-grid{grid-template-columns:1fr}
  .svc{border-right:none}
  .steps-grid{grid-template-columns:1fr}
  .step-item{border-right:none}
  .stats-inner{grid-template-columns:1fr 1fr}
  .hero-h1{font-size:58px}
  .section-title{font-size:38px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
}
nav.open{position:absolute;top:100%;left:0;right:0;background:var(--k);border-bottom:1px solid var(--g2);padding:16px 20px;display:flex!important;flex-direction:column;align-items:stretch;gap:4px}
nav.open a{display:block!important;padding:12px 16px}
