/* ============================================================
   ONE PROTECT SECURITY — styles.css  v4.0
   Palette : Noir pur · Or #D4AF37 · Accent texte Cormorant
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Montserrat',sans-serif;background:#000;color:#fff;overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:.25s ease}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

:root{
  --gold:#D4AF37;
  --gold-dim:rgba(212,175,55,.14);
  --gold-glow:rgba(212,175,55,.38);
  --black:#000;
  --dark:#080808;
  --g1:#0f0f0f;
  --g2:#161616;
  --g3:#222;
  --g4:#2e2e2e;
  --g5:#3a3a3a;
  --muted:rgba(255,255,255,.58);
  --dim:rgba(255,255,255,.84);
  --max-w:1240px;
  --r:6px;
}

/* ── TYPOGRAPHY ── */
h1{font-size:clamp(2.4rem,5.5vw,5rem);font-weight:900;line-height:1.02;letter-spacing:-.03em}
h2{font-size:clamp(1.8rem,3.5vw,3rem);font-weight:800;letter-spacing:-.025em;line-height:1.1}
h3{font-size:clamp(1rem,2vw,1.5rem);font-weight:700;letter-spacing:-.015em}
h4{font-size:1rem;font-weight:700}
p{line-height:1.85;color:var(--muted)}
.serif{font-family:'Cormorant Garamond',serif;font-style:italic}
.gold{color:var(--gold)}
.white{color:#fff}

/* ── LAYOUT ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
section{padding:5.5rem 0}
.section-label{display:block;font-size:.62rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.85rem}
.divider{width:50px;height:1px;background:var(--gold);margin:1.1rem 0;opacity:.8}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.8rem 2rem;font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r);transition:.3s ease;cursor:pointer;border:2px solid transparent;font-family:inherit;white-space:nowrap}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-gold{background:var(--gold);color:#000;border-color:var(--gold)}
.btn-gold:hover{background:transparent;color:var(--gold);box-shadow:0 0 30px var(--gold-glow);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.06);transform:translateY(-2px)}
.btn-outline-gold{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-outline-gold:hover{background:var(--gold);color:#000;transform:translateY(-2px)}
.btn-black{background:#000;color:#fff;border-color:#000}
.btn-black:hover{background:transparent;color:#000;border-color:#000}
.btn-outline-dark{background:transparent;color:#000;border-color:rgba(0,0,0,.25)}
.btn-outline-dark:hover{background:rgba(0,0,0,.08)}

/* ── PAGE TRANSITION OVERLAY ── */


/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.9rem 0;transition:.35s ease}
header.scrolled{background:rgba(0,0,0,.97);backdrop-filter:blur(24px);padding:.6rem 0;border-bottom:1px solid rgba(212,175,55,.15)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.logo-wrap img{height:64px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 14px rgba(212,175,55,.28));transition:.3s}
.logo-wrap:hover img{filter:drop-shadow(0 4px 22px rgba(212,175,55,.5))}

/* NAV */
.main-nav ul{display:flex;align-items:center;gap:.15rem}
.nav-link{display:block;padding:.48rem .82rem;font-size:.76rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-radius:4px;transition:.2s ease}
.nav-link:hover,.nav-link.active{color:#fff}
.nav-dropdown{position:relative}
.dropdown-toggle{display:flex;align-items:center;gap:.3rem;padding:.48rem .82rem;font-size:.76rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:.2s ease}
.dropdown-toggle:hover{color:#fff}
.dropdown-menu{position:absolute;top:calc(100%+.5rem);left:0;background:rgba(6,6,6,.98);backdrop-filter:blur(20px);border:1px solid rgba(212,175,55,.2);border-radius:10px;padding:.65rem;min-width:235px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:.25s ease;z-index:100}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .9rem;border-radius:6px;font-size:.76rem;font-weight:600;color:var(--muted);transition:.2s ease}
.dropdown-item:hover{background:var(--gold-dim);color:var(--gold)}
.header-actions{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.header-phone{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;color:var(--dim);white-space:nowrap}
.header-phone:hover{color:var(--gold)}
.header-phone svg{color:var(--gold)}
/* phone-2 visibility → see bottom */

/* HAMBURGER */
/* old mobile rules → see bottom */

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:#000}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center top;z-index:0}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,rgba(0,0,0,.88) 0%,rgba(0,0,0,.55) 50%,rgba(0,0,0,.35) 100%)}
.hero-texture{position:absolute;inset:0;z-index:1;background-image:radial-gradient(rgba(212,175,55,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:760px;padding-top:6rem}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem;background:var(--gold-dim);border:1px solid rgba(212,175,55,.25);border-radius:50px;padding:.35rem .9rem}
.hero h1{margin-bottom:1.25rem;text-shadow:0 2px 30px rgba(0,0,0,.6)}
.hero-sub{font-size:1.02rem;color:rgba(255,255,255,.8);max-width:540px;margin-bottom:2.25rem;line-height:1.85}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-strip{display:flex;gap:1px;border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;flex-wrap:wrap}
.hs-item{flex:1;min-width:160px;padding:1rem 1.25rem;border-right:1px solid rgba(255,255,255,.08)}
.hs-item:last-child{border-right:none}
.hs-num{font-size:2rem;font-weight:900;color:var(--gold);line-height:1;letter-spacing:-.04em}
.hs-lbl{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.25rem}

/* ── FEATURES STRIP ── */
.features-strip{background:var(--g1);border-top:1px solid rgba(212,175,55,.15);border-bottom:1px solid rgba(212,175,55,.15)}
.features-strip .container{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.feat-block{padding:2.5rem 2rem;border-right:1px solid var(--g3);display:flex;gap:1.25rem;align-items:flex-start}
.feat-block:last-child{border-right:none}
.feat-icon{width:48px;height:48px;background:var(--gold-dim);border:1px solid rgba(212,175,55,.3);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat-icon svg{width:22px;height:22px;color:var(--gold)}
.feat-block h3{color:#fff;font-size:.9rem;margin-bottom:.35rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase}
.feat-block p{font-size:.79rem;margin:0}

/* ── SERVICE CARDS ── */
.services-section{background:var(--dark)}
.services-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:3rem}
.scard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.scard{background:var(--g1);border:1px solid var(--g3);border-radius:14px;overflow:hidden;transition:.35s ease;cursor:pointer;display:flex;flex-direction:column}
.scard:hover{border-color:rgba(212,175,55,.4);transform:translateY(-6px)}
.scard-photo{height:200px;overflow:hidden;position:relative}
.scard-photo img{width:100%;height:100%;object-fit:cover;transition:.5s ease;filter:brightness(.85)}
.scard:hover .scard-photo img{transform:scale(1.05);filter:brightness(.95)}
.scard-photo-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);pointer-events:none}
.scard-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.scard-body h3{color:#fff;font-size:.95rem;margin-bottom:.4rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase}
.scard-body p{font-size:.78rem;margin:0 0 auto}
.scard-feats{display:flex;flex-direction:column;gap:.3rem;margin:.9rem 0}
.scard-feat{display:flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;color:var(--muted)}
.scard-feat::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0}
.scard-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);transition:.2s ease;margin-top:.5rem}
.scard-link svg{width:12px;height:12px;transition:.2s ease}
.scard-link:hover svg{transform:translateX(3px)}

/* ── ABOUT / WHY ── */
.about-section{background:#000}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:580px}
.about-photo{position:relative;overflow:hidden}
.about-photo img{width:100%;height:100%;object-fit:cover;filter:brightness(.85)}
.about-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,#000 100%)}
.about-content{padding:4.5rem 4rem;display:flex;flex-direction:column;justify-content:center}
.about-feats{display:flex;flex-direction:column;gap:1.25rem;margin:1.75rem 0 2rem}
.ab-feat{display:flex;gap:1rem;align-items:flex-start}
.ab-icon{width:38px;height:38px;background:var(--gold-dim);border:1px solid rgba(212,175,55,.25);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ab-icon svg{width:17px;height:17px;color:var(--gold)}
.ab-feat h4{color:#fff;font-size:.9rem;margin-bottom:.2rem;font-weight:700}
.ab-feat p{font-size:.8rem;margin:0}
.cert-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--gold);color:#000;font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.32rem .9rem;border-radius:50px;margin-bottom:1.25rem}

/* ── DEVIS SECTION ── */
.devis-section{position:relative;overflow:hidden}
.devis-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.devis-bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.9)}
.devis-content{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:center}
.devis-left h2{color:#fff}
.devis-left p{font-size:.88rem;max-width:380px;margin:.8rem 0 2rem}
.devis-reassure{display:flex;flex-direction:column;gap:1rem}
.dr-item{display:flex;gap:.8rem;align-items:center;font-size:.8rem;color:var(--dim)}
.dr-item svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}

/* ── CTA BAND ── */
.cta-band{background:var(--gold);padding:4rem 0;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 130% at 80% 50%,rgba(0,0,0,.1),transparent)}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap;position:relative}
.cta-band-inner h2{color:#000;max-width:560px;margin:0;font-size:clamp(1.4rem,3vw,2.2rem)}
.cta-band-inner p{color:rgba(0,0,0,.65);margin:.5rem 0 0}
.cta-band-actions{display:flex;gap:1rem;flex-wrap:wrap;flex-shrink:0}

/* ── PROCESS ── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.5rem}
.proc-step{background:var(--g2);border:1px solid var(--g3);border-radius:12px;padding:1.5rem;position:relative;overflow:hidden;transition:.25s}
.proc-step:hover{border-color:rgba(212,175,55,.3)}
.proc-num{position:absolute;top:.75rem;right:.9rem;font-size:2.8rem;font-weight:900;color:rgba(212,175,55,.07);line-height:1;letter-spacing:-.05em}
.proc-step svg{width:26px;height:26px;color:var(--gold);margin-bottom:.9rem}
.proc-step h4{color:#fff;font-size:.88rem;margin-bottom:.4rem;font-weight:700}
.proc-step p{font-size:.77rem;margin:0}

/* ── PAGE HERO (inner pages) ── */
.page-hero{padding:9rem 0 4rem;background:var(--dark);border-bottom:1px solid rgba(212,175,55,.15);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(212,175,55,.03) 1px,transparent 1px);background-size:50px 50px}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{margin-bottom:1rem}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb svg{width:10px;height:10px}

/* ── PRESTATION HERO ── */
.presta-hero{padding:9rem 0 5rem;background:var(--dark)}
.presta-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}

/* ── DETAIL CARD ── */
.detail-card{background:var(--g1);border:1px solid var(--g3);border-radius:14px;padding:1.75rem}
.detail-card h4{color:#fff;font-size:.88rem;margin-bottom:.8rem;padding-bottom:.8rem;border-bottom:1px solid var(--g3);text-transform:uppercase;letter-spacing:.05em}
.detail-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.8rem;color:var(--muted);margin-bottom:.5rem}
.detail-list li::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:.55rem}

/* ── FAQ ── */
.faq-block{background:var(--g2);border:1px solid var(--g3);border-radius:12px;padding:1.25rem;margin-top:1.25rem}
.faq-block h4{color:#fff;font-size:.82rem;margin-bottom:.85rem;letter-spacing:.05em;text-transform:uppercase}
.faq-item{border-bottom:1px solid var(--g3)}
.faq-item:last-child{border-bottom:none}
.faq-question{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem .1rem;cursor:pointer;font-size:.78rem;font-weight:700;color:var(--dim);transition:.2s}
.faq-question:hover{color:var(--gold)}
.faq-question svg{width:13px;height:13px;flex-shrink:0;transition:.3s}
.faq-question.open svg{transform:rotate(180deg)}
.faq-answer{display:none;font-size:.76rem;color:var(--muted);line-height:1.75;padding-bottom:.85rem}
.faq-answer.open{display:block}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
.contact-block h3{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.citem{display:flex;gap:1rem;align-items:flex-start;margin-bottom:.85rem}
.cico{width:40px;height:40px;background:var(--gold-dim);border:1px solid rgba(212,175,55,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cico svg{width:18px;height:18px;color:var(--gold)}
.citem h4{color:#fff;font-size:.85rem;margin-bottom:.15rem}
.citem a,.citem p{font-size:.8rem;color:var(--muted);margin:0}
.citem a:hover{color:var(--gold)}
.urg-block{background:var(--gold);border-radius:10px;padding:1.1rem 1.35rem;margin-bottom:1.25rem}
.urg-block h4{color:#000;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:.4rem}
.urg-block a{color:#000;font-size:1.5rem;font-weight:900;letter-spacing:-.02em}
.urg-block p{color:rgba(0,0,0,.6);font-size:.7rem;margin:.2rem 0 0}
.map-embed{border-radius:9px;overflow:hidden;border:1px solid var(--g3);margin-top:.6rem}

/* ── FORMS ── */
.form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg label{font-size:.66rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}
.fg label .req{color:var(--gold)}
.form-input,.form-select,.form-textarea{width:100%;padding:.78rem .95rem;background:var(--g2);border:1px solid var(--g4);border-radius:var(--r);color:#fff;font-family:inherit;font-size:.83rem;transition:.2s ease;outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim)}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(255,255,255,.25)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23D4AF37' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;background-size:12px}
.form-select option{background:#1a1a1a}
.form-textarea{resize:vertical;min-height:120px}
.form-error{font-size:.68rem;color:#ef4444;display:none}
.form-error.visible{display:block}
.form-input.invalid,.form-select.invalid,.form-textarea.invalid{border-color:#ef4444}
.cbg{display:flex;align-items:flex-start;gap:.65rem}
.cbg input[type="checkbox"]{width:16px;height:16px;accent-color:var(--gold);flex-shrink:0;margin-top:2px}
.cbg label{font-size:.76rem;color:var(--muted)}
.cbg a{color:var(--gold)}

/* STEPS */
.steps-indicator{display:flex;background:var(--g2);border-radius:var(--r);overflow:hidden;border:1px solid var(--g3);margin-bottom:2rem}
.step-tab{flex:1;padding:.65rem;text-align:center;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);transition:.25s;cursor:pointer}
.step-tab.active{background:var(--gold);color:#000}
.step-content{display:none}
.step-content.active{display:block}
.step-nav{display:flex;justify-content:space-between;margin-top:1.25rem}

/* FILE UPLOAD */
.file-upload{border:1.5px dashed rgba(212,175,55,.3);border-radius:var(--r);padding:2rem;text-align:center;cursor:pointer;transition:.25s;position:relative}
.file-upload:hover{border-color:var(--gold);background:var(--gold-dim)}
.file-upload input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.file-upload svg{width:26px;height:26px;color:var(--gold);margin:0 auto .6rem}
.file-upload p{font-size:.78rem;color:var(--muted);margin:0}
.file-upload .fi-cta{color:var(--gold);font-weight:700}

/* ── RECRUT CARDS ── */
.rcards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2rem 0 2.5rem}

/* ── CARD ── */
.card{background:var(--g1);border:1px solid var(--g3);border-radius:12px;padding:2rem;transition:.3s;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:.3s}
.card:hover{border-color:rgba(212,175,55,.3);transform:translateY(-4px)}
.card:hover::before{opacity:1}
.card-icon{width:50px;height:50px;background:var(--gold-dim);border:1px solid rgba(212,175,55,.25);border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.card-icon svg{width:23px;height:23px;color:var(--gold)}
.card h3{color:#fff;font-size:1rem;margin-bottom:.4rem}
.card p{font-size:.8rem;margin:0}

/* ── PROMISE GRID ── */
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2rem}
.pc{background:var(--g2);border:1px solid var(--g3);border-radius:12px;padding:1.5rem;text-align:center;transition:.25s}
.pc:hover{border-color:rgba(212,175,55,.3);transform:translateY(-3px)}
.pio{width:46px;height:46px;background:var(--gold-dim);border:1px solid rgba(212,175,55,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto .85rem}
.pio svg{width:21px;height:21px;color:var(--gold)}
.pc h4{color:#fff;font-size:.84rem;margin-bottom:.4rem;font-weight:700}
.pc p{font-size:.76rem;margin:0}

/* ── LEGAL ── */
.legal-body{max-width:820px}
.legal-body h2{font-size:1.3rem;color:#fff;margin:2.5rem 0 .8rem;padding-bottom:.6rem;border-bottom:1px solid var(--g3)}
.legal-body h3{font-size:.95rem;color:var(--gold);margin:1.5rem 0 .6rem}
.legal-body p,.legal-body li{font-size:.86rem;line-height:1.85;color:var(--muted);margin-bottom:.6rem}
.legal-body ul{padding-left:1.3rem;list-style:disc}
.legal-body table{width:100%;border-collapse:collapse;margin:1.1rem 0;font-size:.8rem}
.legal-body th{background:var(--g2);color:#fff;padding:.6rem .85rem;text-align:left;font-size:.68rem;letter-spacing:.07em;text-transform:uppercase}
.legal-body td{padding:.6rem .85rem;border-bottom:1px solid var(--g3);color:var(--muted)}

/* ── FOOTER ── */
footer{background:#000;border-top:1px solid rgba(212,175,55,.15);padding:4.5rem 0 2rem;position:relative}
.footer-glow{position:absolute;top:0;left:50%;transform:translateX(-50%);width:600px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.35}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:3.5rem;margin-bottom:3rem}
.ft-brand a{display:inline-block;margin-bottom:1rem}
.ft-brand img{height:66px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 10px rgba(212,175,55,.2))}
.ft-brand p{font-size:.8rem;max-width:260px;color:var(--muted)}
.ft-siren{font-size:.66rem;color:rgba(255,255,255,.28);margin-top:.5rem !important}
.ft-section h5{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.ft-section ul li{margin-bottom:.5rem}
.ft-section ul a{font-size:.8rem;color:var(--muted);transition:.2s}
.ft-section ul a:hover{color:#fff;padding-left:3px}
.ft-contact-item{display:flex;gap:.65rem;align-items:flex-start;margin-bottom:.75rem}
.ft-contact-item svg{width:13px;height:13px;color:var(--gold);flex-shrink:0;margin-top:3px}
.ft-contact-item strong{font-size:.7rem;color:#fff;display:block;margin-bottom:.15rem}
.ft-contact-item a,.ft-contact-item p{font-size:.78rem;color:var(--muted);margin:0;transition:.2s}
.ft-contact-item a:hover{color:#fff}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;padding-top:1.75rem;border-top:1px solid var(--g3)}
.ft-bottom p{font-size:.72rem;color:rgba(255,255,255,.28)}
.ft-bottom p a{color:rgba(255,255,255,.3)}
.ft-bottom p a:hover{color:var(--gold)}
.ft-legal{display:flex;gap:1.25rem;align-items:center}
.ft-legal a{font-size:.72rem;color:rgba(255,255,255,.3)}
.ft-legal a:hover{color:var(--gold)}
.ft-admin-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.62rem;color:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:.25rem .6rem;transition:.2s}
.ft-admin-btn:hover{color:var(--gold);border-color:rgba(212,175,55,.3)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── TOAST ── */
.toast-container{position:fixed;top:1rem;right:1rem;z-index:99999;display:flex;flex-direction:column;gap:.6rem}
.toast{display:flex;align-items:center;gap:.7rem;background:var(--g1);border:1px solid var(--g3);border-radius:8px;padding:.85rem 1rem;min-width:260px;box-shadow:0 8px 30px rgba(0,0,0,.5);animation:t-in .3s ease-out}
.toast.success{border-color:rgba(34,197,94,.4)}.toast.error{border-color:rgba(239,68,68,.4)}
.toast-icon{font-size:.9rem;flex-shrink:0}
.toast p{font-size:.8rem;color:var(--dim);margin:0}
@keyframes t-in{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes t-out{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}

/* responsive → see bottom of file */.rcards{grid-template-columns:1fr}}


/* ── IMAGE ENHANCEMENTS ─────────────────────────────────────── */
/* Larger service card photos */
.scard-photo { height: 240px; }

/* Grain texture overlay on hero images */
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: .35;
}

/* Dramatic gold shimmer line on page-hero with image */
.page-hero[style*="background:transparent"]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: .5;
  z-index: 2;
}

/* Presta hero with background image */
.presta-hero[style*="background:transparent"] {
  padding-bottom: 5rem;
}
.presta-hero[style*="background:transparent"] h1,
.presta-hero[style*="background:transparent"] p,
.presta-hero[style*="background:transparent"] .section-label,
.presta-hero[style*="background:transparent"] .breadcrumb {
  text-shadow: 0 2px 20px rgba(0,0,0,.5);
}

/* Better about photo overlay */
.about-photo::after {
  background: linear-gradient(
    to right,
    transparent 30%,
    rgba(0,0,0,.5) 65%,
    #000 100%
  );
}

/* Detail image in service pages - cinematic look */
.presta-grid img[style*="filter:brightness"] {
  transition: filter .5s ease, transform .5s ease;
}
.presta-grid img[style*="filter:brightness"]:hover {
  filter: brightness(1) contrast(1.05) !important;
  transform: scale(1.02);
}

/* Stats grid responsive */
@media(max-width:768px) {
    section > div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns: repeat(2,1fr) !important;
  }
}

/* ════════════════════════════════════════════════════
   HEADER, MOBILE MENU & FULL RESPONSIVE — v5.0
   ════════════════════════════════════════════════════ */

/* ── HEADER PHONES ── */
.header-phone {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .76rem;
  font-weight: 700;
  color: var(--dim);
  white-space: nowrap;
  text-decoration: none;
  transition: .2s ease;
}
.header-phone:hover { color: var(--gold); }
.header-phone svg { color: var(--gold); flex-shrink: 0; }
.phone-badge {
  font-style: normal;
  font-size: .56rem;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #000;
  background: var(--gold);
  border-radius: 50px;
  padding: .1rem .4rem;
  flex-shrink: 0;
}
.header-actions {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  flex-shrink: 0;
}

/* ── LOGO ── */
.logo-wrap img {
  height: 62px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 14px rgba(212,175,55,.28));
  transition: .3s;
}
.logo-wrap:hover img { filter: drop-shadow(0 4px 22px rgba(212,175,55,.5)); }

/* ── FOOTER LOGO — 160px centré ── */
.ft-logo-wrap {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: 1.25rem;
}
.ft-logo-img {
  height: 160px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 16px rgba(212,175,55,.25));
  display: block;
}

/* ── HAMBURGER — masqué sur desktop, visible mobile ── */
.hamburger {
  display: none;          /* caché par défaut (desktop) */
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: .45rem .5rem;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 6px;
  cursor: pointer;
  flex-shrink: 0;
  z-index: 1001;
  transition: border-color .2s;
}
.hamburger:hover { border-color: rgba(212,175,55,.5); }
.hamburger span {
  display: block;
  height: 1.5px;
  width: 100%;
  background: #fff;
  border-radius: 2px;
  transition: .3s ease;
  transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── MOBILE MENU PANEL ── */
.mobile-menu {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(360px, 100vw);
  background: #050505;
  border-left: 1px solid rgba(212,175,55,.18);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .38s cubic-bezier(.77,0,.18,1);
  overflow-y: auto;
  /* Always rendered in DOM; JS toggles transform */
}
.mobile-menu.open { transform: translateX(0); }

/* Logo dans le menu mobile : 160px centré */
.mm-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.5rem 1.5rem;
  border-bottom: 1px solid rgba(212,175,55,.15);
  background: rgba(212,175,55,.02);
}
.mm-logo {
  height: 160px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 20px rgba(212,175,55,.35));
  display: block;
}

/* Nav items */
.mobile-menu ul { list-style: none; padding: .5rem 0; margin: 0; flex: 1; }
.mobile-menu ul li { border-bottom: 1px solid rgba(255,255,255,.05); }
.mobile-menu ul li a,
.mobile-menu ul li .mm-sub-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: 1rem 1.5rem;
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: .2s ease;
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: inherit;
  box-sizing: border-box;
}
.mobile-menu ul li a:hover,
.mobile-menu ul li .mm-sub-btn:hover,
.mobile-menu ul li a.active { color: var(--gold); background: rgba(212,175,55,.06); }

/* Sub-menu */
.mm-sub { background: rgba(255,255,255,.02); display: none; list-style: none; padding: 0; }
.mm-sub.open { display: block; }
.mm-has-sub .mm-sub-btn svg { transition: transform .25s; flex-shrink: 0; }
.mm-has-sub .mm-sub-btn[aria-expanded="true"] svg { transform: rotate(180deg); }
.mm-sub li { border-bottom: none; }
.mm-sub li a {
  padding: .7rem 1.5rem .7rem 2.5rem;
  font-size: .8rem;
  font-weight: 600;
  text-transform: none;
  letter-spacing: .02em;
  color: rgba(255,255,255,.5);
}
.mm-sub li a:hover { color: var(--gold); padding-left: 2.75rem; }

/* CTA phones in mobile menu */
.mm-cta {
  padding: 1.25rem 1.5rem;
  border-top: 1px solid rgba(212,175,55,.15);
  display: flex;
  flex-direction: column;
  gap: .65rem;
  background: rgba(212,175,55,.03);
}
.mm-tel {
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
  padding: .7rem 1rem;
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  transition: .2s ease;
}
.mm-tel:hover { background: rgba(212,175,55,.1); border-color: rgba(212,175,55,.3); }
.mm-tel span { font-size: .88rem; font-weight: 800; color: #fff; flex: 1; }
.mm-tel small { font-size: .6rem; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.mm-tel svg { color: var(--gold); flex-shrink: 0; }
.mm-tel-urgent { background: rgba(212,175,55,.08); border-color: rgba(212,175,55,.25); }
.mm-tel-urgent span { color: var(--gold); }

/* Backdrop */
.mm-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 999;
  backdrop-filter: blur(3px);
}
.mm-backdrop.show { display: block; }

/* Footer contact items */
.ft-ci { display: flex; gap: .65rem; align-items: flex-start; margin-bottom: .8rem; font-size: .78rem; }
.ft-ci svg { width: 13px; height: 13px; color: var(--gold); flex-shrink: 0; margin-top: 3px; }
.ft-ci strong { color: #fff; font-size: .7rem; display: block; margin-bottom: .1rem; }
.ft-ci span, .ft-ci a { color: var(--muted); text-decoration: none; }
.ft-ci a:hover { color: #fff; }
.urg-tag { font-style: normal; font-size: .6rem; font-weight: 700; letter-spacing: .06em; color: var(--gold); opacity: .7; }

/* Admin btn in footer */
.ft-admin-btn {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .62rem;
  color: rgba(255,255,255,.2);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 4px;
  padding: .25rem .6rem;
  transition: .2s;
  text-decoration: none;
}
.ft-admin-btn:hover { color: var(--gold); border-color: rgba(212,175,55,.3); }

/* ══════════════════════════════════════════════════════
   BREAKPOINTS COMPLETS
   ══════════════════════════════════════════════════════ */

/* ≥1200px : les deux numéros visibles */
/* Entre 1025px et 1199px : masquer le 2e numéro */
@media (max-width: 1199px) {
  .header-phone-urgent { display: none; }
}

/* ≤1024px : ajustements layout */
@media (max-width: 1024px) {
  .about-grid { grid-template-columns: 1fr; }
  .about-photo { height: 400px; }
  .about-photo::after { background: linear-gradient(to bottom, transparent 60%, #000 100%); }
  .about-content { padding: 3rem 2rem; }
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .presta-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .pg { grid-template-columns: repeat(2,1fr); }
  .process-grid { grid-template-columns: repeat(2,1fr); }
  .devis-content { grid-template-columns: 1fr; }
}

/* ≤768px : MOBILE */
@media (max-width: 768px) {
  /* Hamburger : VISIBLE uniquement ici */
  .hamburger { display: flex; }

  /* Desktop nav + phones : masqués */
  .main-nav { display: none; }
  .header-actions { display: none; }

  /* Logo desktop masqué, titre texte visible */
  .logo-wrap { display: none; }
  
  /* Header layout mobile */
  .header-inner {
    justify-content: space-between;
    align-items: center;
  }

  /* Grilles → 1 colonne */
  .scard-grid,
  .grid-2, .grid-3, .grid-4,
  .ft-grid,
  .rcards { grid-template-columns: 1fr; }

  /* Features strip → 1 colonne */
  .features-strip .container { grid-template-columns: 1fr; }
  .feat-block { border-right: none; border-bottom: 1px solid var(--g3); }
  .feat-block:last-child { border-bottom: none; }

  /* CTA band */
  .cta-band-inner { flex-direction: column; align-items: flex-start; }
  .cta-band-actions { flex-wrap: wrap; }

  /* Hero */
  .hero-btns { flex-direction: column; }
  .hero-strip { flex-direction: column; gap: .5rem; }
  .hs-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); padding: .75rem 1rem; }

  /* Sections padding */
  section { padding: 3rem 0; }
  .page-hero { padding: 7rem 0 2.5rem; }
  .presta-hero { padding: 7rem 0 3rem; }

  /* Forms */
  .form-row { grid-template-columns: 1fr; }
  .steps-indicator { flex-wrap: wrap; }

  /* Promises */
  .pg { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }

  /* Footer brand logo : centré en mobile */
  .ft-logo-wrap { justify-content: center; }

  /* Stats band */
  .stats-grid-4 { grid-template-columns: repeat(2,1fr) !important; }
}

/* ≤480px */
@media (max-width: 480px) {
  .container { padding: 0 1rem; }
  .btn { justify-content: center; width: 100%; }
  .hero h1 { font-size: 2rem; }
  h2 { font-size: 1.6rem; }
  .rcards { grid-template-columns: 1fr; }
  .scard-grid { grid-template-columns: 1fr; }
}

/* ── MOBILE SITE TITLE ── */
.mobile-site-title {
  display: none;
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  flex: 1;
  padding: 0 .75rem;
}
@media (max-width: 768px) {
  .mobile-site-title { display: block; }
}


/* 1. Base: toutes les images sont centrées et conservent leur ratio */
img {
  max-width: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
}

/* 2. Fond placeholder pendant le chargement (effet shimmer) */
img:not([src=""]):not([src="undefined"]) {
  background: linear-gradient(90deg, var(--g2) 25%, var(--g3) 50%, var(--g2) 75%);
  background-size: 200% 100%;
  animation: img-shimmer 1.5s infinite;
}
img.loaded, img[loading="eager"] {
  background: none;
  animation: none;
}
@keyframes img-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* 3. Transition douce à l'apparition */
img {
  transition: opacity .4s ease, filter .4s ease, transform .4s ease;
  opacity: 1;
}
img.lazyload { opacity: 0; }
img.lazyloaded { opacity: 1; }

/* 4. Hero background: centré, couvre toujours */
.hero-img {
  position: absolute;
  inset: 0;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  z-index: 0;
  transition: background-position .6s ease;
}

/* 5. Service cards photo: hauteur fixe, image bien cadrée */
.scard-photo {
  height: 220px;
  overflow: hidden;
  position: relative;
  background: var(--g2);
}
.scard-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform .5s ease, filter .4s ease;
  filter: brightness(.85) saturate(.9);
  display: block;
}
.scard:hover .scard-photo img {
  transform: scale(1.06);
  filter: brightness(.95) saturate(1.05);
}

/* 6. About / équipe photo */
.about-photo {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}
.about-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  filter: brightness(.85);
  display: block;
}

/* 7. Galerie images */
.galerie-item img,
.galerie-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  filter: brightness(.7) saturate(.85);
  transition: filter .5s ease, transform .5s ease;
  display: block;
}
.galerie-item:hover img {
  filter: brightness(.85) saturate(1);
  transform: scale(1.04);
}

/* 8. Prestation detail image (page prestation) */
.presta-grid img {
  width: 100%;
  border-radius: 10px;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: filter .4s ease;
}

/* 9. Background images (déjà chargées via url()) */
[style*="background-image"] {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

/* 10. Recrutement equipe photo */
.recrut-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
}

/* 11. Logo : toujours contenu, jamais rogné */
.logo-wrap img,
.mm-logo,
.ft-logo-img,
#header-logo {
  object-fit: contain !important;
  object-position: center center !important;
}

/* ── MOBILE IMAGES ─────────────────────────────────── */
@media (max-width: 1024px) {
  .scard-photo { height: 200px; }
  .about-photo { height: 350px; }
}

@media (max-width: 768px) {
  /* Hero: position plus haute sur mobile pour capter le sujet */
  .hero-img {
    background-position: center 30% !important;
  }
  /* Service cards: légèrement moins hautes */
  .scard-photo { height: 180px; }
  /* About section: hauteur limitée */
  .about-photo { height: 280px; }
  /* Galerie: images carrées sur mobile */
  .galerie-item { aspect-ratio: 1 / 1; overflow: hidden; }
  .galerie-item img { height: 100%; }
  /* Page prestation hero */
  .page-hero [style*="background-image"] {
    background-position: center 25% !important;
  }
  /* Presta grid: image pleine largeur */
  .presta-grid img {
    height: 250px;
    width: 100%;
  }
}

@media (max-width: 480px) {
  .scard-photo { height: 160px; }
  .about-photo { height: 220px; }
  .presta-grid img { height: 200px; }
}
/* ═══════════════════════════════════════════════════════════════
   IMAGE OPTIMIZATION — centrage, couverture, fluidité, mobile
   ═══════════════════════════════════════════════════════════════ */

/* Base: toutes les images couvrent leur conteneur */
img { max-width:100%; display:block; }

/* Transition douce chargement */
img[loading="lazy"] { opacity:0; transition:opacity .45s ease; }
img[loading="lazy"].loaded { opacity:1; }
img[loading="eager"] { opacity:1; }

/* ── HERO BACKGROUND (background-image) ── */
.hero-img {
  position:absolute; inset:0; z-index:0;
  background-size:cover !important;
  background-position:center top !important;
  background-repeat:no-repeat !important;
  transition:background-position .6s ease;
}

/* ── SERVICE CARDS ── */
.scard-photo {
  height:220px;
  overflow:hidden;
  position:relative;
  background:var(--g2);
  flex-shrink:0;
}
.scard-photo img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center center;
  transition:transform .5s ease, filter .4s ease;
  filter:brightness(.85) saturate(.9);
  display:block;
}
.scard:hover .scard-photo img {
  transform:scale(1.06);
  filter:brightness(.95) saturate(1.05);
}
.scard-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%);
  pointer-events:none;
}

/* ── ABOUT SECTION ── */
.about-photo {
  position:relative;
  overflow:hidden;
  border-radius:12px;
  min-height:480px;
}
.about-photo img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 25%;
  filter:brightness(.85);
  display:block;
}

/* ── GALERIE ── */
.galerie-item {
  overflow:hidden;
  position:relative;
}
.galerie-item img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center center;
  filter:brightness(.75) saturate(.85);
  transition:filter .5s ease, transform .5s ease;
  display:block;
}
.galerie-item:hover img {
  filter:brightness(.9) saturate(1);
  transform:scale(1.04);
}

/* ── PRESTATION DETAIL PAGES ── */
.presta-grid img,
.presta-detail-img {
  width:100%;
  border-radius:10px;
  object-fit:cover;
  object-position:center center;
  display:block;
  transition:filter .4s ease;
}

/* ── RECRUTEMENT PHOTO ── */
.recrut-visual img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 35%;
  display:block;
}

/* ── LOGO: toujours contain ── */
.logo-wrap img, .mm-logo, .ft-logo-img, #header-logo {
  object-fit:contain !important;
  object-position:center center !important;
}

/* ── BACKGROUND-IMAGE generiques ── */
[style*="background-image"] {
  background-size:cover !important;
  background-repeat:no-repeat !important;
}

/* ═══════════════════════════════════
   MOBILE — breakpoints par image
   ═══════════════════════════════════ */

/* ≤1200px */
@media (max-width:1200px) {
  .scard-photo { height:200px; }
}

/* ≤1024px */
@media (max-width:1024px) {
  .scard-photo { height:190px; }
  .about-photo { height:380px; }
  .presta-grid img { max-height:400px; }
}

/* ≤768px */
@media (max-width:768px) {
  /* Hero: remonte le sujet (visages en haut) */
  .hero-img {
    background-position:center 15% !important;
  }
  /* Cartes services */
  .scard-photo { height:180px; }
  /* About portrait → hauteur fixe */
  .about-photo { height:320px; }
  .about-photo img { object-position:center 20%; }
  /* Galerie: carré parfait */
  .galerie-item {
    aspect-ratio:1/1;
    height:auto;
  }
  /* Prestation */
  .presta-grid img {
    height:260px;
    max-height:260px;
    border-radius:8px;
  }
  /* Recrutement équipe */
  .recrut-visual { height:280px; overflow:hidden; border-radius:10px; }
  .recrut-visual img { object-position:center 30%; }
  /* Devis hero (portrait) */
  .devis-bg { background-position:center 10% !important; }
}

/* ≤480px */
@media (max-width:480px) {
  .scard-photo { height:160px; }
  .about-photo { height:240px; }
  .about-photo img { object-position:center 15%; }
  .presta-grid img { height:210px; max-height:210px; }
  .recrut-visual { height:220px; }
  .galerie-item { aspect-ratio:4/3; }
}
