.danz-horaire{margin:16px 0}
.danz-horaire-msg{padding:12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff}

.danz-horaire-filters{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.danz-horaire-filters-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.danz-horaire-filters select{padding:8px 10px}
.danz-horaire-filters button{padding:8px 12px;cursor:pointer}

.danz-horaire-viewtoggle{display:flex;gap:10px}
.danz-horaire-viewtoggle a{padding:6px 10px;border:1px solid #e5e7eb;border-radius:999px;text-decoration:none}
.danz-horaire-viewtoggle a.is-active{font-weight:700}

/* Grid */
.danz-horaire-gridwrap{overflow:auto;border:1px solid #e5e7eb;border-radius:12px;-webkit-overflow-scrolling:touch;position:relative}
.danz-horaire-gridwrap:after{content:"↔";position:absolute;right:10px;top:10px;background:rgba(255,255,255,.92);border:1px solid #e5e7eb;border-radius:999px;padding:4px 8px;font-size:12px;opacity:.8;pointer-events:none}
.danz-horaire-grid{width:100%;border-collapse:separate;border-spacing:0;min-width:920px}
.danz-horaire-grid th,.danz-horaire-grid td{border-bottom:1px solid #eef2f7;border-right:1px solid #eef2f7;padding:10px;vertical-align:top}
.danz-horaire-grid th{position:sticky;top:0;background:#fff;z-index:3}
.danz-horaire-grid .danz-horaire-col-time{left:0;z-index:4}
.danz-horaire-time{font-weight:800;white-space:nowrap;background:#fafafa;position:sticky;left:0;z-index:2}
.danz-horaire-empty{opacity:.55}

/* Cards */
.danz-class{border:1px solid #e5e7eb;border-radius:12px;padding:10px;margin:6px 0;background:#fff;display:block;width:100%;text-align:left;cursor:pointer}
.danz-class:hover{border-color:#d1d5db}
.danz-class:focus{outline:2px solid #111827;outline-offset:2px}
.danz-class:disabled{cursor:not-allowed;opacity:.7}
.danz-class-title{font-weight:900;margin-bottom:4px}
.danz-class-meta{opacity:.82;font-size:13px}
.danz-class-cap{margin-top:6px}

.danz-badge{display:inline-block;border:1px solid #e5e7eb;border-radius:999px;padding:2px 8px;font-size:12px;background:#fafafa;color:#000}
.danz-badge.is-full{border-color:#fecaca;background:#fef2f2}

.danz-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:10px 12px;border:1px solid #e5e7eb;text-decoration:none;cursor:pointer;font-weight:800;background:#fff}
.danz-btn[disabled]{opacity:.6;cursor:not-allowed}
.danz-btn--primary{background:#111827;color:#fff;border-color:#111827}

/* List */
.danz-horaire-day{margin:18px 0 8px}
.danz-horaire-daylist{display:flex;flex-direction:column;gap:8px}
.danz-class-row{margin:0}

/* Modal */
body.danz-modal-open{overflow:hidden}
.danz-horaire-modal{position:fixed;inset:0;z-index:99999;display:none}
.danz-horaire-modal.is-open{display:block}
.danz-horaire-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.danz-horaire-modal__panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(640px, calc(100% - 24px));background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);max-height:calc(100% - 24px);overflow:auto}
.danz-horaire-modal__close{position:absolute;right:10px;top:8px;border:0;background:transparent;font-size:26px;line-height:1;padding:6px 10px;cursor:pointer}
.danz-horaire-modal__content{padding:18px}
.danz-horaire-modal__title{font-weight:900;font-size:18px;margin:6px 0 8px}
.danz-horaire-modal__meta{opacity:.85;font-size:13px;margin-bottom:10px}
.danz-horaire-modal__note{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:10px;font-size:13px;white-space:pre-wrap;margin:12px 0}
.danz-horaire-modal__actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

@media (max-width: 720px){
  .danz-horaire-grid{min-width:760px}
  .danz-class{padding:8px}
  .danz-class-title{font-size:14px}
  .danz-class-meta{font-size:12px}
}
