:root{
  --bg:#3b1f6d;
  --accent:#ffd800;
  --text:#ffffff;
  --muted:rgba(255,255,255,.75);
  --glass:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.14);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Inter, Arial, sans-serif;
  font-weight: 300;
  background: var(--bg);
  color: var(--text);
}


.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  width:100%;
  background: rgba(15,8,30,.95);
  backdrop-filter: blur(12px);
  border-top:1px solid rgba(255,255,255,.1);
  padding:20px;
  z-index:9999;
  display:none;
}

.cookie-content{
  max-width:1100px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  align-items:center;
}

.cookie-content p{
  margin:0;
  max-width:600px;
  font-size:14px;
}

.cookie-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.cookie-modal{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.6);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:10000;
}

.cookie-modal-content{
  background: #1a1030;
  padding:30px;
  border-radius:20px;
  width:90%;
  max-width:400px;
  display:flex;
  flex-direction:column;
  gap:15px;
  border:1px solid rgba(255,255,255,.15);
}

.cookie-modal-content h3{
  margin-top:0;
}

#temoignages {
  scroll-margin-top: 80px;
}

.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:84px 0}
.section__head{max-width:900px;margin-bottom:26px}
h1{font-size:clamp(34px,4vw,56px);line-height:1.05;margin:20px 0 10px}
h2{font-size:clamp(26px,3vw,40px);margin:0 0 10px}
h3{margin:0 0 8px}
.muted{color:var(--muted);line-height:1.6}
.tiny{font-size:12px}

h1{
  font-family: 'Yanone Kaffeesatz', sans-serif;
  font-weight: 600;
  font-size: clamp(56px, 8vw, 100px);
  line-height: 1.05;
  letter-spacing: 1px;
}

h2{
  font-family: 'Yanone Kaffeesatz', sans-serif;
  font-weight: 500;
  font-size: clamp(36px, 5vw, 40px);
  letter-spacing: 0.5px;
}

h3{
  font-family: 'Yanone Kaffeesatz', sans-serif;
  font-weight: 400;
  font-size: 22px;
}


.homemade-apple-regular {
  font-family: "Homemade Apple", cursive;
  font-weight: 400;
  font-style: normal;
  text-align: right !important;
}

/* Compense le header fixed pour les ancres */
#presentation, #tarifs, #contact{
  scroll-margin-top: 50px;
}

.kicker-wrapper{
  width:100%;
  display:flex;
}

.kicker-pill{
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--glass);
  padding:6px 12px;
  width:60%;
}

.kicker-text{
  display:inline-block;
  white-space:nowrap;
  color:var(--muted);
  font-size:16px;
  font-weight: 300;
  will-change: transform;
}



.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 18px;       /* mÃªme padding pour tous */
  border-radius:999px;
  border:1px solid var(--border);
  transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
  text-decoration:none;
  font-weight:600;
  font-size:16px;          /* force mÃªme taille */
  line-height:1;           /* supprime diffÃ©rences natives */
  cursor:pointer;
}
.btn:hover{
   
    border-color:rgba(255,255,255,.25);
    transform: translateY(3px);
  box-shadow: 0 4px 10px rgba(0,0,0,.35);
}
.btn--accent{
  background: var(--accent);
  color: var(--bg); /* violet principal #3b1f6d */
  border-color: rgba(0,0,0,.08);
}

.btn--accent:hover{
  background: #f0cc00;
  color: var(--bg); /* on garde violet */
}
.btn--ghost{
    background: var(--glass);
    color: white;
}
.btn:active{
  transform: translateY(5px);
  box-shadow: 0 2px 6px rgba(0,0,0,.4);
}

.cookie-banner .btn--ghost{
  background: transparent;
  border: none;
  opacity: .8;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
  color: #ffffff;
}

.cookie-banner .btn--ghost:hover{
  color: var(--accent);
   opacity: 1;
  transform: none; /* enlÃ¨ve descente */
}

.cookie-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align:middle;
  line-height:1;
  margin: 0 4px;
}

.cookie-icon svg{
  width:18px;
  height:18px;
  color: var(--accent);
  vertical-align:middle;
  display:block;
  animation: cookiePulse 2.5s ease-in-out infinite;
}
@keyframes cookiePulse{
  0%,100%{ transform: scale(1); }
  50%{ transform: scale(1.08); }
}


.cookie-modal-content label{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  cursor:pointer;
}

.cookie-modal-content input[type="checkbox"]{
  width:16px;
  height:16px;
  margin:0;
}

.cookie-modal-content .btn--accent{
  background: var(--accent);
  color: var(--bg) !important;
}
.cookie-modal-content .btn--accent span{
  color: var(--bg) !important;
}

.cookie-modal-content input[type="checkbox"]{
  accent-color: var(--accent);
}


.cookie-modal-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:20px;
  padding-top:15px;
  border-top:1px solid rgba(255,255,255,.1);
}

.cookie-modal .btn--accent{
  background: var(--accent);
  color: var(--bg) !important;;
}

/* ===== IcÃ´ne Feather arrow-right-circle ===== */

.btn{
  position: relative; /* sÃ©curitÃ© */
}

.btn:not(.btn--ghost)::after{
  content:"";
  width:25px;
  height:25px;
  display:inline-block;
  background-color: currentColor;

  mask-image: url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'>\  <circle cx='12' cy='12' r='10'/>\  <polyline points='12 8 16 12 12 16'/>\  <line x1='8' y1='12' x2='16' y2='12'/>\  </svg>");

  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;

  transition: transform .4s cubic-bezier(.22,1,.36,1);
}

/* rotation vers le bas au hover */
.btn:hover::after{
  transform: translateX(4px) rotate(90deg);
}

button.btn{
  appearance:none;
  -webkit-appearance:none;
  border: none;
  background: var(--accent); /* si accent */
}

.btn.phone::after{
  content:"";
  width:22px;
  height:22px;
  display:inline-block;
  background-color: currentColor;

  mask-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'>\
<path d='M15.05 5A5 5 0 0 1 19 8.95'/>\
<path d='M15.05 1A9 9 0 0 1 23 8.95'/>\
<path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.09 4.18 2 2 0 0 1 4.06 2h3a2 2 0 0 1 2 1.72 12.8 12.8 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.8 12.8 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/>\
</svg>");

  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;

  transition: transform .3s ease;
}


.nav{
  position:fixed;       /* au lieu de sticky */
  top:0;
  left:0;
  width:100%;
  z-index:100;
  padding:18px 20PX;
  background:transparent;
  transition: background .25s ease, backdrop-filter .25s ease, border-color .25s ease;
}

.nav.is-scrolled{
  background: rgba(15,8,30,.65);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.12);
}

.nav__inner{max-width:1100px;margin:0 auto;padding:0 18px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.brand{color:var(--text);text-decoration:none;font-weight:800;letter-spacing:.5px}
.nav__links{display:flex;gap:14px;font-weight:200;align-items:center;flex-wrap:wrap}
.nav__links a{color:rgba(255,255,255,.9);text-decoration:none;font-weight:400}
.nav__links a:hover{color:var(--accent)}
.nav__links .btn{
  color: var(--bg);
}
.nav__links .btn:hover{
  color: #24113f;
}

.brand{
  display:flex;
  align-items:center;
}

.brand__logo{
  height: 52px;
  width: 79.2px;
  display:block;
  filter: brightness(0) invert(1);
  transition: transform .3s ease;
}

/* petit effet premium au hover */
.brand:hover .brand__logo{
  transform: translateY(-2px);
}


.hero{padding-top:40px}
.hero__bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(700px 320px at 20% 10%, rgba(255,216,0,.28), transparent 60%),
    radial-gradient(600px 260px at 80% 20%, rgba(255,255,255,.10), transparent 55%);
  opacity:.9;
}
.hero{position:relative}
.hero__grid{display:grid;grid-template-columns:1.2fr .9fr;gap:26px;align-items:center}
.lead{font-size:18px;font-weight:400;color:var(--muted);max-width:580px}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:42px}

.hero__media .media{
  width:100%;
  border-radius:26px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  overflow:hidden;
  min-height:360px;
}

/* HERO plein Ã©cran */
.hero--full{
  position:relative;
  height: 100svh;
  min-height: 100svh; /* mieux sur mobile rÃ©cent */
  display:flex;
  align-items:center;
  padding: 0;
  overflow:hidden;
}

.hero__media-full{
  position:absolute;
  inset:0;
  z-index:0;
  background-image: url("../img/hero.webp"); /* <-- ton image ici */
  background-size: cover;
  background-position: top center;
  transform: scale(1.02); /* lÃ©ger â€œpremiumâ€ÂÂÂÂ */
}

.hero__overlay{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    radial-gradient(700px 360px at 20% 20%, rgba(255,216,0,.22), transparent 60%),
    linear-gradient(180deg, rgba(10,6,18,.15), rgba(10,6,18,.35));
}

.hero__content{
  position:relative;
  z-index:3;
  width:100%;
  padding-top: 140px;  /* laisse la place au menu sticky */
  padding-bottom: 40px;
}

.hero__box{
  max-width: 720px;
}


.hero__fx{
  position:absolute;
  inset:0;
  z-index:1;
  width:100%;
  height:100%;
  pointer-events:none;
  opacity:.9; /* ajuste 0.3 Ã  0.8 */
  mix-blend-mode: normal; /* rend Ã§a subtil sur image sombre */
}





.hero-anim{
  opacity:0;
  transform: translateY(25px);
}

.hero-loaded .hero-anim{
  animation: heroFadeUp .8s cubic-bezier(.22,1,.36,1) forwards;
}

.hero-loaded .hero-anim-1{ animation-delay: .2s; }
.hero-loaded .hero-anim-2{ animation-delay: .5s; }
.hero-loaded .hero-anim-3{ animation-delay: .8s; }
.hero-loaded .hero-anim-4{ animation-delay: 1.1s; }

@keyframes heroFadeUp{
  to{
    opacity:1;
    transform: translateY(0);
  }
}





.media--img{
  background-image: linear-gradient(135deg, rgba(255,216,0,.22), rgba(255,255,255,.08));
}

.card{
  border:1px solid var(--border);
  background:var(--glass);
  border-radius:22px;
  padding:18px;
}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.price-card{border:1px solid var(--border);background:var(--glass);border-radius:22px;padding:18px;display:flex;flex-direction:column;gap:12px}
.price{display:flex;flex-direction:column;gap:4px}
.price__value{font-size:22px;font-weight:800}
.price__note{font-size:12px;color:var(--muted)}
.price-card__actions{display:flex;justify-content: flex-end;gap:10px;flex-wrap:wrap;margin-top:auto}

.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:14px}
label{display:grid;gap:6px;margin-top:10px}
input,textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.16);
  color:var(--text);
  outline:none;
}
input:focus,textarea:focus{border-color:rgba(255,216,0,.55)}
.hp{display:none}

.footer{
  padding:60px 0 40px;
  border-top:1px solid rgba(255,255,255,.08);
  background: linear-gradient(
    to top,
    rgba(0,0,0,.25),
    rgba(0,0,0,.15)
  );
}

.footer__inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:40px;
  flex-wrap:wrap;
}

.footer__logo{
  height:60px;
  margin-bottom:18px;
  filter: brightness(0) invert(1);
}

.footer__tagline{
  color: var(--muted);
  margin:0 0 20px;
  font-size:14px;
  letter-spacing:.5px;
}

.footer__copyright{
  color: rgba(255,255,255,.5);
  font-size:12px;
}

.footer__links{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.footer__links a{
  color: rgba(255,255,255,.75);
  text-decoration:none;
  font-weight:600;
  transition: color .2s ease, transform .2s ease;
}

.footer__links a:hover{
  color: var(--accent);
  transform: translateX(4px);
}


.reveal{opacity:0;transform:translateY(14px);transition:.6s ease}
.reveal.is-in{opacity:1;transform:translateY(0)}

@media (max-width: 900px){
  .hero__grid{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}

/* Animation premium header */
.nav{
  opacity: 0;
  transform: translateY(-15px);
}

.nav.is-loaded{
  animation: navFadeIn 0.8s cubic-bezier(.22,1,.36,1) forwards;
}

@keyframes navFadeIn{
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

/* DÃ©calage subtil du menu */
.nav__links{
  opacity: 0;
  transform: translateY(-8px);
}

.nav.is-loaded .nav__links{
  animation: navLinksIn 0.9s cubic-bezier(.22,1,.36,1) 0.15s forwards;
}

@keyframes navLinksIn{
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

/* H1: lettres par lettre sans couper les mots */
.hero-title .w{
  display:inline-block;
  white-space: nowrap;
  margin-right: .25em;
}

.hero-title .ch{
  display:inline-block;
  opacity:0;
  transform: translateY(18px);
  animation: charIn .55s cubic-bezier(.22,1,.36,1) forwards;
}

@keyframes charIn{
  to{ opacity:1; transform: translateY(0); }
}



/* ===== Mobile: burger simple + dropdown sous le header ===== */

.burger{
  display:none;
  background:transparent;
  border:0;
  padding:10px 0;
  cursor:pointer;
}

.burger span{
  display:block;
  width:28px;
  height:2px;
  background: rgba(255,255,255,.92);
  border-radius:999px;
  transition: transform .35s cubic-bezier(.22,1,.36,1);
}
.burger span + span{ margin-top:8px; }

/* burger -> X */
.nav.is-menu-open .burger span:nth-child(1){
  transform: translateY(5px) rotate(45deg);
}
.nav.is-menu-open .burger span:nth-child(2){
  transform: translateY(-5px) rotate(-45deg);
}

/* dropdown sous header */
.mobile-drop{
  position:absolute;
  left:0; right:0;
  top:100%;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transform: translateY(-6px);
  pointer-events:none;
  transition: max-height .35s cubic-bezier(.22,1,.36,1),
              opacity .25s ease,
              transform .35s cubic-bezier(.22,1,.36,1);
}

.mobile-drop__inner{
  max-width:1100px;
  margin:0 auto;
  padding: 40px;
  background: rgba(15,8,30,.62);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-direction:column;   /* empile verticalement */
  align-items:flex-end;
  gap:24px;
   
}


.mobile-drop__inner a{
  color: rgba(255,255,255,.9);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.3px;
  font-size:22px;
  position:relative;
  text-align: right;
 
}


.mobile-drop__inner a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0;
  height:2px;
  background: var(--accent);
  transition: width .25s ease;
}

.mobile-drop__inner a:hover{
  color:#fff;
}
.mobile-drop__inner a:hover::after{
  width:100%;
}

/* ouvert */
.nav.is-menu-open .mobile-drop{
  max-height:320px;
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

/* responsive */
@media (max-width: 900px){
  .nav__links{ display:none; }
  .burger{ display:block; }
}



.mobile-drop__inner .mobile-shop,
.mobile-drop__inner .btn--accent{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  border-radius:999px;
  background: var(--accent);
  color: var(--bg);
  border:none;
}
.mobile-drop__inner .btn--accent::after{
  display:none;
}

/* pas d'underline sur le bouton boutique */
.mobile-drop__inner a.btn::after{
  display:none;
}
.mobile-drop__inner a.btn:hover{
  color: var(--bg);
}

@media (min-width: 1200px){
  .container{
    max-width: 1200px;     /* optionnel : un peu plus large */
    padding-left: 80px;    /* plus d'espace Ã  gauche */
    padding-right: 80px;   /* plus d'espace Ã  droite */
  }
}

/* PrÃ©sentation : texte gauche / image droite */
.presentation{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:60px;
  align-items:center;
}

.presentation__text{
  margin:0; /* Ã©vite des marges bizarres de section__head */
}

.presentation__image img{
  width:100%;
  height:clamp(280px, 40vw, 480px);
  border-radius:22px;
  display:block;
  object-fit:cover;
  border: 0px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
}

@media (max-width: 900px){
  .presentation__image img{
    height:auto;        /* mobile = hauteur naturelle */
    object-fit:initial; /* plus de recadrage forcÃ© */
  }
}

/* Mobile */
@media (max-width: 900px){
  .presentation{
    grid-template-columns: 1fr;
    gap:28px;
  }
}

.title-with-icon{
  display:flex;
  align-items:center;
  gap:14px;
}

.title-icon svg{
  width:30px;
  height:30px;
  color: var(--accent); /* jaune GUEUJ */
  
}

.form-message{
  margin-bottom:20px;
  padding:14px 18px;
  border-radius:14px;
  font-weight:600;
  display:none;
  animation: fadeSlide .4s ease;
}

@keyframes fadeSlide{
  from{
    opacity:0;
    transform: translateY(-10px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}

.form-message.success{
  background: rgba(255,216,0,.15);
  border:1px solid rgba(255,216,0,.4);
  color: var(--accent);
}




/* Lettres par lettre (rÃ©utilisable H1/H2) */
.type-letters .w{
  display:inline-block;
  white-space: nowrap;
  margin-right: .25em;
}
.type-letters .ch{
  display:inline-block;
  opacity:0;
  transform: translateY(14px);
  animation: charIn .55s cubic-bezier(.22,1,.36,1) forwards;
}

@keyframes charIn{
  to{ opacity:1; transform: translateY(0); }
}

/* Par dÃ©faut (sans JS) : visible */
.after-type,
.after-pricing{ opacity:1; transform:none; }
.after-grid{ opacity: 1; transform: none; }

/* Cache uniquement si JS */
html.js .after-type,
html.js .after-pricing{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .6s cubic-bezier(.22,1,.36,1),
              transform .6s cubic-bezier(.22,1,.36,1);
}

html.js .after-grid{ opacity:0; transform: translateY(10px); transition: opacity .6s cubic-bezier(.22,1,.36,1),  transform .6s cubic-bezier(.22,1,.36,1);}

/* Reveal */
html.js .after-type.is-in,
html.js .after-pricing.is-in{ opacity:1; transform:translateY(0); }
html.js .after-grid.is-in{ opacity:1; transform: translateY(0); }

/* Tant que la section n'est pas dÃ©clenchÃ©e, on garde les lettres cachÃ©es */
html.js .type-letters .ch{
  opacity:0;
  transform: translateY(14px);
  animation: none;
}

/* Quand la section est dÃ©clenchÃ©e, on lance l'anim */
html.js .is-typed .type-letters .ch{
  animation: charIn .55s cubic-bezier(.22,1,.36,1) forwards;
}


.footer--framer{
  padding: 70px 0 34px;
  border-top: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(255,216,0,.10), transparent 60%),
    radial-gradient(700px 380px at 80% 20%, rgba(255,255,255,.06), transparent 55%),
    rgba(0,0,0,.10);
}

/* CTA card */
.footer-cta{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  border-radius: 26px;
  padding: 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 22px;
  margin-bottom: 34px;
  position: relative;
  overflow:hidden;
}

.footer-cta::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(600px 240px at 20% 30%, rgba(255,216,0,.18), transparent 60%);
  pointer-events:none;
}

.footer-cta__text{
  position:relative;
  z-index:1;
  max-width: 620px;
}

.footer-cta__text h3{
  margin:0 0 8px;
  font-family: 'Yanone Kaffeesatz', sans-serif;
  font-weight: 500;
  font-size: 34px;
  letter-spacing: .3px;
}

.footer-cta__actions{
  position:relative;
  z-index:1;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}


/* Grid */
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr repeat(3, minmax(160px, 1fr));
  gap: 60px;
  padding: 16px 0 26px;
}

.footer-brand .muted{ margin: 10px 0 0; }

.footer-logo{
  height: 90px;
  padding-top : 20px;
  width:auto;
  display:block;
  filter: brightness(0) invert(1);
}

.footer-col{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.footer-title{
  font-weight: 600;
  letter-spacing: .3px;
  color: rgba(255,255,255,.9);
  margin-bottom: 6px;
}

.footer-grid a{
  color: rgba(255,255,255,.72);
  text-decoration:none;
  font-weight: 300;
  transition: color .2s ease, transform .2s ease;
}

.footer-grid a:hover{
  color: var(--accent);
  transform: translateX(4px);
}

/* Bottom bar */
.footer-bottom{
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 14px;
  flex-wrap:wrap;
}

.footer-copy{
  color: rgba(255,255,255,.55);
  font-size: 12px;
}

.footer-legal{
  display:flex;
  gap: 14px;
  flex-wrap:wrap;
}

.footer-legal a{
  color: rgba(255,255,255,.60);
  text-decoration:none;
  font-size: 12px;
  font-weight: 700;
}

.footer-legal a:hover{ color: var(--accent); }

/* Responsive */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: repeat(3, 1fr);
    grid-template-areas:
      "brand brand brand"
      "raccourcis site boutique";
    gap: 18px;
  }

  .footer-brand{ grid-area: brand; }
  .footer-col--raccourcis{ grid-area: raccourcis; }
  .footer-col--site{ grid-area: site; }
  .footer-col--boutique{ grid-area: boutique; }

  .footer-col a{
    font-size: 13px;
  }
  .footer-top{
    display:grid;
    grid-template-columns: 1fr auto;
    align-items:start;
    gap:20px;
  }

  .footer-social{
    justify-content:flex-end;
    align-items:flex-start;
  }

}


@media (max-width: 300px){
  .footer-grid{
    grid-template-columns: 1fr;
    grid-template-areas:
      "brand"
      "site"
      "boutique"
      "raccourcis";
  }
}

.footer-social{
  display:flex;
  gap:18px;
  margin-top:18px;
}

.footer-social a{
  color: rgba(255,255,255,.65);
  transition: transform .25s cubic-bezier(.22,1,.36,1),
              color .25s ease;
}

.footer-social svg{
  width:50px;
  height:50px;
  margin-top: 20px;
  stroke-width:1.8;
}

.footer-social a:hover{
  color: var(--accent);
  transform: translateY(3px);
}
.footer-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:30px;
  margin-bottom:30px;
}

.section--tarifs-bg{
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(255,216,0,.10), transparent 60%),
    radial-gradient(700px 380px at 80% 20%, rgba(255,255,255,.06), transparent 55%),
    rgba(0,0,0,.10);
    
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.08);
}


.section--temoignages-bg{
  background: #1c093f;
    
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.08);
}


.ajust{
    width: 100%;
}

.price__value{
  font-size: 28px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.price-prefix{
  display:block;
  font-size:14px;
  color: var(--muted);
}

.hero__video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  transform: scale(1.05); /* lÃ©ger zoom cinÃ©ma */
  filter: brightness(.85) contrast(1.05);
}

/* --- ALIGNEMENT DES BOUTONS CONTACT --- */

/* 1. Aligner le bouton "Appeler" Ã  droite */
#contact .card .btn.phone {
  align-self: flex-end; /* Pousse le bouton Ã  droite dans la colonne flex */
}

/* 2. Aligner le bouton "Envoyer" Ã  droite */
/* On cible le paragraphe qui contient directement le bouton submit */
#contact form p {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  margin-bottom: 4px; /* RÃ©duit l'espace avec le texte tiny juste en dessous */
}

/* 3. Optionnel : Aligner aussi le petit texte de dÃ©lai Ã  droite pour l'harmonie */
#contact form .tiny {
  text-align: right;
  width: 100%;
}




/* On cible la carte qui n'est PAS le formulaire */
#contact .card:not(form) {
    display: block; /* On repasse en mode bloc standard */
    text-align: left; /* Le texte reste Ã  gauche */
}

/* On pousse UNIQUEMENT le bouton Appeler Ã  droite */
#contact .card .btn.phone {
    display: flex;       /* Permet de gÃ©rer les marges */
    width: fit-content;  /* Le bouton ne prend que la place de son texte */
    margin-left: auto;   /* LA MAGIE : pousse le bouton Ã  droite */
    margin-top: 15px;    /* Un peu d'espace avec le texte du dessus */
}