/* EasyImmo — feuille de style mobile-first.
   Couleur de marque : teal/émeraude. Pensé d'abord pour le téléphone,
   confortable au pouce (gros boutons, barre d'onglets en bas). */

:root{
  --brand:#0f766e; --brand-dark:#115e59; --brand-light:#ccfbf1;
  --ink:#0f172a; --muted:#64748b; --line:#e2e8f0; --bg:#f1f5f9; --card:#fff;
  --ok:#16a34a; --ok-bg:#dcfce7; --warn:#d97706; --warn-bg:#fef3c7;
  --bad:#dc2626; --bad-bg:#fee2e2; --info-bg:#e0f2fe;
  --radius:14px; --shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand-dark);text-decoration:none}

/* Barre du haut */
.topbar{
  position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  background:var(--brand);color:#fff;padding:max(12px,env(safe-area-inset-top)) 16px 12px;
  box-shadow:var(--shadow);
}
.topbar .brand{color:#fff;font-weight:700;font-size:1.15rem}
.topbar .logout button{background:rgba(255,255,255,.18);color:#fff;border:0;border-radius:999px;padding:7px 14px;font-size:.85rem;font-weight:600}

/* Conteneur + place pour la tabbar */
.container{max-width:760px;margin:0 auto;padding:16px 16px 96px}

/* Barre d'onglets bas (mobile) */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;
  background:var(--card);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);
}
.tabbar a{
  flex:1;text-align:center;padding:9px 4px 7px;color:var(--muted);font-size:.72rem;font-weight:600;
}
.tabbar a span{display:block;font-size:1.35rem;line-height:1.2}
.tabbar a.active{color:var(--brand)}

/* Cartes */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:14px}
.card h2{margin:0 0 12px;font-size:1.05rem}
.card h3{margin:0 0 8px;font-size:.95rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
h1.page{font-size:1.35rem;margin:4px 0 16px}
.sub{color:var(--muted);font-size:.9rem;margin:-8px 0 14px}

/* Statistiques (tableau de bord) */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.stat .label{color:var(--muted);font-size:.78rem;font-weight:600}
.stat .value{font-size:1.45rem;font-weight:700;margin-top:4px}
.stat.full{grid-column:1/-1}
.stat .value.pos{color:var(--ok)} .stat .value.neg{color:var(--bad)}

/* Lignes / listes */
.row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row .main{font-weight:600}
.row .meta{color:var(--muted);font-size:.85rem}

/* Badges de statut */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:700;white-space:nowrap}
.b-paye{background:var(--ok-bg);color:var(--ok)}
.b-du{background:var(--warn-bg);color:var(--warn)}
.b-impaye{background:var(--bad-bg);color:var(--bad)}
.b-avenir{background:var(--bg);color:var(--muted)}
.b-partiel{background:var(--info-bg);color:#0369a1}

/* Boutons */
.btn{display:inline-block;border:0;border-radius:10px;padding:11px 16px;font-size:.95rem;font-weight:600;cursor:pointer;text-align:center}
.btn-primary{background:var(--brand);color:#fff}
.btn-ok{background:var(--ok);color:#fff}
.btn-light{background:var(--brand-light);color:var(--brand-dark)}
.btn-ghost{background:#f1f5f9;color:var(--ink)}
.btn-danger{background:var(--bad-bg);color:var(--bad)}
.btn-block{display:block;width:100%}
.btn-sm{padding:8px 12px;font-size:.85rem}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.55}
.actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}

/* Formulaires */
label{display:block;font-size:.85rem;font-weight:600;color:var(--muted);margin:10px 0 4px}
input,select,textarea{
  width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:#fff;color:var(--ink);
}
input:focus,select,textarea:focus{outline:2px solid var(--brand-light);border-color:var(--brand)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
textarea{min-height:80px;resize:vertical}

/* Flash */
.flash{padding:12px 14px;border-radius:10px;margin-bottom:14px;font-weight:600;font-size:.92rem}
.flash-success{background:var(--ok-bg);color:var(--ok)}
.flash-error{background:var(--bad-bg);color:var(--bad)}
.flash-info{background:var(--info-bg);color:#0369a1}

/* Login */
.login-wrap{position:fixed;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,var(--brand),var(--brand-dark));overflow:auto}
.login-card{background:#fff;border-radius:18px;box-shadow:0 10px 40px rgba(0,0,0,.2);padding:28px 22px;width:100%;max-width:340px}
.login-card .logo{font-size:2rem;text-align:center;margin-bottom:6px}
.login-card h1{text-align:center;font-size:1.3rem;margin:0 0 4px}
.login-card p.tag{text-align:center;color:var(--muted);margin:0 0 18px;font-size:.9rem}

.hint{color:var(--muted);font-size:.82rem;margin-top:4px}
.divider{height:1px;background:var(--line);margin:16px 0}
.pill-list{display:flex;flex-wrap:wrap;gap:6px}
table.amort{width:100%;border-collapse:collapse;font-size:.82rem}
table.amort th,table.amort td{padding:6px 8px;border-bottom:1px solid var(--line);text-align:right}
table.amort th:first-child,table.amort td:first-child{text-align:left}
.scroll-x{overflow-x:auto}
details summary{cursor:pointer;font-weight:600;color:var(--brand-dark);padding:6px 0}

/* ====================== HABILLAGE / DESIGN ====================== */
body{background:linear-gradient(180deg,#eef4f3 0,#f1f5f9 240px)}
.card{border:1px solid rgba(15,23,42,.04)}

/* Bannière photo du bien (hero) */
.hero{position:relative;border-radius:20px;overflow:hidden;background-size:cover;background-position:center 60%;
  min-height:180px;margin:2px 0 18px;box-shadow:0 8px 24px rgba(15,94,87,.18)}
.hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,94,87,.05) 0,rgba(13,70,64,.82) 100%)}
.hero-body{position:relative;min-height:180px;padding:18px;color:#fff;display:flex;flex-direction:column;justify-content:flex-end}
.hero-badge{align-self:flex-start;background:rgba(255,255,255,.22);padding:4px 12px;border-radius:999px;
  font-size:.7rem;font-weight:800;letter-spacing:.06em;margin-bottom:8px;backdrop-filter:blur(4px)}
.hero-body h1{margin:0;font-size:1.5rem;line-height:1.15;text-shadow:0 2px 10px rgba(0,0,0,.45)}
.hero-body .addr{margin:6px 0 0;font-size:.93rem;opacity:.96;text-shadow:0 1px 8px rgba(0,0,0,.5)}

/* Cartes stat : icône en filigrane + variante mise en avant */
.stat{position:relative;overflow:hidden;border:1px solid rgba(15,23,42,.05)}
.stat .ico{position:absolute;right:12px;top:10px;font-size:1.7rem;opacity:.16}
.stat.feature{background:linear-gradient(135deg,#15b8a6,#0f5e57);color:#fff;border:0}
.stat.feature .label{color:rgba(255,255,255,.85)}
.stat.feature .value{color:#fff}
.stat.feature .meta{color:rgba(255,255,255,.92) !important}
.stat.feature .ico{opacity:.3}

/* En-tête de carte avec pastille d'icône */
.card h3 .h3ico{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;
  border-radius:8px;background:var(--brand-light);margin-right:8px;font-size:.95rem;vertical-align:-6px}

/* Image dans la fiche Bien */
.bien-photo{width:100%;height:150px;object-fit:cover;border-radius:16px;margin-bottom:14px;box-shadow:var(--shadow)}

/* Coffre à documents : vignette d'icône par carte */
.doc-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.doc-row:last-child{border-bottom:0}
.doc-ic{flex:0 0 42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;background:var(--brand-light)}
.doc-main{flex:1;min-width:0}
.doc-main .t{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.doc-main .m{color:var(--muted);font-size:.82rem}

/* Boutons : petite ombre + transition */
.btn{transition:transform .04s, box-shadow .15s, filter .15s}
.btn-primary,.btn-ok{box-shadow:0 2px 8px rgba(15,118,110,.28)}
.btn-primary:hover,.btn-ok:hover{filter:brightness(1.05)}

/* Login : photo du bien en fond */
.login-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(1.05);opacity:.32}
.login-card{position:relative;z-index:1}

/* --- Kanban des loyers ---
   Grand écran : 3 colonnes égales, hauteur naturelle (pas d'étirement).
   Téléphone : défilement horizontal, une colonne par écran. */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:start;padding:4px 0 10px}
.kcol{background:#eef2f6;border-radius:16px;padding:10px 10px 4px;min-width:0}
@media(max-width:700px){
  .kanban{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
  .kcol{flex:0 0 86%;scroll-snap-align:start}
}
.kcol-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;
  padding:4px 6px 10px;color:var(--muted);text-transform:uppercase;font-size:.74rem;letter-spacing:.04em}
.kcol-head .cnt{background:#fff;border-radius:999px;padding:1px 9px;font-size:.74rem;color:var(--ink)}
.kcol.col-paye{background:#e7f6ec}
.kcol.col-du{background:#fef4e2}
.kcard{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:10px;border-left:4px solid var(--line)}
.kcard.s-paye{border-left-color:var(--ok)}
.kcard.s-du{border-left-color:var(--warn)}
.kcard.s-impaye{border-left-color:var(--bad)}
.kcard.s-a_venir{border-left-color:#cbd5e1}
.kcard .mois{font-weight:700;font-size:1.02rem}
.kcard .mont{font-weight:700;color:var(--brand-dark)}
.kcard .info{color:var(--muted);font-size:.82rem;margin-top:2px}
.kcard .actions{margin-top:10px;gap:6px}
.kcard .actions .btn{flex:1 1 auto}
.kempty{color:var(--muted);font-size:.82rem;text-align:center;padding:14px 6px}
.khint{color:var(--muted);font-size:.78rem;text-align:center;margin:-2px 0 8px}
@media(min-width:701px){.khint{display:none}}

/* --- Fenêtre de confirmation d'envoi de quittance --- */
.qc-overlay{position:fixed;inset:0;z-index:50;background:rgba(15,23,42,.55);
  display:flex;align-items:flex-end;justify-content:center;padding:0}
/* Doit l'emporter sur display:flex quand l'attribut hidden est présent,
   sinon la fenêtre reste affichée en permanence et bloque toute l'app. */
.qc-overlay[hidden]{display:none!important}
.qc-modal{background:#fff;width:100%;max-width:560px;border-radius:18px 18px 0 0;
  padding:20px 18px calc(18px + env(safe-area-inset-bottom));box-shadow:0 -8px 40px rgba(0,0,0,.25);
  max-height:90vh;overflow-y:auto;animation:qcUp .22s ease}
@keyframes qcUp{from{transform:translateY(40px);opacity:.6}to{transform:translateY(0);opacity:1}}
@media(min-width:600px){.qc-overlay{align-items:center}.qc-modal{border-radius:18px}}
.qc-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.qc-head .qc-ico{font-size:1.6rem}
.qc-head h2{margin:0;font-size:1.15rem}
.qc-intro{color:var(--ink);margin:.2rem 0 14px}
.qc-meta{background:var(--bg);border-radius:12px;padding:10px 12px;font-size:.9rem;margin-bottom:12px}
.qc-meta>div{padding:3px 0;word-break:break-word}
.qc-lbl{display:inline-block;min-width:84px;color:var(--muted);font-weight:600}
.qc-details{border:1px solid var(--line);border-radius:12px;padding:6px 12px;margin-bottom:12px}
.qc-corps{border-top:1px solid var(--line);margin-top:8px;padding-top:10px;font-size:.92rem;
  max-height:34vh;overflow-y:auto}
.qc-warn{background:var(--warn-bg);color:var(--warn);border-radius:10px;padding:10px 12px;
  font-weight:600;font-size:.88rem;margin-bottom:12px}
.qc-actions{display:flex;gap:10px}
.qc-actions .btn{flex:1;padding:13px}
