:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{height:100%;width:100%;margin:0;padding:0;overflow:hidden}body{margin:0;min-width:320px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1b3540,#2c5f7a);padding:20px}.login-box{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#1b3540;margin:0 0 10px;font-size:28px}.login-header p{color:#666;margin:0;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form label{color:#333;font-weight:500;font-size:14px}.login-form input{padding:12px;border:1px solid #ddd;border-radius:4px;font-size:16px;transition:border-color .3s}.login-form input:focus{outline:none;border-color:#1b3540}.login-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-error{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:4px;font-size:14px;text-align:center}.login-button{padding:12px;background-color:#1b3540;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .3s;margin-top:10px}.login-button:hover:not(:disabled){background-color:#2c5f7a}.login-button:disabled{background-color:#ccc;cursor:not-allowed}.login-footer{margin-top:20px;text-align:center;padding-top:20px;border-top:1px solid #eee}.login-footer p{color:#999;font-size:12px;margin:0}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:250px;background-color:#fff;color:#1b3540;padding:20px;overflow-y:auto;flex-shrink:0;box-shadow:2px 0 8px #0000001a;display:flex;flex-direction:column}.logo-container{margin-bottom:30px;display:flex;justify-content:center;align-items:center;padding:10px 0;min-height:80px}.logo{max-width:100%;width:auto;height:auto;max-height:80px;max-width:200px;object-fit:contain;display:block}.logo-fallback{color:#1b3540;margin:0;font-size:24px;font-weight:400}.sidebar ul{list-style:none}.sidebar li{margin-bottom:10px}.sidebar a{color:#1b3540;text-decoration:none;display:block;padding:10px;border-radius:4px;transition:all .3s}.sidebar a:hover{background-color:#bf953826;text-decoration:underline;text-decoration-color:#bf9538;color:#bf9538}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid #eee;display:flex;flex-direction:column;gap:10px}.user-info{padding:10px;background-color:#f5f5f5;border-radius:4px;text-align:center;font-size:14px;color:#666}.logout-button{padding:10px;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .3s}.logout-button:hover{background-color:#c82333}.content{flex:1;padding:30px;overflow-y:auto;background-color:#f5f5f5}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h2{font-size:28px;color:#1b3540}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-primary{background-color:#1b3540;color:#fff}.btn-primary:hover{background-color:#bf9538}.btn-success{background-color:#27ae60;color:#fff}.btn-success:hover{background-color:#229954}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.form-container{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.form-section{margin-bottom:30px}.form-section h3{margin-bottom:20px;color:#1b3540;border-bottom:2px solid #bf9538;padding-bottom:10px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;color:#1b3540;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:transparent}.form-group textarea{resize:vertical;min-height:100px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#bf9538}.form-group input.error,.form-group input.error:focus{border-color:#d32f2f;border-width:2px}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed;opacity:.7}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #ddd}.search-bar{margin-bottom:20px}.search-bar input{width:100%;max-width:400px;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:transparent}.search-bar input:focus{outline:none;border-color:#bf9538}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:30px;padding:20px}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#1b3540;font-weight:500}.table-container{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}table{width:100%;border-collapse:collapse}table th,table td{padding:12px;text-align:left;border-bottom:1px solid #ddd}table th{background-color:#f8f9fa;font-weight:600;color:#1b3540}table tr:hover{background-color:#bf95381a;cursor:pointer}.actions{display:flex;gap:5px;justify-content:center;align-items:center}.checkbox-group{display:flex;align-items:center;gap:10px}.checkbox-group input[type=checkbox]{width:auto}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.stat-card h3{color:#7f8c8d;font-size:14px;margin-bottom:10px}.stat-card .value{font-size:32px;font-weight:700;color:#1b3540}.error{color:#e74c3c;font-size:12px;margin-top:5px}.loading{text-align:center;padding:20px}.calendar-container{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #bf9538}.calendar-header h3{color:#1b3540;font-size:20px;margin:0;text-transform:capitalize}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:20px}.calendar-weekday{padding:10px;text-align:center;font-weight:600;color:#1b3540;background-color:#f8f9fa;border-radius:4px}.calendar-day{min-height:100px;padding:8px;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s;background-color:#fff;position:relative}.calendar-day:hover{background-color:#f8f9fa;border-color:#bf9538}.calendar-day.empty{background-color:transparent;border:none;cursor:default}.calendar-day.today{background-color:#e8f4f8;border-color:#1b3540;font-weight:700}.calendar-day.selected{background-color:#bf9538;color:#fff;border-color:#1b3540}.calendar-day.has-events{border-left:4px solid #bf9538}.calendar-day-number{font-weight:500;margin-bottom:5px;color:#1b3540}.calendar-day.selected .calendar-day-number{color:#fff}.calendar-events{display:flex;flex-direction:column;gap:3px;margin-top:5px}.calendar-event{font-size:11px;padding:3px 5px;background-color:#bf9538;color:#fff;border-radius:3px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color .2s}.calendar-day.selected .calendar-event,.calendar-event:hover{background-color:#1b3540}.calendar-event-more{font-size:10px;padding:2px 5px;background-color:#95a5a6;color:#fff;border-radius:3px;text-align:center}.calendar-selected-day{margin-top:20px;padding:15px;background-color:#f8f9fa;border-radius:8px;border:2px solid #bf9538}.calendar-selected-day h4{color:#1b3540;margin-bottom:15px;font-size:18px}.calendar-day-visitas{display:flex;flex-direction:column;gap:10px}.calendar-visita-item{padding:10px;background-color:#fff;border-radius:4px;border-left:4px solid #bf9538;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:5px}.calendar-visita-item:hover{background-color:#e8f4f8;transform:translate(5px)}.calendar-visita-item strong{color:#1b3540;font-size:16px}.calendar-visita-item span{color:#7f8c8d;font-size:14px}.notifications-container{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.notification{padding:15px 20px;border-radius:8px;display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #0000001a;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.notification.warning{background-color:#fff3cd;border-left:4px solid #ffc107;color:#856404}.notification.alert{background-color:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.notification:hover{transform:translate(5px);box-shadow:0 4px 8px #00000026}.notification-content{flex:1}.notification-content strong{display:block;margin-bottom:5px;font-size:16px}.notification-content p{margin:5px 0;font-size:14px}.notification-content small{display:block;margin-top:5px;font-size:12px;opacity:.8}.notification-close{background:none;border:none;font-size:24px;cursor:pointer;color:inherit;opacity:.7;padding:0;margin-left:15px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.notification-close:hover{opacity:1;font-weight:700}
