/* =====================================================================
   Hôtel La Perelle — Maintenance — feuille de style
   Charte : bleu site #2F4766, Montserrat, fond clair épuré
   ===================================================================== */
:root{
  --blue:#2F4766;
  --blue-d:#243a55;
  --blue-l:#e9eef4;
  --ink:#2b2b2b;
  --muted:#6b7785;
  --line:#e3e7ec;
  --bg:#f5f6f8;
  --white:#fff;
  --red:#c0392b;
  --amber:#e08a1e;
  --green:#2e8b57;
  --shadow:0 2px 10px rgba(47,71,102,.08);
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:'Montserrat',-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--bg);
  -webkit-tap-highlight-color:transparent;
}
.hidden{display:none !important}
button{font-family:inherit;cursor:pointer}
small{color:var(--muted)}

/* ---------- écran connexion ---------- */
.screen{min-height:100%;display:flex;flex-direction:column}
#screen-login{justify-content:center;align-items:center;
  background:linear-gradient(160deg,var(--blue) 0%,var(--blue-d) 100%);padding:24px}
.login-box{background:var(--white);border-radius:18px;box-shadow:0 12px 40px rgba(0,0,0,.25);
  width:100%;max-width:380px;padding:28px 24px 24px}
.brand{text-align:center;margin-bottom:22px}
.brand-logo{font-weight:700;letter-spacing:2px;color:var(--blue);font-size:19px}
.brand-logo img{max-height:48px;width:auto}
.brand-sub{color:var(--muted);font-size:12px;letter-spacing:1px;text-transform:uppercase;margin-top:6px}
.login-label{text-align:center;color:var(--ink);font-weight:600;margin:6px 0 16px}

.staff-list{display:flex;flex-direction:column;gap:8px}
.staff-group-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:10px 0 2px}
.staff-btn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:var(--blue-l);border:1px solid transparent;border-radius:12px;padding:13px 14px;font-size:15px;color:var(--ink);font-weight:500}
.staff-btn:active{transform:scale(.99)}
.staff-btn .av{width:34px;height:34px;border-radius:50%;background:var(--blue);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:14px;flex:none}
.staff-btn .rl{margin-left:auto;font-size:11px;color:var(--muted)}

/* pinpad */
.pin-dots{display:flex;justify-content:center;gap:14px;margin:6px 0 14px}
.pin-dots .dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--blue)}
.pin-dots .dot.on{background:var(--blue)}
.pin-error{color:var(--red);text-align:center;font-size:13px;margin-bottom:8px}
.pinpad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pinpad button{height:58px;border-radius:12px;border:1px solid var(--line);background:#fff;
  font-size:22px;font-weight:600;color:var(--ink)}
.pinpad button:active{background:var(--blue-l)}
.pinpad button.wide{font-size:15px;font-weight:500}
.btn-text{display:block;margin:14px auto 0;background:none;border:none;color:var(--muted);font-size:13px}

/* ---------- app : topbar ---------- */
.topbar{background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:space-between;
  padding:max(12px,env(safe-area-inset-top)) 16px 12px;position:sticky;top:0;z-index:20}
.topbar-brand{font-weight:700;letter-spacing:1px;font-size:15px}
.topbar-user{display:flex;align-items:center;gap:8px;font-size:13px}
.role-chip{background:rgba(255,255,255,.18);border-radius:20px;padding:3px 9px;font-size:11px}
.icon-btn{background:rgba(255,255,255,.15);border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:16px}

/* notif banner */
.notif-banner{background:#fff8e6;border-bottom:1px solid #f0e2bd;color:#7a5c12;
  font-size:13px;padding:10px 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btn-mini{border:none;background:var(--blue);color:#fff;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:600}
.btn-mini.ghost{background:transparent;color:var(--muted)}

/* ---------- onglets ---------- */
.tab{flex:1;padding:14px 14px calc(86px + var(--safe-b));overflow-y:auto}
.tab-title{font-size:18px;margin:4px 2px 14px;color:var(--blue)}

.filters{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:4px;-webkit-overflow-scrolling:touch}
.chip{border:1px solid var(--line);background:#fff;border-radius:20px;padding:7px 14px;font-size:13px;white-space:nowrap;color:var(--muted)}
.chip.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600}
.mine-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:6px 2px 12px}

/* cartes ticket */
.tickets-list{display:flex;flex-direction:column;gap:10px}
.empty{text-align:center;color:var(--muted);padding:40px 10px;font-size:14px}
.ticket-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:13px 14px;
  border-left:4px solid var(--blue);display:flex;gap:12px;align-items:flex-start}
.ticket-card.urgente{border-left-color:var(--red)}
.ticket-card.resolu{opacity:.62}
.tc-main{flex:1;min-width:0}
.tc-top{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.tc-loc{font-weight:700;color:var(--blue);font-size:15px}
.tc-cat{font-size:11px;color:var(--muted);background:var(--blue-l);padding:2px 8px;border-radius:20px}
.tc-title{font-size:14px;margin:2px 0 6px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tc-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted);flex-wrap:wrap}
.badge{font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px}
.badge.a_faire{background:#fdeeee;color:var(--red)}
.badge.en_cours{background:#fdf3e2;color:var(--amber)}
.badge.resolu{background:#e8f6ee;color:var(--green)}
.tc-thumb{width:54px;height:54px;border-radius:10px;object-fit:cover;flex:none;background:var(--blue-l)}
.tc-urgent-dot{color:var(--red);font-size:10px}

/* ---------- formulaires ---------- */
.form{display:flex;flex-direction:column;gap:14px;max-width:520px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);font-weight:600}
.form input[type=text],.form input:not([type]),.form input[list],.form select,.form textarea,
#s-name,#s-pin,#f-location,#f-title{
  font-family:inherit;font-size:15px;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:12px 12px;width:100%}
.form textarea{resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-l)}
.priority-row{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--muted);font-weight:600}
.radio{display:flex;align-items:center;gap:6px;font-weight:500}
.radio.urgent{color:var(--red)}
.photo-field input[type=file]{font-weight:400}
.photo-preview{margin-top:8px;display:flex;align-items:center;gap:10px}
.photo-preview img{width:84px;height:84px;object-fit:cover;border-radius:10px}

.btn-primary{background:var(--blue);color:#fff;border:none;border-radius:12px;padding:15px;font-size:15px;font-weight:600}
.btn-primary:active{background:var(--blue-d)}
.btn-primary:disabled{opacity:.5}
.new-feedback{font-size:13px;text-align:center;min-height:18px;margin:0}
.new-feedback.ok{color:var(--green)}
.new-feedback.err{color:var(--red)}

/* équipe */
.team-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.team-row{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:10px}
.team-row .av{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.team-row .rl{margin-left:auto;font-size:11px;color:var(--muted)}
.team-row .del{background:none;border:none;color:var(--red);font-size:18px}
.add-staff{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:16px}
.add-staff h3{margin:0 0 10px;color:var(--blue);font-size:15px}

/* ---------- barre d'onglets ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);
  display:flex;padding-bottom:var(--safe-b);z-index:20}
.tabbtn{flex:1;background:none;border:none;padding:10px 4px;font-size:11px;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:3px;font-weight:600}
.tabbtn .ti{font-size:20px;line-height:1}
.tabbtn.active{color:var(--blue)}

/* ---------- modale fiche ticket ---------- */
.modal{position:fixed;inset:0;background:rgba(20,30,45,.5);z-index:40;display:flex;align-items:flex-end;justify-content:center;
  padding-top:env(safe-area-inset-top)}
.modal-card{background:#fff;width:100%;max-width:560px;border-radius:18px 18px 0 0;max-height:86vh;overflow-y:auto;
  padding:0 18px calc(24px + var(--safe-b))}
/* en-tête fixe : reste visible et dégagé de la barre Safari / Dynamic Island */
.mc-head{position:sticky;top:0;background:#fff;z-index:3;display:flex;align-items:flex-start;gap:10px;
  padding-top:16px;padding-bottom:10px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.mc-loc{font-size:20px;font-weight:700;color:var(--blue)}
.mc-close{margin-left:auto;background:var(--blue-l);border:none;width:34px;height:34px;border-radius:50%;font-size:18px;color:var(--blue)}
.mc-row{font-size:14px;margin:6px 0;color:var(--ink)}
.mc-row .k{color:var(--muted);font-size:12px;display:block;margin-bottom:1px}
.mc-photo{width:100%;border-radius:12px;margin:12px 0}
.mc-section-title{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:16px 0 8px}
.status-actions{display:flex;gap:8px;flex-wrap:wrap}
.status-actions button{flex:1;min-width:90px;border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px;font-size:13px;font-weight:600;color:var(--ink)}
.status-actions button.cur{background:var(--blue);color:#fff;border-color:var(--blue)}
.assign-row{display:flex;gap:8px;align-items:center;margin-top:8px}
.assign-row select{flex:1;padding:10px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px}

.events{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.event{font-size:13px;color:var(--ink);background:var(--bg);border-radius:10px;padding:9px 11px}
.event .ev-meta{font-size:11px;color:var(--muted);margin-top:2px}
.comment-row{display:flex;gap:8px;margin-top:10px}
.comment-row input{flex:1;border:1px solid var(--line);border-radius:10px;padding:11px;font-family:inherit;font-size:14px}
.comment-row button{background:var(--blue);color:#fff;border:none;border-radius:10px;padding:0 16px;font-weight:600}

/* toasts */
.toasts{position:fixed;left:0;right:0;top:0;z-index:60;display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px;pointer-events:none}
.toast{background:var(--blue-d);color:#fff;border-radius:12px;padding:12px 16px;font-size:13px;box-shadow:0 6px 20px rgba(0,0,0,.3);max-width:90%;animation:pop .25s ease}
.toast.urgent{background:var(--red)}
@keyframes pop{from{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}
.loading{color:var(--muted);text-align:center;padding:20px;font-size:14px}
