/* Résa — habillage façon « StickyMobile » : header collant, cartes arrondies,
   ombres douces, accent dégradé, boutons pilule. Classes réutilisées telles quelles. */
:root{
  --ink:#1b2440; --muted:#8a93a8; --line:#e7ebf3;
  --bg:#eef1f8; --surface:#ffffff;
  --accent:#3b5bdb; --accent-2:#5b8def;
  --free:#15a35b; --busy:#e23b4e; --soon:#e08a00;
  --radius:18px; --radius-sm:12px;
  --shadow-sm:0 4px 16px rgba(27,36,64,.06);
  --shadow:0 14px 36px -14px rgba(27,36,64,.22);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.45}
a{color:var(--accent)}

/* Header collant */
.resa-top{position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;align-items:center;
  gap:14px;flex-wrap:wrap;padding:13px 20px;background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.resa-top h1{margin:0;font-size:21px;font-weight:800;letter-spacing:-.02em;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.resa-top nav{font-size:14px;display:flex;flex-wrap:wrap;gap:4px 10px;align-items:center}
.resa-top nav a{color:var(--ink);text-decoration:none;font-weight:600;opacity:.82}
.resa-top nav a:hover{opacity:1;color:var(--accent)}

/* Conteneurs */
.resa-main,.resa-occ{max-width:1040px;margin:0 auto;padding:26px 18px 64px}
.resa-main h2{font-size:18px;font-weight:800;letter-spacing:-.01em;margin:28px 0 12px}
.resa-main h2:first-of-type{margin-top:4px}
.resa-occ h1{font-size:25px;font-weight:800;letter-spacing:-.02em;margin:6px 0 20px}
.muted{color:var(--muted)}

/* Barre d'administration (dégradé accent) */
.resa-adminbar{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;
  border-radius:var(--radius);padding:14px 18px;margin-bottom:24px;font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow);display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center}
.resa-adminbar a{color:#fff;text-decoration:none;opacity:.92;border-bottom:1px solid rgba(255,255,255,.45);padding-bottom:1px}
.resa-adminbar a:hover{opacity:1}

/* Liste « mes réservations » */
.resa-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.resa-list li{background:var(--surface);border-radius:var(--radius);padding:14px 16px;
  box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.resa-list li b{font-weight:800}

/* Badges pilule */
.badge{font-size:10.5px;font-weight:800;padding:3px 11px;border-radius:30px;
  text-transform:uppercase;letter-spacing:.04em;margin-left:auto}
.badge-validee{background:#dff3e6;color:#0f7a42}
.badge-en_attente{background:#fdf0d5;color:#9a6800}
.badge-refusee,.badge-no_show,.badge-annulee,.badge-expiree{background:#fbe0dd;color:#b3302a}

/* Grille d'occupation */
.occ-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.occ-card{position:relative;overflow:hidden;background:var(--surface);border-radius:var(--radius);
  padding:18px 18px 16px 22px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}
.occ-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.occ-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.occ-free::before{background:var(--free)}
.occ-busy::before{background:var(--busy)}
.occ-soon::before{background:var(--soon)}
.occ-name{font-weight:800;font-size:15px}
.occ-bat{font-size:12px;color:var(--muted);margin:3px 0 12px}
.occ-state{font-weight:700;font-size:13.5px;display:inline-flex;align-items:center;gap:7px}
.occ-state::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;flex:none}
.occ-closed::before{background:#aab2c2}
.occ-free .occ-state{color:var(--free)}
.occ-busy .occ-state{color:var(--busy)}
.occ-soon .occ-state{color:var(--soon)}
.occ-closed .occ-state{color:#8b93a8}

/* Liste des salles (admin) : cartes compactes + pastilles */
.salle-list{display:grid;gap:10px}
.salle-card{background:var(--surface);border-radius:var(--radius);padding:13px 16px;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sc-main{flex:1;min-width:0}
.sc-name{font-weight:800;font-size:15px;margin-bottom:7px}
.sc-cap{font-weight:600;font-size:12px;color:var(--muted)}
.sc-pills{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.pill{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:30px;background:#eef1f7;color:var(--ink)}
.pill-on{background:#d8f3e6;color:#0f7a42}
.pill-off{background:#eef1f7;color:var(--muted)}
.pill-warn{background:#fdf0d5;color:#9a6800}
.pill-soft{background:transparent;color:var(--muted);padding-left:0}
.pill-busy{background:#fbe0dd;color:#b3302a}
.occ-summary{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.exc-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.list-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin:18px 0 12px}
.list-head h3{margin:0}
@media (max-width:560px){
  .exc-actions{flex-wrap:nowrap}
  .exc-actions button{flex:1;min-width:0;padding:11px 10px;font-size:13.5px}
}
.exc-feries{background:none!important;box-shadow:none!important;padding:0!important;display:flex!important;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:18px;max-width:none!important}
.exc-feries label{font-weight:600;font-size:13px;display:flex;align-items:center;gap:8px}
.exc-feries input{width:auto;padding:8px 10px;border:1.5px solid #dde2ec;border-radius:10px;font-family:inherit}
.os-link{color:var(--accent);font-weight:700;text-decoration:none;margin-left:4px}
.sc-edit{flex:none;color:var(--accent);font-weight:700;text-decoration:none;white-space:nowrap}
.sc-del{flex:none;margin:0}
.sc-del button{padding:5px 11px;font-size:15px;font-weight:800;background:#fbe0dd;color:var(--busy);box-shadow:none;border-radius:10px}
.sc-del button:hover{background:#f6cfca;filter:none}

/* Recherche d'utilisateurs (valideurs) */
.us-search{max-width:540px;margin-bottom:18px}
.us-search>input{width:100%;padding:11px 13px;border:1.5px solid #dde2ec;border-radius:12px;font-size:15px;font-family:inherit}
.us-results{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.us-item{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-weight:700;color:var(--ink);box-shadow:none;cursor:pointer;font-size:14px}
.us-item small{font-weight:500;color:var(--muted);margin-left:6px}
.us-item:hover{background:#f3f5f9;filter:none}
.us-empty{color:var(--muted);font-size:13px;padding:6px 2px}

/* Formulaires (réserver, admin) */
.resa-main form{background:var(--surface);border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow-sm);display:grid;gap:15px;max-width:580px}
.resa-main form label{display:block;font-size:13px;font-weight:700;margin-bottom:5px}
.resa-main form input,.resa-main form select{width:100%;padding:10px 12px;border:1.5px solid #dde2ec;
  border-radius:var(--radius-sm);font-size:15px;font-family:inherit;background:#fff;color:var(--ink)}
.resa-main form input:focus,.resa-main form select:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(59,91,219,.16)}
#f-busy{font-size:13px}
#f-msg{font-weight:700;font-size:14px}

/* Boutons pilule */
button,.btn-login{font-family:inherit;cursor:pointer;border:0;border-radius:30px;padding:11px 22px;
  font-size:14.5px;font-weight:700;background:var(--accent);color:#fff;
  transition:filter .15s,transform .08s;box-shadow:0 6px 16px -6px rgba(59,91,219,.6)}
button:hover,.btn-login:hover{filter:brightness(1.07)}
button:active,.btn-login:active{transform:translateY(1px)}
.btn-ok{background:var(--free);box-shadow:0 6px 16px -6px rgba(21,163,91,.6)}
.btn-no{background:#fff;color:var(--busy);box-shadow:inset 0 0 0 1.5px var(--busy)}
.resa-list button,.occ-card button{padding:7px 14px;font-size:13px}

/* Tables admin */
.resa-tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:18px}
.resa-tbl th,.resa-tbl td{padding:11px 14px;text-align:left;font-size:14px;border-bottom:1px solid #eef1f6}
.resa-tbl th{background:#f4f6fb;font-weight:800;font-size:11.5px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--muted)}
.resa-tbl tr:last-child td{border-bottom:0}
.resa-tbl a{color:var(--accent);font-weight:700;text-decoration:none}

/* Connexion */
.resa-login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#eef2fb,#e6ecf8)}
.resa-login{width:100%;max-width:400px;padding:22px}
.login-card{background:#fff;border-radius:22px;padding:32px 28px;box-shadow:0 28px 64px -22px rgba(27,36,64,.3)}
.login-card h1{margin:0 0 4px;font-size:27px;font-weight:800;letter-spacing:-.02em;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.login-card .lead{margin:0 0 20px;color:var(--muted);font-size:14px}
.login-err{background:#fbe0dd;color:#b3302a;border-radius:var(--radius-sm);padding:9px 13px;font-size:13px;margin:0 0 16px;font-weight:600}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:5px}
.field input{width:100%;padding:11px 13px;border:1.5px solid #dde2ec;border-radius:var(--radius-sm);font-size:15px;font-family:inherit}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,91,219,.16)}
.btn-login{width:100%;margin-top:6px}

/* Marque cliquable (retour accueil) */
.resa-brand{text-decoration:none}

/* Badges de notification de navigation (count = bleu info ; ! = rouge bloquant) */
.navbadge{display:inline-block;min-width:18px;text-align:center;background:var(--accent);color:#fff;
  font-size:11px;font-weight:800;line-height:1;padding:3px 6px;border-radius:20px;margin-left:5px;vertical-align:middle}
.navbadge.alert{background:var(--busy)}
.bn-ico{position:relative}
.bn-badge{position:absolute;top:-6px;right:-11px;min-width:16px;height:16px;padding:0 4px;border-radius:10px;
  background:var(--accent);color:#fff;font-size:10px;font-weight:800;line-height:16px;text-align:center;box-shadow:0 0 0 2px #fff}
.bn-badge.alert{background:var(--busy)}

/* Toggle (ex. afficher les archivées) */
.resa-toggle{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-size:13px;font-weight:700;
  color:var(--ink);background:var(--surface);border:1.5px solid var(--line);border-radius:30px;
  padding:7px 15px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.resa-toggle.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.resa-toggle:active{transform:translateY(1px)}

/* Modal générique (paramètres de salle, etc.) */
.resa-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:18px;
  background:rgba(13,20,38,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.resa-modal[hidden]{display:none}
.resa-modal-card{background:var(--surface);width:100%;max-width:480px;max-height:90vh;overflow:auto;
  border-radius:20px;padding:24px 22px;box-shadow:0 30px 70px -24px rgba(13,20,38,.6)}
.resa-modal-card h3{margin:0 0 14px;font-size:19px;font-weight:800}
.resa-modal-card h4{margin:16px 0 8px;font-size:14px;font-weight:800}
.resa-modal-form{display:grid;gap:12px}
.resa-modal-form>label{font-size:13px;font-weight:700}
.resa-modal-form input[type=date],.resa-modal-form input[type=number],.resa-modal-form input[type=text],.resa-modal-form select{
  width:100%;padding:9px 11px;border:1.5px solid #dde2ec;border-radius:12px;font-size:15px;font-family:inherit;background:#fff;margin-top:4px}
.bm-rappel{background:#f4f6fb;border-radius:12px;padding:11px 14px;font-size:13.5px;line-height:1.5;margin-bottom:14px}
.bm-rappel b{font-weight:800}
.req{color:var(--busy);font-weight:800}
.field-err{border-color:var(--busy)!important;box-shadow:0 0 0 3px rgba(226,59,78,.18)!important}
.bm-err{color:var(--busy);font-weight:700;font-size:13.5px}
.resa-modal-form textarea{width:100%;padding:9px 11px;border:1.5px solid #dde2ec;border-radius:12px;font-size:15px;font-family:inherit;margin-top:4px;resize:vertical}
.val-card{cursor:pointer}
.val-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.val-card{transition:transform .15s,box-shadow .15s}
/* Dialogues modaux (resaAlert/resaConfirm/resaPrompt) */
.dlg-msg{margin:0 0 14px;font-size:14.5px;color:var(--ink);line-height:1.45}
.dlg-input{width:100%;padding:9px 11px;border:1.5px solid #dde2ec;border-radius:12px;font-size:15px;font-family:inherit;margin-bottom:14px}
.btn-danger{background:var(--busy)}
.resa-modal-form label.ck{display:flex;align-items:center;gap:8px;font-weight:600}
.resa-modal-form label.ck input{width:auto;margin:0}
.resa-modal-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.resa-modal-form input[type=time]{padding:6px 8px;border:1.5px solid #dde2ec;border-radius:8px;font-family:inherit}
.resa-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}
/* Actions horaires (recopier / vider un jour) */
.resa-hours .h-act{white-space:nowrap}
.h-act button{padding:4px 9px;font-size:13px;font-weight:700;background:#eef1f7;color:var(--ink);
  box-shadow:none;border-radius:8px;margin:0 1px}
.h-act button:hover{background:#e2e7f0;filter:none}
.h-act .h-clear{color:var(--busy)}

/* Modal clair sur mobile */
@media (max-width:560px){
  .resa-modal{padding:0;align-items:stretch}
  .resa-modal-card{max-width:none;max-height:100vh;height:100vh;border-radius:0;padding:20px 16px calc(20px + env(safe-area-inset-bottom))}
  .resa-modal-card h3{font-size:18px}
  /* Grille d'horaires : un jour = un bloc empilé (pas de défilement horizontal) */
  .resa-tbl.resa-hours{display:block;overflow:visible}
  .resa-hours tr{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid var(--line)}
  .resa-hours tr:first-child{display:none}
  .resa-hours td{display:block;padding:0;border:0}
  .resa-hours td:first-child{flex:0 0 100%;font-weight:700;color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.03em}
  .resa-hours td input[type=time]{width:auto}
  .resa-hours .h-act{margin-left:auto}
}
@media (max-width:480px){ .resa-modal-form .row2{grid-template-columns:1fr} }

/* Réservation par créneaux (façon Affluences) */
.resa-datepick{display:inline-flex;flex-direction:column;gap:5px;font-size:13px;font-weight:700;margin-bottom:14px}
.resa-datepick input{padding:9px 12px;border:1.5px solid #dde2ec;border-radius:12px;font-size:15px;font-family:inherit;background:#fff}
#dispo-head{margin-bottom:14px;font-weight:600}
.dispo-room{background:var(--surface);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.dr-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.dr-head b{font-weight:800;font-size:15px}
.dr-meta{font-size:12px;color:var(--muted)}
.dr-none{font-size:13px}
.dr-half{margin-bottom:10px}
.dr-half:last-child{margin-bottom:0}
.half-label{display:block;font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}
.chip-dur{opacity:.7;font-weight:600;font-size:11.5px}
.slot-chips{display:flex;flex-wrap:wrap;gap:8px}
.slot-chip{padding:8px 13px;border-radius:30px;border:1.5px solid var(--accent);background:#fff;color:var(--accent);
  font-weight:700;font-size:13.5px;cursor:pointer;box-shadow:none}
.slot-chip:hover{background:var(--accent);color:#fff;filter:none}
.next-dispo{padding:5px 11px;border-radius:30px;border:1.5px solid var(--accent);background:#fff;color:var(--accent);
  font-weight:700;font-size:12.5px;cursor:pointer;box-shadow:none}
.next-dispo:hover{background:var(--accent);color:#fff;filter:none}

/* Accueil : hero + tuiles d'action */
.home-hero{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;border-radius:var(--radius);
  padding:20px 22px;margin-bottom:18px;box-shadow:var(--shadow)}
.hh-greet{font-size:21px;font-weight:800;letter-spacing:-.01em}
.hh-sub{opacity:.92;font-size:14px;margin-top:3px}
.home-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:22px}
.act-tile{display:flex;flex-direction:column;align-items:flex-start;gap:10px;background:var(--surface);
  border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);
  transition:transform .15s,box-shadow .15s;position:relative}
.act-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.at-ico{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;position:relative}
.at-ico svg{width:24px;height:24px}
.at-blue{background:rgba(59,91,219,.12);color:var(--accent)}
.at-teal{background:rgba(21,163,91,.13);color:#15a35b}
.at-violet{background:rgba(107,77,255,.14);color:#6b4dff}
.at-lbl{font-weight:800;font-size:14.5px}
.at-badge{position:absolute;top:-5px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:10px;
  background:var(--accent);color:#fff;font-size:11px;font-weight:800;line-height:18px;text-align:center;box-shadow:0 0 0 2px #fff}
.at-badge.alert{background:var(--busy)}
.home-card{background:var(--surface);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);margin-bottom:22px}
.hc-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.hc-head h2{margin:0;font-size:16px}

/* Déconnexion (header) */
.resa-top-right{display:flex;align-items:center;gap:14px}
.resa-logout{display:inline-flex;align-items:center;color:var(--muted);text-decoration:none}
.resa-logout svg{width:22px;height:22px}
.resa-logout:hover{color:var(--busy)}

/* Cartes « mes prochaines réservations » */
.resv-list{display:grid;gap:10px}
.resv-card{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:var(--radius);padding:13px 15px;box-shadow:var(--shadow-sm)}
.rv-ico{flex:none;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(59,91,219,.1);color:var(--accent)}
.rv-ico svg{width:22px;height:22px}
.rv-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.rv-salle{font-weight:800;font-size:14.5px}
.rv-salle small{font-weight:600;color:var(--muted);font-size:12px}
.rv-when{font-size:13px;color:var(--muted)}
.resv-card .badge{margin-left:auto}
/* État vide (aucune réservation) */
.empty-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px 20px;
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.ec-ico{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:rgba(59,91,219,.1);color:var(--accent)}
.ec-ico svg{width:26px;height:26px}
.empty-card p{margin:0;color:var(--muted);font-size:14px}
.ec-btn{display:inline-block;background:var(--accent);color:#fff;font-weight:700;text-decoration:none;padding:10px 20px;border-radius:30px;box-shadow:0 6px 16px -6px rgba(59,91,219,.6)}
.ec-btn:hover{filter:brightness(1.07)}

/* Hub Réglages : liste d'actions en cartes */
.resa-actions{display:grid;gap:12px;max-width:580px}
.action-card{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--radius);
  padding:15px 18px;box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);transition:transform .15s,box-shadow .15s}
.action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.action-card .ac-ico{flex:none;width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:rgba(59,91,219,.1);color:var(--accent)}
.action-card .ac-ico svg{width:22px;height:22px}
.action-card .ac-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.action-card .ac-txt b{font-weight:800}
.action-card .ac-txt small{color:var(--muted);font-size:12.5px}
.action-card .ac-badge{margin-left:auto;flex:none;background:var(--busy);color:#fff;font-weight:800;font-size:12px;border-radius:30px;padding:3px 11px}

/* Barre de navigation basse (mobile) — façon StickyMobile */
.resa-bottomnav{display:none}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  text-decoration:none;color:var(--muted);font-size:11px;font-weight:600;padding:2px 0}
.bn-item .bn-ico svg{width:24px;height:24px;display:block}
.bn-item.is-active{color:var(--accent)}
.bn-item:active{transform:scale(.93)}

@media (max-width:760px){
  /* Sur mobile, la navigation passe en bas */
  .resa-top nav{display:none}
  .resa-bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;
    justify-content:space-around;background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line);
    padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
  body{padding-bottom:76px}
}
/* Garde anti-débord (sans overflow-x:hidden, qui casserait le header sticky) */
html,body{max-width:100%}
img,table{max-width:100%}
[hidden]{display:none!important}   /* garde : un attribut hidden prime sur display:grid/flex des formulaires */
.resa-main,.resa-occ{overflow-wrap:break-word}
.resa-main form input,.resa-main form select,.field input{max-width:100%}

@media (max-width:640px){
  /* Tableaux « denses » -> cartes empilées (libellé via data-label) */
  .resa-tbl.cards{box-shadow:none;background:transparent;border-radius:0}
  .resa-tbl.cards thead{position:absolute;left:-9999px}
  .resa-tbl.cards,.resa-tbl.cards tbody,.resa-tbl.cards tr,.resa-tbl.cards td{display:block;width:auto}
  .resa-tbl.cards tr{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);
    margin-bottom:10px;padding:8px 4px}
  .resa-tbl.cards td{border:0;padding:6px 14px;display:flex;justify-content:space-between;gap:14px;
    align-items:center;font-size:13.5px;text-align:right}
  .resa-tbl.cards td::before{content:attr(data-label);font-weight:700;color:var(--muted);
    text-align:left;flex:none}
  .resa-tbl.cards td:empty{display:none}
  .resa-tbl.cards td form{margin:0}
  /* Tables non converties : défilement horizontal plutôt que débord de page */
  .resa-tbl:not(.cards){display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
}

@media (max-width:560px){
  .resa-top{padding:11px 16px}
  .resa-main,.resa-occ{padding:20px 14px 56px}
  .occ-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
}
