/* =========================================================
   Lisa Martinez - Graphiste · feuille de style
   Charte : Marine #13192e · Or #e2ac6c · Bordeaux #742342
   ========================================================= */

:root{
  --marine:#13192e;
  --marine-2:#1c2440;
  --or:#e2ac6c;
  --or-soft:#eac38a;
  --bordeaux:#742342;
  --bordeaux-2:#8a2c4f;
  --cream:#f6f1ea;
  --cream-2:#efe7db;
  --ink:#1d2233;
  --muted:#5b6173;
  --line:rgba(19,25,46,.12);
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 50px -22px rgba(19,25,46,.45);
  --shadow-soft:0 10px 30px -18px rgba(19,25,46,.4);
  --container:1160px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ff-head:"Montserrat",system-ui,sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ff-script:"Parisienne",cursive;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-size:clamp(15px,1.05vw,17px);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-head);line-height:1.12;font-weight:800;letter-spacing:-.01em}
p{margin:0 0 1rem}

/* Paragraphes en justifié (avec césure pour un rendu propre en français) */
.lead,.section-intro,.about p,.card p,.t-item p:not(.t-place),
.faq-a,.contact-intro,.legal p{
  text-align:justify;
  text-justify:inter-word;
  hyphens:auto;
  -webkit-hyphens:auto;
}

.container{width:min(100% - 2.5rem,var(--container));margin-inline:auto}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--bordeaux);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--or);outline-offset:2px;border-radius:4px}

/* ---------------- Boutons ---------------- */
.btn{
  --b:var(--bordeaux);
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff-head);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.85rem 1.5rem;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--bordeaux);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--bordeaux-2)}
.btn-ghost{background:transparent;border-color:var(--marine);color:var(--marine)}
.btn-ghost:hover{background:var(--marine);color:#fff}
.btn-gold{background:var(--or);color:var(--marine)}
.btn-gold:hover{background:var(--or-soft)}
.btn-outline-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.btn-outline-light:hover{background:rgba(255,255,255,.12)}
.btn-block{width:100%;justify-content:center}

/* ---------------- Header ---------------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(246,241,234,.82);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid transparent;
  transition:padding .3s var(--ease),background .3s,border-color .3s,box-shadow .3s;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 6px 24px -18px rgba(19,25,46,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;transition:padding .3s var(--ease)}
.site-header.scrolled .header-inner{padding:.45rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{width:46px;height:46px;border-radius:50%;transition:width .3s,height .3s}
.site-header.scrolled .brand-logo{width:40px;height:40px}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-family:var(--ff-head);font-weight:800;font-size:1.02rem;color:var(--marine)}
.brand-text em{font-family:var(--ff-script);font-style:normal;font-size:1.05rem;color:var(--bordeaux);margin-top:-2px}

.primary-nav ul{display:flex;align-items:center;gap:1.8rem;list-style:none;margin:0;padding:0}
.primary-nav a{font-family:var(--ff-head);font-weight:500;font-size:.95rem;color:var(--marine);position:relative;padding:.3rem 0}
.primary-nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--or);transition:width .3s var(--ease);
}
.primary-nav a:not(.nav-cta):hover::after,.primary-nav a:not(.nav-cta).active::after{width:100%}
.nav-cta{background:var(--marine);color:#fff!important;padding:.55rem 1.2rem!important;border-radius:50px;transition:background .25s}
.nav-cta:hover{background:var(--bordeaux)}

.nav-toggle{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem;min-width:44px;min-height:44px}
.nav-toggle span{width:26px;height:2px;background:var(--marine);border-radius:2px;transition:transform .3s,opacity .3s}

/* ---------------- Hero ---------------- */
.hero{
  position:relative;
  background:
    radial-gradient(120% 90% at 85% -10%,rgba(116,35,66,.10),transparent 60%),
    radial-gradient(90% 70% at 0% 110%,rgba(226,172,108,.16),transparent 55%),
    var(--cream);
  padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,8vw,7rem);
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.eyebrow{
  font-family:var(--ff-head);font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  font-size:.78rem;color:var(--bordeaux);margin-bottom:1rem;
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--or)}
.hero-text h1{
  font-size:clamp(2.6rem,6.2vw,5rem);margin:0 0 2.2rem;color:var(--marine);letter-spacing:-.02em;
}
.hero-text h1 .script{margin-top:.15em}
.hero-text h1 .script{
  font-family:var(--ff-script);font-weight:400;color:var(--bordeaux);
  font-size:1.12em;letter-spacing:0;display:inline-block;line-height:1;
}
.lead{font-size:clamp(1rem,1.4vw,1.18rem);color:var(--muted);max-width:34rem;margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}

.hero-portrait{position:relative;justify-self:center;width:min(100%,360px)}
.portrait-frame{
  position:relative;aspect-ratio:1;border-radius:50%;padding:10px;
  background:conic-gradient(from 200deg,var(--or),var(--bordeaux),var(--marine),var(--or));
  box-shadow:var(--shadow);
}
.portrait-frame img{border-radius:50%;width:100%;height:100%;object-fit:cover;border:6px solid var(--cream)}
.portrait-badge{
  position:absolute;bottom:6%;left:-6%;width:84px;height:84px;border-radius:50%;
  background:var(--cream);display:grid;place-items:center;box-shadow:var(--shadow-soft);
  animation:float 5s ease-in-out infinite;
}
.portrait-badge img{width:72px;height:72px;border-radius:50%}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.scroll-cue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);width:26px;height:42px;border:2px solid var(--marine);border-radius:14px;opacity:.55}
.scroll-cue span{position:absolute;left:50%;top:8px;width:4px;height:8px;margin-left:-2px;border-radius:2px;background:var(--marine);animation:wheel 1.8s infinite}
@keyframes wheel{0%{opacity:1;top:8px}60%,100%{opacity:0;top:22px}}

/* ---------------- Sections ---------------- */
.section{padding:clamp(3.5rem,8vw,7rem) 0}
.section-kicker{font-family:var(--ff-head);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;color:var(--bordeaux);margin-bottom:.7rem}
.section-kicker.light{color:var(--or)}
.section-title{font-size:clamp(1.8rem,3.6vw,2.8rem);color:var(--marine);margin:0 0 1rem}
.section-title.light{color:#fff}
.section-head{max-width:46rem;margin-bottom:3rem}
.section-intro{color:var(--muted);font-size:1.08rem}

/* ---------------- À propos ---------------- */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.values{list-style:none;margin:1.8rem 0 0;padding:0;display:grid;gap:.9rem}
.values li{position:relative;padding-left:2rem;color:var(--muted)}
.values li::before{content:"✦";position:absolute;left:0;top:0;color:var(--or);font-size:1rem}
.values li span{color:var(--marine);font-weight:700;font-family:var(--ff-head)}
.about-stats{
  position:sticky;top:100px;display:grid;grid-template-columns:1fr 1fr;gap:1rem;
  background:var(--marine);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow);
}
.about-stats .stat{color:#fff;padding:.4rem .2rem}
.about-stats .stat strong{display:block;font-family:var(--ff-head);font-size:2rem;color:var(--or);line-height:1}
.about-stats .stat span{font-size:.85rem;color:rgba(255,255,255,.78)}
.about-photo{grid-column:1/-1;border-radius:var(--radius-sm);overflow:hidden;margin-top:.4rem}
.about-photo img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}

/* ---------------- Expertise ---------------- */
.expertise{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;
  position:relative;overflow:hidden;
}
.card::after{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--or),var(--bordeaux));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::after{transform:scaleX(1)}
.card{text-align:center}
.card-icon{
  width:56px;height:56px;border-radius:16px;display:grid;place-items:center;
  background:rgba(116,35,66,.08);color:var(--bordeaux);font-size:1.5rem;line-height:1;
  margin:.3rem auto 1.6rem;
}
.card h3{margin-top:0}
.card p{text-align:center}
.card h3{font-size:1.18rem;color:var(--marine);margin:0 0 .6rem}
.card p{color:var(--muted);margin:0;font-size:.96rem}

.skills{margin-top:3.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.6rem)}
.skills-title{font-size:1.3rem;color:var(--marine);margin:0 0 1.6rem}
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem 2.5rem}
.skill-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.4rem}
.skill-head span{font-family:var(--ff-head);font-weight:600;color:var(--marine);font-size:.95rem}
.skill-head em{font-style:normal;font-size:.8rem;color:var(--bordeaux);font-weight:600}
.bar{height:8px;background:rgba(19,25,46,.08);border-radius:50px;overflow:hidden}
.bar i{display:block;height:100%;width:0;border-radius:50px;background:linear-gradient(90deg,var(--or),var(--bordeaux));transition:width 1.1s var(--ease)}
.bar.run i{width:var(--lvl)}
.skills-foot{margin:1.8rem 0 0;padding-top:1.3rem;border-top:1px solid var(--line);color:var(--muted);font-size:.92rem}

/* ---------------- Portfolio ---------------- */
.portfolio{background:var(--marine);color:#fff;position:relative}
.portfolio .section-title{color:#fff}
.portfolio .section-kicker{color:var(--or)}
.portfolio .section-intro{color:rgba(255,255,255,.72)}
/* Galerie en masonry (colonnes) : les planches gardent leur ratio, sans recadrage */
.gallery{column-count:3;column-gap:1.1rem}
.gallery-item{
  margin:0 0 1.1rem;position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;
  break-inside:avoid;-webkit-column-break-inside:avoid;display:inline-block;width:100%;
  box-shadow:var(--shadow-soft);
}
.gallery-item picture{display:block}
.gallery-item img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item figcaption{
  position:absolute;inset:auto 0 0 0;padding:1.4rem 1rem .9rem;
  background:linear-gradient(transparent,rgba(13,16,28,.88));
  font-family:var(--ff-head);font-weight:600;font-size:1rem;color:#fff;
  display:flex;flex-direction:column;gap:.4rem;
  transform:translateY(8px);opacity:.95;transition:transform .35s var(--ease);
}
.gallery-item:hover figcaption{transform:translateY(0)}
.tag{align-self:flex-start;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;background:var(--or);color:var(--marine);padding:.18rem .55rem;border-radius:50px;font-weight:700}
.portfolio-cta{text-align:center;margin-top:2.6rem}

/* ---------------- Parcours ---------------- */
.parcours{background:var(--cream)}
.parcours-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.timeline-title{font-size:1.25rem;color:var(--bordeaux);margin:0 0 1.6rem;padding-bottom:.7rem;border-bottom:2px solid var(--or)}
.t-item{position:relative;padding:0 0 1.8rem 1.6rem;border-left:2px solid var(--line)}
.t-item:last-child{padding-bottom:0}
.t-item::before{content:"";position:absolute;left:-7px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--or);border:2px solid var(--cream)}
.t-item.highlight::before{background:var(--bordeaux)}
.t-date{font-family:var(--ff-head);font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--bordeaux)}
.t-item h4{font-size:1.05rem;color:var(--marine);margin:.3rem 0 .2rem}
.t-place{font-size:.88rem;color:var(--muted);font-style:italic;margin:0 0 .5rem}
.t-item p:not(.t-place){font-size:.94rem;color:var(--muted);margin:0}

/* ---------------- FAQ ---------------- */
.faq{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.faq-list{max-width:48rem;margin-inline:auto;display:grid;gap:.9rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.faq-item summary{
  cursor:pointer;list-style:none;padding:1.1rem 1.4rem;font-family:var(--ff-head);font-weight:600;color:var(--marine);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.5rem;color:var(--or);transition:transform .3s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 1.4rem 1.2rem;color:var(--muted);font-size:.96rem}

/* ---------------- Contact ---------------- */
.contact{background:var(--marine);color:#fff;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;top:-30%;right:-10%;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(116,35,66,.45),transparent 70%);pointer-events:none}
.contact-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-intro{color:rgba(255,255,255,.78);max-width:30rem}
.contact-list{list-style:none;margin:1.8rem 0;padding:0;display:grid;gap:1rem}
.contact-list li{display:flex;align-items:center;gap:1rem;font-size:1.02rem}
.contact-list a:hover{color:var(--or)}
.ci{width:42px;height:42px;flex:0 0 42px;border-radius:50%;display:grid;place-items:center;background:rgba(226,172,108,.16);color:var(--or);font-size:1.1rem}
.ci svg{width:20px;height:20px}
.contact-downloads{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.8rem}
.contact-form{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:clamp(1.4rem,3vw,2.2rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--ff-head);font-weight:600;font-size:.85rem;margin-bottom:.4rem;color:rgba(255,255,255,.85)}
.field input,.field textarea{
  width:100%;padding:.8rem 1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);color:#fff;font-family:var(--ff-body);font-size:.98rem;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.4)}
.field input:focus,.field textarea:focus{outline:2px solid var(--or);border-color:transparent}
.form-note{font-size:.8rem;color:rgba(255,255,255,.55);text-align:center;margin:.8rem 0 0}

/* ---------------- Footer ---------------- */
.site-footer{background:#0d1120;color:rgba(255,255,255,.7);padding:3rem 0 2rem;position:relative}
.footer-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.2rem}
.footer-brand{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.footer-brand img{width:58px;height:58px;border-radius:50%}
.footer-brand strong{color:#fff;font-family:var(--ff-head)}
.footer-nav{display:flex;flex-wrap:wrap;gap:1.4rem;justify-content:center}
.footer-nav a{font-size:.92rem;padding:.5rem .2rem}
.footer-nav a:hover{color:var(--or)}
.footer-social{display:flex;gap:.8rem;justify-content:center}
.footer-social a{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.85);transition:transform .25s var(--ease),background .25s,border-color .25s,color .25s}
.footer-social a:hover{background:var(--bordeaux);border-color:var(--bordeaux);color:#fff;transform:translateY(-3px)}
.footer-made{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem;font-size:.95rem;color:rgba(255,255,255,.82);margin:0}
.footer-bretzel{vertical-align:middle;animation:bretzelWobble 4s ease-in-out infinite;transform-origin:center}
.footer-heart{display:inline-block;animation:heartBeat 1.6s ease-in-out infinite;font-size:.95rem}
@keyframes bretzelWobble{0%,100%{transform:rotate(-7deg)}50%{transform:rotate(7deg)}}
@keyframes heartBeat{0%,100%{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1)}45%{transform:scale(1.18)}}
.footer-copy{width:100%;border-top:1px solid rgba(255,255,255,.1);padding-top:1.4rem;margin:.4rem 0 0;font-size:.82rem;color:rgba(255,255,255,.5)}
.to-top{position:absolute;right:clamp(1rem,4vw,3rem);top:-22px;width:46px;height:46px;border-radius:50%;background:var(--or);color:var(--marine);display:grid;place-items:center;font-size:1.3rem;font-weight:700;box-shadow:var(--shadow-soft);transition:transform .25s,background .25s}
.to-top:hover{transform:translateY(-3px);background:var(--or-soft)}

/* ---------------- Lightbox ---------------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(8,10,18,.92);display:grid;place-items:center;padding:4vw;opacity:0;animation:lbin .25s forwards}
@keyframes lbin{to{opacity:1}}
.lightbox[hidden]{display:none}
.lb-img{max-width:92vw;max-height:86vh;border-radius:8px;box-shadow:0 30px 80px -20px #000}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;border-radius:50%;width:50px;height:50px;font-size:1.6rem;display:grid;place-items:center;transition:background .2s}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--bordeaux)}
.lb-close{top:3vw;right:3vw}
.lb-prev{left:3vw;top:50%;transform:translateY(-50%)}
.lb-next{right:3vw;top:50%;transform:translateY(-50%)}

/* ---------------- Reveal / animations (style AOS) ---------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.reveal[data-aos="fade-up"]{transform:translateY(34px)}
.reveal[data-aos="fade-down"]{transform:translateY(-30px)}
.reveal[data-aos="fade-right"]{transform:translateX(-38px)}
.reveal[data-aos="fade-left"]{transform:translateX(38px)}
.reveal[data-aos="zoom-in"]{transform:scale(.9)}
.reveal[data-aos="zoom-out"]{transform:scale(1.08)}
.reveal[data-aos="flip-up"]{transform:perspective(800px) rotateX(14deg) translateY(24px);transform-origin:bottom}
.reveal.in{opacity:1;transform:none}

/* ---------------- Responsive ---------------- */
@media (max-width:920px){
  .hero-grid,.about-grid,.expertise .cards,.parcours-grid,.contact-grid{}
  .cards{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .about-stats{position:static;max-width:480px}
  .parcours-grid,.contact-grid{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-text{order:2}
  .hero-portrait{order:1;width:min(100%,300px)}
  .eyebrow,.hero-actions{justify-content:center}
  .lead{margin-inline:auto}
  .gallery{column-count:2}
}
@media (max-width:760px){
  .nav-toggle{display:flex;z-index:120}
  .primary-nav{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--marine);
    transform:translateX(100%);visibility:hidden;
    transition:transform .35s var(--ease),visibility .35s var(--ease);
    padding:5rem 2rem 2rem;box-shadow:-20px 0 60px -20px rgba(0,0,0,.6);
  }
  .primary-nav.open{transform:translateX(0);visibility:visible}
  .primary-nav ul{flex-direction:column;align-items:flex-start;gap:1.4rem}
  .primary-nav a{color:#fff;font-size:1.1rem}
  .nav-cta{color:#fff!important}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  body.nav-open{overflow:hidden}
  .skills-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-brand{justify-content:center}
  .footer-nav{justify-content:center}
}
@media (max-width:520px){
  .cards{grid-template-columns:1fr}
  .gallery{column-count:1}
  .about-stats{grid-template-columns:1fr 1fr}
  /* colonnes étroites : on évite les rivières du justifié */
  .lead,.section-intro,.about p,.card p,.t-item p:not(.t-place),.faq-a,.contact-intro{text-align:left}
}

/* ---------------- Préférence mouvement réduit ---------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .bar i{width:var(--lvl)!important}
}

/* ---------------- Icône SVG dans les cartes ---------------- */
.card-icon svg{width:26px;height:26px}

/* ---------------- Badges crédibilité ---------------- */
.cred-badges{list-style:none;margin:1.8rem 0 0;padding:1.4rem 0 0;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem}
.cred-badge{display:inline-flex;align-items:center;gap:.6rem;background:rgba(19,25,46,.04);border:1px solid var(--line);border-radius:50px;padding:.55rem 1.1rem .55rem .6rem;font-family:var(--ff-head);font-weight:600;font-size:.86rem;color:var(--marine)}
.cred-ic{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--bordeaux);color:#fff;flex:0 0 30px}
.cred-badge--gold .cred-ic{background:var(--or);color:var(--marine)}
.cred-badge--gold{border-color:rgba(226,172,108,.55);background:rgba(226,172,108,.12)}

/* ---------------- Flèches de téléchargement animées ---------------- */
.dl-ic{display:inline-block;font-size:1.1em;line-height:1;transition:transform .3s var(--ease);will-change:transform}
.btn:hover .dl-ic{animation:dlBounce .6s var(--ease)}
@keyframes dlBounce{0%{transform:translateY(0)}40%{transform:translateY(4px)}70%{transform:translateY(-2px)}100%{transform:translateY(0)}}

/* ---------------- Carte de l'Alsace ---------------- */
.alsace-card{
  margin:0;background:transparent;border:0;
  padding:.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.alsace-map{width:100%;max-width:290px;height:auto}
.als-shape{filter:drop-shadow(0 8px 24px rgba(0,0,0,.4))}
.als-city circle{fill:var(--or)}
.als-city text{fill:#f6f1ea;paint-order:stroke;stroke:#13192e;stroke-width:3px;stroke-linejoin:round}
.als-here-name{fill:var(--or);font-family:"Inter",sans-serif;font-weight:700;font-size:12px;paint-order:stroke;stroke:#13192e;stroke-width:3px;stroke-linejoin:round}
.als-here-sub{fill:var(--or-soft);font-family:"Parisienne",cursive;font-size:16px}
.als-pulse{transform-box:fill-box;transform-origin:center;opacity:.35;animation:alsPulse 2.6s ease-out infinite}
@keyframes alsPulse{0%{transform:scale(.5);opacity:.5}70%{transform:scale(2.6);opacity:0}100%{opacity:0}}
.alsace-cap{display:flex;align-items:center;gap:.6rem;color:rgba(255,255,255,.78);font-size:.9rem;text-align:left;max-width:300px}
.alsace-cap img{flex:0 0 26px}

/* ---------------- Préférence mouvement réduit (composants animés) ---------------- */
@media (prefers-reduced-motion:reduce){
  .als-pulse,.footer-bretzel,.footer-heart,.portrait-badge,.dl-ic{animation:none!important}
}
