/* =========================================================
   SNAKEDEV — CSS PROPRE & RESPONSIVE (mobile-first)
   - Variables de thème
   - Reset & bases
   - Layout utilitaires
   - Sections (ordre de la page)
   - Media queries (>= 640px, 920px, 1200px)
========================================================= */

/* --------------------------
   Variables (couleurs, etc.)
--------------------------- */
:root{
  --brand:#830000;
  --text:#222;
  --white:#fff;
  --muted:#9e9e9e;
  --bg-grad-1:#5e5e5e;
  --bg-grad-2:#c0c0c0;
  --bg-grad-3:#292929;
  --bg-grad-4:#cacaca;

  --card-bg:rgba(255,255,255,0.05);
  --card-bg-strong:rgba(255,255,255,0.1);
  --shadow-1:0 6px 16px rgba(0,0,0,0.30);
  --shadow-2:0 10px 25px rgba(0,0,0,0.50);

  --radius:16px;
  --radius-sm:10px;

  --container:1200px;
  --gutter:20px;
}

/* --------------------------
   Reset & bases
--------------------------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  color:var(--text);
  background:linear-gradient(135deg,var(--bg-grad-1),var(--bg-grad-2),var(--bg-grad-3),var(--bg-grad-4));
  background-size:300% 300%;
  animation:gradientMove 10s ease infinite;
  overflow-x:hidden;
  position:relative;
  font-family:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.55;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

/* --------------------------
   Layout utilitaires
--------------------------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* --------------------------
   Animations
--------------------------- */
@keyframes gradientMove{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseScroll{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.3);opacity:1}}
@keyframes pulseHalo{0%,100%{transform:scale(1);opacity:.08}50%{transform:scale(1.2);opacity:.15}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes gradientText{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* --------------------------
   Effets de fond
--------------------------- */
body::before{
  content:"";
  position:absolute;
  bottom:10%;
  right:10%;
  width:min(35vw,520px);
  height:min(35vw,520px);
  background:radial-gradient(circle, rgba(150,0,0,0.06) 0%, transparent 70%);
  transform:translate(50%,50%);
  animation:pulseHalo 18s ease-in-out infinite;
  pointer-events:none;
  z-index:-1;
}

/* =========================================================
   HEADER / HERO
========================================================= */
header.hautdepage{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:30px;
  padding-block:14px;
  position: relative; /* nécessaire pour que le bloc absolu se cale dessus */
}
header.hautdepage img{width:120px;height:auto}

nav.principal ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
}
nav.principal a{
  color:#fff;
  text-decoration:none;
  font-weight:600;
  font-size:.95rem;
  padding:8px 12px;
  border-radius:999px;
  transition:background .25s,color .25s,transform .2s;
}
nav.principal a:hover{
  background:#ffffff20;
  color:#fff;
  transform:translateY(-1px);
}

section.top-page{
  position:relative;
  background:
    linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,.55)),
    url("../images/bg.jpeg") center/cover no-repeat;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  color:#fff;
  text-align:center;
  padding:20px 0 40px;
}
.landing-page{
  padding:10px 0 0;
}
.landing-page h1,
.landing-page p{
  opacity:0;
  animation:fadeInUp 1s forwards;
}
.landing-page h1{animation-delay:.35s}
.landing-page p{animation-delay:.7s}
.big-title{
  font-family: 'Orbitron', sans-serif;
  font-weight: 800;
  font-size:clamp(2rem, 5vw, 4rem);
  margin-bottom:12px;
  line-height:1.15;
  text-shadow:2px 2px 8px rgba(0,0,0,.6);
}
.mid-title{
  font-family:'Montserrat', sans-serif;
  font-size:clamp(1rem, 2.4vw, 1.4rem);
  max-width:720px;
  margin:0 auto 24px;
  text-shadow:1px 1px 4px rgba(0,0,0,.5);
}
.scroll-down{
  color:#fff;
  text-decoration:none;
  font-weight:700;
  padding:10px 18px;
  border:2px solid #fff;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all .25s;
  margin-top:10px;
}
.scroll-down:hover{background:#fff;color:var(--brand);transform:translateY(-2px)}
.scroll-down i{animation:pulseScroll 2s infinite 1.2s}

.lang-currency {
  position: absolute;
  top: 12px;
  right: 16px;
  display: flex;
  gap: 10px;
  z-index: 999;
}

/* Style général des menus */
.lang-currency select {
  padding: 8px 12px;
  border-radius: 6px;
  border: 1px solid #333;
  background: #1b1b1b;   /* fond sombre */
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  font-size: 0.9rem;
  appearance: none;      /* supprime le style natif */
  -webkit-appearance: none;
  -moz-appearance: none;
  transition: background .25s, transform .2s;
}

/* Icône flèche custom */
.lang-currency select::after {
  content: "▼";
  position: absolute;
  right: 10px;
  pointer-events: none;
}

/* Effet hover */
.lang-currency select:hover {
  background: var(--brand); /* ton rouge */
  transform: translateY(-1px);
}

/* Options dans le menu */
.lang-currency select option {
  background: #1b1b1b;
  color: #fff;
  font-weight: 500;
}

/* =========================================================
   SERVICES (icônes)
========================================================= */
.services{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
  align-items:stretch;
  justify-items:center;
  margin:40px auto;
}
.service-item{
  background:var(--card-bg);
  backdrop-filter:saturate(120%) blur(0.5px);
  border-radius:var(--radius);
  padding:18px 14px;
  width:100%;
  max-width:320px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  box-shadow:var(--shadow-1);
}
.delivery-icon{font-size:42px;color:var(--brand)}
.service-details{
  font-weight:700;
  text-align:center;
  font-size:1rem;
}

/* =========================================================
   TITRES SECTIONS
========================================================= */
.section-title{
  font-size:clamp(1.6rem, 3vw, 2.6rem);
  font-family: 'Russo One', sans-serif;
  font-weight:400;
  letter-spacing: 1px;
  position:relative;
  display:inline-block;
  color:#fff;
}
.section-title::before{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  transform: translateY(0%);
  background-color:var(--brand);
  width: 20%;
  height:0.18em;
  border-radius:4px;
}

/* Modal spécifique aux projets */
.modal-projet {
  display: none;
  position: fixed;
  z-index: 1000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  overflow: auto;
  background-color: rgba(0,0,0,0.5);
}

.modal-projet.open {
  display: block;
}

.modal-projet-inner {
  background-color: #fff;
  margin: 15% auto;
  padding: 20px;
  border-radius: 8px;
  width: 300px;
  text-align: center;
}

.close-projet {
  float: right;
  font-size: 24px;
  cursor: pointer;
}

.modal-projet-inner button {
  display: block;
  margin: 10px auto;
  padding: 8px 15px;
  cursor: pointer;
}

/* =========================================================
   PROJETS (boutons images)
========================================================= */
.projects-buttons{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  justify-content:center;
  margin-top:24px;
}
.project-btn{
  position:relative;
  width:100%;
  aspect-ratio:6/5; /* carré allongé, responsive */
  border:none;
  border-radius:15px;
  cursor:pointer;
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  font-size:18px;
  font-weight:800;
  color:#000;
  transition:transform .25s, filter .25s;
  overflow:hidden;
  box-shadow:var(--shadow-1);
}
.project-btn:hover{transform:scale(1.03);filter:brightness(1.05)}
.project-btn .project-text{
  background:rgba(255,255,255,0.68);
  backdrop-filter:saturate(120%) blur(1px);
  width:100%;
  text-align:center;
  padding:10px 12px;
  border-radius:0 0 15px 15px;
}
.project-btn .price{color:var(--brand);font-size:16px;font-weight:900}
.projet1{background-image:url(../images/peche.jpg)}
.projet2{background-image:url(../images/fumer.jpg)}
.projet3{background-image:url(../images/bracodep.jpg)}
.projet4{background-image:url(../images/pool.jpg)}
.projet5{background-image:url(../images/tobacco.jpg)}

/* =========================================================
   TÉMOIGNAGES
========================================================= */
.temoignages{
  max-width:900px;
  margin:70px auto;
  padding:0 var(--gutter);
  color:#fff;
}
.temoignages-item{
  margin:16px 0;
  border-radius:12px;
  overflow:hidden;
  background:linear-gradient(145deg, #830000, #360000);
  box-shadow:0 4px 15px rgba(0,0,0,.5);
  transition:transform .25s ease;
}
.temoignages-item:hover{transform:scale(1.01)}
.temoignages-item summary{
  cursor:pointer;
  padding:14px 18px;
  font-size:1.05rem;
  font-weight:800;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:color .3s;
  background:linear-gradient(270deg, #ff4b4b, #ff9a3c, #ffd93d, #6bcf63, #3dbfff, #a93cff);
  background-size:400% 400%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:gradientText 8s ease infinite;
}
.temoignages-item summary::after{
  content:"▶";
  transition:transform .25s ease;
  -webkit-text-fill-color:#fff;
}
.temoignages-item[open] summary::after{transform:rotate(90deg)}
.temoignages-stars{
  font-size:1.1rem;
  display:flex;
  gap:3px;
  padding-left:19px;
  margin-top:-4px;
  margin-bottom:8px;
  line-height:1;
}
.temoignages-stars span{display:inline-block;animation:bounce 1s infinite}
.temoignages-stars span:nth-child(2){animation-delay:.1s}
.temoignages-stars span:nth-child(3){animation-delay:.2s}
.temoignages-stars span:nth-child(4){animation-delay:.3s}
.temoignages-stars span:nth-child(5){animation-delay:.4s}
.temoignages-item p{
  padding:14px 18px 18px;
  margin:0;
  background:#250a0a;
  color:#fff;
  line-height:1.6;
}

/* =========================================================
   PRICING
========================================================= */
.pricing-section{
  text-align:center;
  padding:60px 0;
  background:linear-gradient(135deg, #2c2c2c, #3d3d3d);
  color:#fff;
}
.pricing-title{max-width:880px;margin:6px auto 14px;color:#ddd}
.pricing-container{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
  gap:22px;
  margin-top:26px;
  max-width: 1200px; /* 3 cartes max de ~380px */
  margin-left: auto;
  margin-right: auto; /* centre le bloc */
}
.pricing-card{
  position:relative;
  padding:22px;
  border-radius:var(--radius);
  background:var(--card-bg);
  box-shadow:var(--shadow-1);
  color:#fff;
  transition:transform .25s, box-shadow .25s, background .25s;
}
.pricing-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-2);
}
.pricing-card.featured{
  background:var(--card-bg-strong);
  border:2px solid #e63946;
  transform:translateY(0) scale(1.02);
}
.pricing-title{font-size:1.15rem;font-weight:800;margin-bottom:10px}
.pricing-price{font-size:1.6rem;font-weight:900;color: #ffbe32;margin-bottom:14px}
.pricing-price-avant{font-size:1.6rem;font-weight:900;color: #ff3232;margin-bottom:14px}
.pricing-price-rabais{font-size:1.6rem;font-weight:900;color: #ffbe32;margin-bottom:14px}
.pricing-features{list-style:none;margin:0 0 16px 0;padding:0;font-size:.98rem;line-height:1.7}
.pricing-features li{margin:5px 0}
.pricing-btn{
  background:#e63946;
  color:#fff;
  border:none;
  padding:10px 16px;
  border-radius:10px;
  cursor:pointer;
  font-weight:800;
  font-size:.95rem;
  margin-top:6px;
  box-shadow:0 4px 10px rgba(0,0,0,.25);
  transition:transform .2s, box-shadow .25s, background .25s;
}
.pricing-btn:hover{background:#ff4757;transform:translateY(-2px);box-shadow:0 6px 15px rgba(0,0,0,.35)}
.pricing-badge{
  position:absolute;
  top:10px;right:10px;
  font-size:20px;
  cursor:help;
}
.pricing-badge::after{
  content:"Admissible au rabais";
  position:absolute;
  top:-35px;right:0;
  background:rgba(0,0,0,.8);
  color:#fff;font-size:12px;
  padding:7px 8px;border-radius:6px;
  opacity:0;transform:translateY(5px);
  transition:opacity .25s, transform .25s;
  pointer-events:none;
}
.pricing-badge:hover::after{opacity:1;transform:translateY(0)}
.disclaimercart{color:#585858b7}

/* ==========================
   PARTENAIRES
========================== */
.partenaires {
  padding: 60px 0;
  background: linear-gradient(135deg, #290000, #5c0000); /* plus neutre que rouge pétant */
  text-align: center;
  color: #fff;
}

.partners-logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
  margin-top: 26px;
  max-width: 1200px;
  margin-inline: auto;
}

.partner-logo {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  aspect-ratio: 16/9; /* toutes les cartes mêmes dimensions */
  transition: transform .3s ease, box-shadow .3s ease, background .3s;
}

.partner-logo img {
  max-width: 90%;
  max-height: 80%;
  object-fit: contain;
  filter: brightness(.9);
  transition: filter .3s ease;
}

.partner-logo:hover {
  transform: translateY(-6px) scale(1.05);
  box-shadow: var(--shadow-2);
  background: var(--card-bg-strong);
}

.partner-logo:hover img {
  filter: brightness(1.15);
}

/* =========================================================
   CONTACT
========================================================= */
.contact{
  padding:50px 0;
  background:#111;
  color:#fff;
}

.contact-title {
  text-align:center;
  font-size:1.8rem;
  font-weight:800;
  margin-bottom:30px;
  color:#fff;
}

/* Grille en 3 colonnes */
.contact-grid{
  display:center;
  grid-template-columns: 1fr auto 1fr;
  gap:30px;
  align-items:center;
  max-width:1000px;
  margin:0 auto;
}
.contact input,
.contact textarea{
  padding:12px;
  border:none;
  border-radius:8px;
  font-size:16px;
  background:#1b1b1b;
  color:#fff;
}
.contact textarea{min-height:140px;resize:vertical}
.contact button{
  padding:12px;
  border:none;
  border-radius:8px;
  background:var(--brand);
  color:#fff;
  font-size:16px;
  font-weight:800;
  cursor:pointer;
  transition:background .25s, transform .2s;
}
.contact button:hover{background:#a30000;transform:translateY(-1px)}

/* Bloc Discord à droite */
.contact-discord a{text-decoration:none}
.discord-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  background:linear-gradient(145deg, #5865F2, #404EED);
  padding:30px 20px;
  border-radius:12px;
  color:#fff;
  font-weight:800;
  box-shadow:0 6px 16px rgba(0,0,0,0.35);
  transition:transform .25s, box-shadow .25s;
}
.discord-card img{
  width:60px;
  height:60px;
}
.discord-card:hover{
  transform:translateY(-5px);
  box-shadow:0 10px 25px rgba(0,0,0,0.5);
}

/* =========================================================
   FOOTER
========================================================= */
footer{
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
  justify-content:space-between;
  align-items:center;
  padding:18px var(--gutter) 30px;
  font-weight:700;
  color:#fff;
}
footer a.cgv{text-decoration:none;color:#fff;opacity:.9}
footer a.cgv:hover{opacity:1;text-decoration:underline}

/* =========================================================
   MODALE (CGV)
========================================================= */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0;
  visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
  z-index: 9999;
}

.modal.open {
  opacity: 1;
  visibility: visible;
}

.modal-content {
  background: #fff;
  color: #000;
  border-radius: 12px;
  width: min(90%, 680px);
  padding: 20px;
  transform: translateY(-20px);
  transition: transform .35s ease;
}

.modal.open .modal-content {
  transform: translateY(0);
}
.close{float:right;font-size:24px;cursor:pointer}

/* =========================================================
   CART (Bouton + Panneau)
========================================================= */
.cart-btn{
  position:fixed;
  top:14px;right:14px;
  background:linear-gradient(135deg, #ff9800, var(--brand));
  color:#fff;border:none;border-radius:999px;
  padding:10px 16px;
  font-size:.95rem;font-weight:800;
  cursor:pointer;z-index:10000;
  box-shadow:0 4px 15px rgba(0,0,0,.25);
  transition:transform .2s, filter .25s, background .25s;
}
.cart-btn:hover{transform:scale(1.05);filter:saturate(1.1)}

.cart{
  position:fixed;
  top:70px;
  right:-100%;
  width:100%;
  max-width:560px; /* tablette / desktop plafonné */
  background:#2c2c2c;color:#fff;
  border-radius:15px 0 0 15px;
  padding:18px;
  transition:right .35s ease;
  z-index:9999;
  display:flex;flex-direction:column;
  max-height:80vh;overflow:hidden;
  box-shadow:var(--shadow-2);
}
.cart.open{right:0}
.cart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:8px;margin-bottom:12px;border-bottom:1px solid #444;
}
.cart-header h3{font-size:1.15rem;font-weight:800;margin:0}
.close-btn{
  background:none;border:none;font-size:1.2rem;color:#bbb;cursor:pointer;transition:color .2s;
}
.close-btn:hover{color:#ff4d4d}

.cart-items{list-style:none;flex:1;overflow-y:auto}
.cart-items li{
  display:flex;justify-content:space-between;align-items:center;
  gap:10px;padding:8px 0;border-bottom:1px dashed #444;
}
.cart-items li button{
  background:none;border:none;color:#ff4d4d;font-size:1rem;cursor:pointer;
}

.cart-summary {
  margin-top: auto;
  margin-bottom: 12px;
  padding: 10px;
  background: #1e1e1e;
  border-radius: 10px;
}

.cart-summary .row {
  display: grid;
  grid-template-columns: auto 1fr auto; /* libellé | espace flexible | montant */
  font-size: .95rem;
  margin: 5px 0;
}

.cart-summary .label {
  white-space: nowrap; /* évite les retours à la ligne */
}

.cart-summary .money {
  text-align: right;
  min-width: 90px; /* fixe la largeur min pour tous les montants */
  white-space: nowrap;
}

.cart-summary .total .money {
  font-size: 1.05rem;
  color: #4caf50;
  font-weight: bold;
}

.cart-inputs input{
  width:100%;padding:10px;margin:6px 0;border-radius:8px;border:1px solid #444;
  background:#121212;color:#fff;font-size:.95rem;
}
.cart-inputs input:focus{border-color:var(--brand);outline:none}

.checkout-btn{
  background:linear-gradient(135deg, #4caf50, #2e7d32);
  color:#fff;font-weight:800;border:none;border-radius:8px;
  padding:12px;font-size:1rem;cursor:pointer;width:100%;
  margin:4px 0 8px;transition:transform .2s, filter .25s;
}
.checkout-btn:hover{transform:scale(1.02);filter:saturate(1.05)}

/* =========================================================
   MEDIA QUERIES
========================================================= */

/* >= 640px (petites tablettes) */
@media (min-width:640px){
  nav.principal a{font-size:1rem}
  .services{grid-template-columns:repeat(4, minmax(0,1fr))}
  .projects-buttons{grid-template-columns:repeat(2, minmax(280px,1fr))}
  .project-btn{aspect-ratio:4/3}
}

/* >= 920px (tablettes larges / desktop) */
@media (min-width:920px){
  header.hautdepage img{width:150px}
  nav.principal ul{gap:18px}
  .projects-buttons{grid-template-columns:repeat(3, minmax(280px,1fr))}
  .project-btn{max-width:380px;margin-inline:auto}
  .cart{
    right:-400px; /* état fermé */
    top:80px;
    width:350px;max-width:95%;
    border-radius:15px;
  }
  .cart.open{right:20px}
}

/* >= 1200px (desktop large) */
@media (min-width:1200px){
  .projects-buttons{grid-template-columns:repeat(4, minmax(280px,1fr))}
  .big-title{font-size:4rem}
  .mid-title{font-size:1.5rem}
}

@media (min-width: 920px) {
  .pricing-container {
    grid-template-columns: repeat(3, 1fr); /* force max 3 colonnes */
    max-width: 1200px; /* centre les 3 colonnes */
  }
}

@media (min-width: 920px) {
  .partners-logos {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width:820px){
  .contact-grid{
    grid-template-columns:1fr;
    text-align:center;
  }
  .contact-or{margin:20px 0}
}