/* ==========================================================================
   PURE — Optique Artisanat Français
   Charte : corail #f48980 · rose #fabfba · indigo #5253a4
   Typo  : Cormorant Garamond (display) + Jost (texte)
   ========================================================================== */

:root{
  --corail:#f48980;
  --rose:#fabfba;
  --indigo:#5253a4;
  --encre:#2e2f5b;          /* indigo profond, texte */
  --ivoire:#fdf7f4;         /* fond chaud dérivé du rose */
  --blanc:#ffffff;
  --rose-pale:#fdeae8;
  --trait:#e7d8d4;

  --font-display:"Cormorant Garamond", Georgia, serif;
  --font-body:"Jost", "Century Gothic", sans-serif;

  --maxw:1180px;
  --radius:14px;
  --transition:.35s cubic-bezier(.25,.8,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-weight:300;
  font-size:17px;
  line-height:1.65;
  color:var(--encre);
  background:var(--ivoire);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--indigo);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--corail)}
a:focus-visible,button:focus-visible{outline:2px solid var(--indigo);outline-offset:3px}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Typographie ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:500;color:var(--encre);line-height:1.12}
h1{font-size:clamp(2rem,5vw,3.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem)}
h3{font-size:1.5rem}
h1 em,h2 em{font-style:italic;color:var(--indigo)}
.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.78rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;
  color:var(--corail);margin-bottom:18px;
}
.eyebrow::before{content:"";width:42px;height:1px;background:var(--corail)}
.lead{font-size:1.18rem;font-weight:300;color:#55567f;max-width:62ch}

/* Filet de cotation — motif signature "plan d'atelier" */
.cote{
  position:relative;display:block;width:120px;height:14px;margin:26px 0 0;
}
.cote::before{content:"";position:absolute;left:0;right:0;top:7px;height:1px;background:var(--indigo);opacity:.5}
.cote::after{
  content:"";position:absolute;top:2px;width:1px;height:11px;background:var(--indigo);opacity:.5;
  box-shadow:119px 0 0 var(--indigo);
}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  background:rgba(253,247,244,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.site-header.scrolled{border-bottom-color:var(--trait);box-shadow:0 6px 30px rgba(82,83,164,.07)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.logo{display:flex;flex-direction:column;line-height:1}
.logo strong{
  font-family:var(--font-display);font-size:2rem;font-weight:600;
  letter-spacing:.14em;color:var(--encre);
}
.logo strong span{color:var(--corail)}
.logo small{
  font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--indigo);margin-top:4px;font-weight:400;
}
.main-nav ul{display:flex;gap:34px;list-style:none;align-items:center}
.main-nav a{
  font-size:.82rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;
  color:var(--encre);position:relative;padding:6px 0;
}
.main-nav a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--corail);transition:width var(--transition);
}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.main-nav a.active{color:var(--indigo)}
.nav-cta{
  background:var(--indigo);color:var(--blanc)!important;
  padding:12px 24px!important;border-radius:50px;
  transition:background var(--transition), transform var(--transition);
}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--corail);transform:translateY(-2px)}

.burger{
  display:none;background:none;border:0;cursor:pointer;
  width:42px;height:42px;position:relative;z-index:110;
}
.burger span{
  display:block;width:26px;height:2px;background:var(--encre);
  margin:6px auto;transition:var(--transition);
}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:140px 0 80px;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:-220px;right:-180px;width:640px;height:640px;
  border-radius:50%;background:radial-gradient(circle, var(--rose) 0%, transparent 68%);
  opacity:.55;pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero-text .baseline{
  font-size:.8rem;letter-spacing:.4em;text-transform:uppercase;color:var(--indigo);
  margin:26px 0 36px;font-weight:400;
}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:8px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 34px;border-radius:50px;font-size:.85rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:1px solid transparent;
  transition:var(--transition);
}
.btn-primary{background:var(--corail);color:var(--blanc)}
.btn-primary:hover{background:var(--indigo);color:var(--blanc);transform:translateY(-2px)}
.btn-ghost{border-color:var(--indigo);color:var(--indigo);background:transparent}
.btn-ghost:hover{background:var(--indigo);color:var(--blanc)}

/* Dessin technique (signature) */
.blueprint{position:relative}
.blueprint svg{width:100%;height:auto}
.blueprint .draw{
  fill:none;stroke:var(--indigo);stroke-width:2.2;stroke-linecap:round;
  stroke-dasharray:1600;stroke-dashoffset:1600;
  animation:draw 2.8s ease forwards .4s;
}
.blueprint .lens{fill:var(--corail);opacity:0;animation:fadein 1.2s ease forwards 2.4s}
.blueprint .dim{
  stroke:var(--corail);stroke-width:1;fill:none;opacity:0;
  animation:fadein 1s ease forwards 2.8s;
}
.blueprint text{
  font-family:var(--font-body);font-size:11px;letter-spacing:.18em;
  fill:var(--indigo);text-transform:uppercase;opacity:0;
  animation:fadein 1s ease forwards 3s;
}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes fadein{to{opacity:1}}
@media (prefers-reduced-motion:reduce){
  .blueprint .draw{animation:none;stroke-dashoffset:0}
  .blueprint .lens,.blueprint .dim,.blueprint text{animation:none;opacity:1}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}

/* ---------- Sections ---------- */
.section{padding:110px 0}
.section-rose{background:linear-gradient(180deg,var(--rose-pale) 0%, var(--ivoire) 100%)}
.section-indigo{background:var(--encre);color:var(--rose-pale)}
.section-indigo h2,.section-indigo h3{color:var(--blanc)}
.section-indigo .lead{color:#cfd0ee}
.section-head{max-width:720px;margin-bottom:64px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}

/* Cartes */
.card{
  background:var(--blanc);border:1px solid var(--trait);border-radius:var(--radius);
  padding:38px 32px;transition:transform var(--transition), box-shadow var(--transition);
}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(82,83,164,.12)}
.card .pictoline{width:54px;height:54px;margin-bottom:22px}
.card .pictoline svg{width:100%;height:100%;fill:none;stroke:var(--corail);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.card h3{margin-bottom:12px;font-size:1.45rem}
.card p{font-size:.98rem;color:#55567f}
.card .more{display:inline-block;margin-top:18px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500}

/* Photos atelier — cadres élégants avec fallback illustré */
.photo{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,var(--rose) 0%, var(--indigo) 130%);
  aspect-ratio:4/3;
}
.photo.portrait{aspect-ratio:3/4}
.photo img{width:100%;height:100%;object-fit:cover}
.photo::after{
  content:attr(data-legende);position:absolute;left:18px;bottom:14px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blanc);
  text-shadow:0 1px 8px rgba(46,47,91,.5);
}
.photo.is-placeholder img{display:none}
.photo.is-placeholder::before{
  content:"◯—◯";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:2.6rem;color:rgba(255,255,255,.85);letter-spacing:.1em;
}
.photo-frame{position:relative}
.photo-frame::before{
  content:"";position:absolute;inset:-16px 16px 16px -16px;border:1px solid var(--corail);
  border-radius:var(--radius);pointer-events:none;
}

/* Chiffres / engagements */
.engagements{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;text-align:center}
.engagements .num{
  font-family:var(--font-display);font-size:3.4rem;font-weight:500;color:var(--corail);line-height:1;
}
.engagements .label{
  font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;margin-top:10px;color:inherit;
}

/* Marques */
.marques{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.marque{
  border:1px solid var(--trait);border-radius:var(--radius);background:var(--blanc);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;
  padding:42px 20px;transition:var(--transition);
}
.marque:hover{border-color:var(--corail);transform:translateY(-4px)}
.marque strong{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.16em;font-weight:600}
.marque small{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--corail)}
.marque img{max-height:52px;width:auto;max-width:100%;object-fit:contain;display:block}
@media (max-width:520px){.marque img{max-height:40px}}

/* Boutiques */
.boutique-card{
  display:grid;grid-template-columns:1fr 1fr;border-radius:var(--radius);overflow:hidden;
  background:var(--blanc);border:1px solid var(--trait);
}
.boutique-card .infos{padding:46px 42px}
.boutique-card h3{font-size:1.9rem;margin-bottom:6px}
.boutique-card .ville{color:var(--corail);font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500}
.boutique-card address{font-style:normal;margin:20px 0;color:#55567f;font-size:.98rem}
.boutique-card .tel{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--encre);display:inline-block;margin-bottom:18px}

/* Horaires */
.horaires{width:100%;border-collapse:collapse;font-size:.95rem}
.horaires td{padding:9px 0;border-bottom:1px dashed var(--trait)}
.horaires td:last-child{text-align:right;color:#55567f}
.horaires tr.ferme td:last-child{color:var(--corail);letter-spacing:.08em}

/* Bandeau CTA */
.cta-band{
  background:linear-gradient(120deg,var(--indigo) 0%, #3c3d86 100%);
  border-radius:calc(var(--radius) + 8px);padding:70px 60px;color:var(--blanc);
  display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;right:-90px;top:-90px;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle, var(--corail) 0%, transparent 70%);opacity:.45;
}
.cta-band h2{color:var(--blanc);font-size:clamp(1.7rem,3vw,2.4rem)}
.cta-band p{color:#d8d9f5;margin-top:8px}

/* Étapes savoir-faire */
.etapes{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.etapes::before{content:"";position:absolute;top:27px;left:7%;right:7%;height:1px;background:var(--trait)}
.etape{position:relative;padding:0 22px;text-align:center}
.etape .point{
  width:54px;height:54px;border-radius:50%;background:var(--blanc);border:1px solid var(--corail);
  display:flex;align-items:center;justify-content:center;margin:0 auto 22px;position:relative;z-index:1;
  font-family:var(--font-display);font-size:1.3rem;font-style:italic;color:var(--corail);
}
.etape h3{font-size:1.25rem;margin-bottom:10px}
.etape p{font-size:.92rem;color:#55567f}

/* Avis */
.avis{background:var(--blanc);border:1px solid var(--trait);border-radius:var(--radius);padding:36px 32px;position:relative}
.avis::before{
  content:"“";position:absolute;top:8px;left:24px;font-family:var(--font-display);
  font-size:4.6rem;color:var(--rose);line-height:1;
}
.avis p{font-size:.97rem;color:#55567f;padding-top:30px;font-style:italic}
.avis cite{display:block;margin-top:18px;font-style:normal;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--indigo);font-weight:500}
.etoiles{color:var(--corail);letter-spacing:4px;margin-top:6px;font-size:.85rem}

/* FAQ / listes services */
.liste-coche{list-style:none;margin-top:22px}
.liste-coche li{
  padding:12px 0 12px 36px;position:relative;border-bottom:1px dashed var(--trait);font-size:1rem;
}
.liste-coche li::before{
  content:"";position:absolute;left:0;top:18px;width:18px;height:9px;
  border-left:2px solid var(--corail);border-bottom:2px solid var(--corail);transform:rotate(-45deg);
}

/* Page header (pages internes) */
.page-hero{
  padding:190px 0 90px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--rose-pale) 0%, var(--ivoire) 100%);
}
.page-hero::after{
  content:"";position:absolute;right:-140px;bottom:-200px;width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,var(--rose) 0%, transparent 70%);opacity:.5;
}
.page-hero .container{position:relative;z-index:1}
.breadcrumb{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:#8a8bb5;margin-bottom:22px}
.breadcrumb a{color:#8a8bb5}
.breadcrumb a:hover{color:var(--corail)}

/* Formulaire contact */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-bottom:8px;color:var(--indigo)}
input,select,textarea{
  width:100%;padding:15px 18px;border:1px solid var(--trait);border-radius:10px;
  font-family:var(--font-body);font-size:1rem;color:var(--encre);background:var(--blanc);
  transition:border-color var(--transition);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--indigo)}
textarea{min-height:150px;resize:vertical}
.form-note{font-size:.8rem;color:#8a8bb5;margin-top:14px}

/* Carte (iframe) */
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--trait);height:100%;min-height:340px}
.map-embed iframe{width:100%;height:100%;border:0;display:block;min-height:340px}

/* ---------- Footer ---------- */
.site-footer{background:var(--encre);color:#b9bae2;padding:80px 0 0;margin-top:110px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:60px}
.site-footer h4{
  font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;color:var(--rose);
  margin-bottom:20px;font-weight:500;font-family:var(--font-body);
}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:10px}
.site-footer a{color:#b9bae2;font-size:.95rem}
.site-footer a:hover{color:var(--corail)}
.footer-logo strong{font-family:var(--font-display);font-size:2.2rem;letter-spacing:.14em;color:var(--blanc);font-weight:600}
.footer-logo strong span{color:var(--corail)}
.footer-logo p{margin-top:14px;font-size:.92rem;max-width:30ch;color:#9d9ed0}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding:24px 0;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:.8rem;color:#8a8bc0;
}
.footer-bottom a{color:#8a8bc0}

/* Révélations au scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease, transform .8s ease}
.reveal.visible{opacity:1;transform:none}

/* ---------- Sous-menu ---------- */
.main-nav li{position:relative}
.submenu{
  position:absolute;top:calc(100% + 10px);left:0;
  background:var(--blanc);border:1px solid var(--trait);
  border-radius:var(--radius);padding:8px 0;min-width:220px;
  box-shadow:0 16px 40px rgba(5,1,86,.12);
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .3s ease, transform .3s ease, visibility .3s ease;
  list-style:none;z-index:10;
}
.submenu::before{
  content:"";position:absolute;top:-6px;left:24px;width:12px;height:12px;
  background:var(--blanc);border-left:1px solid var(--trait);border-top:1px solid var(--trait);
  transform:rotate(45deg);
}
.submenu li{margin:0}
.submenu a{
  display:block;padding:10px 24px;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--encre);
  white-space:nowrap;
}
.submenu a:hover{background:var(--rose-pale);color:var(--marine)}
.has-submenu > a::after{display:none}
.submenu-toggle{display:none}

@media (min-width:1101px){
  .has-submenu:hover > .submenu{opacity:1;visibility:visible;transform:translateY(0)}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .grid-4,.marques{grid-template-columns:repeat(2,1fr)}
  .etapes{grid-template-columns:repeat(2,1fr);gap:44px}
  .etapes::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:auto;padding:140px 0 60px}
  .hero-grid,.grid-2,.boutique-card{grid-template-columns:1fr}
  .hero-grid{gap:42px}
  .blueprint{max-width:460px;margin:0 auto}
  .grid-3{grid-template-columns:1fr}
  .engagements{grid-template-columns:1fr;gap:30px}
  .section{padding:74px 0}
  .cta-band{padding:50px 32px}
  .form-grid{grid-template-columns:1fr}
}
@media (max-width:880px){
  .hero{padding:130px 0 50px}
  .hero-grid{gap:36px}
}
@media (max-width:1100px){
  .burger{display:block}
  .main-nav{
    position:fixed;top:0;left:0;width:100%;height:100dvh;
    background:var(--ivoire);
    display:flex;align-items:center;justify-content:center;
    transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.3,1);
    overflow-y:auto;
  }
  .main-nav.open{transform:none}
  .main-nav ul{flex-direction:column;gap:18px;text-align:center;padding:40px 0}
  .main-nav a{font-size:1.15rem}

  /* Sous-menu mobile */
  .has-submenu{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0 12px}
  .has-submenu > a{flex:1 1 auto}
  .submenu-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:36px;height:36px;border:1px solid var(--trait);border-radius:50%;
    background:none;font-size:1.2rem;color:var(--encre);cursor:pointer;
    transition:transform .3s ease, border-color .3s ease;
  }
  .submenu-toggle.open{transform:rotate(45deg);border-color:var(--corail)}
  .submenu{
    position:static;opacity:1;visibility:visible;transform:none;
    display:none;box-shadow:none;border:none;background:transparent;
    padding:8px 0 0;width:100%;min-width:auto;
  }
  .submenu::before{display:none}
  .submenu.open{display:block}
  .submenu a{font-size:1rem;padding:8px 16px;color:var(--indigo)}
}
@media (max-width:520px){
  body{font-size:16px}
  .marques{grid-template-columns:1fr 1fr;gap:14px}
  .marque{padding:30px 12px}
  .etapes{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .header-inner{height:74px}
  .logo strong{font-size:1.6rem}
  .hero{padding:120px 0 40px}
  .hero-text h1{font-size:clamp(2rem,7vw,2.6rem)}
  .hero-actions{justify-content:center}
  .hero-side .offre{padding:14px 18px}
  .hero-side .offre strong{font-size:1.4rem}
}

/* ==========================================================================
   V2 — alignement charte flyer (illustration flat, logo, citation, offre)
   ========================================================================== */
:root{--violet:#9b6fc3;--peau:#f2b9a1}

/* Logo avec emblème béret */
.logo{flex-direction:row;align-items:center;gap:12px}
.logo-mark{width:40px;height:40px;flex:0 0 auto}
.logo-mark svg{width:100%;height:100%}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-text strong{
  font-family:var(--font-display);font-size:1.9rem;font-weight:500;
  letter-spacing:.3em;color:var(--encre);
}
.logo-text small{
  font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--indigo);margin-top:5px;font-weight:400;
}
.footer-logo .logo-mark{width:46px;height:46px;margin-bottom:14px}
.footer-logo strong{letter-spacing:.3em;font-weight:500}

/* Badge Nouveau (flyer) */
.badge-nouveau{
  display:inline-block;background:var(--corail);color:var(--blanc);
  font-size:.66rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  padding:6px 14px;border-radius:50px;margin-left:10px;vertical-align:middle;
}

/* Offre prix (flyer) */
.offre{
  display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;
  margin:30px 0 6px;padding:18px 26px;border:1px dashed var(--corail);
  border-radius:var(--radius);background:var(--blanc);width:fit-content;
}
.offre strong{font-family:var(--font-display);font-size:1.7rem;font-weight:600;color:var(--encre)}
.offre strong b{color:var(--corail);font-weight:600}
.offre span{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--indigo)}
.offre small{flex-basis:100%;font-size:.72rem;color:#8a8bb5}

/* Citation manifeste (bloc indigo du flyer) */
.quote-band{text-align:center;max-width:760px;margin:0 auto 70px;position:relative;padding-top:54px}
.quote-band::before{
  content:"“";position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  font-family:var(--font-display);font-size:7rem;line-height:1;color:var(--corail);
}
.quote-band p{
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.3;color:var(--blanc);
}
.quote-band p b{color:var(--rose);font-weight:500}

/* Illustration flat (style flyer) */
.illu{position:relative}
.illu svg{width:100%;height:auto;display:block}
@media (max-width:880px){.illu{max-width:480px;margin:0 auto}}

/* Blueprint en usage secondaire (savoir-faire) */
.blueprint.compact{max-width:560px;margin:54px auto 0}

/* ==========================================================================
   V3 — vraie identité : logo officiel, marine #050156, rouge coq #ea3449
   ========================================================================== */
:root{--marine:#0a0b51;--marine-fonce:#050156;--rouge:#ea3449}

h1,h2,h3{color:var(--marine)}
.logo-img{height:44px;width:auto;display:block}
.logo .logo-baseline{
  font-size:.56rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--marine);margin-top:6px;font-weight:400;display:block;
}
.site-footer{background:var(--marine-fonce)}
.section-indigo{background:var(--marine-fonce)}
.cta-band{background:linear-gradient(120deg,var(--marine-fonce) 0%, #1c1d72 100%)}
.footer-logo .logo-img{height:42px;filter:brightness(0) invert(1);margin-bottom:16px}
.boutique-card h3,.card h3{color:var(--marine)}
.offre strong{color:var(--marine)}

/* Section équipe (photo réelle) */
.equipe-photo{border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 60px rgba(5,1,86,.18)}
.equipe-photo img{width:100%;display:block}

/* ==========================================================================
   V4 — corrections : menu 1 ligne, menu mobile opaque, titres équilibrés,
   photos non déformées, lisibilité renforcée (clientèle malvoyante)
   ========================================================================== */

/* --- Lisibilité : tailles de police augmentées --- */
body{font-size:19px;line-height:1.7}
.lead{font-size:1.32rem;line-height:1.6}
.card p{font-size:1.08rem}
.card .more{font-size:.85rem}
.avis p{font-size:1.08rem}
.avis cite{font-size:.88rem}
.liste-coche li{font-size:1.1rem;padding:14px 0 14px 38px}
.liste-coche li::before{top:21px}
.horaires{font-size:1.05rem}
.horaires td{padding:11px 0}
.boutique-card address{font-size:1.08rem}
.btn{font-size:.92rem;padding:17px 36px}
.eyebrow{font-size:.85rem}
.breadcrumb{font-size:.82rem}
.form-note{font-size:.92rem}
.site-footer a,.site-footer li{font-size:1.05rem}
.footer-bottom{font-size:.9rem}
label{font-size:.85rem}
input,select,textarea{font-size:1.05rem}
.engagements .label{font-size:.85rem}
.etape p{font-size:1rem}
.marque small{font-size:.74rem}
.offre span{font-size:.9rem}
.offre small{font-size:.8rem}
.badge-nouveau{font-size:.72rem}
.photo::after{font-size:.78rem}

/* --- Titres : plus de mot orphelin sur la 2e ligne --- */
h1,h2,h3{text-wrap:balance}
.lead,.quote-band p{text-wrap:pretty}

/* --- Images : jamais déformées --- */
img{height:auto}
.photo img{height:100%}          /* object-fit:cover conserve les proportions */
.equipe-photo img{width:100%;height:auto}

/* --- Menu : libellés sur une seule ligne --- */
.main-nav a{white-space:nowrap}
.main-nav ul{gap:26px}
.main-nav a{font-size:.8rem;letter-spacing:.1em}
.nav-cta{padding:12px 22px!important}

/* --- Logo sans baseline : un peu plus grand --- */
.logo-img{height:48px}
.logo .logo-baseline{display:none}

/* --- Menu burger dès 1100px (plus jamais de nav à l'étroit) --- */
@media (max-width:1100px){
  .burger{display:block}
  .main-nav{
    position:fixed;top:0;left:0;width:100%;height:100dvh;
    background:var(--ivoire);          /* fond OPAQUE */
    display:flex;align-items:center;justify-content:center;
    transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.3,1);
    overflow-y:auto;
  }
  .main-nav.open{transform:none}
  .main-nav ul{flex-direction:column;gap:28px;text-align:center;padding:40px 0}
  .main-nav a{font-size:1.15rem}
}
/* le header ne doit pas « piéger » le menu fixe quand il est ouvert */
.site-header.menu-open{backdrop-filter:none;background:var(--ivoire)}

@media (max-width:520px){
  body{font-size:17px}
  .logo-img{height:40px}
}
.main-nav ul{gap:22px}   /* marge de sécurité entre 1100 et 1180px */
@media (max-width:1100px){.main-nav ul{gap:28px}}

/* ==========================================================================
   V5 — illustration officielle, graisses renforcées, footer contrasté
   ========================================================================== */

/* --- Illustration du hero --- */
.illu img{
  width:100%;max-width:557px;height:auto;margin:0 auto;display:block;
  border-radius:var(--radius);box-shadow:0 26px 60px rgba(5,1,86,.16);
}

/* --- Police : plus jamais de maigre 300, lecture confortable --- */
body{font-weight:400}
.lead{font-weight:400;color:#4a4b78}
.card p{color:#4a4b78}
.avis p{color:#4a4b78}
.boutique-card address{color:#4a4b78}
.etape p{color:#4a4b78}
h1,h2,h3{font-weight:600}
.logo-text strong{font-weight:600}
.engagements .num{font-weight:600}
.offre strong{font-weight:600}

/* --- Footer : contraste renforcé sur fond marine --- */
.site-footer{color:#dadbf8}
.site-footer a,.site-footer li{color:#e6e7ff}
.site-footer a:hover{color:var(--rose)}
.site-footer h4{color:#fabfba}
.footer-logo p{color:#cfd0f2}
.footer-bottom{color:#bfc0ea;border-top-color:rgba(255,255,255,.16)}
.footer-bottom a{color:#bfc0ea;text-decoration:underline;text-underline-offset:3px}
.section-indigo .lead{color:#dadbf8}
.cta-band p{color:#e6e7ff}

/* ==========================================================================
   V6 — hero PC : colonne droite équilibrée (illustration + offre + repères)
   ========================================================================== */
.hero-side{display:flex;flex-direction:column;align-items:center;gap:26px}
.hero-side .offre{margin:0;width:100%;max-width:557px;justify-content:center;text-align:center}
.hero-side .offre small{text-align:center}
.hero-reperes{
  list-style:none;display:flex;gap:10px 26px;flex-wrap:wrap;justify-content:center;
  margin:0;padding:0;
}
.hero-reperes li{
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  color:var(--indigo);display:flex;align-items:center;gap:9px;white-space:nowrap;
}
.hero-reperes li::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--corail);flex:0 0 auto;
}
@media (max-width:880px){
  .hero-side{margin-top:6px}
}
