@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&family=Inter:wght@400;500;600&display=swap);:root{--primary:#1b4f72;--primary-dark:#154060;--secondary:#f39c12;--secondary-dark:#d68910;--bg:#f8f9fa;--white:#fff;--text:#1a1a2e;--success:#27ae60;--danger:#e74c3c;--muted:#7f8c8d;--border:#e0e0e0;--shadow:0 4px 20px #00000014;--shadow-hover:0 8px 30px #00000024;--radius-card:12px;--radius-btn:8px;--transition:0.3s ease;--sidebar-width:260px;--bottom-nav:64px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8f9fa;background-color:var(--bg);color:#1a1a2e;color:var(--text);font-family:Inter,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif;font-weight:700;line-height:1.3}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer}button,input,select,textarea{font-family:Inter,sans-serif;outline:none}img{display:block;max-width:100%}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f8f9fa;background:var(--bg)}::-webkit-scrollbar-thumb{background:#e0e0e0;background:var(--border);border-radius:3px}.card{background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-card);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow);transition:box-shadow .3s ease;transition:box-shadow var(--transition)}.card:hover{box-shadow:0 8px 30px #00000024;box-shadow:var(--shadow-hover)}.btn{align-items:center;border-radius:8px;border-radius:var(--radius-btn);display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.6rem 1.2rem;transition:all .3s ease;transition:all var(--transition);white-space:nowrap}.btn-primary{background:#1b4f72;background:var(--primary);color:#fff;color:var(--white)}.btn-primary:hover{background:#154060;background:var(--primary-dark)}.btn-secondary{background:#f39c12;background:var(--secondary);color:#fff;color:var(--white)}.btn-secondary:hover{background:#d68910;background:var(--secondary-dark)}.btn-outline{background:#0000;border:2px solid #1b4f72;border:2px solid var(--primary);color:#1b4f72;color:var(--primary)}.btn-outline:hover{background:#1b4f72;background:var(--primary);color:#fff;color:var(--white)}.btn-danger{background:#e74c3c;background:var(--danger);color:#fff;color:var(--white)}.btn-ghost{background:#0000;color:#7f8c8d;color:var(--muted)}.btn-ghost:hover{background:#f8f9fa;background:var(--bg)}.btn-sm{font-size:.8rem;padding:.35rem .8rem}.btn-lg{font-size:1rem;padding:.85rem 1.8rem}.btn:disabled{cursor:not-allowed;opacity:.6}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-label{font-size:.875rem;font-weight:600}.form-control,.form-label{color:#1a1a2e;color:var(--text)}.form-control{background:#fff;background:var(--white);border:1.5px solid #e0e0e0;border:1.5px solid var(--border);border-radius:8px;border-radius:var(--radius-btn);font-size:.9rem;padding:.65rem 1rem;transition:border-color .3s ease;transition:border-color var(--transition);width:100%}.form-control:focus{border-color:#1b4f72;border-color:var(--primary)}.form-control::placeholder{color:#7f8c8d;color:var(--muted)}textarea.form-control{min-height:100px;resize:vertical}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%237F8C8D' d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2.5rem}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.badge-success{background:#d4edda;color:#27ae60;color:var(--success)}.badge-danger{background:#fde8e8;color:#e74c3c;color:var(--danger)}.badge-warning{background:#fef3d7;color:#e67e22}.badge-muted{background:#ecf0f1;color:#7f8c8d;color:var(--muted)}.badge-primary{background:#d6e4f0;color:#1b4f72;color:var(--primary)}.grid-2{grid-gap:1rem;grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:1rem}.grid-3{grid-gap:1rem;grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal{animation:slideUp .3s ease;background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-card);max-height:90vh;max-width:540px;overflow-y:auto;padding:1.5rem;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tabs{background:#f8f9fa;background:var(--bg);border-radius:8px;border-radius:var(--radius-btn);display:flex;gap:.25rem;margin-bottom:1.25rem;overflow-x:auto;padding:.25rem}.tab-btn{background:#0000;border-radius:6px;color:#7f8c8d;color:var(--muted);font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .3s ease;transition:all var(--transition);white-space:nowrap}.tab-btn.active{background:#fff;background:var(--white);box-shadow:0 2px 8px #00000014;color:#1b4f72;color:var(--primary)}.app-wrapper{display:flex;min-height:100vh}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:1.5rem 1.5rem calc(64px + 1rem);padding-bottom:calc(var(--bottom-nav) + 1rem);width:100%}@media (min-width:992px){.main-content{margin-left:260px;margin-left:var(--sidebar-width);padding-bottom:1.5rem}}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-bottom:1.5rem}.page-title{color:#1a1a2e;color:var(--text);font-size:1.4rem}.text-center{text-align:center}.text-right{text-align:right}.divider{border:none;border-top:1px solid #e0e0e0;border-top:1px solid var(--border);margin:1rem 0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:1rem}.w-full{width:100%}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.spinner{animation:spin .8s linear infinite;border:4px solid #e0e0e0;border-top-color:#1b4f72;border:4px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:40px;margin:2rem auto;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{align-items:center;color:#7f8c8d;color:var(--muted);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem 1rem;text-align:center}.empty-state svg{opacity:.4}.chip,.empty-state h3{color:#1a1a2e;color:var(--text)}.chip{background:#f8f9fa;background:var(--bg);border:1px solid #e0e0e0;border:1px solid var(--border);border-radius:20px;display:inline-flex;font-size:.8rem;gap:.3rem;padding:.25rem .7rem}.chip,.stat-card{align-items:center}.stat-card{background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-card);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow);display:flex;gap:1rem;padding:1.25rem;transition:box-shadow .3s ease;transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:0 8px 30px #00000024;box-shadow:var(--shadow-hover)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.stat-info{flex:1 1}.stat-value{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:700}.stat-label{color:#7f8c8d;color:var(--muted);font-size:.8rem}.residence-card{background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-card);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow);cursor:pointer;overflow:hidden;transition:all .3s ease;transition:all var(--transition)}.residence-card:hover{box-shadow:0 8px 30px #00000024;box-shadow:var(--shadow-hover);transform:translateY(-2px)}.residence-card-img{background:#f8f9fa;background:var(--bg);height:200px;object-fit:cover;width:100%}.residence-card-img-placeholder{align-items:center;background:linear-gradient(135deg,#d6e4f0,#f0f4f8);color:#7f8c8d;color:var(--muted);display:flex;height:200px;justify-content:center;width:100%}.residence-card-body{padding:1rem}.residence-card-title{font-size:1rem;font-weight:700;margin-bottom:.25rem}.residence-card-meta{color:#7f8c8d;color:var(--muted);font-size:.82rem}.residence-card-footer{align-items:center;border-top:1px solid #f8f9fa;border-top:1px solid var(--bg);display:flex;justify-content:space-between;padding:.75rem 1rem}.chambre-card{align-items:center;background:#fff;background:var(--white);border-radius:12px;border-radius:var(--radius-card);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow);display:flex;gap:.75rem;padding:1rem;transition:box-shadow .3s ease;transition:box-shadow var(--transition)}.chambre-status-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.dot-libre{background:#27ae60;background:var(--success)}.dot-occupée{background:#e74c3c;background:var(--danger)}.dot-réservée{background:#e67e22}.dot-maintenance{background:#7f8c8d;background:var(--muted)}
/*# sourceMappingURL=main.bb3668fa.css.map*/