body{margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-form input{border:1px solid #ddd;border-radius:4px;font-size:16px;height:45px;outline:none;padding:10px;transition:border-color .3s}.login-form input:focus{border-color:#556070}.login-form input.error{border-color:#dc3545}.login-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{font-size:14px;margin-top:5px}.global-error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;padding:10px;text-align:center}.submit-button{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;height:45px;transition:opacity .3s}.submit-button:disabled{cursor:not-allowed;opacity:.6}.login-page{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:40px;width:400px}.login-title{color:#556070;font-size:32px;font-weight:700;margin-bottom:30px;text-align:center}.dashboard-page{background-color:#f5f5f5;min-height:100vh;padding:40px}.dashboard-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:800px;padding:40px}.dashboard-container h1{color:#556070;margin-bottom:30px}.user-info{background-color:#f9f9f9;border-radius:4px;margin-bottom:30px;padding:20px}.user-info p{font-size:16px;margin:10px 0}.logout-button{font-size:16px;padding:10px 20px}.building-form{display:flex;flex-direction:column;gap:20px}.building-form input,.building-form textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;outline:none;padding:10px;transition:border-color .3s}.building-form input:focus,.building-form textarea:focus{border-color:#556070}.building-form input.error,.building-form textarea.error{border-color:#dc3545}.building-form input:disabled,.building-form textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.building-form textarea{min-height:80px;resize:vertical}.buildings-page{background-color:#f5f5f5;min-height:100vh}.page-header{background-color:#fff;padding:20px 40px}.page-header h1{color:#556070;font-size:24px}.logout-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:opacity .3s}.logout-button:hover{opacity:.9}.page-content{padding:40px 20px}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.content-header h2{color:#333;font-size:28px;margin:0}.add-button{background-color:#556070;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:opacity .3s}.add-button:hover{opacity:.9}.search-container{margin-bottom:30px}.search-input{font-size:14px;max-width:500px;outline:none;padding:12px;transition:border-color .3s}.search-input:focus{border-color:#556070}.buildings-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.building-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:default;display:flex;flex-direction:column;padding:20px;transition:transform .2s,box-shadow .2s}.building-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.building-icon{font-size:32px;margin-bottom:10px}.building-info{flex:1 1;margin-bottom:15px}.building-details h3{color:#333;font-size:18px;margin:0 0 8px}.building-address{color:#666;font-size:14px;margin:4px 0}.building-floors{color:#888;font-size:14px;margin:4px 0}.building-description{color:#999;font-size:13px;line-height:1.4;margin:8px 0 0}.building-actions{display:flex;gap:10px;margin-top:15px}.btn-select{background:#556070;border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:8px 16px;transition:background .3s}.btn-select:hover{background:#445060}.btn-edit{background:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .3s}.btn-edit:hover{background:#e0e0e0}@media (max-width:768px){.page-header{padding:15px 20px}.page-content{padding:20px 15px}.content-header{align-items:flex-start;flex-direction:column;gap:15px}.buildings-list{grid-template-columns:1fr}}.sidebar{background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:250px;z-index:100}.sidebar-header{border-bottom:1px solid #e0e0e0;padding:20px}.back-button{background-color:#f5f5f5;padding:10px;width:100%}.sidebar-nav{flex:1 1;overflow-y:auto;padding:10px 0}.sidebar-item{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 20px;text-align:left;transition:background .2s;width:100%}.sidebar-item:hover{background-color:#f5f5f5}.sidebar-item.active{background-color:#556070;color:#fff}.sidebar-item.active:hover{background-color:#445060}.sidebar-icon{font-size:18px}.sidebar-label{flex:1 1}.building-info-container{max-width:800px;padding:40px}.building-info-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;gap:15px;margin-bottom:30px;padding-bottom:20px}.building-info-icon{font-size:48px}.building-info-header h1{color:#333;font-size:32px;margin:0}.building-info-content{display:flex;flex-direction:column;gap:30px}.info-section{background-color:#f9f9f9;border-radius:8px;padding:20px}.info-section h2{color:#556070;font-size:20px;margin:0 0 15px}.info-item{border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:10px 0}.info-item:last-child{border-bottom:none}.info-label{color:#666;font-weight:500}.info-value{color:#333;text-align:right}.description-text{color:#333;line-height:1.6;margin:0}.error-message,.loading{color:#666;font-size:16px;padding:40px;text-align:center}.room-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:30px}.tab-button{border-bottom:3px solid #0000;bottom:-2px;color:#666;font-size:16px;font-weight:500;padding:12px 24px;position:relative;transition:color .3s,border-color .3s}.tab-button:hover{color:#556070}.tab-button.active{border-bottom-color:#556070;color:#556070}.room-photos-preview{border-radius:8px 8px 0 0;margin-bottom:10px;overflow:hidden;width:100%}.photo-thumbnails{background:#f8f9fa;display:flex;gap:5px;height:80px;padding:5px}.photo-thumbnails .thumbnail{border-radius:4px;cursor:pointer;flex:1 1;height:100%;object-fit:cover;transition:transform .2s}.photo-thumbnails .thumbnail:hover{transform:scale(1.05)}.more-photos{align-items:center;background:#00000080;border-radius:4px;color:#fff;display:flex;flex:1 1;font-size:.9rem;font-weight:700;justify-content:center}.room-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;padding:20px;transition:transform .2s,box-shadow .2s}.room-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.room-header{margin-bottom:15px}.room-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.room-info{display:flex;flex-direction:column;gap:8px;margin-bottom:15px}.room-detail{display:flex;font-size:14px;justify-content:space-between}.detail-value{font-weight:500}.room-divider{background-color:#e0e0e0;height:1px;margin:15px 0}.room-pricing{display:flex;flex-direction:column;gap:8px}.price-item{display:flex;font-size:14px;justify-content:space-between}.price-label{color:#666}.price-value{color:#556070;font-weight:600}.room-actions{border-top:1px solid #e0e0e0;display:flex;gap:10px;margin-top:15px;padding-top:15px}.btn-delete-room,.btn-edit-room{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:13px;padding:8px 12px;transition:opacity .3s}.btn-edit-room{background-color:#f0f0f0;color:#333}.btn-edit-room:hover{background-color:#e0e0e0}.btn-delete-room{background-color:#dc3545;color:#fff}.btn-delete-room:hover{opacity:.9}.room-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:5px}.form-group label{font-size:14px}.room-form input,.room-form select{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;outline:none;padding:10px;transition:border-color .3s}.room-form input:focus,.room-form select:focus{border-color:#556070}.room-form input.error,.room-form select.error{border-color:#dc3545}.room-form input:disabled,.room-form select:disabled{background-color:#f5f5f5;cursor:not-allowed}.checkbox-group label{gap:8px}.checkbox-group input[type=checkbox]{height:18px;width:18px}.error-message{font-size:12px;margin-top:2px}.form-actions{gap:10px;margin-top:10px}.cancel-button,.submit-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:opacity .3s}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){opacity:.9}.submit-button{background-color:#556070;color:#fff}.submit-button:hover:not(:disabled){opacity:.9}.cancel-button:disabled,.submit-button:disabled{cursor:not-allowed;opacity:.6}.room-photo-manager{background:#f8f9fa;border-radius:8px;margin:20px 0;padding:15px}.room-photo-manager h3{color:#333;font-size:1.2rem;margin-bottom:15px}.photos-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:15px}.photo-item{aspect-ratio:1;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;position:relative;transition:transform .2s}.photo-item:hover{box-shadow:0 4px 8px #00000026;transform:scale(1.05)}.photo-item img{display:block;height:100%;object-fit:cover;width:100%}.photo-description{background:#000000b3;bottom:0;color:#fff;font-size:.85rem;left:0;overflow:hidden;padding:5px 8px;position:absolute;right:0;text-overflow:ellipsis;white-space:nowrap}.delete-btn{align-items:center;background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 2px 4px #0003;color:#e74c3c;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:30px;justify-content:center;opacity:0;position:absolute;right:5px;top:5px;transition:opacity .2s,transform .2s;width:30px}.photo-item:hover .delete-btn{opacity:1}.delete-btn:hover{background:#fff;transform:scale(1.1)}.delete-btn:active{transform:scale(.95)}.upload-box{align-items:center;aspect-ratio:1;background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;cursor:pointer;display:flex;justify-content:center;min-height:150px;transition:all .3s}.upload-box:hover{background:#e7f3ff;border-color:#007bff}.upload-box label{align-items:center;color:#666;cursor:pointer;display:flex;flex-direction:column;gap:8px;height:100%;justify-content:center;padding:20px;text-align:center;width:100%}.upload-box label.uploading{cursor:not-allowed;opacity:.6}.upload-icon{font-size:32px}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin:10px 0;padding:10px 15px}@media (max-width:768px){.photos-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.room-photo-manager{padding:10px}}.rooms-content{min-height:100vh;padding:40px}.rooms-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.back-button{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:10px 20px;transition:background .3s}.back-button:hover{background-color:#e0e0e0}.add-room-button{background-color:#556070;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:opacity .3s}.add-room-button:hover{opacity:.9}.rooms-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.empty-state{color:#999;grid-column:1/-1}.empty-state,.loading{font-size:16px;padding:60px 20px;text-align:center}.loading{color:#666}.modal-overlay{padding:20px}.modal-content{background-color:#fff;box-shadow:0 4px 20px #0000004d;width:100%}.modal-header{padding:20px}.modal-header h2{color:#556070;font-size:24px}.close-button{font-size:32px;height:32px;transition:color .3s;width:32px}.modal-body{padding:20px}@media (max-width:768px){.rooms-content{margin-left:0;padding:20px}.rooms-header{align-items:flex-start;flex-direction:column;gap:15px}.rooms-grid{grid-template-columns:1fr}}.tenant-form{display:flex;flex-direction:column;gap:1.5rem}.tenant-form .form-group{display:flex;flex-direction:column;gap:.5rem}.tenant-form label{color:#333;font-weight:500}.tenant-form .required{color:#e74c3c}.tenant-form input[type=email],.tenant-form input[type=tel],.tenant-form input[type=text],.tenant-form textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.tenant-form input:focus,.tenant-form textarea:focus{border-color:#3498db;outline:none}.tenant-form input.error,.tenant-form textarea.error{border-color:#e74c3c}.tenant-form .error-message{color:#e74c3c;font-size:.875rem}.tenant-form .checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.tenant-form .checkbox-group input[type=checkbox]{margin:0;width:auto}.tenant-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.tenant-form .cancel-button,.tenant-form .submit-button{border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.tenant-form .cancel-button{background-color:#95a5a6;color:#fff}.tenant-form .cancel-button:hover:not(:disabled){background-color:#7f8c8d}.tenant-form .submit-button{background-color:#3498db;color:#fff}.tenant-form .submit-button:hover:not(:disabled){background-color:#2980b9}.tenant-form button:disabled{cursor:not-allowed;opacity:.6}.tenant-form select{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.tenant-form select:focus{border-color:#3498db;outline:none}.tenant-form select.error{border-color:#e74c3c}.tenant-form input[type=date]{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.tenant-form .form-section{border-top:2px solid #eee;margin-top:2rem;padding-top:1.5rem}.tenant-form .form-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.tenant-form .form-section h3{color:#333;font-size:1.25rem;margin:0 0 1rem}.tenant-form .form-section h4{color:#555;font-size:1.1rem;margin:1.5rem 0 1rem}.tenants-page{background-color:#f5f5f5;min-height:100vh}.tenants-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.tenant-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.tenant-card.inactive{background-color:#f9f9f9;opacity:.7}.tenant-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.tenant-info h3{color:#333;font-size:1.25rem;margin:0}.tenant-type-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.tenant-details{flex-direction:column;gap:.5rem}.tenant-actions{display:flex;gap:.5rem;margin-top:auto}.landlord-form{display:flex;flex-direction:column;gap:1.5rem}.landlord-form .form-group{display:flex;flex-direction:column;gap:.5rem}.landlord-form label{color:#333;font-weight:500}.landlord-form .required{color:#e74c3c}.landlord-form input[type=email],.landlord-form input[type=tel],.landlord-form input[type=text],.landlord-form textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.landlord-form input:focus,.landlord-form textarea:focus{border-color:#3498db;outline:none}.landlord-form input.error,.landlord-form textarea.error{border-color:#e74c3c}.landlord-form .error-message{color:#e74c3c;font-size:.875rem}.landlord-form .checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.landlord-form .checkbox-group input[type=checkbox]{margin:0;width:auto}.landlord-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.landlord-form .cancel-button,.landlord-form .submit-button{border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.landlord-form .cancel-button{background-color:#95a5a6;color:#fff}.landlord-form .cancel-button:hover:not(:disabled){background-color:#7f8c8d}.landlord-form .submit-button{background-color:#3498db;color:#fff}.landlord-form .submit-button:hover:not(:disabled){background-color:#2980b9}.landlord-form button:disabled{cursor:not-allowed;opacity:.6}.landlord-form select{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.landlord-form select:focus{border-color:#3498db;outline:none}.landlord-form select.error{border-color:#e74c3c}.landlord-form input[type=date]{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s}.landlord-form .form-section{border-top:2px solid #eee;margin-top:2rem;padding-top:1.5rem}.landlord-form .form-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.landlord-form .form-section h3{color:#333;font-size:1.25rem;margin:0 0 1rem}.landlord-form .form-section h4{color:#555;font-size:1.1rem;margin:1.5rem 0 1rem}.close-button:hover:not(:disabled){color:#333}.close-button:disabled{cursor:not-allowed;opacity:.5}.landlords-page{background-color:#f5f5f5;min-height:100vh}.search-bar{margin-bottom:2rem}.search-input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;width:100%}.landlords-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.landlord-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.landlord-card.inactive{background-color:#f9f9f9;opacity:.7}.landlord-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.landlord-info h3{color:#333;font-size:1.25rem;margin:0}.landlord-type-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.landlord-details{display:flex;flex-direction:column;gap:.5rem}.status-badge{font-size:.875rem;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.landlord-actions{display:flex;gap:.5rem;margin-top:auto}.btn-delete,.btn-edit{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.contract-form{display:flex;flex-direction:column;gap:1.5rem}.contract-form .form-section{border-top:1px solid #eee;margin-top:1rem;padding-top:1rem}.contract-form .form-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.contract-form .form-section h3{color:#333;font-size:1.25rem;margin:0 0 1rem}.contract-form .form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.contract-form .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.contract-form label{color:#333;font-weight:500}.contract-form label .hint{color:#666;font-size:.85rem;font-weight:400;margin-left:.5rem}.contract-form input[type=date],.contract-form input[type=number],.contract-form input[type=text],.contract-form select{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem}.contract-form input:focus,.contract-form select:focus{border-color:#3498db;outline:none}.contract-form .checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.contract-form .checkbox-group input[type=checkbox]{width:auto}.contract-form .rooms-checkbox-list{border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem}.contract-form .checkbox-label{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem}.contract-form .checkbox-label:hover{background-color:#f5f5f5}.contract-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.contract-form .cancel-button,.contract-form .submit-button{border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem}.contract-form .cancel-button{background-color:#95a5a6;color:#fff}.contract-form .cancel-button:hover:not(:disabled){background-color:#7f8c8d}.contract-form .submit-button{background-color:#3498db;color:#fff}.contract-form .submit-button:hover:not(:disabled){background-color:#2980b9}.contract-form button:disabled{cursor:not-allowed;opacity:.6}.contract-form .readonly-field{background-color:#f5f5f5;cursor:not-allowed}.contract-form .field-hint{color:#666;display:block;font-size:.75rem;font-style:italic;margin-top:.25rem}.contract-form .calculation-details{color:#3498db;font-weight:500}.template-manager-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.template-manager-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:900px;width:100%}.template-manager-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1.5rem}.template-manager-header h2{color:#333;font-size:1.5rem;margin:0}.close-button{transition:color .2s}.template-manager-body{flex:1 1;overflow-y:auto;padding:1.5rem}.upload-section{border-bottom:2px solid #eee;margin-bottom:2rem;padding-bottom:2rem}.upload-section h3{color:#333;font-size:1.2rem;margin:0 0 1rem}.upload-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-size:.95rem}.form-group input[type=file],.form-group input[type=text],.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem}.form-group input[type=file]{padding:.5rem}.help-text{color:#666;font-size:.85rem;font-style:italic;margin:0}.checkbox-group{align-items:center;flex-direction:row}.checkbox-group input[type=checkbox]{margin:0;transform:scale(1.1)}.btn-upload{align-self:flex-start;background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s}.btn-upload:hover:not(:disabled){background-color:#2980b9}.btn-upload:disabled{cursor:not-allowed;opacity:.6}.templates-section h3{color:#333;font-size:1.2rem;margin:0 0 1rem}.empty-state,.loading{padding:2rem}.templates-list{display:flex;flex-direction:column;gap:1rem}.template-card{align-items:flex-start;border:1px solid #ddd;border-radius:6px;display:flex;gap:1rem;justify-content:space-between;padding:1rem}.template-card.default{background-color:#f0f8ff;border-color:#3498db}.template-info{flex:1 1}.template-info h4{align-items:center;color:#333;display:flex;font-size:1.1rem;gap:.5rem;margin:0 0 .5rem}.default-badge{background-color:#3498db;border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.template-description{color:#666;font-size:.9rem;margin:.5rem 0}.template-variables{margin:.75rem 0}.template-variables strong{color:#555;display:block;font-size:.85rem;margin-bottom:.5rem}.variables-list{display:flex;flex-wrap:wrap;gap:.5rem}.variable-tag{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;color:#333;font-family:monospace;font-size:.85rem;padding:.25rem .5rem}.template-date{color:#999;font-size:.85rem;margin:.5rem 0 0}.template-actions{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.btn-delete,.btn-download,.btn-set-default{border:none;border-radius:4px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn-set-default{background-color:#f39c12;color:#fff}.btn-set-default:hover{background-color:#e67e22}.btn-download{background-color:#3498db}.btn-download:hover{background-color:#2980b9}.contract-status-manager{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.current-status{border-bottom:1px solid #e0e0e0;margin-bottom:2rem;padding-bottom:1.5rem}.current-status h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.status-badge{border-radius:4px;font-size:.9rem;padding:.5rem 1rem}.status-draft{background-color:#e9ecef;color:#495057}.status-active{background-color:#d4edda;color:#155724}.status-expired{background-color:#fff3cd;color:#856404}.status-terminated{background-color:#f8d7da;color:#721c24}.status-cancelled{background-color:#d1ecf1;color:#0c5460}.upload-signed-section{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.upload-signed-section h4{color:#333;font-size:1rem;margin:0 0 .5rem}.upload-signed-section p{color:#666;font-size:.9rem;margin:0 0 1rem}.upload-controls{display:flex;flex-direction:column;gap:1rem}.file-input-wrapper{position:relative}.file-input{height:0;opacity:0;position:absolute;width:0}.file-label{background:#fff;border:2px dashed #007bff;border-radius:4px;box-sizing:border-box;color:#007bff;cursor:pointer;display:inline-block;font-weight:500;padding:.75rem 1rem;text-align:center;transition:all .2s;width:100%}.file-label:hover{background:#f0f7ff;border-color:#0056b3}.file-input:disabled+.file-label{cursor:not-allowed;opacity:.6}.signed-document-info{background:#e7f3ff;border-left:4px solid #007bff;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.signed-document-info h4{color:#333;font-size:1rem;margin:0 0 .5rem}.signed-document-info p{color:#666;font-size:.9rem;margin:0 0 1rem}.status-actions{border-top:1px solid #e0e0e0;padding-top:1.5rem}.status-actions h4{color:#333;font-size:1rem;margin:0 0 1rem}.status-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.btn-status{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-status-active{background-color:#28a745;color:#fff}.btn-status-active:hover{background-color:#218838}.btn-status-expired{background-color:#ffc107;color:#212529}.btn-status-expired:hover{background-color:#e0a800}.btn-status-danger{background-color:#dc3545;color:#fff}.btn-status-danger:hover{background-color:#c82333}.btn-status-cancel{background-color:#6c757d;color:#fff}.btn-status-cancel:hover{background-color:#545b62}@media (max-width:768px){.contract-status-manager{padding:1rem}.status-buttons{flex-direction:column}.btn-status{width:100%}}.contracts-page{background-color:#f5f5f5;min-height:100vh}.page-header{background:#fff;box-shadow:0 2px 4px #0000001a;padding:2rem}.header-actions{align-items:center}.btn-templates{background-color:#9b59b6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-templates:hover{background-color:#8e44ad}.btn-add{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-add:hover{background-color:#2980b9}.page-content{margin:0 auto;max-width:1200px;padding:2rem}.empty-state,.loading{color:#666;padding:3rem;text-align:center}.contracts-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.contract-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.contract-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.status-section{align-items:center;display:flex;gap:.5rem}.btn-status-manager{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:background-color .2s}.btn-status-manager:hover{background-color:#f0f0f0}.status-manager-modal{max-width:600px;width:90%}.contract-header h3{color:#333;font-size:1.25rem;margin:0}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.status-badge.status-draft{background-color:#e3f2fd;color:#1976d2}.status-badge.status-active{background-color:#d4edda;color:#155724}.status-badge.status-expired{background-color:#fff3cd;color:#856404}.status-badge.status-cancelled,.status-badge.status-terminated{background-color:#f8d7da;color:#721c24}.contract-details{flex-direction:column;margin-bottom:1rem}.contract-details,.detail-item{display:flex;gap:.5rem}.detail-label{color:#666;font-weight:500;min-width:120px}.detail-value{color:#333}.contract-actions{display:flex;gap:.5rem;margin-top:1rem}.btn-delete,.btn-download,.btn-edit{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn-download{background-color:#27ae60;color:#fff}.btn-download:hover{background-color:#229954}.btn-edit{background-color:#f39c12;color:#fff}.btn-edit:hover{background-color:#e67e22}.btn-delete{background-color:#e74c3c;color:#fff}.btn-delete:hover{background-color:#c0392b}.modal-content{max-width:800px}.modal-header{border-bottom:1px solid #eee}.close-button{color:#999}.close-button:hover{color:#333}.expense-form-modal{max-width:700px}.expense-form{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.expenses-page{margin:0;max-width:100%;padding:2rem}.expenses-page.loading{align-items:center;display:flex;justify-content:center;min-height:400px;padding:2rem}.btn-primary:hover{background-color:#0056b3}.stat-card.total{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;margin-bottom:1.5rem;padding:2rem;text-align:center}.stat-card.total h3{font-size:1.2rem;margin:0 0 1rem;opacity:.9}.stat-card.total .amount{font-size:2.5rem;font-weight:700}.stat-card{background:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.stat-card .category-name{color:#333;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.stat-card .category-amount{color:#007bff;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-card .category-count{color:#666;font-size:.85rem}.expenses-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.expenses-table{border-collapse:collapse;width:100%}.expenses-table thead{background-color:#f8f9fa}.expenses-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.expenses-table td{border-bottom:1px solid #dee2e6;padding:1rem}.expenses-table tbody tr:hover{background-color:#f8f9fa}.expenses-table .no-data{color:#666;padding:2rem;text-align:center}.category-badge{background-color:#e7f3ff;border-radius:12px;color:#06c;display:inline-block;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.amount{color:#333;font-weight:600}@media (max-width:768px){.expenses-page{padding:1rem}.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.filter-group{align-items:stretch;flex-direction:column}.filter-date,.filter-select{width:100%}.stats-grid{grid-template-columns:1fr}.expenses-table{font-size:.9rem}.expenses-table td,.expenses-table th{padding:.75rem .5rem}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.income-form-modal{max-width:700px}.modal-header{border-bottom:1px solid #dee2e6}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:2rem;height:2rem;justify-content:center;line-height:1;padding:0;transition:background-color .2s;width:2rem}.close-button:hover{background-color:#f0f0f0}.income-form{gap:1.5rem;padding:1.5rem}.form-group,.income-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group label{color:#333;font-size:.9rem;font-weight:500}.required{color:#dc3545}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:1rem;padding:.75rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#28a745;box-shadow:0 0 0 3px #28a7451a;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545}.error-message{color:#dc3545;font-size:.85rem}.form-group textarea{min-height:80px;resize:vertical}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.btn-primary:hover:not(:disabled){background-color:#218838}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.modal-content{max-height:95vh;width:95%}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.category-modal{max-width:800px}.category-actions{margin-bottom:1.5rem}.category-form{background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.category-form .form-group{display:flex;flex-direction:column;gap:.5rem}.category-form label{color:#333;font-size:.9rem;font-weight:500}.category-form input[type=text],.category-form textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:1rem;padding:.75rem}.category-form textarea{min-height:60px;resize:vertical}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.checkbox-group input[type=checkbox]{cursor:pointer;height:1.2rem;width:1.2rem}.category-form .form-actions{border-top:1px solid #dee2e6;display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem;padding-top:1rem}.categories-list h3{color:#333;font-size:1.2rem;margin:0 0 1rem}.no-categories{background:#f8f9fa;border-radius:8px;color:#666;padding:2rem;text-align:center}.category-list{display:flex;flex-direction:column;gap:1rem;list-style:none;margin:0;padding:0}.category-item{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:8px;display:flex;justify-content:space-between;padding:1rem;transition:box-shadow .2s}.category-item:hover{box-shadow:0 2px 4px #0000001a}.category-item.inactive{background-color:#f8f9fa;opacity:.6}.category-info{flex:1 1}.category-info h4{color:#333;font-size:1.1rem;margin:0 0 .5rem}.category-description{color:#666;font-size:.9rem;margin:.25rem 0 0}.inactive-badge{background-color:#ffc107;border-radius:4px;color:#333;display:inline-block;font-size:.75rem;font-weight:500;margin-top:.5rem;padding:.25rem .5rem}.category-actions{display:flex;gap:.5rem}.btn-icon:hover:not(:disabled){background-color:#f0f0f0}.btn-icon.btn-danger:hover:not(:disabled){background-color:#ffe0e0}.btn-icon:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.category-item{align-items:flex-start;flex-direction:column;gap:1rem}.category-actions{align-self:flex-end}}.incomes-page{margin:0;max-width:100%;padding:2rem}.incomes-page.loading{align-items:center;display:flex;justify-content:center;min-height:400px;padding:2rem}.page-header{align-items:center;display:flex;justify-content:space-between}.header-actions{display:flex;gap:1rem}.btn-primary{background-color:#28a745}.btn-primary:hover{background-color:#218838}.btn-secondary:hover{background-color:#545b62}.filters-panel{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.filter-group{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem}.filter-date,.filter-select{border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:200px;padding:.75rem}.filter-date{min-width:150px}.btn-clear{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.75rem 1rem}.btn-clear:hover{background-color:#c82333}.stats-panel{margin-bottom:2rem}.stat-card.total.success{background:linear-gradient(135deg,#28a745,#20c997);border-radius:8px;color:#fff;margin-bottom:1.5rem;padding:2rem;text-align:center}.stat-card.total.success h3{font-size:1.2rem;margin:0 0 1rem;opacity:.9}.stat-card.total.success .amount{font-size:2.5rem;font-weight:700}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.stat-card.success{background:#fff;border-left:4px solid #28a745;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.stat-card.success .category-name{color:#333;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.stat-card.success .category-amount{color:#28a745;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-card.success .category-count{color:#666;font-size:.85rem}.incomes-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.incomes-table{border-collapse:collapse;width:100%}.incomes-table thead{background-color:#f8f9fa}.incomes-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.incomes-table td{border-bottom:1px solid #dee2e6;padding:1rem}.incomes-table tbody tr:hover{background-color:#f8f9fa}.incomes-table .no-data{color:#666;padding:2rem;text-align:center}.category-badge.success{background-color:#d4edda;border-radius:12px;color:#155724;display:inline-block;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.contract-link{color:#007bff;cursor:pointer;text-decoration:none}.contract-link:hover{text-decoration:underline}.amount.success{color:#28a745;font-weight:600}.actions{gap:.5rem}.btn-icon{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;transition:background-color .2s}.btn-icon:hover{background-color:#f0f0f0}.btn-icon.btn-danger:hover{background-color:#ffe0e0}@media (max-width:768px){.incomes-page{padding:1rem}.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.filter-group{align-items:stretch;flex-direction:column}.filter-date,.filter-select{width:100%}.stats-grid{grid-template-columns:1fr}.incomes-table{font-size:.9rem}.incomes-table td,.incomes-table th{padding:.75rem .5rem}}.notification-modal{max-height:90vh;max-width:900px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.close-btn{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;line-height:1;padding:0;width:30px}.close-btn:hover{color:#333}.modal-body{padding:1.5rem}.notification-info{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.info-card{background:#f8f9fa;border-radius:8px;padding:1.5rem}.info-card h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.info-card p{color:#666;margin:.5rem 0}.send-methods{background:#f8f9fa;border-radius:8px;padding:1.5rem}.send-methods h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.send-methods label{align-items:center;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;margin-bottom:.75rem}.send-methods input[type=checkbox]{cursor:pointer;height:18px;width:18px}.template-preview{margin-bottom:2rem}.template-preview h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.preview-box{background:#fff;border:1px solid #e0e0e0;border-radius:8px;max-height:300px;overflow-y:auto;padding:1.5rem}.preview-subject{border-bottom:2px solid #e0e0e0;color:#333;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}.preview-body{color:#555;font-size:.95rem;line-height:1.6;white-space:pre-wrap}.tenant-selection{margin-bottom:1rem}.tenant-selection h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.select-all-controls{background:#f8f9fa;border-radius:4px;margin-bottom:1rem;padding:.75rem}.select-all-controls label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:.5rem}.select-all-controls input[type=checkbox]{cursor:pointer;height:18px;width:18px}.tenant-list{border:1px solid #e0e0e0;border-radius:4px;max-height:300px;overflow-y:auto}.tenant-item{align-items:flex-start;border-bottom:1px solid #e0e0e0;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:background-color .2s}.tenant-item:last-child{border-bottom:none}.tenant-item:hover{background-color:#f8f9fa}.tenant-item input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;margin-top:.25rem;width:18px}.tenant-info{flex:1 1}.tenant-name{color:#333;font-weight:600;margin-bottom:.5rem}.tenant-details{color:#666;display:flex;flex-wrap:wrap;font-size:.85rem;gap:1rem}.tenant-details span{align-items:center;display:flex;gap:.25rem}.loading-tenants,.no-tenants{color:#666;padding:2rem;text-align:center}.modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}@media (max-width:768px){.notification-modal{width:95%}.notification-info{grid-template-columns:1fr}.modal-body,.preview-box{padding:1rem}}.price-management{max-width:100%;padding:2rem}.price-management.loading{align-items:center;display:flex;justify-content:center;min-height:400px}.page-header{margin-bottom:2rem}.page-header h1{color:#333;font-size:2rem;margin:0}.tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:.5rem;margin-bottom:2rem}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:1rem;margin-bottom:-2px;padding:.75rem 1.5rem;transition:all .2s}.tab:hover{background-color:#f5f5f5;color:#333}.tab.active{border-bottom-color:#007bff;color:#007bff;font-weight:600}.loading-message{color:#666;padding:2rem;text-align:center}.price-change-tab{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:400px 1fr}.change-params{background:#f8f9fa;border-radius:8px;height:-webkit-fit-content;height:fit-content;padding:1.5rem;position:-webkit-sticky;position:sticky;top:20px}.change-params h3{color:#333;font-size:1.25rem;margin:0 0 1.5rem}.param-group{margin-bottom:1.5rem}.param-group label{color:#333;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.param-group input[type=date],.param-group input[type=number],.param-group select,.param-group textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:1rem;padding:.75rem;width:100%}.param-group input:focus,.param-group select:focus,.param-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.param-group textarea{min-height:80px;resize:vertical}.radio-group{display:flex;gap:1.5rem}.radio-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:.5rem}.radio-group input[type=radio]{cursor:pointer;width:auto}.input-group{display:flex;gap:.5rem}.input-group select{flex:0 0 150px}.input-group input{flex:1 1}.hint-text{color:#666;display:block;font-size:.75rem;font-style:italic;margin-top:.25rem}.rooms-selection{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.selection-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.selection-header h3{color:#333;font-size:1.25rem;margin:0}.rooms-list{border:1px solid #e0e0e0;border-radius:4px;max-height:600px;overflow-y:auto}.rooms-list table{border-collapse:collapse;width:100%}.rooms-list thead{background-color:#f8f9fa;position:-webkit-sticky;position:sticky;top:0;z-index:1}.rooms-list th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.rooms-list td{border-bottom:1px solid #e0e0e0;padding:1rem}.rooms-list tbody tr:hover{background-color:#f8f9fa}.rooms-list tbody tr.selected{background-color:#e7f3ff}.rooms-list tbody tr.selected:hover{background-color:#d0e7ff}.rooms-list input[type=checkbox]{cursor:pointer}.new-price{color:#28a745;font-weight:600}.price-details{display:flex;flex-direction:column;gap:.25rem}.price-details .rent-rate{color:#666;font-size:.9rem}.price-details .total-price{color:#333;font-size:1rem;font-weight:600}.price-details .water-compensation{color:#999;font-size:.75rem;font-style:italic}.new-price .rent-rate,.new-price .total-price{color:#28a745}.no-rooms{color:#666;padding:3rem;text-align:center}.actions{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1.5rem}.selected-info{color:#666;font-size:.9rem}.btn-primary,.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.price-history-tab{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.history-table{border-collapse:collapse;width:100%}.history-table thead{background-color:#f8f9fa}.history-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.history-table td{border-bottom:1px solid #e0e0e0;padding:1rem}.history-table tbody tr:hover{background-color:#f8f9fa}.history-table .increase{color:#28a745;font-weight:600}.history-table .decrease{color:#dc3545;font-weight:600}.no-history{color:#666;padding:3rem;text-align:center}@media (max-width:1200px){.price-change-tab{grid-template-columns:1fr}.change-params{position:static}}@media (max-width:768px){.price-management{padding:1rem}.tabs{flex-direction:column}.tab{border-bottom:none;border-left:3px solid #0000;margin-bottom:0;text-align:left}.tab.active{border-bottom-color:#0000;border-left-color:#007bff}.rooms-list{overflow-x:auto}.rooms-list table{min-width:600px}.actions{align-items:stretch;flex-direction:column;gap:1rem}.btn-primary,.btn-secondary{width:100%}.history-table{font-size:.9rem}.history-table td,.history-table th{padding:.75rem .5rem}}.analytics-page{background-color:#f5f5f5;min-height:100vh;padding:2rem}.analytics-loading{align-items:center;color:#6b7280;display:flex;font-size:1.2rem;justify-content:center;min-height:400px}.analytics-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.analytics-header h1{color:#1f2937;font-size:2rem;margin:0}.date-filter{align-items:center;display:flex;gap:.5rem}.date-filter input{border:1px solid #d1d5db;border-radius:4px;font-size:.9rem;padding:.5rem}.date-filter span{color:#6b7280}.metrics-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.metric-card{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.metric-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.metric-icon{align-items:center;border-radius:8px;display:flex;font-size:1.5rem;height:50px;justify-content:center;width:50px}.metric-content{flex:1 1}.metric-label{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.metric-value{color:#1f2937;font-size:1.5rem;font-weight:600}.analytics-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:.5rem;margin-bottom:2rem}.tab-button{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:1rem;margin-bottom:-2px;padding:.75rem 1.5rem;transition:color .2s}.tab-button:hover{color:#3b82f6}.tab-button.active{border-bottom-color:#3b82f6;color:#3b82f6;font-weight:600}.analytics-content{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem}.tab-content{min-height:400px}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.chart-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem}.chart-card.full-width{grid-column:1/-1}.chart-card h3{color:#1f2937;font-size:1.25rem;margin:0 0 1rem}.rooms-heatmap{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));padding:1rem}.room-heatmap-item{align-items:center;aspect-ratio:1;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.75rem;font-weight:600;justify-content:center;transition:transform .2s}.room-heatmap-item:hover{transform:scale(1.1)}.room-heatmap-item.occupied{background-color:#10b981}.room-heatmap-item.free{background-color:#ef4444}.table-container{overflow-x:auto}.data-table{border-collapse:collapse;margin-top:1rem;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;padding:.75rem;text-align:left}.data-table th{color:#374151;font-weight:600}.data-table th,.data-table tr:hover{background-color:#f9fafb}@media (max-width:768px){.analytics-page{padding:1rem}.analytics-header{align-items:flex-start;flex-direction:column;gap:1rem}.charts-grid,.metrics-cards{grid-template-columns:1fr}.analytics-tabs{flex-wrap:nowrap;overflow-x:auto}.tab-button{white-space:nowrap}}.building-detail-page{background-color:#f5f5f5;display:flex;min-height:100vh}.building-detail-content{background-color:#fff;box-sizing:border-box;flex:1 1;margin-left:250px;min-height:100vh;overflow-x:hidden;padding:20px;width:calc(100% - 250px)}@media (max-width:768px){.building-detail-content{margin-left:60px;padding:10px;width:calc(100% - 60px)}}.placeholder-page{padding:40px;text-align:center}.placeholder-page h1{color:#333;margin-bottom:20px}.placeholder-page p{color:#666;font-size:16px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.f8e31933.css.map*/