:root{--primary: #2563eb;--secondary: #64748b;--bg: #f8fafc;--border: #e2e8f0;--text: #1e293b;--reserva: #fbbf24;--checkin: #be185d;--checkout: #94a3b8;--noalojado: #10b981}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg);color:var(--text);overflow-x:hidden}.planning-container{display:flex;flex-direction:column;height:100vh}.sidebar{width:240px;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column}.main-content{flex:1;overflow:auto;position:relative}.planning-grid{display:grid;border-collapse:collapse;min-width:100%;position:relative}.cell{border:1px solid var(--border);min-width:40px;background:#fff}.cell-header-day{background:#f1f5f9;text-align:center;font-weight:700;font-size:.8rem;padding:4px;position:sticky;top:0;z-index:30}.cell-header-corner{position:sticky;top:0;left:0;z-index:40;background:#f1f5f9}.cell-header-type{background:#f8fafc;font-size:.6rem;text-transform:uppercase;color:var(--secondary);position:sticky;top:35px;z-index:30;display:flex;align-items:center;justify-content:center}.cell-s{border-right:none!important}.cell-e{border-left:none!important}.cell-spot-label{position:sticky;left:0;background:#fff;z-index:31;font-size:.75rem;font-weight:500;padding:0 10px;display:flex;align-items:center;width:150px;min-width:150px}.floor-header-row{background-color:#fce7d2;color:#c2410c;font-weight:700;font-size:.85rem;display:flex;align-items:center;padding-left:10px;border-top:2px solid #fdba74;border-bottom:2px solid #fdba74}.reservation-block{align-self:center;height:22px;border-radius:4px;font-size:.7rem;color:#fff;padding:2px 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;cursor:pointer;transition:transform .1s,box-shadow .1s;z-index:10;box-shadow:0 2px 4px #0003;border:2px solid rgba(0,0,0,.3)}.reservation-block:hover{transform:scale(1.02);z-index:11;box-shadow:0 4px 8px #0003}.reservation-block:active{cursor:grabbing;opacity:.6}.status-reserva{background-color:var(--reserva);color:#78350f}.status-checkin{background-color:var(--checkin);color:#fff}.status-checkout{background-color:var(--checkout);color:#fff}.status-noalojado{background-color:var(--noalojado)!important;color:#fff}.cell-blocked{background-color:#fef2f2;background-image:linear-gradient(45deg,#fca5a5 25%,transparent 25%,transparent 50%,#fca5a5 50%,#fca5a5 75%,transparent 75%,transparent);background-size:20px 20px;cursor:not-allowed;opacity:.8}.cell-alt-bg{background-color:#f1f5f9!important}.cell-header-day.cell-today{background-color:#dbeafe!important;color:#1e40af!important}.cell-header-type.cell-today{background-color:#eff6ff!important}.modal-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;padding:0;border-radius:16px;width:100%;max-width:720px;max-height:95vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#fcfcfd}.modal-title-group{display:flex;align-items:center;gap:12px}.modal-icon-bg{width:40px;height:40px;background:#eff6ff;color:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center}.modal-header h2{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0}.modal-close-btn{background:none;border:none;color:#94a3b8;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s,color .2s}.modal-close-btn:hover{background:#f1f5f9;color:#475569}.modal-form{padding:16px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.form-section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;align-items:center;gap:8px;color:var(--secondary);border-bottom:1px solid #f1f5f9;padding-bottom:4px}.section-header h3{font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;margin:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.form-grid-single{display:flex;flex-direction:column;gap:12px}.form-row-double{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.8rem;font-weight:600;color:#475569}.form-group input,.form-group select,.form-group textarea{padding:7px 10px;border:1px solid #cbd5e1;border-radius:8px;font-size:.85rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:60px}.plate-input{font-family:JetBrains Mono,Courier New,monospace;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:#f8fafc}.status-select-reserva{border-left:4px solid var(--reserva)!important}.status-select-checkin{border-left:4px solid var(--checkin)!important}.status-select-checkout{border-left:4px solid var(--checkout)!important}.modal-footer{padding:12px 20px;background:#fcfcfd;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px}.btn-primary{background:var(--primary);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;display:inline-flex;align-items:center;justify-content:center}.btn-primary:hover{background:#1d4ed8}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:#fff;color:#475569;border:1px solid #cbd5e1;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s;display:inline-flex;align-items:center;justify-content:center}.btn-secondary:hover{background:#f8fafc}.toast-container{position:fixed;top:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:9999;pointer-events:none}.toast{pointer-events:auto;min-width:300px;max-width:450px;background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid var(--border);animation:toastIn .3s cubic-bezier(.16,1,.3,1);position:relative}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:4px solid var(--checkout)}.toast-error{border-left:4px solid #ef4444}.toast-warning{border-left:4px solid var(--reserva)}.toast-info{border-left:4px solid var(--primary)}.toast-icon{flex-shrink:0}.toast-success .toast-icon{color:var(--checkout)}.toast-error .toast-icon{color:#ef4444}.toast-warning .toast-icon{color:var(--reserva)}.toast-info .toast-icon{color:var(--primary)}.toast-message{font-size:.9rem;color:#1e293b;font-weight:500;flex:1}.toast-close{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:6px;transition:background .2s;display:flex;align-items:center;justify-content:center}.toast-close:hover{background:#f1f5f9;color:#475569}.dashboard-page{padding:24px;background-color:#f8fafc;min-height:100vh;display:flex;flex-direction:column;gap:24px;align-items:center}.dashboard-header,.dashboard-content{width:100%;max-width:1200px}.dashboard-header{display:flex;justify-content:space-between;align-items:center}.dashboard-content{display:flex;flex-direction:column;gap:48px;align-items:center}.header-left{display:flex;align-items:center;gap:16px}.brand-icon{width:40px;height:40px;background-color:#2563eb;border-radius:8px;display:flex;align-items:center;justify-content:center}.header-titles h1{font-size:1.5rem;font-weight:700;color:#0f172a}.header-titles p{font-size:.9rem;color:#64748b;text-transform:capitalize}.header-right{display:flex;align-items:center;gap:16px}.summary-pill{display:flex;background:#fff;padding:8px 16px;border-radius:12px;box-shadow:0 4px 12px #0000000d;border:1px solid #e2e8f0}.pill-item{display:flex;flex-direction:column;padding:0 16px}.pill-label{font-size:.65rem;font-weight:600;color:#94a3b8;letter-spacing:.05em}.pill-value{font-size:1.25rem;font-weight:700}.pill-value.occupied{color:#3b82f6}.pill-value.available{color:#10b981}.pill-value.rate{color:#f59e0b}.pill-total{font-size:.9rem;font-weight:400;color:#94a3b8}.pill-divider{width:1px;background-color:#e2e8f0}.date-picker-button{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e2e8f0;padding:8px 16px;border-radius:10px;font-size:.9rem;font-weight:500;color:#1e293b;cursor:pointer}.floor-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%}@media(max-width:900px){.floor-cards-grid{grid-template-columns:1fr}}.floor-card{background:#fff;padding:20px;border-radius:16px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:12px}.floor-card-header{display:flex;justify-content:space-between;align-items:center}.floor-name{font-size:.95rem;font-weight:500;color:#64748b}.status-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:12px}.status-badge.risk{background:#fee2e2;color:#ef4444}.status-badge.tension{background:#ffedd5;color:#f97316}.floor-main-stat{display:flex;align-items:baseline;gap:4px}.stat-value{font-size:2rem;font-weight:700;color:#0f172a}.stat-divider{font-size:1.25rem;color:#cbd5e1}.stat-total{font-size:1.25rem;color:#94a3b8}.floor-occupancy-label{font-size:.9rem;font-weight:600;color:#10b981}.progress-container{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.progress-bar{height:100%;border-radius:4px;transition:width .5s ease-out}.floor-card-footer{font-size:.85rem;color:#64748b;margin-top:4px}.forecast-section{background:#fff;padding:24px;border-radius:16px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:24px;max-width:1000px;width:100%}.forecast-section .section-header{display:flex;justify-content:space-between;align-items:flex-start}.forecast-section h2{font-size:1.25rem;font-weight:700;color:#0f172a}.forecast-section p{font-size:.9rem;color:#64748b}.chart-legend{display:flex;gap:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:500;color:#475569}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.occupied{background:#3b82f6}.legend-dot.reserved{background:#3b82f6;opacity:.5}.chart-container{width:100%;height:320px}.custom-chart-tooltip{background:#fff;padding:12px;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a;border:1px solid #e2e8f0;min-width:150px}.tooltip-date{font-weight:700;color:#0f172a;margin-bottom:8px}.tooltip-row{display:flex;justify-content:space-between;font-size:.85rem;color:#64748b;margin-bottom:4px}.tooltip-row.total{margin-top:8px;color:#1e293b;font-weight:600}.dashboard-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.1rem;color:#64748b}
