/* ===== Fonts ===== */
@font-face {
  font-family: "WDXL Lubrifont TC";
  src: url("../fonts/WDXLLubrifontTC-Regular.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "PostNoBills Jaffna";
  src: url("../fonts/PostNoBillsJaffna-ExtraBold.woff2") format("woff2");
  font-weight: 800;
  font-display: swap;
}

/* =========================================================
   PALETTE  -  change une valeur ici = change tout le site
   ========================================================= */
:root {
  /* --- Fonds de sections --- */
  --fond-sombre: #2b3038;        /* header bas, video, points forts, contact */
  --fond-sombre-fonce: #21262d;  /* avis + champs de formulaire */
  --fond-creme: #f4f1e8;         /* hero, concept, reserver, faq, footer */
  --fond-header: #353b44;        /* haut du degrade du header */
  --fond-carte: #424a54;         /* cartes (points forts + avis) - gris clair pour contraste */

  /* --- Placeholders / surfaces images --- */
  --placeholder-image: #7f8896;  /* zones [IMG] */
  --placeholder-video: #e4e5df;  /* zone video */
  --placeholder-concept: #c9cac3;/* visuel concept */

  /* --- Texte --- */
  --texte-sombre: #2b3038;           /* texte sur fond clair */
  --texte-clair: #d9d9d9;            /* texte sur fond sombre */
  --texte-clair-fort: #eceef0;       /* texte clair accentue (cartes, boutons) */
  --texte-creme: #f4f0e6;            /* gros titres clairs sur fond sombre */
  --texte-nav: #cfd3da;              /* liens de navigation */
  --texte-secondaire-sombre: #4a505a;/* texte secondaire sur fond clair */
  --texte-secondaire-clair: #b7bcc4; /* texte secondaire sur fond sombre */
  --texte-discret-clair: #aeb4bd;    /* tagline, descriptions */
  --texte-discret: #6b7079;          /* texte discret / placeholders */
  --placeholder-texte: #7d838c;      /* texte des champs (placeholder) */
  --nav-user: #8d939c;               /* nom utilisateur connecte */
  --blanc: #ffffff;

  /* --- Accent (teal) --- */
  --accent: #2f9389;
  --accent-hover: #277a72;
  --survol-sombre: #3a414b;          /* hover boutons jour / tarif */

  /* --- Bordures --- */
  --bordure-sombre: #1f242b;         /* sous le header */
  --bordure-sur-sombre: #5a626c;     /* boutons outline sur fond sombre */
  --bordure-champ: #3a414b;          /* champs de formulaire */
  --bordure-claire: #b9bab3;         /* separateurs sur fond clair */
  --bordure-creme: #d8d4c6;          /* separateur footer */

  /* --- Etats --- */
  --etoile: #e8c14a;                 /* etoiles des avis */
  --statut-libre: #3fae62;           /* pastille disponible */
  --statut-complet: #d24b4b;         /* pastille complet */
}

/* ===== Base ===== */
* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; font-size: 18px; }

body {
  background: var(--fond-sombre);
  color: var(--texte-clair);
  font-family: system-ui, "Segoe UI", Arial, sans-serif;
  font-size: 1.05rem;
  line-height: 1.55;
}

img { display: block; max-width: 100%; height: auto; }

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

:where(section)[id] { scroll-margin-top: 1.5rem; }

/* ===== Boutons ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-family: inherit;
  font-size: 1rem;
  padding: 0.75em 1.5em;
  border: 1px solid transparent;
  border-radius: 2px;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0.03em;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.btn-primary { background: var(--accent); color: var(--blanc); }
.btn-primary:hover, .btn-primary:focus { background: var(--accent-hover); }
.btn-outline { background: transparent; color: var(--texte-clair); border-color: var(--bordure-sur-sombre); }
.btn-outline:hover, .btn-outline:focus { border-color: var(--texte-clair); color: var(--blanc); }
.btn-block { width: 100%; justify-content: center; }

/* ===== Header ===== */
.site-header {
  position: relative;
  overflow: hidden;
  text-align: center;
  padding: clamp(2.4rem, 4vw, 3.4rem) 1rem clamp(1.6rem, 2.5vw, 2.2rem);
  background: linear-gradient(180deg, var(--fond-header) 0%, var(--fond-sombre) 100%);
  border-bottom: 1px solid var(--bordure-sombre);
}
.site-header::before {
  content: "";
  position: absolute;
  top: 0.4rem;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(360px, 38vw, 480px);
  height: clamp(170px, 18vw, 226px);
  background: url("../img/eagle.svg") no-repeat center / contain;
  opacity: 0.14;
  pointer-events: none;
}
.site-title {
  position: relative;
  display: inline-block;
  text-decoration: none;
  font-family: "WDXL Lubrifont TC", sans-serif;
  font-weight: 400;
  font-size: clamp(2.8rem, 7.5vw, 6rem);
  line-height: 1;
  letter-spacing: 0.06em;
  color: var(--texte-clair);
}
.site-title:hover, .site-title:focus { color: var(--blanc); }
.site-tagline {
  position: relative;
  margin-top: 0.5rem;
  font-size: clamp(0.8rem, 1.6vw, 1.15rem);
  letter-spacing: 0.32em;
  color: var(--texte-discret-clair);
}
.main-nav {
  position: relative;
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(1.8rem, 6vw, 5rem);
}
.main-nav a {
  color: var(--texte-nav);
  text-decoration: none;
  font-size: clamp(1.05rem, 1.8vw, 1.4rem);
  letter-spacing: 0.12em;
  transition: color 0.15s ease;
}
.main-nav a:hover, .main-nav a:focus { color: var(--blanc); }
.main-nav .user-name { color: var(--nav-user); letter-spacing: 0.12em; }

/* ===== Hero ===== */
/* fond blanc creme ("blanc scientifique"), texte fonce */
.hero { background: var(--fond-creme); color: var(--texte-sombre); }
.hero-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1rem, 5vw, 3rem);
}
.badge {
  display: inline-block;
  border: 1px solid var(--texte-secondaire-sombre);
  color: var(--accent);
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  padding: 0.35em 0.85em;
  margin-bottom: 1.4rem;
  border-radius: 2px;
}
.hero-title {
  /* meme typo que le header */
  font-family: "WDXL Lubrifont TC", sans-serif;
  font-weight: 400;
  font-size: clamp(2.8rem, 8vw, 5.8rem);
  line-height: 1;
  color: var(--texte-sombre);
}
.accent { color: var(--accent); }
.hero-text {
  max-width: 36rem;
  margin: 1.4rem 0 2rem;
  color: var(--texte-secondaire-sombre);
  line-height: 1.65;
}
.btn-row { display: flex; flex-wrap: wrap; gap: 1rem; }
.hero .btn-outline { color: var(--texte-sombre); border-color: var(--texte-sombre); }
.hero .btn-outline:hover, .hero .btn-outline:focus { background: var(--texte-sombre); color: var(--fond-creme); }

/* ===== Vidéo ===== */
.video-section {
  background: var(--fond-sombre);
  text-align: center;
  padding: clamp(2.5rem, 6vw, 4.5rem) clamp(1rem, 5vw, 3rem);
}
.media-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--texte-discret);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.video-placeholder {
  max-width: 1320px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  background: var(--placeholder-video);
  border-radius: 2px;
}
.video-mark { margin: 1.2rem auto 0; opacity: 0.5; }

/* ===== Concept ===== */
.concept { background: var(--fond-creme); color: var(--texte-sombre); }
.concept-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1rem, 5vw, 3rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 5vw, 3.5rem);
  align-items: center;
}
.concept-media {
  aspect-ratio: 1 / 1;
  background: var(--placeholder-concept) url("../img/eagle.svg") no-repeat center / 45%;
  border-radius: 2px;
}
.concept-text h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(1.9rem, 3.8vw, 2.8rem);
  margin-bottom: 1.2rem;
}
.concept-list { margin-bottom: 1.8rem; }
.concept-list dt { font-weight: 700; }
.concept-list dd { margin: 0 0 0.9rem; color: var(--texte-secondaire-sombre); }

/* ===== Points forts ===== */
.features { background: var(--fond-sombre); }
.card-grid {
  list-style: none;
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4rem) clamp(1rem, 5vw, 3rem);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(1rem, 3vw, 1.8rem);
}
.feature-card {
  background: var(--fond-carte);
  padding: 1.4rem;
  clip-path: polygon(0 20px, 20px 0, calc(100% - 20px) 0, 100% 20px, 100% 100%, 0 100%);
}
.card-media {
  aspect-ratio: 4 / 3;
  background: var(--placeholder-image);
  border-radius: 2px;
  margin-bottom: 1.1rem;
}
.card-tag {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--texte-clair-fort);
  margin-bottom: 0.5rem;
}
.feature-card > p:last-child { color: var(--texte-discret-clair); font-size: 0.95rem; line-height: 1.5; }

/* ===== Réserver ===== */
.reserver { background: var(--fond-creme); color: var(--texte-sombre); text-align: center; }
.reserver-inner {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1rem, 5vw, 3rem);
}
.reserver-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2.6rem, 6.5vw, 4.6rem);
}
.reserver-sub { color: var(--texte-secondaire-sombre); margin-bottom: 2rem; letter-spacing: 0.03em; }
.field-label { font-weight: 700; margin: 1.6rem 0 1rem; }
.date-range {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.4rem;
}
.range-arrow {
  width: 2.2rem; height: 2.2rem;
  border: 1px solid var(--texte-sombre);
  background: transparent;
  cursor: pointer;
  font-size: 1.1rem;
  border-radius: 2px;
}
.range-arrow:hover { background: var(--texte-sombre); color: var(--texte-clair); }
.range-value { font-weight: 700; letter-spacing: 0.03em; }
.day-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.6rem;
  margin-bottom: 1rem;
}
.day {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--fond-sombre);
  color: var(--texte-clair-fort);
  border: none;
  cursor: pointer;
  padding: 1rem 0.4rem;
  border-radius: 2px;
  font-family: inherit;
  font-size: 0.95rem;
}
.day:hover { background: var(--survol-sombre); }
.dot { width: 0.55rem; height: 0.55rem; border-radius: 50%; display: inline-block; }
.dot-free { background: var(--statut-libre); }
.dot-full { background: var(--statut-complet); }
.legend {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  color: var(--texte-secondaire-sombre);
  font-size: 0.9rem;
  margin-bottom: 1.6rem;
}
.reserver-sep { border: none; border-top: 1px solid var(--bordure-claire); margin: 2rem 0; }
.tarif-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.tarif {
  flex: 1 1 180px;
  max-width: 240px;
  background: var(--fond-sombre);
  color: var(--texte-clair-fort);
  border: none;
  padding: 1.4rem 1rem;
  cursor: pointer;
  font-family: inherit;
  font-size: 1rem;
  border-radius: 2px;
}
.tarif:hover { background: var(--survol-sombre); }

/* ===== Avis ===== */
.reviews { background: var(--fond-sombre-fonce); }
.reviews-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4rem) clamp(1rem, 5vw, 3rem);
}
.reviews-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(1.9rem, 3.8vw, 2.8rem);
  margin-bottom: 1.8rem;
}
.star { color: var(--accent); }
.review-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.2rem;
}
.review { background: var(--fond-carte); padding: 1.4rem; margin: 0; border-radius: 2px; }
.stars { color: var(--etoile); margin-bottom: 0.7rem; letter-spacing: 0.12em; }
.review blockquote { margin: 0; }
.review blockquote p { color: var(--texte-secondaire-clair); font-size: 0.95rem; line-height: 1.55; }
.review figcaption { margin-top: 0.6rem; color: var(--texte-discret-clair); font-size: 0.85rem; }

/* Meilleurs scores (accueil) */
.score-list { list-style: none; max-width: 520px; margin: 0 auto; counter-reset: rang; }
.score-list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.7rem 0.2rem;
  border-bottom: 1px solid var(--fond-carte);
}
.score-list li::before { counter-increment: rang; content: counter(rang) "."; color: var(--texte-discret-clair); margin-right: 0.6rem; }
.score-equipe { flex: 1; color: var(--texte-clair-fort); font-weight: 700; }
.score-valeur { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: 1.3rem; color: var(--accent); }

/* ===== FAQ ===== */
.faq { background: var(--fond-creme); color: var(--texte-sombre); }
.faq-inner {
  max-width: 1040px;
  margin: 0 auto;
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1rem, 5vw, 3rem);
}
.faq-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}
.faq-head h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
}
.faq-aside { color: var(--texte-discret); }
.faq-item { border-top: 1px solid var(--bordure-claire); }
.faq-item:last-of-type { border-bottom: 1px solid var(--bordure-claire); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 0;
  font-weight: 700;
  font-size: 1.05rem;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-size: 1.5rem; line-height: 1; color: var(--texte-secondaire-sombre); }
.faq-item[open] summary::after { content: "×"; }
.faq-item > p { padding: 0 0 1.2rem; color: var(--texte-secondaire-sombre); line-height: 1.6; max-width: 62ch; }

/* ===== Contact ===== */
.contact { background: var(--fond-sombre); }
.contact-inner {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4rem) clamp(1rem, 5vw, 3rem);
  text-align: center;
}
.contact-media {
  aspect-ratio: 3 / 1;
  background: var(--fond-carte) url("../img/eagle.svg") no-repeat center / 120px;
  border-radius: 2px;
  margin-bottom: 1.6rem;
}
.contact-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5.5vw, 3.6rem);
  color: var(--texte-creme);
  margin-bottom: 1.8rem;
}
.contact-form { display: flex; flex-direction: column; gap: 1rem; text-align: left; }
.contact-form input, .contact-form textarea,
.auth-form input {
  width: 100%;
  background: var(--fond-sombre-fonce);
  border: 1px solid var(--bordure-champ);
  color: var(--texte-clair-fort);
  padding: 1rem 1.1rem;
  font-family: inherit;
  font-size: 1rem;
  border-radius: 2px;
}
.contact-form input::placeholder, .contact-form textarea::placeholder,
.auth-form input::placeholder { color: var(--placeholder-texte); }
.contact-form input:focus, .contact-form textarea:focus,
.auth-form input:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}
.contact-form .btn-block { margin-top: 0.5rem; }

/* ===== Footer ===== */
.site-footer { background: var(--fond-creme); color: var(--texte-secondaire-sombre); }
.footer-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 5vw, 3rem);
  display: grid;
  grid-template-columns: 2fr repeat(4, 1fr);
  gap: 2rem;
}
.footer-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-family: "WDXL Lubrifont TC", sans-serif;
  font-size: 1.5rem;
  color: var(--texte-sombre);
  margin-bottom: 1rem;
}
.footer-eagle { opacity: 0.85; width: 52px; height: auto; }
.footer-desc { font-size: 0.98rem; line-height: 1.6; max-width: 36ch; }
.footer-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--texte-sombre);
  letter-spacing: 0.03em;
  margin-bottom: 1rem;
}
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 0.6rem; }
.footer-col a { color: var(--texte-secondaire-sombre); text-decoration: none; font-size: 0.98rem; }
.footer-col a:hover, .footer-col a:focus { color: var(--texte-sombre); }
.social-list { display: flex; gap: 0.8rem; }
.social-list a { color: var(--texte-secondaire-sombre); display: inline-flex; }
.social-list a:hover, .social-list a:focus { color: var(--accent); }
.footer-copyright {
  text-align: center;
  background: var(--fond-sombre-fonce);
  padding: 1.2rem 1rem;
  font-size: 0.8rem;
  color: var(--texte-discret-clair);
}

/* ===== Page Info Pratiques ===== */
.info-block { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.info-light { background: var(--fond-creme); color: var(--texte-sombre); }
.info-dark { background: var(--fond-sombre); color: var(--texte-clair); }
.info-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding-inline: clamp(1rem, 5vw, 3rem);
}
.info-center { text-align: center; }
.section-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3.4rem);
  line-height: 1.05;
  margin-bottom: 1.8rem;
}
.info-dark .section-title { color: var(--texte-creme); }

/* Localisation */
.loc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1.2rem, 3vw, 2rem);
  align-items: stretch;
}
.loc-map {
  display: grid;
  place-items: center;
  min-height: 260px;
  background: var(--placeholder-concept);
  border-radius: 2px;
  font-family: "PostNoBills Jaffna", sans-serif;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  letter-spacing: 0.1em;
  color: var(--fond-sombre);
}
.loc-card {
  font-style: normal;
  border: 2px solid var(--fond-sombre);
  border-radius: 2px;
  padding: clamp(1.4rem, 3vw, 2.2rem);
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.loc-card-title { font-weight: 800; font-size: 1.15rem; }
.loc-card > p { color: var(--texte-secondaire-sombre); }
.loc-contact { margin-top: 0.6rem; display: flex; flex-direction: column; gap: 0.4rem; }
.loc-contact-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding-top: 0.7rem;
  border-top: 1px dashed var(--bordure-claire);
}
.loc-contact-row dt { font-weight: 700; }
.loc-contact-row dd { margin: 0; }
.loc-contact-row a { color: var(--accent); text-decoration: none; font-weight: 700; }
.loc-contact-row a:hover, .loc-contact-row a:focus { text-decoration: underline; }

/* Déroulé (timeline) */
.steps-list { list-style: none; position: relative; max-width: 760px; }
.steps-list::before {
  content: "";
  position: absolute;
  left: 0.5rem;
  top: 0.4rem;
  bottom: 0.4rem;
  width: 2px;
  background: var(--bordure-sur-sombre);
}
.step { position: relative; padding-left: 2.6rem; padding-bottom: 2.2rem; }
.step:last-child { padding-bottom: 0; }
.step::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.2rem;
  width: 1.1rem;
  height: 1.1rem;
  background: var(--texte-clair-fort);
  transform: rotate(45deg);
}
.step-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--texte-clair-fort);
  margin-bottom: 0.3rem;
}
.step > p { color: var(--texte-secondaire-clair); }

/* Conditions (stats) */
.facts-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(1rem, 3vw, 1.8rem);
}
.stat-card {
  background: var(--fond-sombre);
  color: var(--texte-clair);
  border-radius: 2px;
  padding: clamp(1.6rem, 4vw, 2.6rem) 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.stat-num {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 3.2rem);
  color: var(--texte-creme);
  line-height: 1;
}
.stat-label { font-size: 0.9rem; color: var(--texte-secondaire-clair); letter-spacing: 0.03em; }

/* Comment venir */
.come-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(1rem, 3vw, 1.8rem);
  text-align: left;
}
.come-card {
  background: var(--fond-carte);
  border-radius: 2px;
  padding: clamp(1.4rem, 3vw, 2rem);
}
.come-card-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--texte-clair-fort);
  margin-bottom: 0.6rem;
}
.come-card > p { color: var(--texte-secondaire-clair); line-height: 1.55; }

/* CTA */
.cta-text {
  max-width: 50ch;
  margin: 0 auto 1.8rem;
  color: var(--texte-secondaire-sombre);
  line-height: 1.65;
}
.cta-btns { justify-content: center; }
.cta .btn-outline { color: var(--texte-sombre); border-color: var(--texte-sombre); }
.cta .btn-outline:hover, .cta .btn-outline:focus { background: var(--texte-sombre); color: var(--fond-creme); }

/* ===== Mentions légales ===== */
.legal { max-width: 800px; margin: 0 auto; }
.legal-section + .legal-section { margin-top: 2.2rem; }
.legal-section h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(1.35rem, 3vw, 1.9rem);
  color: var(--texte-sombre);
  margin-bottom: 0.7rem;
}
.legal-section p { color: var(--texte-secondaire-sombre); line-height: 1.65; }
.legal-section p + p { margin-top: 0.7rem; }
.legal-section a { color: var(--accent); text-decoration: none; }
.legal-section a:hover, .legal-section a:focus { text-decoration: underline; }
.legal-updated {
  margin-top: 2.6rem;
  font-size: 0.85rem;
  color: var(--texte-discret);
}

/* ===== Espace connecte / pages applicatives / admin =====
   Reutilise la section .auth (fond sombre, titre creme, champs sombres). */
.auth-inner--full { max-width: 1100px; }
.auth-inner--wide, .auth-inner--full { text-align: left; }

.auth h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(1.3rem, 3vw, 1.9rem);
  color: var(--texte-creme);
  margin: 1.8rem 0 0.9rem;
}
.auth p, .auth li { color: var(--texte-secondaire-clair); }
.auth a { color: var(--accent); text-decoration: none; }
.auth a:hover, .auth a:focus { text-decoration: underline; }
.auth ul { padding-left: 1.2rem; }
.auth ul.no-puces { list-style: none; padding-left: 0; }

/* Champs (toutes les pages auth, pas seulement .auth-form) */
.auth input[type="text"],
.auth input[type="email"],
.auth input[type="password"],
.auth input[type="tel"],
.auth input[type="number"],
.auth input[type="datetime-local"],
.auth input[type="file"],
.auth textarea,
.auth select {
  display: block;
  width: 100%;
  background: var(--fond-sombre-fonce);
  border: 1px solid var(--bordure-champ);
  color: var(--texte-clair-fort);
  padding: 0.7rem 0.9rem;
  font-family: inherit;
  font-size: 1rem;
  border-radius: 6px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.auth input::placeholder, .auth textarea::placeholder { color: var(--texte-discret); }
.auth input:focus, .auth textarea:focus, .auth select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 147, 137, 0.25);
  outline: none;
}
.auth label { color: var(--texte-clair); }

/* Boutons par defaut dans les pages auth (teal) */
.auth button {
  background: var(--accent);
  color: var(--blanc);
  border: none;
  border-radius: 2px;
  padding: 0.55em 1.1em;
  font-family: inherit;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background 0.15s ease;
}
.auth button:hover, .auth button:focus { background: var(--accent-hover); }

/* Tableaux */
.app-table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
.app-table th, .app-table td {
  border: 1px solid var(--bordure-champ);
  padding: 0.6rem 0.8rem;
  text-align: left;
  vertical-align: top;
}
.app-table th { background: var(--fond-sombre-fonce); color: var(--texte-clair-fort); }
.app-table img { display: block; border-radius: 2px; }

/* Carte (bloc d'info) */
.app-card {
  background: var(--fond-carte);
  border-radius: 4px;
  padding: 1.2rem 1.4rem;
  margin: 1rem 0;
}
.app-card h2 { margin-top: 0; }

/* Lien d'invitation en lecture seule */
.invite-link { width: 100%; max-width: 520px; }

/* Boutons d'action alignes */
.app-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.app-actions form { margin: 0; }

/* ===== 2e ligne de navigation (utilisateur connecte / auth) ===== */
.user-nav {
  position: relative;
  margin: 1.1rem auto 0;
  padding-top: 1.1rem;
  max-width: 920px;
  border-top: 1px solid var(--bordure-sombre);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(1rem, 4vw, 2.6rem);
}
.user-nav a {
  color: var(--texte-discret-clair);
  text-decoration: none;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  transition: color 0.15s ease;
}
.user-nav a:hover, .user-nav a:focus { color: var(--blanc); }
.user-nav .nav-hello { color: var(--accent); font-weight: 700; letter-spacing: 0.04em; }
.user-nav .nav-admin { color: var(--accent); }

/* ===== Espace membre (pages connecte : groupe, profil, panier) ===== */
.space { background: var(--fond-sombre); color: var(--texte-clair); }
.space-head {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 5vw, 3rem) 0;
}
.space-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  color: var(--texte-creme);
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1;
}
.space-sub { color: var(--texte-secondaire-clair); margin-top: 0.5rem; }
.space-body {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(1.4rem, 4vw, 2.4rem) clamp(1rem, 5vw, 3rem) clamp(3rem, 6vw, 4.5rem);
}
.space-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.4rem;
  align-items: start;
}
.space-card {
  background: var(--fond-carte);
  border: 1px solid var(--bordure-champ);
  border-radius: 10px;
  padding: 1.5rem;
}
.space-card h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  color: var(--texte-creme);
  font-size: 1.25rem;
  margin: 0 0 1rem;
}
.space-card p { color: var(--texte-secondaire-clair); }
.space-card a { color: var(--accent); text-decoration: none; }
.space-card a:hover { text-decoration: underline; }
.space-list { list-style: none; padding: 0; margin: 0; }
.space-list li { padding: 0.45rem 0; border-bottom: 1px solid var(--fond-sombre-fonce); color: var(--texte-clair); }
.space-list li:last-child { border-bottom: none; }
.space-data { display: grid; grid-template-columns: auto 1fr; gap: 0.4rem 1rem; }
.space-data dt { color: var(--texte-discret-clair); }
.space-data dd { margin: 0; color: var(--texte-clair-fort); }
.space-badge { color: var(--accent); font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: 1.6rem; }

/* Champs et boutons dans l'espace membre */
.space input[type="text"], .space input[type="email"], .space input[type="password"],
.space input[type="tel"], .space input[type="number"], .space input[type="datetime-local"],
.space textarea, .space select {
  display: block;
  width: 100%;
  background: var(--fond-sombre-fonce);
  border: 1px solid var(--bordure-champ);
  color: var(--texte-clair-fort);
  padding: 0.7rem 0.9rem;
  font-family: inherit;
  font-size: 1rem;
  border-radius: 6px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.space input::placeholder, .space textarea::placeholder { color: var(--texte-discret); }
.space input:focus, .space textarea:focus, .space select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 147, 137, 0.25);
  outline: none;
}
.space label { color: var(--texte-clair); display: block; margin-bottom: 0.35rem; font-size: 0.95rem; }
.space-inline { display: flex; flex-direction: column; gap: 0.6rem; align-items: stretch; }
.space-inline .btn { align-self: flex-start; }

/* ===== Back-office (layout sidebar) ===== */
.admin-body { margin: 0; }
.admin-shell { display: flex; min-height: 100vh; }

.admin-side {
  width: 250px;
  flex-shrink: 0;
  background: var(--fond-sombre-fonce);
  border-right: 1px solid var(--bordure-sombre);
  display: flex;
  flex-direction: column;
  padding: 1.5rem 0;
  position: sticky;
  top: 0;
  height: 100vh;
}
.admin-brand {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  color: var(--texte-creme);
  padding: 0 1.5rem 1.4rem;
}
.admin-nav { display: flex; flex-direction: column; }
.admin-nav a {
  color: var(--texte-clair);
  text-decoration: none;
  padding: 0.75rem 1.5rem;
  border-left: 3px solid transparent;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.admin-nav a:hover, .admin-nav a:focus { background: rgba(255, 255, 255, 0.05); }
.admin-nav a.is-active {
  background: rgba(47, 147, 137, 0.16);
  border-left-color: var(--accent);
  color: var(--blanc);
}
.admin-side-bottom {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  padding: 1rem 1.5rem 0;
  border-top: 1px solid var(--bordure-sombre);
}
.admin-side-bottom a { color: var(--texte-discret-clair); text-decoration: none; font-size: 0.9rem; }
.admin-side-bottom a:hover { color: var(--blanc); }

.admin-main {
  flex: 1;
  min-width: 0;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  background: var(--fond-sombre);
}
.admin-main h1 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  color: var(--texte-creme);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  margin-bottom: 1.5rem;
}
.admin-main h2 {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  color: var(--texte-creme);
  font-size: 1.3rem;
  margin: 0 0 1rem;
}
.admin-main a { color: var(--accent); }
.admin-main input[type="text"],
.admin-main input[type="email"],
.admin-main input[type="password"],
.admin-main input[type="tel"],
.admin-main input[type="number"],
.admin-main input[type="datetime-local"],
.admin-main input[type="file"],
.admin-main textarea,
.admin-main select {
  display: block;
  width: 100%;
  max-width: 420px;
  background: var(--fond-sombre-fonce);
  border: 1px solid var(--bordure-champ);
  color: var(--texte-clair-fort);
  padding: 0.7rem 0.9rem;
  font-family: inherit;
  font-size: 1rem;
  border-radius: 6px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.admin-main input::placeholder, .admin-main textarea::placeholder { color: var(--texte-discret); }
.admin-main input:focus, .admin-main textarea:focus, .admin-main select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 147, 137, 0.25);
  outline: none;
}
/* dans une table, les champs restent compacts */
.app-table input, .app-table select { max-width: 220px; }
.app-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.app-actions input { width: auto; }
.admin-main button {
  background: var(--accent);
  color: var(--blanc);
  border: none;
  border-radius: 4px;
  padding: 0.55em 1.1em;
  font-family: inherit;
  font-size: 0.92rem;
  cursor: pointer;
  transition: background 0.15s ease;
}
.admin-main button:hover, .admin-main button:focus { background: var(--accent-hover); }

/* Cartes de statistiques (dashboard) */
.stat-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem;
  margin-bottom: 2rem;
}
.stat-box {
  background: var(--fond-carte);
  border: 1px solid var(--bordure-champ);
  border-radius: 10px;
  padding: 1.5rem;
}
.stat-box .num {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 2.6rem;
  line-height: 1;
  color: var(--blanc);
}
.stat-box .lab { color: var(--texte-secondaire-clair); margin-top: 0.4rem; }

/* Grille de cartes admin (listes en cartes si besoin) */
.admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.2rem;
}

@media (max-width: 760px) {
  .admin-shell { flex-direction: column; }
  .admin-side {
    width: auto;
    height: auto;
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
    padding: 1rem;
  }
  .admin-brand { padding: 0 1rem 0 0; }
  .admin-nav { flex-direction: row; flex-wrap: wrap; }
  .admin-nav a { padding: 0.5rem 0.8rem; border-left: none; border-bottom: 3px solid transparent; }
  .admin-nav a.is-active { border-left: none; border-bottom-color: var(--accent); }
  .admin-side-bottom { margin: 0 0 0 auto; border: none; padding: 0; flex-direction: row; gap: 1rem; }
}

/* ===== Correctifs boutons-liens (texte toujours lisible) ===== */
a.btn-primary, a.btn-primary:hover, a.btn-primary:focus { color: var(--blanc); text-decoration: none; }
.space-card a.btn, .space a.btn, .auth a.btn { color: var(--blanc); }
.space-card a.btn:hover, .space a.btn:hover, .auth a.btn:hover { color: var(--blanc); text-decoration: none; }
.space-card a.btn-outline, .space a.btn-outline, .auth a.btn-outline { color: var(--texte-clair); }

/* ===== Code d'invitation ===== */
.invite-box { display: flex; flex-direction: column; gap: 0.8rem; align-items: stretch; }
.invite-code {
  font-family: ui-monospace, "Courier New", monospace;
  font-size: 1.05rem;
  letter-spacing: 0.12em;
  text-align: center;
  background: var(--fond-sombre-fonce);
  border: 1px dashed var(--bordure-sur-sombre);
  color: var(--texte-clair-fort);
  padding: 0.7rem 0.9rem;
  border-radius: 8px;
  word-break: break-all;
}
.invite-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.copy-btn.copied { background: var(--statut-libre); }

/* Formulaires admin sur plusieurs colonnes + messages */
.form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0 1.2rem; }
.form-row p { margin: 0 0 0.9rem; }
.admin-message {
  background: var(--fond-carte);
  border-left: 3px solid var(--accent);
  padding: 0.7rem 1rem;
  border-radius: 4px;
  color: var(--texte-clair-fort);
  margin-bottom: 1.2rem;
}

/* ===========================================================
   PAGE CONCEPT : dossier officiel (haut) puis immersion (bas)
   =========================================================== */
:root { --ochre: #e0a516; --ochre-clair: #f3d877; --ochre-bord: #b9871a; --back-encre: #1d1a12; }

/* --- Partie dossier (D.A du site) --- */
.concept-doc { background: var(--fond-creme); color: var(--texte-sombre); }
.doc-inner { max-width: 840px; margin: 0 auto; padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 5vw, 3rem); }
.doc-title { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: clamp(2.4rem, 6vw, 4rem); line-height: 1; }
.doc-badge { margin: 0.7rem 0 1rem; color: var(--texte-secondaire-sombre); }
.doc-badge .accent { color: var(--accent); font-weight: 700; }
.doc-rule { border: none; border-top: 2px solid var(--texte-sombre); margin: 1rem 0 2.6rem; }
.doc-step { display: grid; grid-template-columns: auto 1fr; gap: 1.4rem; margin-bottom: 2.6rem; }
.doc-step-num { display: flex; flex-direction: column; align-items: center; gap: 0.6rem; }
.doc-step-num .num { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: 2.4rem; color: var(--accent); line-height: 1; }
.doc-step-label { writing-mode: vertical-rl; transform: rotate(180deg); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--texte-discret); }
.doc-step-body h2 { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: clamp(1.5rem, 3.5vw, 2.2rem); margin-bottom: 0.8rem; }
.doc-step-body p { color: var(--texte-secondaire-sombre); line-height: 1.65; margin-bottom: 0.8rem; }
.doc-table { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; border: 1px solid var(--bordure-claire); padding: 1.3rem; margin: 0.5rem 0 2rem; }
.doc-col h3 { font-size: 1rem; margin-bottom: 0.9rem; }
.doc-col ul { list-style: none; padding: 0; margin: 0; }
.doc-col li { position: relative; padding-left: 1.5rem; margin-bottom: 0.7rem; color: var(--texte-secondaire-sombre); }
.doc-col li::before { content: ""; position: absolute; left: 0; top: 0.3em; width: 0.7rem; height: 0.7rem; background: var(--texte-sombre); }
.doc-signal { font-family: ui-monospace, "Courier New", monospace; font-size: 0.8rem; color: var(--texte-discret); text-align: center; margin-top: 1.6rem; }
.doc-stamp { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: clamp(1.6rem, 4vw, 2.6rem); text-align: center; letter-spacing: 0.12em; text-transform: uppercase; margin-top: 0.6rem; }

/* --- Bande de transition (glitch) --- */
.concept-transition { background: var(--fond-sombre-fonce); text-align: center; padding: clamp(2rem, 5vw, 3.2rem) 1rem; }
.glitch {
  position: relative;
  display: inline-block;
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(1.4rem, 4vw, 2.4rem);
  letter-spacing: 0.15em;
  color: var(--texte-creme);
  text-transform: uppercase;
}
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; left: 0; top: 0; width: 100%; overflow: hidden; }
.glitch::before { color: #2f9389; clip-path: inset(0 0 55% 0); animation: glitch-a 2.4s infinite linear alternate; }
.glitch::after { color: #7b3ff2; clip-path: inset(55% 0 0 0); animation: glitch-b 2.4s infinite linear alternate; }
@keyframes glitch-a { 0% { transform: translateX(2px); } 50% { transform: translateX(-1px); } 100% { transform: translateX(2px); } }
@keyframes glitch-b { 0% { transform: translateX(-2px); } 50% { transform: translateX(1px); } 100% { transform: translateX(-2px); } }
@media (prefers-reduced-motion: reduce) { .glitch::before, .glitch::after { animation: none; } }

/* --- Partie immersion Backrooms (ocre, manuscrit) --- */
.backrooms { background: var(--ochre); color: var(--back-encre); font-family: "Segoe Print", "Bradley Hand", "Comic Sans MS", cursive; }
.back-inner { max-width: 840px; margin: 0 auto; padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 5vw, 3rem) clamp(3rem, 6vw, 4.5rem); }
.back-hero { text-align: center; font-family: inherit; font-weight: 400; font-size: clamp(2rem, 6vw, 3.4rem); margin-bottom: 2.6rem; }
.back-step { display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; margin-bottom: 2.6rem; }
.back-num { font-size: 2.2rem; font-weight: 700; color: rgba(0, 0, 0, 0.28); }
.back-body h2 { font-family: inherit; font-weight: 400; font-size: clamp(1.5rem, 4vw, 2.2rem); margin-bottom: 0.8rem; }
.back-body p { line-height: 1.7; margin-bottom: 0.8rem; }
.back-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; margin-top: 1.2rem; }
.back-card { background: var(--ochre-clair); border: 1px solid var(--ochre-bord); padding: 1rem; }
.back-card h3 { font-family: inherit; font-weight: 700; font-size: 1.1rem; margin-bottom: 0.4rem; }
.back-card p { font-size: 0.95rem; line-height: 1.5; }
.back-team { display: grid; grid-template-columns: 220px 1fr; gap: 1.6rem; align-items: center; }
.team-img { aspect-ratio: 3 / 4; background: var(--ochre-clair); border: 1px solid var(--ochre-bord); display: grid; place-items: center; transform: rotate(-6deg); font-size: 1.2rem; }
.back-timeline { list-style: none; padding: 0; margin: 0.5rem 0 0; position: relative; }
.back-timeline::before { content: ""; position: absolute; left: 0.4rem; top: 0.4rem; bottom: 0.4rem; width: 2px; background: rgba(0, 0, 0, 0.4); }
.back-tl-step { position: relative; padding-left: 2.2rem; padding-bottom: 1.8rem; }
.back-tl-step:last-child { padding-bottom: 0; }
.back-tl-step::before { content: ""; position: absolute; left: 0; top: 0.2rem; width: 0.9rem; height: 0.9rem; background: var(--back-encre); transform: rotate(45deg); }
.back-tl-step h3 { font-family: inherit; font-weight: 700; font-size: 1.2rem; margin-bottom: 0.3rem; }
.back-tl-step p { font-size: 0.95rem; line-height: 1.5; }
.back-end { text-align: center; margin-top: 2.6rem; }
.back-end p { font-size: 1.3rem; margin-bottom: 0.3rem; }
.back-surface { display: inline-block; margin-top: 1.2rem; background: transparent; border: 2px solid var(--back-encre); color: var(--back-encre); padding: 0.6rem 1.4rem; font-family: inherit; font-size: 1.05rem; cursor: pointer; }
.back-surface:hover, .back-surface:focus { background: var(--back-encre); color: var(--ochre); }
@media (max-width: 640px) { .doc-table, .back-team { grid-template-columns: 1fr; } .back-team .team-img { max-width: 220px; } }

/* ===== Boutons icones (poubelle, crayon) ===== */
.btn-icone {
  display: inline-grid;
  place-items: center;
  width: 2.1rem;
  height: 2.1rem;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  background: var(--bordure-champ);
  color: var(--texte-clair-fort);
  transition: background 0.15s ease;
}
.btn-icone svg { width: 1.05rem; height: 1.05rem; }
/* On force la specificite pour passer devant la regle generale .admin-main button */
.btn-icone.btn-suppr, .admin-main .btn-icone.btn-suppr { background: #5a2b2b; color: #f4c9c9; }
.btn-icone.btn-suppr:hover, .btn-icone.btn-suppr:focus,
.admin-main .btn-icone.btn-suppr:hover { background: var(--statut-complet); color: #fff; }

/* ===== Fenetre de confirmation de suppression ===== */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: grid;
  place-items: center;
  z-index: 100;
  padding: 1rem;
}
.modal-overlay[hidden] { display: none; }
.modal-box {
  background: var(--fond-sombre-fonce);
  border: 1px solid var(--bordure-champ);
  border-radius: 10px;
  padding: 1.6rem;
  max-width: 460px;
  width: 100%;
  color: var(--texte-clair);
}
.modal-box h2 { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; color: var(--texte-creme); margin: 0 0 0.8rem; }
.modal-warn { color: #e7a3a3; font-size: 0.92rem; }
.modal-check { display: flex; align-items: center; gap: 0.5rem; margin: 1.1rem 0; color: var(--texte-clair); }
.modal-actions { display: flex; justify-content: flex-end; gap: 0.6rem; }
.btn-modal-annuler { background: transparent; border: 1px solid var(--bordure-sur-sombre); color: var(--texte-clair); border-radius: 6px; padding: 0.5em 1em; cursor: pointer; }
.btn-modal-suppr { background: var(--statut-complet); border: none; color: #fff; border-radius: 6px; padding: 0.5em 1.1em; cursor: pointer; }
.btn-modal-suppr:disabled { opacity: 0.5; cursor: not-allowed; }

/* ===== Jauge de mot de passe ===== */
.pwd-meter { font-size: 0.85rem; margin: 0.4rem 0 0; min-height: 1.1em; }
.pwd-meter.ok { color: var(--statut-libre); }
.pwd-meter.faible { color: var(--statut-complet); }

/* ===== CRUD admin : bouton ajouter, cellule actions ===== */
a.btn-icone { text-decoration: none; }
.actions-cell { display: flex; gap: 0.45rem; align-items: center; }
.actions-cell form { margin: 0; }
.btn-ajout {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--accent);
  color: var(--blanc);
  text-decoration: none;
  border-radius: 6px;
  padding: 0.55em 1.1em;
  font-weight: 700;
  margin-bottom: 1rem;
}
/* On force la couleur du texte pour passer devant la regle .admin-main a */
.admin-main a.btn-ajout, .btn-ajout, .btn-ajout:hover, .btn-ajout:focus { color: var(--blanc); }
.btn-ajout:hover, .btn-ajout:focus { background: var(--accent-hover); }
.admin-form { max-width: 620px; }
.admin-form p { margin: 0 0 1rem; }
.admin-form .form-actions { display: flex; gap: 0.6rem; align-items: center; margin-top: 0.5rem; }
.admin-form .form-actions a { color: var(--texte-discret-clair); }
.produit-actuel { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 0.5rem; }
.produit-actuel img { width: 70px; height: 70px; object-fit: cover; border-radius: 6px; }

/* ===== Renommer une equipe (back-office) ===== */
.admin-rename { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-top: 0.6rem; }
.admin-rename input { flex: 1; min-width: 180px; }

/* ===== Back to top ===== */
.back-to-top {
  position: fixed;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  width: 3rem;
  height: 3rem;
  display: grid;
  place-items: center;
  background: var(--accent);
  color: var(--blanc);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  z-index: 50;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s, background 0.15s ease, box-shadow 0.2s ease;
}
.back-to-top svg { display: block; }
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover, .back-to-top:focus {
  background: var(--accent-hover);
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.34);
}
.back-to-top:focus-visible { outline: 2px solid var(--blanc); outline-offset: 2px; }

/* ===== Auth (connexion / inscription) ===== */
.auth { background: var(--fond-sombre); }
.auth-inner {
  max-width: 560px;
  margin: 0 auto;
  padding: clamp(2.5rem, 7vw, 5rem) clamp(1rem, 5vw, 3rem);
  text-align: center;
}
.auth-inner--wide { max-width: 900px; }
.auth-media {
  aspect-ratio: 3 / 1;
  background: var(--placeholder-image) url("../img/eagle.svg") no-repeat center / 110px;
  border-radius: 2px;
  margin-bottom: 1.6rem;
}
.auth-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5.5vw, 3.4rem);
  color: var(--texte-creme);
  margin-bottom: 0.6rem;
}
.auth-sub { color: var(--texte-secondaire-clair); margin-bottom: 1.8rem; }
.auth-form { display: flex; flex-direction: column; gap: 1rem; text-align: left; }
.auth-form--grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.auth-form--grid .full,
.auth-form .btn-block { grid-column: 1 / -1; }
.auth-field { display: flex; flex-direction: column; gap: 0.35rem; }
.auth-field > span { font-size: 0.85rem; color: var(--texte-discret-clair); letter-spacing: 0.02em; }
.auth-switch { margin-top: 1.4rem; color: var(--texte-secondaire-clair); font-size: 0.95rem; }
.auth-switch a { color: var(--accent); text-decoration: none; }
.auth-switch a:hover, .auth-switch a:focus { text-decoration: underline; }

/* ===== Boutique / Magasin ===== */
.shop-head {
  background: var(--fond-sombre);
  color: var(--texte-clair);
  text-align: center;
  padding: clamp(2.5rem, 6vw, 4.5rem) clamp(1rem, 5vw, 3rem);
}
.shop-title {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: clamp(2.4rem, 6vw, 4rem);
  color: var(--texte-creme);
}
.shop-sub {
  margin: 0.6rem auto 0;
  max-width: 48ch;
  color: var(--texte-secondaire-clair);
  line-height: 1.6;
}
.shop-grid-wrap { background: var(--fond-creme); }
.product-grid {
  list-style: none;
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) clamp(1rem, 5vw, 3rem);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: clamp(1.2rem, 3vw, 2rem);
}
.product-card {
  background: var(--blanc);
  border: 1px solid var(--bordure-creme);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.product-media {
  aspect-ratio: 3 / 4;
  background: var(--placeholder-concept) url("../img/eagle.svg") no-repeat center / 42%;
}
.product-body {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  flex: 1;
  padding: 1.1rem 1.2rem 1.3rem;
  color: var(--texte-sombre);
}
.product-cat {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--texte-discret);
}
.product-name {
  font-family: "PostNoBills Jaffna", sans-serif;
  font-weight: 800;
  font-size: 1.25rem;
}
.product-desc { color: var(--texte-secondaire-sombre); font-size: 0.92rem; flex: 1; }
.product-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: 0.6rem;
}
.product-price { font-family: "PostNoBills Jaffna", sans-serif; font-weight: 800; font-size: 1.3rem; }
.product-foot .btn { padding: 0.5em 1em; font-size: 0.9rem; }

/* ===== Responsive ===== */
@media (max-width: 820px) {
  .concept-inner { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .day-grid { grid-template-columns: repeat(4, 1fr); }
  .footer-inner { grid-template-columns: 1fr; }
  .auth-form--grid { grid-template-columns: 1fr; }
  .btn { width: 100%; justify-content: center; }
  .btn-row { width: 100%; }
}
