:root{
  --vacs-bg: #0b1220;
  --vacs-card: #0f1a2e;
  --vacs-text: #eaf0ff;
  --vacs-muted: rgba(234,240,255,.72);
  --vacs-border: rgba(255,255,255,.10);
  --vacs-shadow: 0 12px 40px rgba(0,0,0,.35);
  --vacs-shadow-soft: 0 8px 24px rgba(0,0,0,.25);

  /* Accent global (jours fériés) */
  --vacs-primary: #ef4444;
  --vacs-primary-2: #f87171;

  /* Couleurs zones */
  --zoneA: #3b82f6;   /* bleu */
  --zoneB: #22c55e;   /* vert */
  --zoneC: #f59e0b;   /* orange */
  --white: #fff;

  --radius: 18px;
}

.vacs{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--vacs-text);
  background: var(--vacs-bg);
  /* ✨ NOUVEAUX STYLES - Bords arrondis */
  border-radius: 24px;
  padding: 24px;
  border: 1px solid var(--vacs-border);
  box-shadow: var(--vacs-shadow);
}

.vacs .vacs-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin: 0 0 20px;
  flex-wrap:wrap;
}

.vacs .vacs-title{
  display:flex;
  align-items:center;
  gap:10px;
}

.vacs .vacs-title .badge{
  width:34px;height:34px;
  border-radius: 10px;
  display:grid;place-items:center;
  background: rgba(239,68,68,.15);
  color: #fca5a5;
  box-shadow: 0 10px 18px rgba(239,68,68,.2);
}

.vacs .vacs-title h2{
  font-size: clamp(22px, 2.2vw, 34px);
  line-height: 1.1;
  margin:0;
}

.vacs .vacs-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.vacs .vacs-btn{
  appearance:none;
  border:1px solid var(--vacs-border);
  background:var(--vacs-card);
  color: #e5e7eb;
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 800;
  font-size: 14px;
  box-shadow: var(--vacs-shadow-soft);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}

.vacs .vacs-btn:hover{ transform: translateY(-1px); box-shadow: var(--vacs-shadow); }
.vacs .vacs-btn[aria-pressed="true"]{
  background: rgba(239,68,68,.15);
  border-color: rgba(239,68,68,.4);
  color: #fca5a5;
}

.vacs .vacs-subbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin: 10px 0 18px;
  flex-wrap:wrap;
}

.vacs .vacs-meta{
  color: var(--vacs-muted);
  font-size: 13px;
}

.vacs .vacs-search{
  display:flex;
  align-items:center;
  gap:10px;
}

.vacs .vacs-input{
  width: min(420px, 100%);
  border:1px solid var(--vacs-border);
  background:var(--vacs-card);
  color: var(--vacs-text);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 14px;
  outline:none;
  box-shadow: var(--vacs-shadow-soft);
}

/* --- ZONES 3 COLONNES --- */
.vacs-zones{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 1024px){
  .vacs-zones{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .vacs-zones{ grid-template-columns: 1fr; }
}

.vacs-zone{
  background: var(--vacs-card);
  border:1px solid var(--vacs-border);
  border-radius: var(--radius);
  box-shadow: var(--vacs-shadow-soft);
  overflow:hidden;
}

.vacs-zone-head{
  padding: 14px 16px;
  color: #fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-weight: 900;
}

.vacs-zone-head small{
  font-weight: 700;
  opacity:.95;
}

.vacs-zone[data-zone="A"] .vacs-zone-head{ background: linear-gradient(90deg, var(--zoneA), rgba(37,99,235,.75)); }
.vacs-zone[data-zone="B"] .vacs-zone-head{ background: linear-gradient(90deg, var(--zoneB), rgba(22,163,74,.75)); }
.vacs-zone[data-zone="C"] .vacs-zone-head{ background: linear-gradient(90deg, var(--zoneC), rgba(245,158,11,.78)); }

.vacs-zone-body{
  padding: 14px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

/* --- CARTE --- */
.vacs-card{
  background: var(--vacs-card);
  border: 1px solid var(--vacs-border);
  border-radius: 16px;
  box-shadow: var(--vacs-shadow-soft);
  overflow:hidden;
  transition: transform .12s ease, box-shadow .12s ease;
}

.vacs-card:hover{ transform: translateY(-2px); box-shadow: var(--vacs-shadow); }

.vacs-card::before{
  content:"";
  display:block;
  height: 5px;
  background: linear-gradient(90deg, var(--vacs-primary), var(--vacs-primary-2));
}

.vacs-card[data-accent="A"]::before{ background: linear-gradient(90deg, var(--zoneA), rgba(37,99,235,.55)); }
.vacs-card[data-accent="B"]::before{ background: linear-gradient(90deg, var(--zoneB), rgba(22,163,74,.55)); }
.vacs-card[data-accent="C"]::before{ background: linear-gradient(90deg, var(--zoneC), rgba(245,158,11,.55)); }

.vacs-card-inner{
  padding: 14px 14px 12px;
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.vacs-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

.vacs-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background: rgba(255,255,255,.08);
  color: var(--vacs-text);
  font-weight: 900;
  font-size: 13px;
  padding: 8px 10px;
  border-radius: 999px;
  width: fit-content;
}

.vacs-icon{
  width: 46px;
  height: 46px;
  display:grid;
  place-items:center;
  border-radius: 14px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  font-size: 22px;
}

.vacs-card h3{
  margin: 0;
  font-size: 16px;
  letter-spacing: .2px;
}

.vacs-kicker{
  margin: 0;
  color: var(--vacs-muted);
  font-size: 12.5px;
}

.vacs-tags{
  margin-top: 4px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.vacs-tag{
  display:inline-flex;
  align-items:center;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.08);
  color: var(--vacs-text);
}

.vacs-tag.holiday{
  background: rgba(239,68,68,.15);
  color: #fca5a5;
  border-color: rgba(239,68,68,.3);
}

.vacs-tag.alsace{
  background: rgba(59,130,246,.15);
  color: #93c5fd;
  border-color: rgba(59,130,246,.3);
}

.vacs-tag.famille{
  background: rgba(236,72,153,.15);
  color: #f9a8d4;
  border-color: rgba(236,72,153,.3);
}

.vacs-empty{
  border: 1px dashed rgba(255,255,255,.15);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 14px;
  color: var(--vacs-muted);
}

/* --- JOURS FÉRIÉS (grid 3 colonnes) --- */
.vacs-holidays-grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 1024px){
  .vacs-holidays-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .vacs-holidays-grid{ grid-template-columns: 1fr; }
}

.vacs-section-title{
  margin: 24px 0 12px;
  font-size: 16px;
  font-weight: 900;
}

/* =========================
   RESPONSIVE MOBILE
   ========================= */
@media (max-width: 768px){
  .vacs{
    border-radius: 20px;
    padding: 20px;
  }
  
  .vacs .vacs-header{
    margin: 0 0 16px;
  }
  
  .vacs .vacs-actions{
    width: 100%;
    justify-content: flex-start;
  }
  
  .vacs .vacs-btn{
    font-size: 13px;
    padding: 9px 11px;
  }
}

@media (max-width: 640px){
  .vacs{
    border-radius: 18px;
    padding: 16px;
  }
  
  .vacs .vacs-title .badge{
    width: 30px;
    height: 30px;
  }
  
  .vacs .vacs-input{
    width: 100%;
  }
  
  .vacs-section-title{
    margin: 20px 0 10px;
    font-size: 15px;
  }
}

@media (max-width: 480px){
  .vacs{
    border-radius: 16px;
    padding: 14px;
  }
  
  .vacs .vacs-header{
    margin: 0 0 14px;
  }
  
  .vacs .vacs-actions{
    gap: 8px;
  }
  
  .vacs .vacs-btn{
    font-size: 12px;
    padding: 8px 10px;
  }
  
  .vacs .vacs-subbar{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  
  .vacs .vacs-search{
    width: 100%;
  }
  
  .vacs .vacs-input{
    width: 100%;
  }
}
