
:root{
  --bg:#f7f8fb;
  --paper:#ffffff;
  --ink:#0f172a;
  --muted:#64748b;
  /* Ivory Coast palette (modifiable) */
  --c-orange:#f97316;
  --c-white:#ffffff;
  --c-green:#16a34a;
  /* roles */
  --accent:#2563eb;
  --radius:18px;
  --shadow:0 10px 24px rgba(2,6,23,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--ink)}
.container{max-width:1024px;margin:0 auto;padding:clamp(16px,3vw,28px)}
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.brand{font-weight:800;letter-spacing:.3px}
.badge{display:inline-flex;gap:8px;align-items:center;font-size:.85rem;color:#0f172a;background:linear-gradient(90deg,var(--c-orange),var(--c-white),var(--c-green));padding:6px 10px;border-radius:99px;border:1px solid rgba(0,0,0,.05)}

.tiles{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.tile{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;text-align:center}
.tile h3{margin:0 0 14px;font-size:1.1rem}
.cta{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:999px;font-weight:700;text-decoration:none;color:#fff;box-shadow:0 8px 16px rgba(0,0,0,.10);border:0;cursor:pointer}
.cta img{width:20px;height:20px;object-fit:contain;filter:brightness(0) invert(1)}
.cta.contrat{background:var(--c-orange)}
.cta.quittances{background:var(--accent)}
.cta.agent{background:#0ea5e9}
.cta.bailleur{background:#f59e0b}
.cta.incident{background:#ef4444}
.cta.news{background:#10b981}

.panel{background:var(--paper);border-radius:16px;box-shadow:var(--shadow);padding:18px;margin-top:16px}
.panel h2{margin:0 0 10px;font-size:1.1rem}
label{display:block;margin:10px 0 6px;color:var(--muted)}
input[type="text"],input[type="email"],textarea,select{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px}
button.btn{background:var(--accent);color:#fff;border:0;padding:10px 16px;border-radius:10px;font-weight:700;cursor:pointer}

.alert{padding:10px 12px;border-radius:10px;background:#fff7ed;border:1px solid #fed7aa;color:#7c2d12;margin:8px 0}
.success{padding:10px 12px;border-radius:10px;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;margin:8px 0}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid #eef2f7;text-align:left}
.footer{margin:24px 0;color:var(--muted);font-size:.9rem;text-align:center}
a.link{color:#2563eb;text-decoration:none}
a.link:hover{text-decoration:underline}
.hidden{display:none}

/* ===== Mobile responsiveness tweaks ===== */
html { -webkit-text-size-adjust: 100%; }
body { font-size: clamp(14px, 2.2vw, 16px); line-height: 1.35; }
.container{ max-width: 980px; padding: clamp(12px, 3vw, 28px); }
.tiles{ grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: clamp(12px, 2.5vw, 18px); }
.cta{ min-height: 42px; padding: 12px 16px; font-size: clamp(14px, 2.3vw, 15.5px); }
.tile{ padding: clamp(16px, 2.8vw, 22px); }
.panel{ padding: clamp(14px, 2.8vw, 18px); }
input[type="text"],input[type="email"],textarea,select{ font-size: 16px; } /* iOS zoom fix */
.header{ gap: 8px; flex-wrap: wrap; }
.badge{ white-space: nowrap; font-size: .8rem; }
@media (max-width: 480px){
  .cta{ width: 100%; justify-content: center; }
  .tiles{ grid-template-columns: 1fr; }
}
