:root {
  --bg:#0F172A;--surface:#1E293B;--surface2:#162033;
  --red:#FF6B6B;--red-glow:rgba(255,107,107,0.25);--red-soft:rgba(255,107,107,0.12);
  --blue:#4D4DFF;--blue-glow:rgba(77,77,255,0.25);--blue-soft:rgba(77,77,255,0.1);
  --text:#F1F5F9;--text-muted:#94A3B8;--text-dim:#64748B;
  --border:rgba(255,255,255,0.07);--border-hover:rgba(255,107,107,0.35);
  --radius:16px;--radius-sm:10px;--radius-lg:24px;
  --input-bg:#0F172A;
}
[data-theme="light"] {
  --bg:#F8FAFC;--surface:#FFFFFF;--surface2:#F1F5F9;
  --text:#0F172A;--text-muted:#475569;--text-dim:#94A3B8;
  --border:rgba(0,0,0,0.09);--border-hover:rgba(255,107,107,0.4);
  --input-bg:#F8FAFC;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);transition:background .25s,color .25s;}
h1,h2,h3,h4,.brand{font-family:'Outfit',sans-serif;}

.bg-mesh{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.bg-mesh::before{content:'';position:absolute;top:-20%;left:-10%;width:70%;height:70%;background:radial-gradient(ellipse,rgba(255,107,107,0.06) 0%,transparent 65%);animation:drift1 18s ease-in-out infinite alternate;}
.bg-mesh::after{content:'';position:absolute;bottom:-20%;right:-10%;width:65%;height:65%;background:radial-gradient(ellipse,rgba(77,77,255,0.08) 0%,transparent 65%);animation:drift2 22s ease-in-out infinite alternate;}
@keyframes drift1{from{transform:translate(0,0) scale(1);}to{transform:translate(4%,6%) scale(1.08);}}
@keyframes drift2{from{transform:translate(0,0) scale(1);}to{transform:translate(-5%,-4%) scale(1.06);}}

.theme-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;flex-shrink:0;}
.theme-btn:hover{background:var(--red-soft);border-color:var(--border-hover);}

/* ---- LOADING ---- */
#page-loading{position:fixed;inset:0;z-index:300;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;}
.loading-logo{display:flex;align-items:center;gap:12px;}
.loading-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--red),#FF4040);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 20px var(--red-glow);}
.loading-logo-text{font-family:'Outfit',sans-serif;font-size:24px;font-weight:800;letter-spacing:-0.5px;}
.loading-logo-text span{color:var(--red);}
.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-text{font-size:13px;color:var(--text-dim);}
.loading-error{font-size:13px;color:var(--red);text-align:center;max-width:320px;line-height:1.6;display:none;}

/* ---- LOGIN PAGE ---- */
#page-login{position:fixed;inset:0;z-index:200;background:var(--bg);display:none;align-items:center;justify-content:center;padding:24px;transition:background .25s;}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;position:relative;z-index:1;}
.login-logo{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:32px;}
.login-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--red),#FF4040);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 20px var(--red-glow);}
.login-logo-text{font-family:'Outfit',sans-serif;font-size:24px;font-weight:800;letter-spacing:-0.5px;}
.login-logo-text span{color:var(--red);}
.login-title{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;text-align:center;margin-bottom:6px;}
.login-sub{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:28px;}
.login-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.login-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;}
.login-input{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--text);outline:none;width:100%;transition:all .18s;}
.login-input::placeholder{color:var(--text-dim);}
.login-input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,107,107,0.12);}
.login-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--red),#FF4040);color:white;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:700;font-family:'Outfit',sans-serif;cursor:pointer;transition:all .18s;margin-top:4px;letter-spacing:.2px;display:flex;align-items:center;justify-content:center;gap:8px;}
.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px var(--red-glow);}
.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;}
.login-top-right{position:absolute;top:16px;right:16px;}
.login-top-left{position:absolute;top:16px;left:16px;}
.alert{border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:14px;display:none;}
.alert-error{background:rgba(255,107,107,0.12);border:1px solid rgba(255,107,107,0.3);color:var(--red);}
.alert-success{background:rgba(52,211,153,0.12);border:1px solid rgba(52,211,153,0.3);color:#34D399;}

/* ---- APP LAYOUT ---- */
#app{position:fixed;inset:0;display:none;overflow:hidden;}
.sidebar{width:260px;flex-shrink:0;background:rgba(30,41,59,0.85);backdrop-filter:blur(20px);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:28px 0;height:100%;overflow-y:auto;transition:background .25s;}
[data-theme="light"] .sidebar{background:rgba(255,255,255,0.92);}
.logo{display:flex;align-items:center;gap:12px;padding:0 24px 32px;}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--red),#FF4040);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px var(--red-glow);flex-shrink:0;}
.logo-text{font-family:'Outfit',sans-serif;font-size:20px;font-weight:800;letter-spacing:-.5px;}
.logo-text span{color:var(--red);}
.logo-sub{font-size:11px;color:var(--text-dim);font-weight:400;margin-top:1px;letter-spacing:.5px;text-transform:uppercase;}
.nav-section{padding:0 16px;margin-bottom:8px;}
.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-weight:600;padding:0 8px;margin-bottom:6px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .18s;color:var(--text-muted);font-size:14px;font-weight:500;text-decoration:none;border:1px solid transparent;margin-bottom:2px;background:none;width:100%;text-align:left;}
.nav-item:hover{background:var(--red-soft);color:var(--text);border-color:var(--border-hover);}
.nav-item.active{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,107,0.2);}
.nav-item .icon{font-size:16px;width:20px;text-align:center;}
.nav-divider{height:1px;background:var(--border);margin:16px;}
.sidebar-bottom{margin-top:auto;padding:0 16px;}
.user-card{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--blue));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:'Outfit',sans-serif;flex-shrink:0;}
.user-info{flex:1;min-width:0;}
.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-role{font-size:11px;color:var(--red);font-weight:500;}
.logout-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;padding:4px;border-radius:6px;transition:all .15s;}
.logout-btn:hover{color:var(--red);}
.main{flex:1;min-width:0;padding:32px 40px;height:100%;overflow-y:auto;position:relative;z-index:1;}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;}
.page-title{font-size:26px;font-weight:800;letter-spacing:-.5px;}
.page-title span{color:var(--red);}
.page-sub{font-size:14px;color:var(--text-muted);margin-top:4px;}
.topbar-right{display:flex;gap:12px;align-items:center;}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;border:none;font-family:'Outfit',sans-serif;letter-spacing:.2px;text-decoration:none;}
.btn-primary{background:linear-gradient(135deg,var(--red),#FF4040);color:white;box-shadow:0 4px 16px var(--red-glow);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(255,107,107,0.4);}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);}
.btn-ghost:hover{background:var(--surface);color:var(--text);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .2s;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--red),transparent);opacity:0;transition:opacity .2s;}
.stat-card:hover{border-color:rgba(255,107,107,0.2);transform:translateY(-2px);}
.stat-card:hover::before{opacity:1;}
.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px;}
.stat-icon.red{background:var(--red-soft);}
.stat-icon.blue{background:var(--blue-soft);}
.stat-icon.green{background:rgba(52,211,153,0.12);}
.stat-icon.orange{background:rgba(251,146,60,0.12);}
.stat-val{font-family:'Outfit',sans-serif;font-size:28px;font-weight:800;letter-spacing:-1px;}
.stat-label{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:500;}
.stat-trend{font-size:11px;color:#34D399;font-weight:600;margin-top:6px;}
.two-col{display:grid;grid-template-columns:1fr 380px;gap:24px;}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);}
.card-title{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;}
.card-title .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red);}
.card-body{padding:20px 24px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-grid .full{grid-column:1/-1;}
.field{display:flex;flex-direction:column;gap:6px;}
.label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;}
.label .req{color:var(--red);}
.input,.textarea,.select{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--text);transition:all .18s;outline:none;width:100%;}
.input::placeholder,.textarea::placeholder{color:var(--text-dim);}
.input:focus,.textarea:focus,.select:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-soft);}
.textarea{resize:vertical;min-height:200px;}
.select option{background:var(--surface);}
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all .2s;background:rgba(255,107,107,0.02);position:relative;}
.upload-zone:hover{border-color:rgba(255,107,107,0.4);background:var(--red-soft);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.upload-icon{font-size:32px;margin-bottom:10px;}
.upload-title{font-size:14px;font-weight:600;margin-bottom:4px;}
.upload-sub{font-size:12px;color:var(--text-dim);}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{padding:6px 14px;border-radius:100px;font-size:12px;font-weight:600;border:1px solid var(--border);cursor:pointer;transition:all .15s;color:var(--text-muted);background:transparent;font-family:'Outfit',sans-serif;letter-spacing:.2px;}
.chip:hover{border-color:rgba(255,107,107,0.4);color:var(--text);}
.chip.active{background:var(--red);color:white;border-color:var(--red);box-shadow:0 2px 12px var(--red-glow);}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);}
.toggle-row:last-child{border-bottom:none;}
.toggle-title{font-size:14px;font-weight:500;}
.toggle-desc{font-size:12px;color:var(--text-dim);margin-top:2px;}
.toggle{width:44px;height:24px;background:var(--surface2);border-radius:100px;position:relative;cursor:pointer;border:1px solid var(--border);transition:background .2s;flex-shrink:0;}
.toggle.on{background:var(--red);border-color:var(--red);}
.toggle::after{content:'';width:18px;height:18px;border-radius:50%;background:white;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,0.3);}
.toggle.on::after{transform:translateX(20px);}
.price-row{display:flex;align-items:center;gap:8px;}
.currency-badge{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;font-size:14px;color:var(--text-muted);font-weight:600;flex-shrink:0;}
.event-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);}
.event-item:last-child{border-bottom:none;}
.event-thumb{width:56px;height:56px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;}
.event-meta{flex:1;min-width:0;}
.event-name{font-size:14px;font-weight:700;font-family:'Outfit',sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.event-date{font-size:12px;color:var(--text-dim);margin-top:3px;}
.event-badges{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap;}
.badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:100px;font-family:'Outfit',sans-serif;letter-spacing:.3px;}
.badge-published{background:rgba(52,211,153,0.15);color:#34D399;}
.badge-draft{background:rgba(251,146,60,0.15);color:#FB923C;}
.badge-red{background:var(--red-soft);color:var(--red);}
.event-actions{display:flex;gap:6px;}
.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);transition:all .15s;font-size:14px;}
.icon-btn:hover{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,107,0.3);}
.mini-stat{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;}
.mini-stat:last-child{border-bottom:none;}
.mini-stat-label{color:var(--text-muted);display:flex;align-items:center;gap:8px;}
.mini-stat-val{font-weight:700;font-family:'Outfit',sans-serif;}
.tabs{display:flex;gap:4px;background:var(--surface2);padding:4px;border-radius:var(--radius-sm);margin-bottom:24px;}
.tab{flex:1;padding:8px 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .18s;color:var(--text-muted);font-family:'Outfit',sans-serif;border:none;background:transparent;}
.tab.active{background:var(--surface);color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.section-label{font-size:13px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--red-soft);display:flex;align-items:center;gap:8px;font-family:'Outfit',sans-serif;}
.preview-phone{background:var(--bg);border-radius:20px;overflow:hidden;border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,0.4);}
.preview-header{background:linear-gradient(180deg,rgba(255,107,107,0.4) 0%,transparent 100%),var(--surface);height:140px;display:flex;align-items:flex-end;padding:16px;}
.preview-title{font-size:20px;font-weight:800;font-family:'Outfit',sans-serif;}
.preview-body{padding:16px;}
.preview-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:8px;}
.preview-price{display:inline-block;background:var(--red);color:white;padding:6px 14px;border-radius:100px;font-size:13px;font-weight:700;font-family:'Outfit',sans-serif;}
.preview-music{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;}
.preview-chip{padding:4px 10px;border-radius:100px;font-size:11px;font-weight:600;background:rgba(255,255,255,0.08);color:var(--text-muted);font-family:'Outfit',sans-serif;}
[data-theme="light"] .preview-chip{background:rgba(0,0,0,0.06);}
.toast{position:fixed;bottom:32px;right:32px;background:var(--surface);border:1px solid rgba(52,211,153,0.3);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,0.3);z-index:400;transform:translateY(100px);opacity:0;transition:all .3s cubic-bezier(0.34,1.56,0.64,1);}
.toast.show{transform:translateY(0);opacity:1;}
.toast-icon{font-size:20px;}
.fade-in{opacity:0;transform:translateY(16px);animation:fadeUp .5s ease forwards;}
.fade-in:nth-child(1){animation-delay:.05s;}
.fade-in:nth-child(2){animation-delay:.1s;}
.fade-in:nth-child(3){animation-delay:.15s;}
.fade-in:nth-child(4){animation-delay:.2s;}
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
.view{display:none;}
.view.active{display:block;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.2);}
@media(max-width:1200px){.two-col{grid-template-columns:1fr;}.stats-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:900px){.sidebar{display:none;}.main{padding:24px 20px;}}

/* ---- CORRECTION APERÃ‡U IMAGE ---- */
#prev-header {
  position: relative;
  overflow: hidden;
}
#prev-header > div {
  position: relative; /* Met le texte au-dessus de l'image absolue */
  z-index: 10;
}
.preview-image-tag {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.8; /* LÃ©gÃ¨re transparence pour garder le texte lisible */
}

/* ============================================================
   VUE CARTE (GRID) & FILTRES POUR "MES SOIRÃ‰ES"
============================================================ */

/* ðŸ‘‰ LE NOUVEAU JOLI BOUTON "PILULE" */
.btn-toggle-view {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px 6px 6px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 100px;
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  font-family: 'Outfit', sans-serif;
  cursor: pointer;
  transition: all 0.3s ease;
}
.btn-toggle-view:hover {
  background: var(--surface);
  border-color: rgba(255, 107, 107, 0.4);
  box-shadow: 0 4px 16px var(--red-glow);
  transform: translateY(-1px);
}
.btn-toggle-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
  font-size: 14px;
  transition: all 0.3s ease;
}

/* 👉 LA GRILLE ET LES CARTES (AJUSTÉES) */
.events-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.event-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; display: flex; flex-direction: column; transition: all 0.2s; box-shadow: 0 4px 12px rgba(0,0,0,0.05); }
.event-card:hover { border-color: rgba(255,107,107,0.3); transform: translateY(-4px); box-shadow: 0 12px 24px rgba(0,0,0,0.1); }

/* 1. On augmente la hauteur de l'image (240px au lieu de 180px) */
.event-card-thumb { height: 240px; width: 100%; position: relative; background: var(--surface2); display: flex; align-items: center; justify-content: center; }

/* 2. On réduit les marges, les paddings et les tailles de texte pour compenser */
.event-card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.event-card-title { font-size: 16px; font-weight: 800; font-family: 'Outfit', sans-serif; margin-bottom: 4px; line-height: 1.2; }
.event-card-date { font-size: 12px; color: var(--text-dim); margin-bottom: 12px; line-height: 1.4; }
.event-card-badges { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.event-card-actions { display: flex; gap: 8px; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--border); }
.event-card-actions .btn { flex: 1; justify-content: center; padding: 8px; font-size: 12px; }

/* ============================================================
   BANDEAU CENTRAL (ANNULÉ/REPORTÉ) & EFFET NOIR/BLANC
============================================================ */
/* Conteneur qui prend 100% de l'image pour centrer le bandeau */
.ribbon-wrapper-center {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 10;
  pointer-events: none;
}

/* Le bandeau au milieu, incliné en diagonale */
.ribbon-center {
  width: 150%; /* Assez large pour couvrir les coins */
  transform: rotate(-35deg); /* Angle diagonal */
  text-align: center;
  color: white;
  font-weight: 900;
  font-size: 26px; /* Texte bien visible */
  padding: 12px 0;
  font-family: 'Outfit', sans-serif;
  letter-spacing: 6px;
  text-transform: uppercase;
  box-shadow: 0 4px 24px rgba(0,0,0,0.6);
  text-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

.ribbon-cancelled { background: rgba(239, 68, 68, 0.9); border-top: 2px solid #fca5a5; border-bottom: 2px solid #fca5a5; }
.ribbon-postponed { background: rgba(249, 115, 22, 0.9); border-top: 2px solid #fdba74; border-bottom: 2px solid #fdba74; }

/* Filtre magique : passe l'image en noir et blanc et l'assombrit un peu */
.img-grayscale {
  filter: grayscale(100%) contrast(1.1) brightness(0.6);
}/* ============================================================
   BANDEAU CENTRAL (ANNULÉ/REPORTÉ) & EFFET NOIR/BLANC
============================================================ */
/* Conteneur qui prend 100% de l'image pour centrer le bandeau */
.ribbon-wrapper-center {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 10;
  pointer-events: none;
}

/* Le bandeau au milieu, incliné en diagonale */
.ribbon-center {
  width: 150%; /* Assez large pour couvrir les coins */
  transform: rotate(-35deg); /* Angle diagonal */
  text-align: center;
  color: white;
  font-weight: 900;
  font-size: 26px; /* Texte bien visible */
  padding: 12px 0;
  font-family: 'Outfit', sans-serif;
  letter-spacing: 6px;
  text-transform: uppercase;
  box-shadow: 0 4px 24px rgba(0,0,0,0.6);
  text-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

.ribbon-cancelled { background: rgba(239, 68, 68, 0.9); border-top: 2px solid #fca5a5; border-bottom: 2px solid #fca5a5; }
.ribbon-postponed { background: rgba(249, 115, 22, 0.9); border-top: 2px solid #fdba74; border-bottom: 2px solid #fdba74; }

/* Filtre magique : passe l'image en noir et blanc et l'assombrit un peu */
.img-grayscale {
  filter: grayscale(100%) contrast(1.1) brightness(0.6);
}