.navbar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:0;box-shadow:0 2px 10px #0000001a}.navbar-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:15px 20px;flex-wrap:wrap;gap:15px}.navbar-brand h2{margin:0;font-size:24px;font-weight:600}.navbar-links{display:flex;gap:20px;flex-wrap:wrap}.navbar-links a{color:#fff;text-decoration:none;padding:8px 16px;border-radius:6px;transition:background-color .3s;font-weight:500}.navbar-links a:hover{background-color:#fff3}.navbar-links a.active{background-color:#ffffff4d}.navbar-user{display:flex;align-items:center;gap:15px}.user-name{font-weight:500}.logout-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .3s}.logout-button:hover{background:#ffffff4d}@media (max-width: 768px){.navbar-container{flex-direction:column}.navbar-links,.navbar-user{width:100%;justify-content:center}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-card h1{margin:0 0 10px;color:#333;font-size:28px;text-align:center}.login-card h2{margin:0 0 30px;color:#666;font-size:20px;text-align:center;font-weight:400}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center;font-size:14px}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;font-size:12px;color:#666;text-align:center}.login-hint p{margin:0 0 10px;font-weight:600}.login-hint ul{list-style:none;padding:0;margin:0}.login-hint li{margin:5px 0;color:#999}.dashboard{padding:30px;max-width:1400px;margin:0 auto}.dashboard h1{margin:0 0 30px;color:#333;font-size:32px}.dashboard-loading,.dashboard-error{text-align:center;padding:50px;font-size:18px}.dashboard-error{color:#c33}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a;display:flex;align-items:center;gap:20px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00000026}.stat-icon{font-size:40px}.stat-content{flex:1}.stat-content h3{margin:0;font-size:32px;color:#667eea}.stat-content p{margin:5px 0 0;color:#666;font-size:14px}.stat-link{color:#667eea;text-decoration:none;font-weight:500;font-size:14px;transition:color .2s}.stat-link:hover{color:#764ba2}.dashboard-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:30px}.dashboard-section{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a}.dashboard-section h2{margin:0 0 20px;color:#333;font-size:24px}.empty-state{color:#999;text-align:center;padding:40px;font-style:italic}.reservas-list{display:flex;flex-direction:column;gap:15px}.reserva-item{padding:15px;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s}.reserva-item:hover{background:#e9ecef}.reserva-info{display:flex;flex-direction:column;gap:5px}.reserva-info strong{color:#333;font-size:16px}.reserva-info span{color:#666;font-size:14px}.reserva-fechas{color:#667eea;font-weight:500;font-size:14px}.habitaciones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px}.habitacion-card{padding:15px;background:#f8f9fa;border-radius:8px;text-align:center;transition:transform .2s,box-shadow .2s}.habitacion-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}.habitacion-numero{font-size:24px;font-weight:600;color:#667eea;margin-bottom:10px}.habitacion-details{display:flex;flex-direction:column;gap:5px;font-size:12px;color:#666}@media (max-width: 768px){.dashboard{padding:15px}.dashboard-sections{grid-template-columns:1fr}.reserva-item{flex-direction:column;align-items:flex-start;gap:10px}}.habitaciones-page{padding:30px;max-width:1400px;margin:0 auto}.page-header h1{margin:0 0 10px;color:#333;font-size:32px}.page-subtitle{margin:0;color:#666;font-size:16px}.habitaciones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.habitacion-card-full{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000001a;transition:transform .2s,box-shadow .2s}.habitacion-card-full:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00000026}.habitacion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.habitacion-numero-large{font-size:32px;font-weight:700;color:#667eea}.habitacion-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.habitacion-details-full{display:flex;flex-direction:column;gap:12px}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{color:#666;font-size:14px}.detail-value{color:#333;font-weight:500;font-size:14px}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background:#5a6268}.btn-edit{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .2s}.btn-edit:hover{background:#5568d3;transform:translateY(-1px)}@media (max-width: 768px){.habitaciones-page{padding:15px}.habitaciones-grid,.form-row{grid-template-columns:1fr}}.reservas-page{padding:30px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.page-header h1{margin:0;color:#333;font-size:32px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.reserva-form-container{background:#fff;border-radius:12px;padding:25px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.reserva-form-container h2{margin:0 0 20px;color:#333;font-size:24px}.reserva-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#333;font-weight:500;font-size:14px}.form-group input,.form-group select{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.reservas-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.reservas-table{width:100%;border-collapse:collapse}.reservas-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.reservas-table th{padding:15px;text-align:left;font-weight:600;font-size:14px}.reservas-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s}.reservas-table tbody tr:hover{background-color:#f8f9fa}.reservas-table td{padding:15px;color:#333;font-size:14px}.btn-delete{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.btn-delete:hover{background:#c82333}.page-loading,.page-error,.empty-state{text-align:center;padding:50px;font-size:18px}.page-error{color:#c33}.empty-state{color:#999;font-style:italic}@media (max-width: 768px){.reservas-page{padding:15px}.form-row{grid-template-columns:1fr}.reservas-table-container{overflow-x:auto}.reservas-table{min-width:600px}}.calendario-page{padding:24px;max-width:100%;margin:0 auto;background:#f5f7fa;min-height:calc(100vh - 80px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;width:90%;max-height:90vh;overflow:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;color:#1a202c;font-size:20px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;line-height:1}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:24px}.detalle-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f3f4f6}.detalle-item:last-child{border-bottom:none}.detalle-item label{font-weight:600;color:#374151;font-size:14px}.detalle-item span{color:#1a202c;font-size:14px;text-align:right}.loading-message{text-align:center;color:#6b7280;font-style:italic;padding:20px}.reserva-celda.clickable{cursor:pointer;transition:all .2s ease}.reserva-celda.clickable:hover{transform:scale(1.05);box-shadow:0 4px 8px #00000026;z-index:10;position:relative}.calendario-header{margin-bottom:24px;background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014}.calendario-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendario-header h1{margin:0;color:#1a202c;font-size:32px;font-weight:700;letter-spacing:-.5px}.btn-exportar{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #10b98133;display:flex;align-items:center;gap:8px}.btn-exportar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166;background:linear-gradient(135deg,#059669,#047857)}.btn-exportar:active{transform:translateY(0)}.calendario-controls{display:flex;align-items:center;justify-content:center;gap:24px}.calendario-mes-info{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:220px}.mes-nombre{font-size:28px;font-weight:700;color:#2d3748;letter-spacing:1px}.mes-año{font-size:18px;font-weight:500;color:#718096}.btn-nav{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea33}.btn-nav:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-nav:active{transform:translateY(0)}.calendario-spreadsheet-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;overflow-x:auto;overflow-y:visible}.calendario-table-wrapper{overflow-x:auto;overflow-y:visible;width:100%;-webkit-overflow-scrolling:touch}.calendario-spreadsheet{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background:#fff;min-width:900px;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.calendario-spreadsheet thead{background:linear-gradient(180deg,#f7fafc,#edf2f7)}.calendario-spreadsheet th{border-right:1px solid #e2e8f0;border-bottom:2px solid #cbd5e0;padding:12px 10px;text-align:center;font-weight:600;position:sticky;top:0;z-index:10;white-space:nowrap;background:inherit}.calendario-spreadsheet th:last-child{border-right:none}.calendario-spreadsheet .col-dias{background:linear-gradient(180deg,#edf2f7,#e2e8f0);font-weight:700;min-width:150px;text-align:left;padding:12px 16px;position:sticky;left:0;z-index:11;box-shadow:2px 0 4px #0000000d}.col-dias-header{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.dias-label{font-size:14px;color:#2d3748;text-transform:uppercase;letter-spacing:.5px}.mes-año-header{display:flex;flex-direction:column;gap:2px;align-items:flex-start}.mes-header{font-size:12px;color:#4a5568;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.año-header{font-size:14px;color:#718096;font-weight:500}.calendario-spreadsheet .col-habitacion{min-width:90px;font-size:12px;color:#2d3748;background:linear-gradient(180deg,#f7fafc,#edf2f7)}.calendario-spreadsheet tbody tr{transition:background-color .15s ease}.calendario-spreadsheet tbody tr:hover{background-color:#f7fafc}.calendario-spreadsheet tbody tr.row-domingo{background-color:#fef5e7}.calendario-spreadsheet tbody tr.row-domingo:hover{background-color:#fdebd0}.calendario-spreadsheet td{border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:8px 10px;text-align:center;vertical-align:middle;min-height:40px;position:relative}.calendario-spreadsheet td:last-child{border-right:none}.calendario-spreadsheet tbody tr:last-child td{border-bottom:none}.calendario-spreadsheet .cell-dia{text-align:left;font-weight:500;padding:10px 16px;min-width:150px;position:sticky;left:0;z-index:5;box-shadow:2px 0 4px #0000000d;background:#f8f9fa}.calendario-spreadsheet .cell-dia.domingo{background-color:#fef5e7;font-weight:600;color:#d68910}.calendario-spreadsheet .cell-reserva{background:#fff;min-width:90px;padding:4px}.calendario-spreadsheet .cell-reserva.domingo{background-color:#fef5e7}.fecha-text{display:block;font-size:13px;color:#2d3748;font-weight:500}.calendario-spreadsheet .cell-dia.domingo .fecha-text{color:#d68910}.reserva-celda{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 8px;border-radius:6px;font-size:11px;text-align:center;word-break:break-word;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #667eea4d;min-height:24px;display:flex;align-items:center;justify-content:center}.reserva-celda:hover{transform:translateY(-1px);box-shadow:0 2px 6px #667eea66}.reserva-cliente{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.page-loading,.page-error,.empty-state{text-align:center;padding:60px 20px;font-size:18px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.page-loading{color:#667eea}.page-error{color:#e53e3e}.empty-state{color:#a0aec0;font-style:italic}.calendario-table-wrapper::-webkit-scrollbar{height:10px}.calendario-table-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.calendario-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.calendario-table-wrapper::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width: 768px){.calendario-page{padding:12px}.calendario-header{padding:16px}.calendario-header h1{font-size:24px;margin-bottom:16px}.calendario-controls{flex-direction:column;gap:16px}.calendario-mes-info{min-width:auto}.mes-nombre{font-size:24px}.mes-año{font-size:16px}.btn-nav{padding:10px 20px;font-size:14px;width:100%;max-width:200px}.calendario-spreadsheet-container{padding:12px}.calendario-spreadsheet{font-size:11px;min-width:700px}.calendario-spreadsheet th,.calendario-spreadsheet td{padding:6px 8px}.calendario-spreadsheet .col-dias{min-width:120px;padding:8px 12px}.dias-label{font-size:12px}.mes-header{font-size:10px}.año-header{font-size:12px}.fecha-text{font-size:11px}.reserva-celda{padding:4px 6px;font-size:10px}}*{box-sizing:border-box;margin:0;padding:0}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;background-color:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
