/* =====================================================================
   GESTI-IMMO — Thème (Bleu nuit + Or)
   ===================================================================== */
:root{
  --gi-navy:#0e2748;
  --gi-navy-2:#163758;
  --gi-navy-dark:#0a1c34;
  --gi-gold:#f5b921;
  --gi-gold-2:#f7c948;
  --gi-bg:#f4f6fb;
  --gi-card:#ffffff;
  --gi-text:#1f2937;
  --gi-muted:#6b7280;
  --gi-border:#e5e9f2;
  --gi-sidebar-w:262px;
}
*{box-sizing:border-box}
body{
  margin:0;background:var(--gi-bg);color:var(--gi-text);
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
  font-size:14px;
}
a{text-decoration:none;color:var(--gi-navy)}
.text-gold{color:var(--gi-gold)!important}
.bg-navy{background:var(--gi-navy)!important;color:#fff}
.btn-gold{background:var(--gi-gold);border:none;color:var(--gi-navy);font-weight:600}
.btn-gold:hover{background:var(--gi-gold-2);color:var(--gi-navy)}
.btn-navy{background:var(--gi-navy);border:none;color:#fff}
.btn-navy:hover{background:var(--gi-navy-2);color:#fff}

/* ---------- Layout ---------- */
.gi-wrap{display:flex;min-height:100vh}
.gi-sidebar{
  width:var(--gi-sidebar-w);background:var(--gi-navy);color:#cdd7e6;
  position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:1030;
  transition:transform .25s ease;
}
.gi-sidebar .brand{
  display:flex;align-items:center;gap:10px;padding:16px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.gi-sidebar .brand img{width:40px;height:40px;border-radius:9px;object-fit:cover}
.gi-sidebar .brand b{color:#fff;font-size:17px}
.gi-sidebar .brand small{color:var(--gi-gold);font-size:10px;display:block;letter-spacing:.5px}
.gi-nav{list-style:none;padding:10px 0;margin:0}
.gi-nav .nav-title{padding:14px 18px 6px;font-size:10px;text-transform:uppercase;
  letter-spacing:1px;color:#6f86a6}
.gi-nav a{
  display:flex;align-items:center;gap:11px;padding:10px 18px;color:#cdd7e6;
  font-size:13.5px;border-left:3px solid transparent;
}
.gi-nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.gi-nav a.active{background:rgba(245,185,33,.12);color:#fff;border-left-color:var(--gi-gold)}
.gi-nav a .ic{width:20px;text-align:center;opacity:.9}
.gi-nav a .badge{margin-left:auto}

.gi-main{flex:1;margin-left:var(--gi-sidebar-w);min-width:0}
.gi-topbar{
  background:#fff;border-bottom:1px solid var(--gi-border);
  height:60px;display:flex;align-items:center;gap:14px;padding:0 22px;
  position:sticky;top:0;z-index:1020;
}
.gi-topbar .page-title{font-weight:700;color:var(--gi-navy);font-size:16px}
.gi-content{padding:24px}

.gi-card{background:var(--gi-card);border:1px solid var(--gi-border);border-radius:14px}
.gi-card .gi-card-h{padding:16px 18px;border-bottom:1px solid var(--gi-border);
  font-weight:600;color:var(--gi-navy);display:flex;align-items:center;gap:8px}
.gi-card .gi-card-b{padding:18px}

/* Stat cards */
.stat{background:#fff;border:1px solid var(--gi-border);border-radius:14px;padding:18px;
  display:flex;align-items:center;gap:14px}
.stat .ico{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:22px;color:#fff}
.stat .v{font-size:22px;font-weight:700;color:var(--gi-navy);line-height:1}
.stat .l{font-size:12px;color:var(--gi-muted);margin-top:3px}

.table thead th{background:#f7f9fc;color:var(--gi-navy);font-size:12px;
  text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--gi-border)}
.table td{vertical-align:middle}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--gi-navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}

.progress{height:8px;background:#e9eef6;border-radius:6px}
.progress-bar{background:var(--gi-gold)}

/* ---------- Login ---------- */
.gi-login{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;position:relative}
.gi-login::before{content:"";position:absolute;inset:0;background:rgba(8,20,40,.55)}
.gi-login .card-login{position:relative;z-index:2;width:100%;max-width:410px;
  background:rgba(255,255,255,.97);border-radius:20px;padding:36px 32px;
  box-shadow:0 25px 60px rgba(0,0,0,.4)}
.gi-login .logo{display:block;width:96px;height:96px;margin:0 auto 14px;
  border-radius:18px;object-fit:cover;box-shadow:0 8px 22px rgba(14,39,72,.25)}
.gi-login h1{text-align:center;color:var(--gi-navy);font-size:22px;margin:0 0 2px}
.gi-login .sub{text-align:center;color:var(--gi-gold);font-size:11px;
  text-transform:uppercase;letter-spacing:1.5px;margin-bottom:22px}
.gi-login .form-control{padding:12px 14px;border-radius:10px}
.gi-login .btn{padding:12px;border-radius:10px;font-weight:600}

/* Sidebar mobile */
.gi-burger{display:none;background:none;border:none;font-size:22px;color:var(--gi-navy)}
@media(max-width:992px){
  .gi-sidebar{transform:translateX(-100%)}
  .gi-sidebar.open{transform:translateX(0)}
  .gi-main{margin-left:0}
  .gi-burger{display:block}
}
.gi-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1025}
.gi-overlay.show{display:block}

/* ================= Composants modules ================= */

/* Avatars */
.gi-avatar{width:40px;height:40px;border-radius:50%;background:var(--gi-navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex:0 0 auto}
.gi-avatar-lg{width:64px;height:64px;border-radius:50%;background:var(--gi-navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;flex:0 0 auto}

/* Utilitaires couleur */
.text-navy{color:var(--gi-navy)!important}
.bg-navy{background:var(--gi-navy)!important;color:#fff}
.text-gold{color:var(--gi-gold)!important}
.btn-gold{background:var(--gi-gold);border-color:var(--gi-gold);color:var(--gi-navy);font-weight:600}
.btn-gold:hover{background:var(--gi-gold-2);border-color:var(--gi-gold-2);color:var(--gi-navy)}
.btn-outline-gold{border:1px solid var(--gi-gold);color:var(--gi-navy);background:transparent;font-weight:600}
.btn-outline-gold:hover{background:var(--gi-gold);color:var(--gi-navy)}

/* Cartes stat (KPI) */
.gi-stat{background:var(--gi-card);border:1px solid var(--gi-border);border-radius:14px;
  padding:18px 20px;display:flex;flex-direction:column;gap:4px;height:100%;
  box-shadow:0 1px 3px rgba(14,39,72,.05)}
.gi-stat .lbl{font-size:12px;color:var(--gi-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.gi-stat .val{font-size:24px;font-weight:700;color:var(--gi-navy);line-height:1.1}
.gi-stat.gold{border-left:4px solid var(--gi-gold)}
.gi-stat.navy{border-left:4px solid var(--gi-navy)}

/* ---------- Stepper workflow projet ---------- */
.gi-stepper{display:flex;flex-wrap:wrap;gap:0;list-style:none;padding:0;margin:0}
.gi-stepper li{flex:1 1 0;min-width:96px;text-align:center;position:relative;padding:0 4px}
.gi-stepper li::before{content:"";position:absolute;top:16px;left:-50%;width:100%;height:3px;
  background:var(--gi-border);z-index:0}
.gi-stepper li:first-child::before{display:none}
.gi-stepper .dot{position:relative;z-index:1;width:34px;height:34px;border-radius:50%;
  background:#fff;border:3px solid var(--gi-border);color:var(--gi-muted);
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-bottom:6px}
.gi-stepper .lbl{display:block;font-size:11px;color:var(--gi-muted);font-weight:600;line-height:1.2}
.gi-stepper li.done .dot{background:var(--gi-gold);border-color:var(--gi-gold);color:var(--gi-navy)}
.gi-stepper li.done::before{background:var(--gi-gold)}
.gi-stepper li.active .dot{background:var(--gi-navy);border-color:var(--gi-navy);color:#fff;
  box-shadow:0 0 0 4px rgba(14,39,72,.12)}
.gi-stepper li.active .lbl{color:var(--gi-navy)}

/* Timeline avancement */
.gi-timeline-dot{width:14px;height:14px;border-radius:50%;background:var(--gi-gold);
  border:3px solid #fff;box-shadow:0 0 0 2px var(--gi-gold);flex:0 0 auto}

/* ---------- Galerie médias (avancement) ---------- */
.gi-media-cover{width:100%;height:180px;object-fit:cover;border-radius:12px 12px 0 0;background:#eef2f8}
.gi-media-empty{width:100%;height:180px;border-radius:12px 12px 0 0;background:linear-gradient(135deg,#eef2f8,#dde6f2);
  display:flex;align-items:center;justify-content:center;color:var(--gi-muted);font-size:40px}
.gi-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.gi-gallery-item{border-radius:12px;overflow:hidden;border:1px solid var(--gi-border);background:#000;
  position:relative;aspect-ratio:1/1}
.gi-gallery-item img,.gi-gallery-item video{width:100%;height:100%;object-fit:cover;display:block}
.gi-gallery-file{border-radius:12px;border:1px solid var(--gi-border);background:#f8fafc;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  aspect-ratio:1/1;color:var(--gi-navy);text-decoration:none;gap:6px;font-size:13px;padding:8px;text-align:center}
.gi-gallery-file:hover{background:#eef2f8}

/* ---------- Éditeur de contrat ---------- */
.gi-editor-toolbar{display:flex;flex-wrap:wrap;gap:4px;padding:8px;background:#f1f4fa;
  border:1px solid var(--gi-border);border-bottom:none;border-radius:10px 10px 0 0}
.gi-editor-toolbar button{border:1px solid var(--gi-border);background:#fff;border-radius:6px;
  padding:4px 10px;font-size:13px;cursor:pointer;color:var(--gi-navy)}
.gi-editor-toolbar button:hover{background:var(--gi-gold);border-color:var(--gi-gold)}
.gi-editor{min-height:420px;border:1px solid var(--gi-border);border-radius:0 0 10px 10px;
  padding:28px 32px;background:#fff;outline:none;line-height:1.7;color:var(--gi-text);overflow:auto}
.gi-editor:focus{border-color:var(--gi-gold)}

/* Contrat papier (affichage) */
.gi-contract-paper{background:#fff;border:1px solid var(--gi-border);border-radius:12px;
  padding:40px 48px;line-height:1.7;max-width:900px;margin:0 auto;
  box-shadow:0 2px 12px rgba(14,39,72,.06)}
.gi-contract-paper h1,.gi-contract-paper h2,.gi-contract-paper h3{color:var(--gi-navy)}

/* Signature pad */
.gi-sign-pad{border:2px dashed var(--gi-gold);border-radius:12px;background:#fffdf6;
  touch-action:none;cursor:crosshair;display:block;width:100%;max-width:420px}

/* ---------- Documents (devis/facture...) ---------- */
.gi-doc{background:#fff;border:1px solid var(--gi-border);border-radius:12px;padding:40px 44px;
  max-width:920px;margin:0 auto;box-shadow:0 2px 12px rgba(14,39,72,.06)}
.gi-doc .doc-head{display:flex;justify-content:space-between;align-items:flex-start;
  border-bottom:3px solid var(--gi-navy);padding-bottom:18px;margin-bottom:24px}
.gi-doc .doc-title{font-size:30px;font-weight:800;color:var(--gi-navy);text-transform:uppercase;letter-spacing:1px}
.gi-doc .doc-meta{font-size:13px;color:var(--gi-muted)}
.gi-doc-client{background:#f8fafc;border-radius:10px;padding:14px 18px;margin-bottom:20px}
.gi-doc table{width:100%;border-collapse:collapse;margin:18px 0}
.gi-doc table th{background:var(--gi-navy);color:#fff;padding:10px 12px;font-size:13px;text-align:left}
.gi-doc table td{padding:10px 12px;border-bottom:1px solid var(--gi-border);font-size:14px}
.gi-doc .doc-totals{margin-left:auto;width:300px}
.gi-doc .doc-totals .row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}
.gi-doc .doc-totals .row.grand{border-top:2px solid var(--gi-navy);margin-top:6px;padding-top:10px;
  font-size:18px;font-weight:800;color:var(--gi-navy)}

/* ---------- Messagerie / chat ---------- */
.gi-chat{display:flex;flex-direction:column;gap:12px;padding:18px;max-height:560px;overflow-y:auto;
  background:#f4f6fb;border-radius:12px}
.gi-msg{max-width:72%;padding:10px 14px;border-radius:14px;background:#fff;border:1px solid var(--gi-border);
  align-self:flex-start;box-shadow:0 1px 2px rgba(14,39,72,.04)}
.gi-msg .meta{font-size:11px;color:var(--gi-muted);margin-bottom:3px;font-weight:600}
.gi-msg .body{font-size:14px;color:var(--gi-text);white-space:pre-wrap;word-break:break-word}
.gi-msg.mine{align-self:flex-end;background:var(--gi-navy);border-color:var(--gi-navy);color:#fff}
.gi-msg.mine .meta{color:rgba(255,255,255,.7)}
.gi-msg.mine .body{color:#fff}

@media print{
  .gi-sidebar,.gi-topbar,.gi-burger,.no-print,.btn{display:none!important}
  .gi-main{margin-left:0!important}
  .gi-content{padding:0!important}
  .gi-doc,.gi-contract-paper{box-shadow:none;border:none}
}

/* ---------- Matrice de permissions (chips) ---------- */
.perm-chip{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border:1px solid var(--gi-border);
  border-radius:9px;cursor:pointer;background:#fff;transition:.15s;height:100%;font-size:13px;line-height:1.3}
.perm-chip:hover{border-color:var(--gi-gold);background:#fffdf6}
.perm-chip input{margin-top:2px;flex:0 0 auto}
.perm-chip span{display:flex;flex-direction:column;gap:1px;color:var(--gi-text)}
.perm-chip code{font-size:10.5px;background:#f1f4fa;padding:0 5px;border-radius:4px;width:fit-content}
.perm-chip input:checked + span{font-weight:600;color:var(--gi-navy)}
.perm-chip:has(input:checked){border-color:var(--gi-gold);background:#fff8e8}

/* ---------- UI moderne : Toasts ---------- */
.gi-toasts{position:fixed;top:18px;right:18px;z-index:11000;display:flex;flex-direction:column;gap:10px;max-width:370px}
.gi-toast{display:flex;align-items:flex-start;gap:11px;background:#fff;border-radius:13px;padding:13px 15px;
  box-shadow:0 12px 34px rgba(14,39,72,.18);border-left:4px solid var(--gi-navy);
  transform:translateX(125%);opacity:0;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .4s}
.gi-toast.show{transform:none;opacity:1}
.gi-toast .ic{font-size:20px;line-height:1.1}
.gi-toast .tx{flex:1;font-size:14px;color:var(--gi-navy);line-height:1.4}
.gi-toast .cl{border:0;background:none;color:#9aa6b8;font-size:20px;line-height:1;cursor:pointer;padding:0 2px}
.gi-toast.success{border-left-color:#1ea672} .gi-toast.success .ic{color:#1ea672}
.gi-toast.error{border-left-color:#e0414e}   .gi-toast.error .ic{color:#e0414e}
.gi-toast.warning{border-left-color:#f5b921} .gi-toast.warning .ic{color:#e0a500}
.gi-toast.info{border-left-color:#2b7de9}    .gi-toast.info .ic{color:#2b7de9}

/* ---------- UI moderne : Modal de confirmation ---------- */
.gi-modal-backdrop{position:fixed;inset:0;z-index:10900;background:rgba(14,39,72,.45);
  backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s}
.gi-modal-backdrop.show{opacity:1;pointer-events:auto}
.gi-modal{background:#fff;border-radius:18px;max-width:430px;width:92%;padding:28px 26px;text-align:center;
  box-shadow:0 26px 64px rgba(14,39,72,.32);transform:scale(.9) translateY(8px);
  transition:transform .28s cubic-bezier(.22,1,.36,1)}
.gi-modal-backdrop.show .gi-modal{transform:none}
.gi-modal .ic{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:28px}
.gi-modal .ic.danger{background:#fdecee;color:#e0414e}
.gi-modal .ic.gold{background:#fff6e0;color:#e0a500}
.gi-modal h5{color:var(--gi-navy);font-weight:700;margin-bottom:8px}
.gi-modal p{color:#5b6675;margin-bottom:22px;font-size:14.5px}
.gi-modal .btns{display:flex;gap:10px;justify-content:center}
.gi-modal .btns .btn{min-width:120px}

/* ---------- Avatars image ---------- */
.gi-avatar img,.gi-avatar-lg img,.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.gi-avatar.has-img,.gi-avatar-lg.has-img,.avatar.has-img{background:transparent !important;padding:0;overflow:hidden}
.gi-msg .av{width:32px;height:32px;border-radius:50%;background:var(--gi-navy);color:#fff;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;overflow:hidden}
.gi-msg .av img{width:100%;height:100%;object-fit:cover}
.gi-msg{display:flex;gap:8px;align-items:flex-end}
.gi-msg.mine{flex-direction:row-reverse}

/* ---------- Intervention : légende du plan ---------- */
.iv-legend{display:flex;flex-direction:column;gap:6px}
.iv-leg-row{display:flex;align-items:center;gap:8px;font-size:12.5px;padding:4px 0;border-bottom:1px dashed #eef1f6}
.iv-leg-row:last-child{border-bottom:0}
.iv-sw{width:16px;height:16px;border-radius:4px;flex:0 0 auto;border:1px solid rgba(0,0,0,.15)}
.iv-leg-n{width:18px;height:18px;border-radius:50%;background:var(--gi-navy);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.iv-leg-name{flex:1;font-weight:600;color:var(--gi-navy)}
.iv-leg-tag{font-weight:400;font-size:10.5px;background:#fff3d6;color:#a8780a;padding:0 5px;border-radius:4px}
.iv-leg-type{color:#8893a5;font-size:11px}
.iv-leg-dim{color:#5b6675;font-size:11px;min-width:60px;text-align:right}
.iv-leg-qty{font-weight:600;color:var(--gi-navy);min-width:48px;text-align:right}
.iv-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
#planWrap{background:#fff;border-radius:10px}
.iv-block{transition:filter .12s}.iv-block:hover{filter:brightness(1.05)}

/* ---------- Impression ---------- */
@media print{
  .gi-sidebar,.gi-topbar,.gi-overlay,.d-print-none,.gi-toasts{display:none !important}
  .gi-main{margin:0 !important}
  .gi-content{padding:0 !important}
  .iv-print-area{padding:6mm}
  .gi-card{box-shadow:none !important;border:1px solid #dde3ec !important;break-inside:avoid}
  body{background:#fff !important}
  a[href]:after{content:''}
}
