/* ==========================================================================
   Team Superior Rafalcycling — Team VTT Made in Normandie
   Feuille de style principale
   Palette : Rouge #D81E27 · Or #F4C20D · Noir #111
   ========================================================================== */

:root{
  --rouge:#d81e27;
  --rouge-fonce:#a4161a;
  --or:#f4c20d;
  --or-fonce:#d9a900;
  --noir:#121212;
  --noir-doux:#1c1c1e;
  --gris:#6b6b70;
  --gris-clair:#f4f4f6;
  --gris-bord:#e6e6ea;
  --blanc:#ffffff;
  --ombre:0 10px 30px rgba(0,0,0,.10);
  --ombre-forte:0 18px 50px rgba(0,0,0,.22);
  --rayon:14px;
  --rayon-sm:9px;
  --max:1180px;
  --transition:.25s cubic-bezier(.4,0,.2,1);
  --police-titre:"Oswald",system-ui,sans-serif;
  --police-texte:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--police-texte);
  color:var(--noir);
  line-height:1.65;
  background:var(--blanc);
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4{font-family:var(--police-titre);font-weight:600;line-height:1.1;text-transform:uppercase;letter-spacing:.01em}
h1{font-size:clamp(2.3rem,6vw,4.4rem)}
h2{font-size:clamp(1.8rem,4vw,2.9rem)}
h3{font-size:clamp(1.25rem,2.4vw,1.6rem)}
p{margin:0 0 1rem}

.container{width:100%;max-width:var(--max);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section--gris{background:var(--gris-clair)}
.section--noir{background:var(--noir);color:#eee}
.text-center{text-align:center}

/* --- Bandeau d'accent / eyebrow --- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--police-titre);text-transform:uppercase;
  letter-spacing:.18em;font-size:.82rem;font-weight:600;
  color:var(--rouge);margin-bottom:.9rem;
}
.eyebrow::before{content:"";width:30px;height:3px;background:var(--or);border-radius:2px}
.section--noir .eyebrow{color:var(--or)}

.section-head{max-width:720px;margin-bottom:2.6rem}
.section-head.text-center{margin-inline:auto}
.section-head p{color:var(--gris);font-size:1.06rem}
.section--noir .section-head p{color:#bcbcc2}

/* --- Boutons --- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.06em;
  font-weight:600;font-size:.95rem;
  padding:.85rem 1.7rem;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:var(--transition);will-change:transform;
}
.btn--primary{background:var(--rouge);color:#fff}
.btn--primary:hover{background:var(--rouge-fonce);transform:translateY(-2px);box-shadow:0 10px 24px rgba(216,30,39,.35)}
.btn--or{background:var(--or);color:var(--noir)}
.btn--or:hover{background:var(--or-fonce);transform:translateY(-2px);box-shadow:0 10px 24px rgba(244,194,13,.4)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--ghost:hover{background:#fff;color:var(--noir);transform:translateY(-2px)}
.btn--dark{background:var(--noir);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-2px)}

/* ==========================================================================
   HEADER / NAVIGATION
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(18,18,18,.96);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav__brand{display:flex;align-items:center;gap:.7rem;color:#fff}
.nav__brand img{height:46px;width:auto}
.nav__brand-text{display:flex;flex-direction:column;line-height:1.05}
.nav__brand-text strong{font-family:var(--police-titre);text-transform:uppercase;font-size:1.02rem;letter-spacing:.02em}
.nav__brand-text span{font-size:.68rem;color:var(--or);text-transform:uppercase;letter-spacing:.14em}

.nav__menu{display:flex;align-items:center;gap:.35rem}
.nav__menu a{
  color:#dcdce0;font-family:var(--police-titre);text-transform:uppercase;
  font-size:.92rem;letter-spacing:.04em;font-weight:500;
  padding:.55rem .8rem;border-radius:8px;transition:var(--transition);position:relative;
}
.nav__menu a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav__menu a.is-active{color:var(--or)}
.nav__menu a.is-active::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.25rem;height:2px;background:var(--or);border-radius:2px}
.nav__cta{margin-left:.6rem;padding:.6rem 1.2rem}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:26px;height:3px;background:#fff;border-radius:2px;transition:var(--transition)}

@media(max-width:940px){
  .nav__toggle{display:flex}
  .nav__menu{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--noir);padding:1rem 1.2rem 1.6rem;
    border-bottom:3px solid var(--rouge);
    transform:translateY(-130%);transition:transform .35s ease;max-height:calc(100vh - 74px);overflow:auto;
  }
  .nav__menu.is-open{transform:translateY(0)}
  .nav__menu a{padding:.9rem .4rem;border-bottom:1px solid rgba(255,255,255,.07)}
  .nav__menu a.is-active::after{display:none}
  .nav__cta{margin:.9rem 0 0;justify-content:center}
  .nav__toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav__toggle.is-open span:nth-child(2){opacity:0}
  .nav__toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(10,10,10,.86) 0%,rgba(15,15,15,.6) 45%,rgba(20,20,20,.3) 100%);
}
.hero__inner{position:relative;z-index:2;max-width:740px;padding-block:5rem}
.hero h1{margin-bottom:1.1rem;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.hero h1 .accent{color:var(--or)}
.hero__lead{font-size:clamp(1.05rem,2vw,1.28rem);color:#e9e9ec;max-width:600px;margin-bottom:2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__badge{
  display:inline-flex;align-items:center;gap:.5rem;background:rgba(216,30,39,.92);
  font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;
  padding:.45rem 1rem;border-radius:50px;margin-bottom:1.4rem;
}

/* hero secondaire (pages internes) */
.hero--page{min-height:52vh}
.hero--page .hero__inner{padding-block:3.5rem}
.breadcrumb{font-size:.85rem;color:#cfcfd4;margin-top:1rem}
.breadcrumb a:hover{color:var(--or)}

/* ==========================================================================
   STATS / CHIFFRES CLÉS
   ========================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{
  background:var(--blanc);border:1px solid var(--gris-bord);border-radius:var(--rayon);
  padding:1.7rem 1.2rem;text-align:center;box-shadow:var(--ombre);
  border-top:4px solid var(--rouge);
}
.stat__num{font-family:var(--police-titre);font-size:clamp(2.1rem,4vw,3rem);color:var(--rouge);line-height:1}
.stat__label{font-size:.92rem;color:var(--gris);margin-top:.4rem;font-weight:500}
.section--noir .stat{background:var(--noir-doux);border-color:rgba(255,255,255,.08);color:#eee}
.section--noir .stat__num{color:var(--or)}
.section--noir .stat__label{color:#b5b5bb}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ==========================================================================
   GRILLE GÉNÉRIQUE & CARTES
   ========================================================================== */
.grid{display:grid;gap:1.6rem}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{
  background:var(--blanc);border:1px solid var(--gris-bord);border-radius:var(--rayon);
  overflow:hidden;box-shadow:var(--ombre);transition:var(--transition);height:100%;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--ombre-forte)}
.card__media{aspect-ratio:4/3;overflow:hidden;background:var(--gris-clair)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card__media img{transform:scale(1.06)}
.card__body{padding:1.4rem}
.card__body h3{margin-bottom:.5rem}
.card__tag{
  display:inline-block;background:var(--noir);color:#fff;font-family:var(--police-titre);
  text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;padding:.25rem .7rem;border-radius:50px;margin-bottom:.7rem;
}
.card__tag--rouge{background:var(--rouge)}
.card__tag--or{background:var(--or);color:var(--noir)}

/* --- Split image + texte --- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}
.split__media img{border-radius:var(--rayon);box-shadow:var(--ombre-forte);width:100%}
.split__media::before{content:"";position:absolute;inset:auto -16px -16px auto;width:60%;height:60%;
  border-right:5px solid var(--or);border-bottom:5px solid var(--or);border-radius:0 0 var(--rayon) 0;z-index:-1}
.split__body h2{margin-bottom:1rem}
@media(max-width:820px){
  .split{grid-template-columns:1fr}
  .split--reverse .split__media{order:0}
  .split__media::before{display:none}
}

.feature-list{display:grid;gap:1rem;margin-top:1.2rem}
.feature-list li{display:flex;gap:.85rem;align-items:flex-start}
.feature-list .ico{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:var(--rouge);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--police-titre)}

/* ==========================================================================
   COUREURS
   ========================================================================== */
.rider{position:relative;display:block;color:inherit;border-radius:var(--rayon);overflow:hidden;box-shadow:var(--ombre);background:var(--noir);transition:var(--transition)}
a.rider{cursor:pointer}
.rider:hover{transform:translateY(-5px);box-shadow:var(--ombre-forte)}
.rider__media{aspect-ratio:3/4;overflow:hidden;background:linear-gradient(160deg,#2a2a2e,#161618)}
.rider__media img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s}
.rider:hover .rider__media img{transform:scale(1.05)}
.rider__info{position:absolute;left:0;right:0;bottom:0;padding:1.3rem 1.1rem .95rem;
  background:linear-gradient(transparent,rgba(0,0,0,.92));color:#fff}
.rider__cat{font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--or);margin-bottom:.2rem}
.rider__name{font-family:var(--police-titre);text-transform:uppercase;font-size:1.18rem;line-height:1.05}
.rider__meta{font-size:.85rem;color:#cfcfd4}
.rider--placeholder .rider__media{display:grid;place-items:center}
.rider--placeholder .rider__media img{width:55%;height:auto;object-fit:contain;opacity:.85;filter:grayscale(.1)}

.cat-block{margin-bottom:2.5rem}
.cat-block__title{display:flex;align-items:center;gap:.8rem;margin-bottom:1.3rem}
.cat-block__title h3{color:var(--noir)}
.cat-block__title .line{flex:1;height:2px;background:var(--gris-bord)}
.cat-block__title .pill{background:var(--rouge);color:#fff;font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;padding:.3rem .9rem;border-radius:50px}

/* ==========================================================================
   STAFF
   ========================================================================== */
.staff-card{text-align:center;background:var(--blanc);border:1px solid var(--gris-bord);border-radius:var(--rayon);padding:1.6rem 1rem;box-shadow:var(--ombre);transition:var(--transition)}
.staff-card:hover{transform:translateY(-4px);box-shadow:var(--ombre-forte);border-color:var(--or)}
.staff-card__avatar{width:74px;height:74px;border-radius:50%;margin:0 auto .9rem;background:var(--noir);color:var(--or);
  display:grid;place-items:center;font-family:var(--police-titre);font-size:1.5rem}
.staff-card h3{font-size:1.1rem;margin-bottom:.15rem}
.staff-card .role{color:var(--rouge);font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.06em;font-size:.82rem}

/* ==========================================================================
   PALMARÈS / TIMELINE
   ========================================================================== */
.results-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
@media(max-width:760px){.results-band{grid-template-columns:repeat(2,1fr)}}
.result{background:var(--noir-doux);border-radius:var(--rayon);padding:1.6rem 1.2rem;text-align:center;border-bottom:4px solid var(--or)}
.result__num{font-family:var(--police-titre);font-size:2.6rem;color:var(--or);line-height:1}
.result__label{color:#cfcfd4;font-size:.92rem;margin-top:.35rem}

.honors{display:grid;gap:1rem;margin-top:1rem}
.honor{display:flex;align-items:center;gap:1rem;background:var(--blanc);border:1px solid var(--gris-bord);
  border-left:5px solid var(--rouge);border-radius:var(--rayon-sm);padding:1.05rem 1.3rem;box-shadow:var(--ombre)}
.honor .medal{font-size:1.5rem;flex:0 0 auto}
.honor strong{font-family:var(--police-titre);font-size:1.4rem;color:var(--rouge);margin-right:.2rem}

/* ==========================================================================
   PROGRAMME / CALENDRIER
   ========================================================================== */
.calendar{display:grid;gap:.8rem}
.cal-row{display:grid;grid-template-columns:120px 1fr auto;gap:1.2rem;align-items:center;
  background:var(--blanc);border:1px solid var(--gris-bord);border-radius:var(--rayon-sm);padding:1rem 1.3rem;
  box-shadow:var(--ombre);transition:var(--transition)}
.cal-row:hover{border-color:var(--or);transform:translateX(4px)}
.cal-row__level{font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;
  padding:.3rem .7rem;border-radius:50px;text-align:center}
.lvl-mondial{background:var(--noir);color:#fff}
.lvl-national{background:var(--rouge);color:#fff}
.lvl-inter{background:#234bd8;color:#fff}
.lvl-regional{background:var(--or);color:var(--noir)}
.cal-row__name{font-weight:600}
.cal-row__zone{color:var(--gris);font-size:.9rem}
@media(max-width:680px){.cal-row{grid-template-columns:1fr;gap:.4rem}.cal-row__level{justify-self:start}}

/* ==========================================================================
   SPONSORS
   ========================================================================== */
.logos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gris-bord);
  border:1px solid var(--gris-bord);border-radius:var(--rayon);overflow:hidden}
.logos-grid .logo-cell{background:#fff;aspect-ratio:16/9;display:grid;place-items:center;padding:1.4rem;
  font-family:var(--police-titre);text-transform:uppercase;letter-spacing:.04em;color:#333;font-size:1.05rem;
  text-align:center;transition:var(--transition)}
.logos-grid .logo-cell:hover{background:var(--gris-clair);color:var(--rouge)}
.logos-grid .logo-cell span{font-size:.78rem;color:var(--gris);display:block;letter-spacing:.08em}
@media(max-width:820px){.logos-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.logos-grid{grid-template-columns:repeat(2,1fr)}}

.offers{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
@media(max-width:900px){.offers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.offers{grid-template-columns:1fr}}
.offer{display:flex;flex-direction:column;background:var(--blanc);border:1px solid var(--gris-bord);
  border-radius:var(--rayon);overflow:hidden;box-shadow:var(--ombre);transition:var(--transition)}
.offer:hover{transform:translateY(-6px);box-shadow:var(--ombre-forte)}
.offer__head{padding:1.3rem 1.3rem 1rem;color:#fff;text-align:center}
.offer--bronze .offer__head{background:linear-gradient(135deg,#b06a2c,#8a4f1d)}
.offer--silver .offer__head{background:linear-gradient(135deg,#8a8d92,#62656a)}
.offer--gold .offer__head{background:linear-gradient(135deg,#e6b417,#c8920a)}
.offer--premium .offer__head{background:linear-gradient(135deg,#1d1d1f,#000)}
.offer__name{font-family:var(--police-titre);text-transform:uppercase;font-size:1.35rem;letter-spacing:.05em}
.offer__price{font-family:var(--police-titre);font-size:2rem;margin-top:.2rem}
.offer__price small{font-size:.85rem;opacity:.85}
.offer__body{padding:1.3rem;flex:1}
.offer__body ul{display:grid;gap:.65rem}
.offer__body li{display:flex;gap:.55rem;font-size:.93rem;align-items:flex-start}
.offer__body li::before{content:"✓";color:var(--rouge);font-weight:800}
.offer--premium.offer{outline:3px solid var(--or)}
.offer__foot{padding:0 1.3rem 1.4rem}
.offer__foot .btn{width:100%;justify-content:center}

/* ==========================================================================
   GALERIE
   ========================================================================== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
@media(max-width:820px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery a{display:block;border-radius:var(--rayon-sm);overflow:hidden;aspect-ratio:3/2;position:relative;box-shadow:var(--ombre)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery a::after{content:"";position:absolute;inset:0;background:rgba(216,30,39,0);transition:var(--transition)}
.gallery a:hover img{transform:scale(1.08)}
.gallery a:hover::after{background:rgba(216,30,39,.18)}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.93);display:none;
  align-items:center;justify-content:center;padding:2rem;cursor:zoom-out}
.lightbox.is-open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lightbox__close{position:absolute;top:1.2rem;right:1.6rem;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer;font-family:var(--police-titre)}

/* ==========================================================================
   BANDEAU CTA
   ========================================================================== */
.cta-band{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta-band__bg{position:absolute;inset:0;z-index:0}
.cta-band__bg img{width:100%;height:100%;object-fit:cover}
.cta-band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(164,22,26,.92),rgba(18,18,18,.92))}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{margin-bottom:.8rem}
.cta-band p{max-width:600px;margin:0 auto 1.8rem;color:#f0e6e6}
.cta-band__actions{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-card{display:flex;gap:1rem;align-items:flex-start;background:var(--blanc);border:1px solid var(--gris-bord);
  border-radius:var(--rayon);padding:1.3rem;box-shadow:var(--ombre);margin-bottom:1rem;transition:var(--transition)}
.contact-card:hover{border-color:var(--or)}
.contact-card .ico{flex:0 0 auto;width:46px;height:46px;border-radius:12px;background:var(--rouge);color:#fff;display:grid;place-items:center;font-size:1.3rem}
.contact-card .ico svg{width:23px;height:23px;fill:#fff;display:block}
.contact-card h3{font-size:1.05rem;margin-bottom:.1rem}
.contact-card a,.contact-card p{color:var(--gris);font-size:.97rem;margin:0}
.contact-card a:hover{color:var(--rouge)}
.map-wrap{border-radius:var(--rayon);overflow:hidden;box-shadow:var(--ombre);border:1px solid var(--gris-bord)}
.map-wrap iframe{display:block;width:100%;height:340px;border:0}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--noir);color:#c7c7cc;padding-top:3.5rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:2.5rem}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:64px;margin-bottom:1rem}
.footer-brand p{font-size:.92rem;color:#9a9aa0}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:1rem;letter-spacing:.05em}
.footer-links{display:grid;gap:.55rem}
.footer-links a{color:#c7c7cc;font-size:.95rem;transition:var(--transition)}
.footer-links a:hover{color:var(--or);padding-left:4px}
.socials{display:flex;gap:.7rem;margin-top:.4rem}
.socials a{width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:var(--transition)}
.socials a:hover{background:var(--rouge);transform:translateY(-3px)}
.socials svg{width:20px;height:20px;fill:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.3rem 0;font-size:.85rem;color:#8a8a90;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}
.footer-bottom a:hover{color:var(--or)}

/* ==========================================================================
   ANIMATIONS AU SCROLL
   ========================================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* Utilitaires */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mb-0{margin-bottom:0}
.lead{font-size:1.12rem;color:var(--gris)}
.prose p{margin-bottom:1.1rem}
.prose p:last-child{margin-bottom:0}
