*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;background:#f5fafa;color:#1a2e3a;font-size:14px}
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#e8f4fd 0%,#d4f1f9 50%,#e8f5e9 100%)}
.login-card{background:#fff;padding:40px;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.08);text-align:center;width:100%;max-width:380px}
.login-card input{width:100%;padding:12px 14px;border:1px solid #dce8ea;border-radius:8px;font-size:14px;margin-bottom:10px;font-family:inherit}
.login-card input:focus{outline:0;border-color:#1e8fc7;box-shadow:0 0 0 3px rgba(30,143,199,.1)}
.client-wrap{min-height:100vh;display:flex;flex-direction:column}
.client-header{background:#fff;border-bottom:1px solid #e8eef2;position:sticky;top:0;z-index:50}
.client-header-inner{max-width:1080px;width:90%;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:60px}
.client-logo{display:flex;align-items:center}
.client-nav{display:flex;gap:6px}
.client-nav a{font-size:13px;font-weight:500;color:#2c4456;padding:8px 14px;border-radius:8px;transition:.15s;text-decoration:none}
.client-nav a:hover{background:#e0f2fb;color:#1e8fc7}
.client-nav a.active{background:linear-gradient(135deg,#1e8fc7,#26c6da);color:#fff;font-weight:600}
.client-user{font-size:13px;font-weight:600;color:#0d2137}
.client-main{flex:1;padding:30px 0}
.client-content{max-width:1080px;width:90%;margin:0 auto}
.client-title{font-family:'Fraunces',serif;font-size:24px;font-weight:700;margin-bottom:24px;color:#0d2137}
.client-footer{padding:20px 0;text-align:center;font-size:12px;color:#888;border-top:1px solid #e8eef2}
.client-footer a{color:#1e8fc7;text-decoration:none}
.btn-client{display:inline-block;padding:12px 24px;background:linear-gradient(135deg,#1e8fc7,#26c6da);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:.2s;text-decoration:none;width:100%}
.btn-client:hover{opacity:.9;transform:translateY(-1px)}
.btn-client-sm{padding:8px 16px;font-size:13px;width:auto}
.btn-client-outline{background:transparent;border:2px solid #1e8fc7;color:#1e8fc7}
.btn-client-outline:hover{background:#e0f2fb}
.client-card{background:#fff;border-radius:14px;padding:24px;border:1px solid #e8eef2;margin-bottom:20px}
.client-card h3{font-family:'Fraunces',serif;font-size:17px;font-weight:700;margin-bottom:14px;color:#0d2137}
.client-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.client-stat{background:#fff;border-radius:14px;padding:20px;border:1px solid #e8eef2;text-align:center}
.client-stat .val{font-size:28px;font-weight:800;color:#1e8fc7}
.client-stat .lbl{font-size:12px;color:#888;margin-top:4px}
.client-table{width:100%;border-collapse:collapse}
.client-table th{text-align:left;padding:10px 14px;background:#f8fafc;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#888;border-bottom:1px solid #e8eef2}
.client-table td{padding:10px 14px;border-bottom:1px solid #f0f4f8;font-size:13px}
.client-table a{color:#1e8fc7;font-weight:600}
.client-form label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:4px;margin-top:14px}
.client-form input,.client-form select,.client-form textarea{width:100%;padding:10px 12px;border:1px solid #dce8ea;border-radius:8px;font-size:14px;font-family:inherit}
.client-form input:focus,.client-form textarea:focus{outline:0;border-color:#1e8fc7;box-shadow:0 0 0 3px rgba(30,143,199,.1)}
.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}
.badge-planifie{background:#e3f2fd;color:#1565c0}
.badge-realise{background:#e8f5e9;color:#2e7d32}
.badge-annule{background:#fce4ec;color:#c62828}
.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:13px;font-weight:500}
.alert-error{background:#fce4ec;color:#c62828;border:1px solid #f8bbd0}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.share-box{background:var(--warm-light,#e0f2fb);border-radius:12px;padding:20px;text-align:center;margin:16px 0}
.share-code{font-size:24px;font-weight:800;letter-spacing:2px;color:#1e8fc7;margin:10px 0}
.share-btns{display:flex;gap:8px;justify-content:center;margin-top:12px}
@media(max-width:768px){
  .client-nav{display:none}
  .client-stat-grid{grid-template-columns:1fr}
  .client-header-inner{flex-wrap:wrap;height:auto;padding:10px 0}
}
