/*
  Style sheet for the Olami Montpellier donation platform.
  Palette bordeaux / design propre.
*/

/* ======================= THEME ======================= */
:root{
  --primary-color:#b71c45;
  --primary-dark:#951637;
  --secondary-color:#f8f9fb;
  --text-color:#2c3e50;
  --card-bg:#ffffff;
  --shadow:0 4px 12px rgba(0,0,0,0.08);
  --border-radius:12px;
  --border-soft:rgba(0,0,0,0.04);
}

/* ======================= BASE ======================= */
body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:var(--secondary-color);
  color:var(--text-color);
  line-height:1.6;
}
a{ color:var(--primary-color); text-decoration:none; }

/* ======================= HEADER ======================= */
header{
  background:linear-gradient(90deg,var(--primary-color) 0%,var(--primary-dark) 100%);
  padding:20px; display:flex; justify-content:space-between; align-items:center; color:#fff; box-shadow:var(--shadow);
}
header img.logo{ height:60px; object-fit:contain; }
nav a{ margin-left:15px; color:#fff; font-weight:600; position:relative; }
nav a::after{ content:''; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:#fff; transition:width .3s; }
nav a:hover::after{ width:100%; }

/* ======================= CONTAINER ======================= */
.container{ max-width:1200px; margin:0 auto; padding:20px; }

/* ======================= LISTE CAMPAGNES ======================= */
.campaigns-grid{ display:flex; flex-wrap:wrap; gap:20px; }
.campaign-card{
  background:var(--card-bg); border-radius:var(--border-radius); box-shadow:var(--shadow);
  padding:24px; width:calc(50% - 20px); box-sizing:border-box; display:flex; flex-direction:column; justify-content:space-between;
  transition:transform .2s;
}
.campaign-card:hover{ transform:translateY(-4px); box-shadow:0 8px 20px rgba(0,0,0,.12); }
.campaign-card h3{ margin-top:0; color:var(--primary-color); }

.button{
  display:inline-block; background:var(--primary-color); color:#fff; padding:12px 18px; border-radius:8px; font-weight:600; text-align:center; cursor:pointer;
  transition:background-color .3s ease, transform .2s;
}
.button:hover{ background:var(--primary-dark); transform:translateY(-2px); }

/* ======================= PAGE CAMPAGNE – HEADER ======================= */
.campaign-header{ margin-top:20px; text-align:center; }
#page-heading{
  font-size:40px; font-weight:700; color:#fff; margin:50px auto 20px; padding:20px 30px;
  background:linear-gradient(135deg,#b4003a,#90002c); border-radius:10px; text-transform:uppercase; letter-spacing:1.5px;
  box-shadow:0 4px 8px rgba(0,0,0,.15); width:fit-content; transition:all .3s ease;
}
#page-heading:hover{
  background:#fff; color:transparent; background-image:linear-gradient(135deg,#b4003a,#90002c);
  -webkit-background-clip:text; background-clip:text;
}
.campaign-timer{ margin:10px 0; font-weight:600; font-size:1.1rem; color:var(--primary-color); }

/* Deadline */
.deadline-banner{ display:flex; align-items:center; gap:16px; font-weight:600; color:#1f2937; }
.deadline-text-before,.deadline-text-after{ font-size:18px; }
.deadline-circle{
  --pct:0; --ring-bg:#e5e7eb; --ring-fg:#b71c45;
  width:84px; height:84px; border-radius:50%;
  background:conic-gradient(var(--ring-fg) calc(var(--pct)*1%), var(--ring-bg) 0);
  display:grid; place-items:center; padding:8px;
}
.deadline-circle-inner{ width:100%; height:100%; border-radius:50%; background:#fff; display:grid; place-items:center; }
.deadline-days{ font-size:26px; font-weight:800; line-height:1; color:#111827; }
.deadline-day-unit{ font-size:14px; margin-left:4px; color:#6b7280; }
@media (max-width:640px){
  .deadline-text-before,.deadline-text-after{ font-size:16px; }
  .deadline-circle{ width:70px; height:70px; }
  .deadline-days{ font-size:22px; }
}

/* KPI ring */
.kpi-days-wrap{ display:inline-flex; align-items:center; gap:10px; }
.time-ring{
  --pct:0; --ring-bg:#e5e7eb; --ring-fg:#b71c45;
  width:44px; height:44px; background:conic-gradient(var(--ring-fg) calc(var(--pct)*1%), var(--ring-bg) 0);
  border-radius:50%; padding:6px; display:grid; place-items:center;
}
.time-ring-inner{ width:100%; height:100%; background:#fff; border-radius:50%; display:grid; place-items:center; }
.time-ring-inner [data-days]{ font-size:14px; font-weight:800; color:#111827; }

/* ======================= KPI / OBJECTIFS ======================= */
.goals-container{ margin:20px 0; }
.kpi-goal{ background:#f3f4f6; border-radius:12px; padding:18px 22px; position:relative; margin-bottom:18px; }
.kpi-goal::before,.kpi-goal::after{ content:""; position:absolute; left:14px; right:14px; height:1px; background:#e5e7eb; }
.kpi-goal::before{ top:10px; } .kpi-goal::after{ bottom:54px; }
.kpi-row{ display:grid; grid-template-columns:1fr 2fr 1fr; align-items:center; gap:24px; padding:14px 0 22px 0; }
.kpi-col{ display:flex; flex-direction:column; align-items:center; text-align:center; }
.kpi-col + .kpi-col{ border-left:1px solid #e5e7eb; }
.kpi-percent{ display:none !important; }
.kpi-title{ font-size:20px; font-weight:700; color:#374151; margin-bottom:6px; }
.kpi-main{ font-size:42px; font-weight:800; color:#1f2937; line-height:1.1; }
.kpi-sub{ margin-top:6px; font-size:18px; color:#4b5563; }
.kpi-donors{ font-size:44px; font-weight:800; color:#1f2937; line-height:1; }
.kpi-donors-label{ margin-top:6px; font-size:18px; color:#4b5563; }
.kpi-progress{ margin-top:18px; width:100%; height:14px; background:#e5e7eb; border-radius:999px; overflow:hidden; }
.kpi-fill{ height:100%; background:#b71c45; width:0%; border-radius:999px; transition:width .5s ease; }
@media (max-width:860px){
  .kpi-row{ grid-template-columns:1fr; gap:12px; }
  .kpi-col + .kpi-col{ border-left:none; }
  .kpi-goal::after{ bottom:60px; }
}

/* ======================= BADGES IMPACT ======================= */
.impact-badges-bar{ display:flex; flex-wrap:wrap; gap:16px; margin:20px 0 30px; justify-content:center; }
.impact-badge{
  background:#fff; border:1px solid #e5e7eb; border-radius:12px; box-shadow:0 6px 16px rgba(17,24,39,.06);
  padding:12px 16px; min-width:110px; max-width:140px; cursor:pointer; text-align:center;
  transition:box-shadow .15s ease, transform .1s ease; display:flex; flex-direction:column; align-items:center;
}
.impact-badge:hover{ box-shadow:0 10px 24px rgba(17,24,39,.12); transform:translateY(-2px); }
.impact-badge-icon{
  width:70px; height:70px; border-radius:50%; background:#f3f4f6; border:2px solid #e5e7eb; overflow:hidden;
  display:flex; align-items:center; justify-content:center; margin-bottom:8px;
}
.impact-badge-icon img{ width:100%; height:100%; object-fit:cover; border-radius:50%; }
.impact-badge-fallback{ font-weight:700; font-size:14px; color:#374151; }
.impact-badge-label{ font-size:13px; font-weight:600; color:#111827; line-height:1.3; text-wrap:balance; text-align:center; }
.impact-badge-amount{ font-size:14px; font-weight:700; color:#b71c45; margin-top:4px; text-align:center; }

/* ======================= GRID PRINCIPALE ======================= */
/* >>> CLEF : 2 lignes explicites en tête.
     - row 1 : vidéo (col 1)  + donbox (col 2, commence en row1)
     - row 2 : bandeau violet (col 1) + DONBOX s’étend (row1 → row2)
     - row 3 : présentation & donateurs
*/
.campaign-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  grid-template-rows:auto auto;   /* ✅ deux lignes fixes au-dessus */
  grid-auto-rows:auto;
  column-gap:24px;
  row-gap:16px;
  margin-bottom:40px;
}

/* Ligne 1 */
.grid-video  { grid-column:1; grid-row:1; align-self:start; }
.grid-donbox { grid-column:2; grid-row:1 / span 2; align-self:start; } /* ✅ s'étend sur 2 lignes */

/* Ligne 2 (bandeau sous la vidéo) */
.grid-left-match{ grid-column:1; grid-row:2; }

/* Ligne 3 */
.grid-presentation{ grid-column:1; grid-row:3; }
.grid-donors      { grid-column:2; grid-row:3; }

/* Vidéo */
.video-container{
  width:100%; aspect-ratio:16/9; max-height:440px;
  background:#000; border-radius:16px; overflow:hidden; position:relative;
}
.video-container iframe,.video-container img,.video-container div{
  position:absolute; inset:0; width:100%; height:100%; border:0; object-fit:cover; border-radius:16px;
}

/* ======================= DON BOX ======================= */
#donation-section,.donbox,.don-box{
  background:#fff; border-radius:12px; box-shadow:0 12px 32px rgba(17,24,39,.08); border:1px solid var(--border-soft);
  display:flex; flex-direction:column; gap:16px; padding:20px; box-sizing:border-box;
}
.donbox-header-card{
  display:flex; align-items:flex-start; justify-content:space-between;
  background:linear-gradient(90deg, rgba(183,28,69,.06) 0%, rgba(183,28,69,.015) 100%);
  border:2px solid var(--primary-color); border-radius:12px; padding:12px 16px;
  box-shadow:0 10px 24px rgba(183,28,69,.12); line-height:1.2;
}
.donbox-header-left{ max-width:70%; }
.donbox-main-title{ margin:0; font-size:1.1rem; font-weight:800; color:var(--primary-color); letter-spacing:-.03em; text-transform:uppercase; }
.donbox-subtitle{ margin-top:6px; font-size:.88rem; color:#6b7280; font-weight:500; line-height:1.3; }
.donbox-type-badge{
  background:var(--primary-color); color:#fff; font-size:.8rem; font-weight:700; padding:8px 10px; border-radius:10px; text-transform:uppercase;
  line-height:1.2; box-shadow:0 8px 18px rgba(183,28,69,.35); border:2px solid #fff; white-space:nowrap;
}

.amount-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px 16px; }
.amount-chip{
  display:flex; align-items:center; justify-content:center; height:44px; border-radius:10px; background:var(--primary-color); border:1px solid var(--primary-color);
  color:#fff; font-weight:700; font-size:15px; line-height:1; cursor:pointer; box-shadow:0 16px 24px rgba(183,28,69,.2); transition:filter .15s, box-shadow .15s, transform .08s;
}
.amount-chip:hover{ filter:brightness(1.05); transform:translateY(-1px); box-shadow:0 20px 32px rgba(183,28,69,.3); }
.amount-chip.active{ background:#fff; color:var(--primary-color); border:2px solid var(--primary-color); box-shadow:0 0 0 3px rgba(183,28,69,.15); }
@media (max-width:480px){ .amount-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }

.amount-input{
  display:flex; align-items:center; gap:8px; border:1px solid #d1d5db; border-radius:10px; padding:10px 12px; background:#fff; font-size:16px; font-weight:600; color:#111827;
}
.amount-input input[type="number"]{ width:100%; border:none; outline:none; font-size:16px; font-weight:600; color:#111827; background:transparent; }
.amount-input .suffix{ color:#6b7280; font-weight:600; font-size:14px; }

.split-card{ border:1px solid #d1d5db; border-radius:10px; background:#fff; box-shadow:0 4px 10px rgba(0,0,0,.04); padding:12px 14px; display:flex; flex-direction:column; gap:10px; }
.split-row-top{ display:flex; align-items:flex-start; gap:10px; line-height:1.3; }
.split-checkbox{ width:18px; height:18px; border-radius:4px; border:2px solid var(--primary-color); accent-color:var(--primary-color); cursor:pointer; flex-shrink:0; margin-top:2px; }
.split-row-title{ font-size:.9rem; font-weight:700; color:#111827; line-height:1.2; }
.split-row-desc{ font-size:.8rem; color:#6b7280; font-weight:400; line-height:1.3; margin-top:2px; }
.split-row-bottom{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:.8rem; color:#374151; }
.split-row-bottom select{ border:1px solid #d1d5db; border-radius:8px; padding:6px 8px; font-size:.8rem; min-width:90px; outline:none; background:#fff; }
.split-inline-hint{ font-size:.8rem; font-weight:600; color:#374151; }

.btn-primary{
  display:flex; align-items:center; justify-content:center; height:44px; width:100%;
  background:#b71c45; color:#fff; border:none; border-radius:10px; font-weight:700; font-size:16px; line-height:1; cursor:pointer;
  box-shadow:0 8px 20px rgba(183,28,69,.25); transition:filter .15s, transform .08s;
}
.btn-primary:hover{ filter:brightness(1.05); transform:translateY(-1px); }

.donbox-footer{ text-align:center; font-size:13px; color:#6b7280; line-height:1.4; }
.donbox-type-static{ display:block; font-weight:600; color:var(--primary-color); font-size:13px; text-transform:uppercase; letter-spacing:.03em; margin-bottom:4px; }

/* ======================= DONATEURS ======================= */
.donor-card{
  background:#fff; border-radius:12px; box-shadow:0 12px 32px rgba(17,24,39,.08); border:1px solid var(--border-soft);
  display:flex; flex-direction:column; overflow:hidden;
}
.donor-card-header{
  border-bottom:1px solid rgba(0,0,0,.06); background:#fff; padding:16px 20px 12px; display:flex; flex-direction:column; gap:10px;
}
.donor-card-title{ font-weight:700; font-size:1rem; color:#111827; line-height:1.3; }
.donor-search-input{
  width:100%; border:1px solid #d1d5db; border-radius:8px; padding:10px 12px; font-size:.9rem; line-height:1.3; outline:none; background:#fff; color:#111827; box-sizing:border-box;
}
.donor-search-input:focus{ border-color:var(--primary-color); box-shadow:0 0 0 3px rgba(183,28,69,.18); }
.donor-card-body{ max-height:260px; overflow-y:auto; padding:12px 20px 20px; display:flex; flex-direction:column; gap:12px; }
.donor-row{
  display:flex; justify-content:space-between; align-items:flex-start; background:#f9fafb; border:1px solid #e5e7eb; border-radius:10px; padding:10px 12px;
  font-size:.9rem; line-height:1.4; color:#1f2937;
}
.donor-row-left{ display:flex; flex-direction:column; min-width:0; }
.donor-name{ font-weight:600; color:#111827; word-break:break-word; }
.donor-message{ font-size:.8rem; color:#6b7280; margin-top:2px; line-height:1.3; word-break:break-word; }
.donor-amount{ font-weight:700; color:var(--primary-color); white-space:nowrap; margin-left:12px; flex-shrink:0; font-size:.9rem; }

/* ======================= TABS PRÉSENTATION/ÉQUIPE ======================= */
.tab-card{
  background:#fff; border-radius:12px; box-shadow:0 12px 32px rgba(17,24,39,.08); border:1px solid var(--border-soft);
  display:flex; flex-direction:column; overflow:hidden;
}
.tab-card-header{
  display:flex; flex-wrap:wrap; gap:8px;
  background:linear-gradient(90deg, rgba(183,28,69,.06) 0%, rgba(183,28,69,.015) 100%);
  border-bottom:1px solid rgba(0,0,0,.06); padding:8px 12px;
}
.tab-btn{
  appearance:none; border:1px solid var(--primary-color); background:#fff; color:var(--primary-color);
  font-weight:600; font-size:.9rem; line-height:1.2; border-radius:8px; padding:8px 12px; cursor:pointer;
  box-shadow:0 8px 18px rgba(183,28,69,.15); transition:all .15s ease;
}
.tab-btn:hover{ filter:brightness(1.05); transform:translateY(-1px); box-shadow:0 12px 24px rgba(183,28,69,.25); }
.tab-btn-active{ background:var(--primary-color); color:#fff; border-color:var(--primary-color); box-shadow:0 12px 24px rgba(183,28,69,.4); }
.tab-card-body{ padding:16px 20px; font-size:.95rem; color:#1f2937; line-height:1.5; }
.tab-panel{ display:none; }
.tab-panel-active{ display:block; }
.tab-panel-inner{ white-space:pre-line; color:#2c3e50; font-size:1rem; line-height:1.55; }

/* Équipe */
.teams-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.team-card.team-pro{
  border:1px solid #e5e7eb; border-radius:12px; background:#fff; box-shadow:0 8px 22px rgba(2,6,23,.06);
  padding:16px; display:flex; flex-direction:column; gap:12px;
}
.team-header{ display:flex; align-items:center; gap:12px; }
.team-avatar{ width:56px; height:56px; border-radius:50%; object-fit:cover; border:2px solid #fff; box-shadow:0 6px 14px rgba(2,6,23,.15); }
.team-avatar.fallback{ display:grid; place-items:center; background:#f3f4f6; color:#374151; font-weight:800; }
.team-title{ margin:0; font-size:1rem; color:#111827; }
.team-goal-line{ font-size:.85rem; color:#6b7280; }
.team-desc{ margin:0; font-size:.92rem; color:#374151; }
.team-stats{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ display:flex; gap:6px; align-items:baseline; background:#f8fafc; border:1px solid #e5e7eb; border-radius:999px; padding:6px 10px; font-size:.86rem; }
.chip-accent{ background:#fff5f7; border-color:rgba(183,28,69,.25); }
.team-progress{ width:100%; height:10px; background:#f1f5f9; border-radius:999px; overflow:hidden; }
.team-progress-fill{ height:100%; background:linear-gradient(90deg,#b71c45,#e63c74); width:0%; }
.team-progress-legend{ display:flex; justify-content:space-between; font-size:.78rem; color:#6b7280; }
.team-link-btn{ margin-left:auto; background:#fff; border:1px solid #e5e7eb; border-radius:999px; padding:6px 10px; cursor:pointer; font-weight:600; }
.team-btn{ display:inline-block; margin-top:4px; }

/* ======================= MINI-GALERIE / CAROUSEL ======================= */
.carousel-container{ position:relative; max-width:100%; margin:20px 0; padding:8px 0; }
.carousel{
  display:flex; gap:16px; padding:12px 56px; overflow-x:auto; scroll-behavior:smooth; -webkit-overflow-scrolling:touch; align-items:center;
}
.carousel img{
  width:260px; height:170px; object-fit:cover; border-radius:16px; border:2px solid rgba(255,255,255,.8);
  background:#f3f4f6; box-shadow:0 10px 24px rgba(17,24,39,.12); cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, opacity .18s ease; flex-shrink:0; opacity:.95;
}
.carousel img:hover,.carousel img.active{
  transform:translateY(-6px) scale(1.03);
  box-shadow:0 20px 40px rgba(17,24,39,.18); border-color:rgba(183,28,69,.28); opacity:1;
}
@media (max-width:700px){
  .carousel{ padding:10px 48px; }
  .carousel img{ width:190px; height:125px; border-radius:12px; }
}
@media (max-width:480px){
  .carousel img{ width:150px; height:100px; }
}
.carousel-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:52px; height:52px; border-radius:999px; border:none; cursor:pointer;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(245,247,250,.9));
  box-shadow:0 10px 24px rgba(17,24,39,.18), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter:blur(6px); display:grid; place-items:center;
  transition:transform .12s ease, box-shadow .18s ease, opacity .18s ease; opacity:.96; z-index:30;
}
.carousel-btn:hover{ transform:translateY(-50%) scale(1.06); box-shadow:0 16px 36px rgba(17,24,39,.22); }
.carousel-btn:active{ transform:translateY(-50%) scale(.98); }
.carousel-btn:focus-visible{ outline:3px solid rgba(183,28,69,.35); outline-offset:2px; }
.carousel-prev{ left:8px; } .carousel-next{ right:8px; }
.carousel-btn .arrow{ font-size:22px; line-height:1; color:#0f172a; font-weight:700; user-select:none; }
.carousel-prev .arrow::before{ content:'‹'; } .carousel-next .arrow::before{ content:'›'; }
.carousel-dots{ display:flex; gap:8px; justify-content:center; margin-top:10px; }
.carousel-dots button{
  width:8px; height:8px; border-radius:999px; border:none; background:#e5e7eb; cursor:pointer; transition:transform .12s ease, background .18s ease;
}
.carousel-dots button.active{ background:#b71c45; transform:scale(1.2); }

/* LIGHTBOX */
.gallery-lightbox{
  position:fixed; inset:0; display:none; align-items:center; justify-content:center;
  background:rgba(3,6,10,.65); z-index:9999; padding:28px;
}
.gallery-lightbox.open{ display:flex; }
.gallery-lightbox .lightbox-inner{
  max-width:92%; max-height:92%; border-radius:12px; overflow:hidden; box-shadow:0 30px 80px rgba(2,6,23,.6); background:#000; position:relative;
}
.gallery-lightbox img{ display:block; width:100%; height:100%; object-fit:contain; background:#000; }
.lightbox-close{
  position:absolute; right:8px; top:8px; width:40px; height:40px; border-radius:999px; background:rgba(255,255,255,.92);
  display:grid; place-items:center; cursor:pointer; box-shadow:0 8px 24px rgba(0,0,0,.3); z-index:20;
}
.lightbox-close:after{ content:"✕"; font-size:18px; color:#111827; line-height:1; }

/* ======================= CONTACT ======================= */
#contact-form{
  max-width:600px; margin:0 auto; background:var(--card-bg); border-radius:var(--border-radius); box-shadow:var(--shadow);
  padding:20px; display:flex; flex-direction:column; gap:12px;
}
#contact-form input,#contact-form textarea{
  width:100%; padding:12px; border:1px solid #ccc; border-radius:8px; font-size:1rem; box-sizing:border-box;
}
#contact-form button{
  padding:14px; font-size:1rem; border:none; border-radius:8px; background:var(--primary-color); color:#fff; cursor:pointer;
  transition:background-color .3s ease, transform .2s;
}
#contact-form button:hover{ background:var(--primary-dark); transform:translateY(-2px); }

/* ======================= ADMIN ======================= */
.admin-container{ max-width:1200px; margin:0 auto; padding:20px; background:#fff; border-radius:12px; box-shadow:0 4px 12px rgba(0,0,0,.1); }
.admin-nav{ display:flex; gap:20px; margin-bottom:20px; }
.admin-nav button{ padding:10px 20px; border:none; border-radius:6px; background:#b71c45; color:#fff; cursor:pointer; transition:background-color .3s; }
.admin-nav button:hover{ background:#951637; }
table{ width:100%; border-collapse:collapse; margin-top:15px; }
th,td{ padding:10px; border-bottom:1px solid #ddd; text-align:left; }
th{ background:#f7f7f7; }
.form-section{ margin-top:20px; padding:15px; background:#f9fafb; border-radius:8px; border:1px solid #e0e0e0; }
.form-section input,.form-section textarea,.form-section select{ width:100%; padding:8px; margin-bottom:10px; border:1px solid #ccc; border-radius:6px; }
.form-section button{ padding:10px 16px; border:none; border-radius:6px; background:#b71c45; color:#fff; cursor:pointer; transition:background-color .3s; }
.form-section button:hover{ background:#951637; }

/* Bouton secondaire */
.btn-secondary{
  display:flex;align-items:center;justify-content:center; height:44px;width:100%;
  background:#fff;color:var(--primary-color); border:2px solid var(--primary-color); border-radius:10px;font-weight:800;font-size:15px;
  cursor:pointer;gap:8px; box-shadow:0 6px 16px rgba(183,28,69,.10);
  transition:transform .08s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.btn-secondary:hover{ transform:translateY(-1px); box-shadow:0 10px 24px rgba(183,28,69,.18); background:linear-gradient(0deg, rgba(183,28,69,.06), rgba(183,28,69,.06)); }
.btn-secondary:active{ transform:translateY(0); }
.split-card.disabled{ opacity:.45; pointer-events:none; filter:grayscale(0.2); }
.donor-message{ font-size:12px; color:#666; margin-top:2px; white-space:pre-wrap; }

/* ===== Bandeau "Campagne doublée" (format compact pour colonne gauche) ===== */
.grid-left-match{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:22px 24px; border-radius:16px;
  background:radial-gradient(120% 140% at 0% 0%, #7B61FF 0%, #5F5BFF 45%, #4B3FF0 100%);
  color:#fff; box-shadow:0 10px 28px rgba(33,28,87,.22), inset 0 1px 0 rgba(255,255,255,.10);
}
.match-left{ flex:1 1 auto; min-width:0; }
.match-right{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; }
.match-pill{
  display:inline-flex; align-items:center; gap:8px; padding:6px 12px; border-radius:999px;
  background:rgba(255,255,255,.14); font-weight:700; text-transform:uppercase; font-size:.85rem;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.22);
}
.match-title{ margin:10px 0 4px; font-size:clamp(1.05rem, 0.9rem + .9vw, 1.5rem); font-weight:800; }
.match-title .under{ padding:0 6px; border-radius:8px; background:rgba(255,255,255,.16); box-shadow:inset 0 0 0 1px rgba(255,255,255,.18); }
.match-sub{ margin:0; opacity:.95; font-weight:500; }
.x2-badge{ width:112px; height:112px; filter:drop-shadow(0 8px 18px rgba(0,0,0,.30)); }

/* Responsive : tout en pile, bandeau entre vidéo et donateurs */
@media (max-width:900px){
  .campaign-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;   /* vidéo puis bandeau */
    row-gap:16px;
  }
  .grid-video       { grid-column:1; grid-row:1; }
  .grid-donbox      { grid-column:1; grid-row:auto; } /* ne span plus */
  .grid-left-match  { grid-column:1; grid-row:2; }
  .grid-presentation{ grid-column:1; grid-row:3; }
  .grid-donors      { grid-column:1; grid-row:4; }
  .x2-badge{ width:96px; height:96px; }
}
/* ---- FORCE LA DISPOSITION EXACTE ---- */
.campaign-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) 420px !important;
  grid-template-rows:auto auto !important;   /* ligne1: vidéo | donbox  /  ligne2: bandeau sous la vidéo */
  grid-auto-rows:auto;
  column-gap:24px;
  row-gap:16px;
}

/* Colonne gauche */
.grid-video{ grid-column:1 !important; grid-row:1 !important; align-self:start; }

/* Colonne droite : donbox occupe L1 et L2 */
.grid-donbox{ grid-column:2 !important; grid-row:1 / 3 !important; align-self:start; }

/* Bandeau sous la vidéo (colonne gauche, ligne 2) */
.grid-left-match{
  grid-column:1 !important;
  grid-row:2 !important;
  margin:0 !important;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:22px 24px; border-radius:16px;
  background:radial-gradient(120% 140% at 0% 0%, #7B61FF 0%, #5F5BFF 45%, #4B3FF0 100%);
  color:#fff; box-shadow:0 10px 28px rgba(33,28,87,.22), inset 0 1px 0 rgba(255,255,255,.10);
}

/* Optionnel: rétrécit l’écart vidéo/bandeau */
.grid-video{ margin-bottom:0 !important; }

/* Responsive: pile tout, bandeau entre vidéo et reste */
@media (max-width:900px){
  .campaign-grid{
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
  }
  .grid-video{ grid-column:1 !important; grid-row:1 !important; }
  .grid-donbox{ grid-column:1 !important; grid-row:auto !important; }
  .grid-left-match{ grid-column:1 !important; grid-row:2 !important; }
}
/* ====== Contour "Stripe" + badge x2 pour la progression ====== */

/* Palette match (peut être ajustée) */
:root{
  --match-1: #6D5BFF;
  --match-2: #4B3FF0;
}

/* Contour dégradé et léger padding interne */
.goals-outline{
  position: relative;
  padding: 16px;                 /* espace pour le contour */
  border-radius: 16px;
  border: 2px solid transparent; /* on utilise la technique border-box */
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, var(--match-1), var(--match-2)) border-box;
  box-shadow: 0 10px 24px rgba(33,28,87,.12);
}

/* Réduit les marges internes des blocs KPI pour que tout rentre proprement */
.goals-outline .kpi-goal{ margin: 10px 0; }

/* Badge ×2 accroché au bord haut-droit du contour */
.goals-outline::after{
  content: "×" attr(data-match);  /* ex: ×2 ; lit la valeur depuis data-match */
  position: absolute;
  top: -18px;                     /* chevauche le bord */
  right: -18px;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font: 800 28px/1 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: #fff;

  /* look Stripe */
  background: radial-gradient(120% 120% at 30% 30%, #8C7CFF 0%, var(--match-1) 50%, var(--match-2) 100%);
  box-shadow: 0 10px 22px rgba(33,28,87,.35);
  outline: 6px solid #fff;       /* liseré blanc pour le détacher du fond */
}

/* (Optionnel) petite étiquette "impact" sous le ×2, à l'intérieur du badge */
.goals-outline::before{
  content: "impact";
  position: absolute;
  top: 28px;                      /* se positionne dans le badge */
  right: -18px;
  width: 72px;
  text-align: center;
  font: 700 11px/1 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: rgba(255,255,255,.95);
  pointer-events: none;
}
/* ==================== FIX RESPONSIVE GÉNÉRAL ==================== */

/* Petits écrans : header compact et nav en wrap */
@media (max-width: 768px){
  header { padding: 14px 16px; gap: 10px; flex-wrap: wrap; }
  header img.logo { height: 44px; }
  header nav { width: 100%; display: flex; gap: 12px; flex-wrap: wrap; }
  header nav a { margin: 0; font-size: .95rem; padding: 6px 0; }
}

/* Container respirant sur mobile */
@media (max-width: 768px){
  .container { padding: 14px; }
}

/* Titre de page plus court */
@media (max-width: 640px){
  #page-heading { font-size: 26px; padding: 12px 16px; margin: 28px auto 14px; }
}

/* Grille de campagne : ordre lisible sur mobile */
@media (max-width: 1024px){
  .campaign-grid{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    row-gap: 16px;
  }
  .grid-video        { grid-column: 1 !important; grid-row: 1 !important; }
  .grid-donbox       { grid-column: 1 !important; grid-row: auto !important; }
  .grid-left-match   { grid-column: 1 !important; grid-row: 2 !important; }
  .grid-presentation { grid-column: 1 !important; grid-row: 3 !important; }
  .grid-donors       { grid-column: 1 !important; grid-row: 4 !important; }
}

/* KPI : lignes en pile + tailles de police adaptées */
@media (max-width: 900px){
  .kpi-row{ grid-template-columns: 1fr; gap: 10px; }
  .kpi-col + .kpi-col{ border-left: 0; }
  .kpi-main   { font-size: 32px; }
  .kpi-title  { font-size: 18px; }
  .kpi-sub    { font-size: 16px; }
  .kpi-donors { font-size: 34px; }
}

/* Badges d’impact : carte plus étroite */
@media (max-width: 640px){
  .impact-badge{ min-width: 100px; max-width: 120px; padding: 10px 12px; }
  .impact-badge-icon{ width: 60px; height: 60px; }
  .impact-badge-amount{ font-size: 13px; }
}

/* Vidéo : ratio et bords sûrs */
@media (max-width: 768px){
  .video-container { max-height: none; aspect-ratio: 16/9; border-radius: 12px; }
  .video-container iframe { border-radius: 12px; }
}

/* DonBox : grilles et champs qui ne débordent pas */
@media (max-width: 768px){
  .donbox, #donation-section, .don-box { padding: 16px; border-radius: 10px; }
  .donbox-header-card { gap: 10px; padding: 10px 12px; }
  .donbox-header-left { max-width: 100%; }
  .donbox-main-title { font-size: 1rem; }
  .donbox-subtitle   { font-size: .85rem; }
  .donbox-type-badge { font-size: .75rem; padding: 6px 8px; }

  .amount-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 12px; }
  .amount-chip { height: 42px; font-size: 14px; }

  .amount-input { padding: 10px; }
  .amount-input input[type="number"] { font-size: 16px; }
  .amount-input .suffix { font-size: 13px; }

  .split-row-top { align-items: center; }
  .split-row-desc { font-size: .78rem; }
  .btn-primary, .btn-secondary { height: 44px; font-size: 15px; }
}

/* Donateurs : pas de débordement, wrap propre */
@media (max-width: 768px){
  .donor-card-body { max-height: 320px; }
  .donor-row{ gap: 8px; padding: 10px; }
  .donor-row-left{ min-width: 0; }
  .donor-name{ font-size: .95rem; word-break: break-word; }
  .donor-message{ font-size: .78rem; }
  .donor-amount{ font-size: .95rem; margin-left: 8px; }
}

/* Tabs présentation/équipes : boutons lisibles */
@media (max-width: 640px){
  .tab-card-header{ gap: 6px; padding: 6px 8px; }
  .tab-btn{ font-size: .85rem; padding: 7px 10px; }
  .tab-card-body{ padding: 14px; font-size: .95rem; }
  .teams-grid{ grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
}

/* Carousel : images plus petites, flèches discrètes */
@media (max-width: 700px){
  .carousel{ padding: 10px 40px; gap: 12px; }
  .carousel img{ width: 180px; height: 118px; border-radius: 12px; }
}
@media (max-width: 480px){
  .carousel{ padding: 8px 36px; gap: 10px; }
  .carousel img{ width: 150px; height: 96px; }
  .carousel-btn{ width: 42px; height: 42px; }
}

/* Bandeau ×2 : réduit la pastille pour éviter le chevauchement */
@media (max-width: 640px){
  .goals-outline{ padding: 12px; }
  .goals-outline::after{
    right: -14px; top: -14px; width: 58px; height: 58px; font-size: 22px; outline-width: 5px;
  }
  .goals-outline::before{ top: 22px; right: -14px; font-size: 10px; }
}

/* Petits détails anti-débordement globaux */
@media (max-width: 768px){
  .kpi-goal, .donor-card, .tab-card, .donbox { box-shadow: 0 8px 18px rgba(0,0,0,.08); }
  .deadline-banner{ gap: 10px; }
  .deadline-days{ font-size: 20px; }
  .deadline-circle{ width: 64px; height: 64px; }
}
/* ==================== FIX RESPONSIVE GÉNÉRAL ==================== */

/* Petits écrans : header compact et nav en wrap */
@media (max-width: 768px){
  header { padding: 14px 16px; gap: 10px; flex-wrap: wrap; }
  header img.logo { height: 44px; }
  header nav { width: 100%; display: flex; gap: 12px; flex-wrap: wrap; }
  header nav a { margin: 0; font-size: .95rem; padding: 6px 0; }
}

/* Container respirant sur mobile */
@media (max-width: 768px){
  .container { padding: 14px; }
}

/* Titre de page plus court */
@media (max-width: 640px){
  #page-heading { font-size: 26px; padding: 12px 16px; margin: 28px auto 14px; }
}

/* Grille de campagne : ordre lisible sur mobile */
@media (max-width: 1024px){
  .campaign-grid{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    row-gap: 16px;
  }
  .grid-video        { grid-column: 1 !important; grid-row: 1 !important; }
  .grid-donbox       { grid-column: 1 !important; grid-row: auto !important; }
  .grid-left-match   { grid-column: 1 !important; grid-row: 2 !important; }
  .grid-presentation { grid-column: 1 !important; grid-row: 3 !important; }
  .grid-donors       { grid-column: 1 !important; grid-row: 4 !important; }
}

/* KPI : lignes en pile + tailles de police adaptées */
@media (max-width: 900px){
  .kpi-row{ grid-template-columns: 1fr; gap: 10px; }
  .kpi-col + .kpi-col{ border-left: 0; }
  .kpi-main   { font-size: 32px; }
  .kpi-title  { font-size: 18px; }
  .kpi-sub    { font-size: 16px; }
  .kpi-donors { font-size: 34px; }
}

/* Badges d’impact : carte plus étroite */
@media (max-width: 640px){
  .impact-badge{ min-width: 100px; max-width: 120px; padding: 10px 12px; }
  .impact-badge-icon{ width: 60px; height: 60px; }
  .impact-badge-amount{ font-size: 13px; }
}

/* Vidéo : ratio et bords sûrs */
@media (max-width: 768px){
  .video-container { max-height: none; aspect-ratio: 16/9; border-radius: 12px; }
  .video-container iframe { border-radius: 12px; }
}

/* DonBox : grilles et champs qui ne débordent pas */
@media (max-width: 768px){
  .donbox, #donation-section, .don-box { padding: 16px; border-radius: 10px; }
  .donbox-header-card { gap: 10px; padding: 10px 12px; }
  .donbox-header-left { max-width: 100%; }
  .donbox-main-title { font-size: 1rem; }
  .donbox-subtitle   { font-size: .85rem; }
  .donbox-type-badge { font-size: .75rem; padding: 6px 8px; }

  .amount-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 12px; }
  .amount-chip { height: 42px; font-size: 14px; }

  .amount-input { padding: 10px; }
  .amount-input input[type="number"] { font-size: 16px; }
  .amount-input .suffix { font-size: 13px; }

  .split-row-top { align-items: center; }
  .split-row-desc { font-size: .78rem; }
  .btn-primary, .btn-secondary { height: 44px; font-size: 15px; }
}

/* Donateurs : pas de débordement, wrap propre */
@media (max-width: 768px){
  .donor-card-body { max-height: 320px; }
  .donor-row{ gap: 8px; padding: 10px; }
  .donor-row-left{ min-width: 0; }
  .donor-name{ font-size: .95rem; word-break: break-word; }
  .donor-message{ font-size: .78rem; }
  .donor-amount{ font-size: .95rem; margin-left: 8px; }
}

/* Tabs présentation/équipes : boutons lisibles */
@media (max-width: 640px){
  .tab-card-header{ gap: 6px; padding: 6px 8px; }
  .tab-btn{ font-size: .85rem; padding: 7px 10px; }
  .tab-card-body{ padding: 14px; font-size: .95rem; }
  .teams-grid{ grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
}

/* Carousel : images plus petites, flèches discrètes */
@media (max-width: 700px){
  .carousel{ padding: 10px 40px; gap: 12px; }
  .carousel img{ width: 180px; height: 118px; border-radius: 12px; }
}
@media (max-width: 480px){
  .carousel{ padding: 8px 36px; gap: 10px; }
  .carousel img{ width: 150px; height: 96px; }
  .carousel-btn{ width: 42px; height: 42px; }
}

/* Bandeau ×2 : réduit la pastille pour éviter le chevauchement */
@media (max-width: 640px){
  .goals-outline{ padding: 12px; }
  .goals-outline::after{
    right: -14px; top: -14px; width: 58px; height: 58px; font-size: 22px; outline-width: 5px;
  }
  .goals-outline::before{ top: 22px; right: -14px; font-size: 10px; }
}

/* Petits détails anti-débordement globaux */
@media (max-width: 768px){
  .kpi-goal, .donor-card, .tab-card, .donbox { box-shadow: 0 8px 18px rgba(0,0,0,.08); }
  .deadline-banner{ gap: 10px; }
  .deadline-days{ font-size: 20px; }
  .deadline-circle{ width: 64px; height: 64px; }
}

/* Custom override: place donation box above presentation/teams on mobile */
@media (max-width: 1024px) {
  .campaign-grid .grid-donbox { grid-row: 3 !important; }
  .campaign-grid .grid-left-match { grid-row: 2 !important; }
  .campaign-grid .grid-presentation { grid-row: 4 !important; }
  .campaign-grid .grid-donors { grid-row: 5 !important; }
}
