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;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.app{display:flex;min-height:100vh}.loading,.loading-spinner{align-items:center;color:#666;display:flex;font-size:18px;height:100vh;justify-content:center}.loading-spinner .spinner{animation:spin 2s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin-bottom:10px;width:40px}.error{color:#dc3545;font-size:16px;height:200px}.error,.login-container{align-items:center;display:flex;justify-content:center}.login-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.login-form{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0000001a;max-width:400px;padding:40px;width:100%}.login-form h1{color:#333;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:5px}.form-group input{border:1px solid #ddd;border-radius:5px;font-size:16px;padding:12px;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545;margin-bottom:15px;padding:10px}.sidebar{background-color:#2c3e50;color:#fff;display:flex;flex-direction:column;padding:20px;width:280px}.sidebar-header{margin-bottom:30px}.sidebar-header h2{color:#ecf0f1;margin-bottom:10px}.user-info{display:flex;flex-direction:column;gap:5px}.user-info strong{color:#ecf0f1}.role{border-radius:12px;font-size:12px;font-weight:700;padding:2px 8px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.role.admin{background-color:#e74c3c}.role.concierge{background-color:#3498db}.facility-selector{margin-bottom:30px}.facility-selector h3{color:#bdc3c7;font-size:14px;margin-bottom:10px;text-transform:uppercase}.facility-selector select{background-color:#34495e;border:none;border-radius:4px;color:#fff;font-size:14px;padding:8px;width:100%}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:10px}.sidebar-nav a{align-items:center;border-radius:6px;color:#bdc3c7;display:flex;gap:10px;padding:12px 16px;text-decoration:none;transition:all .2s}.sidebar-nav a:hover{background-color:#34495e;color:#ecf0f1}.sidebar-nav a.active{background-color:#3498db;color:#fff}.sidebar-footer{margin-top:auto}.logout-btn{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px;transition:background-color .2s;width:100%}.logout-btn:hover{background-color:#c0392b}.main-content{flex:1 1;overflow-y:auto;padding:30px}.no-facility{align-items:center;color:#666;display:flex;flex-direction:column;height:50vh;justify-content:center;text-align:center}.page-header{gap:20px;margin-bottom:30px}.page-header h1{color:#2c3e50;flex:1 1}.back-btn{border:1px solid #3498db;border-radius:4px;color:#3498db;padding:8px 16px;transition:all .2s}.back-btn:hover{background-color:#3498db;color:#fff}.btn-primary{background-color:#3498db;border:none;border-radius:4px;cursor:pointer;display:inline-block;font-size:14px;padding:10px 20px;transition:background-color .2s}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .2s}.btn-secondary:hover{background-color:#7f8c8d}.btn-view{background-color:#17a2b8;margin-right:5px}.btn-survey,.btn-view{border:none;border-radius:3px;font-size:12px;padding:6px 12px;text-decoration:none}.btn-survey{background-color:#28a745;cursor:pointer}.dashboard h1{color:#2c3e50;margin-bottom:30px}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;text-align:center}.stat-card.priority{border-left:4px solid #e74c3c}.stat-card h3{color:#666;font-size:14px;margin-bottom:10px;text-transform:uppercase}.stat-number{color:#2c3e50;font-size:32px}.rating-distribution{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px}.rating-distribution h2{color:#2c3e50;margin-bottom:20px}.rating-bars{display:flex;flex-direction:column;gap:10px}.rating-bar{align-items:center;display:flex;gap:10px}.rating-label{font-size:14px;width:60px}.bar-container{background-color:#ecf0f1;border-radius:10px;flex:1 1;height:20px;overflow:hidden}.bar-fill{background:linear-gradient(90deg,#f39c12,#e67e22);height:100%;transition:width .3s ease}.rating-count{color:#666;font-weight:500;text-align:right;width:40px}.dashboard-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:2fr 1fr}.agenda-section,.reviews-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.agenda-section h2,.reviews-section h2{color:#2c3e50;margin-bottom:20px}.agenda-list{display:flex;flex-direction:column;gap:10px}.agenda-item{align-items:center;border:1px solid #ecf0f1;border-radius:6px;display:flex;gap:15px;padding:12px;transition:background-color .2s}.agenda-item:hover{background-color:#f8f9fa}.agenda-item.new-admission{border-left:4px solid #3498db}.agenda-item.one-star{border-left:4px solid #e74c3c}.priority-badge{border-radius:12px;font-size:10px;padding:4px 8px}.agenda-item.new-admission .priority-badge{background-color:#3498db;color:#fff}.agenda-item.one-star .priority-badge{background-color:#e74c3c;color:#fff}.guest-info{display:flex;flex:1 1;flex-direction:column}.guest-info strong{color:#2c3e50}.guest-info span{color:#666;font-size:14px}.action-btn{background-color:#28a745;border-radius:4px;color:#fff;font-size:12px;padding:6px 12px;text-decoration:none;transition:background-color .2s}.action-btn:hover{background-color:#218838}.survey-form-container{max-width:800px}.guest-info-summary{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:20px;margin-bottom:30px;padding:15px}.guest-info-summary span{color:#666;font-size:14px}.survey-form{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.form-section{margin-bottom:30px}.form-section h3{color:#2c3e50;font-size:18px;margin-bottom:15px}.radio-group{display:flex;gap:20px}.radio-group label{align-items:center;border:1px solid #ddd;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:10px 15px;transition:all .2s}.radio-group label:hover{background-color:#f8f9fa}.radio-group input[type=radio]{margin:0}.radio-group label:has(input:checked){background-color:#3498db;border-color:#3498db;color:#fff}.form-section select{background-color:#fff;border:1px solid #ddd;border-radius:6px;font-size:14px;padding:12px;width:100%}.form-section select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.star-rating{display:flex;gap:10px;margin-bottom:10px}.star{background:none;border:none;border-radius:4px;color:#ddd;cursor:pointer;font-size:32px;padding:5px;transform:scale(1);transition:all .3s ease}.star:hover{transform:scale(1.1)}.star.active{text-shadow:0 0 8px #f39c124d}.star-rating[data-rating="1"] .star:first-child.active{color:#e74c3c}.star-rating[data-rating="2"] .star:nth-child(-n+2).active{color:#f39c12}.star-rating[data-rating="3"] .star:nth-child(-n+3).active{color:#f1c40f}.star-rating[data-rating="4"] .star:nth-child(-n+4).active{color:#2ecc71}.star-rating[data-rating="5"] .star:nth-child(-n+5).active{color:#27ae60}.star.hover-preview{color:#f39c12;transform:scale(1.1)}.star.hover-preview.rating-1{color:#e74c3c}.star.hover-preview.rating-2{color:#f39c12}.star.hover-preview.rating-3{color:#f1c40f}.star.hover-preview.rating-4{color:#2ecc71}.star.hover-preview.rating-5{color:#27ae60}.rating-label{color:#666;font-size:16px;font-weight:500}.form-section textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;width:100%}.form-section textarea:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:15px;justify-content:flex-end;padding-top:20px}.department-surveys{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.department-survey-card{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;padding:20px}.department-survey-card h4{color:#2c3e50;margin-bottom:15px;text-transform:capitalize}.department-survey-card .star-rating{justify-content:center;margin-bottom:15px}.department-survey-card .star{font-size:24px}.department-survey-card textarea{margin-top:10px;min-height:80px;width:100%}@media (max-width:768px){.survey-form-container{padding:15px}.radio-group{gap:10px}.form-actions,.radio-group{flex-direction:column}.department-surveys{grid-template-columns:1fr}.star{font-size:28px}}.user-management{background:linear-gradient(135deg,#f8fafc,#f1f5f9);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh}.user-management-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.user-management-header .container{margin:0 auto;max-width:1400px;padding:0 1rem}.user-management-header .header-content{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;padding:2rem 0}.header-icon,.header-left{align-items:center;display:flex}.header-icon{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:.75rem;box-shadow:0 4px 6px #6366f133;height:3rem;justify-content:center;margin-right:1rem;width:3rem}.header-icon span{font-size:1.5rem}.header-text h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:2rem;font-weight:700;margin:0 0 .25rem}.header-text p{color:#64748b;font-size:.95rem;margin:0}.facility-name{color:#6366f1;font-weight:600}.invite-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.75rem;box-shadow:0 2px 4px #10b98133;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.invite-button:hover{border-color:#fff3;box-shadow:0 6px 12px #10b98166;transform:translateY(-2px)}.invite-button span:first-child{margin-right:.5rem}.user-management-content{margin:0 auto;max-width:1400px;padding:2rem 1rem}.error-alert{background:linear-gradient(135deg,#fef2f2,#fef7f7);border:1px solid #fca5a5;border-radius:.75rem;box-shadow:0 2px 4px #dc26261a;margin-bottom:2rem;padding:1rem}.error-alert-content{align-items:center;display:flex}.error-icon{color:#dc2626;height:1.25rem;margin-right:.75rem;width:1.25rem}.error-text{color:#991b1b;font-size:.875rem;font-weight:500}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.stat-card:before{background:linear-gradient(135deg,#3b82f6,#8b5cf6);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 8px 15px #00000026;transform:translateY(-2px)}.stat-card-content{align-items:center;display:flex;justify-content:space-between}.stat-number{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#64748b;font-size:.875rem;font-weight:500}.stat-icon{align-items:center;border-radius:.75rem;display:flex;font-size:1.25rem;height:3rem;justify-content:center;width:3rem}.stat-card.total .stat-number{color:#1e293b}.stat-card.total .stat-icon{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.stat-card.admin .stat-number{color:#dc2626}.stat-card.admin .stat-icon{background:linear-gradient(135deg,#fee2e2,#fecaca)}.stat-card.manager .stat-number{color:#d97706}.stat-card.manager .stat-icon{background:linear-gradient(135deg,#fef3c7,#fde68a)}.stat-card.invites .stat-number{color:#2563eb}.stat-card.invites .stat-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.main-content-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.tabs-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.tabs-nav{display:flex;padding:0 2rem}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;font-size:.875rem;font-weight:600;margin-right:2rem;padding:1.25rem .5rem;transition:all .3s ease}.tab-button.active{border-bottom-color:#6366f1;color:#6366f1}.tab-button:hover:not(.active){border-bottom-color:#d1d5db;color:#374151}.tab-button-content{align-items:center;display:flex}.tab-button-content span:first-child{margin-right:.5rem}.table-container{padding:2rem}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#6366f1;height:2rem;margin-bottom:1rem;width:2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#64748b;font-size:.875rem}.empty-state{padding:4rem 2rem;text-align:center}.empty-state-icon{align-items:center;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:50%;display:flex;font-size:2rem;height:4rem;justify-content:center;margin:0 auto 1.5rem;width:4rem}.empty-state h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0 0 .75rem}.empty-state p{color:#64748b;font-size:.95rem;margin:0 0 1.5rem}.empty-state-button{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bfdbfe;border-radius:.75rem;color:#6366f1;cursor:pointer;display:inline-flex;font-weight:500;padding:.75rem 1.25rem;text-decoration:none;transition:all .3s ease}.empty-state-button:hover{background:linear-gradient(135deg,#e0f2fe,#bae6fd);transform:translateY(-1px)}.empty-state-button span:first-child{margin-right:.5rem}.users-table{border-collapse:collapse;font-size:.95rem;width:100%}.users-table thead th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:1.25rem 1.5rem;text-align:left;text-transform:uppercase}.users-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s ease}.users-table tbody tr:hover{background:linear-gradient(135deg,#f8fafc,#f5f8ff);box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.users-table tbody tr.loading{opacity:.6}.users-table tbody td{padding:1.25rem 1.5rem;vertical-align:middle}.user-info .user-email{color:#1e293b;font-size:.95rem;font-weight:600;margin-bottom:.25rem}.user-info .user-tag{color:#2563eb;font-size:.75rem;margin-left:.5rem}.user-info .user-joined{color:#64748b;font-size:.875rem}.role-badge,.status-badge{border:1px solid;border-radius:1rem;cursor:pointer;font-size:.8rem;font-weight:600;padding:.375rem .75rem;text-transform:capitalize;transition:all .2s ease}.role-badge:disabled,.status-badge:disabled{cursor:not-allowed;opacity:.7}.role-badge.admin{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#fca5a5;color:#991b1b}.role-badge.manager{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fcd34d;color:#92400e}.role-badge.user{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#93c5fd;color:#1e40af}.status-badge.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#86efac;color:#065f46}.status-badge.inactive{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-color:#d1d5db;color:#374151}.action-buttons{gap:.75rem;justify-content:flex-end}.action-button{background:none;border:none;color:#6366f1;cursor:pointer;font-size:.875rem;font-weight:500;padding:.25rem 0;text-decoration:none;transition:all .2s ease}.action-button:hover{color:#4f46e5;text-decoration:underline}.action-button.danger{color:#dc2626}.action-button.danger:hover{color:#b91c1c}.action-button:disabled{cursor:not-allowed;opacity:.5}.invitation-badge{align-items:center;border-radius:1rem;display:inline-flex;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.invitation-badge.pending{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.invitation-badge.expired{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.invitation-badge.role{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.modal{max-width:500px}.modal-header{padding:2rem}.modal-icon{align-items:center;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:.75rem;display:flex;font-size:1.25rem;height:2.5rem;justify-content:center;margin-right:1rem;width:2.5rem}.modal-title h3{color:#1e293b;font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.modal-title p{color:#64748b;font-size:.875rem;margin:0}.form-group{margin-bottom:1.5rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-input{background:#fff;border:2px solid #e2e8f0;border-radius:.75rem;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.form-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none;transform:translateY(-1px)}.form-input::placeholder{color:#9ca3af}.form-input:disabled{background:#f9fafb;cursor:not-allowed}.role-options{display:flex;flex-direction:column;gap:.75rem}.role-option{align-items:center;border:2px solid #e2e8f0;border-radius:.75rem;cursor:pointer;display:flex;padding:.75rem;transition:all .3s ease}.role-option:hover{background:#f8fafc;border-color:#6366f1}.role-option input[type=radio]{color:#6366f1;height:1rem;margin-right:.75rem;width:1rem}.role-option-content{flex:1 1}.role-option-header{align-items:center;display:flex;margin-bottom:.25rem}.role-option-icon{margin-right:.5rem}.role-option-name{font-weight:600;text-transform:capitalize}.role-option-desc{color:#64748b;font-size:.75rem;margin:0}.role-option-name.admin{color:#dc2626}.role-option-name.manager{color:#d97706}.role-option-name.user{color:#2563eb}.modal-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #fca5a5;border-radius:.75rem;margin-bottom:1.5rem;padding:1rem}.modal-error-content{align-items:center;display:flex}.modal-error-icon{color:#dc2626;margin-right:.5rem}.modal-error-text{color:#991b1b;font-size:.875rem;font-weight:600}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1.5rem}.modal-button{align-items:center;border:2px solid #0000;border-radius:.75rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;padding:.75rem 1.25rem;transition:all .3s ease}.modal-button.secondary{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#374151}.modal-button.secondary:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);transform:translateY(-1px)}.modal-button.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.modal-button.primary:hover:not(:disabled){border-color:#fff3;box-shadow:0 4px 8px #6366f166;transform:translateY(-2px)}.modal-button:disabled{cursor:not-allowed;opacity:.6}.modal-button-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:1rem;margin-right:.5rem;width:1rem}.no-facility-state{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);display:flex;justify-content:center;min-height:100vh;padding:2rem}.no-facility-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;border-radius:1rem;box-shadow:0 4px 6px #0000000d;margin-top:5rem;max-width:500px;padding:3rem 2rem;text-align:center;width:100%}.no-facility-icon{align-items:center;background:#fbbf24;border-radius:50%;display:flex;font-size:2rem;height:4rem;justify-content:center;margin:0 auto 1.5rem;width:4rem}.no-facility-card h3{color:#92400e;font-size:1.25rem;font-weight:600;margin:0 0 .75rem}.no-facility-card p{color:#d97706;font-size:.95rem;margin:0}@media (max-width:1024px){.user-management-content{padding:1.5rem 1rem}.stats-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card,.table-container{padding:1.5rem}}@media (max-width:768px){.user-management-header .header-content{align-items:stretch;flex-direction:column;text-align:center}.header-left{justify-content:center}.stats-grid{grid-template-columns:1fr}.tabs-nav{overflow-x:auto;padding:0 1rem}.tab-button{margin-right:1.5rem;white-space:nowrap}.users-table{font-size:.875rem}.users-table tbody td,.users-table thead th{padding:1rem .75rem}.modal{margin:1rem;max-height:calc(100vh - 2rem)}.modal-content,.modal-header{padding:1.5rem}.action-buttons{flex-direction:column;gap:.5rem}}@media print{.user-management{background:#fff}.action-buttons,.invite-button,.modal-overlay{display:none}.main-content-card{border:1px solid #000;box-shadow:none}.users-table thead th{background:#f5f5f5!important;color:#000!important}}.action-button:focus,.form-input:focus,.invite-button:focus,.modal-button:focus,.role-option:focus-within,.tab-button:focus{outline:3px solid #3b82f680;outline-offset:2px}.guest-list{background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.page-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:2.5rem;font-weight:700;margin:0}.search-bar{position:relative}.search-bar input{background-color:#fff;border:2px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;font-size:1rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .3s ease;width:300px}.search-bar input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none;transform:translateY(-1px)}.search-bar input::placeholder{color:#94a3b8}.search-bar:before{color:#94a3b8;content:"🔍";font-size:1rem;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.guests-table{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden}table{border-collapse:collapse;font-size:.95rem;width:100%}thead th{background:linear-gradient(135deg,#1e293b,#334155);border-bottom:3px solid #3b82f6;color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:1.25rem 1rem;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:10}thead th:first-child{border-top-left-radius:1rem}thead th:last-child{border-top-right-radius:1rem}tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s ease}tbody tr:hover{background-color:#f8fafc;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}tbody tr:last-child{border-bottom:none}tbody td{border-right:1px solid #f1f5f9;padding:1.25rem 1rem;vertical-align:top}tbody td:last-child{border-right:none}tbody td:first-child{background:linear-gradient(135deg,#dbeafe,#f0f9ff);color:#3b82f6;font-size:1.1rem;font-weight:700;min-width:80px;text-align:center}tbody td:nth-child(2) strong{color:#1e293b;display:block;font-size:1.1rem;font-weight:600;margin-bottom:.25rem}tbody td:nth-child(2) small{color:#64748b;display:block;font-size:.85rem;margin-top:.25rem}.latest-note{max-width:250px}.latest-note .rating{display:block;font-size:1.1rem;margin-bottom:.5rem}.latest-note p{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#475569;display:-webkit-box;font-size:.9rem;line-height:1.4;margin:.5rem 0;overflow:hidden}.latest-note small{color:#94a3b8;font-size:.8rem}.no-survey{color:#94a3b8;font-size:.9rem;font-style:italic}.rating-trend{text-align:center}.trend-number{color:#1e293b;display:block;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.trend-stars{font-size:.9rem}.priority-badge{border-radius:.5rem;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.375rem .75rem;text-transform:uppercase}.priority-badge.high{animation:pulse 2s infinite;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 4px #ef44444d;color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.action-buttons{display:flex;gap:.5rem;justify-content:center}.btn-survey,.btn-view{border:2px solid #0000;border-radius:.5rem;font-size:.875rem;font-weight:500;min-width:70px;padding:.5rem 1rem;text-align:center;text-decoration:none;transition:all .2s ease}.btn-survey{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-survey:hover{border-color:#ffffff4d;box-shadow:0 4px 8px #10b98166;transform:translateY(-2px)}.error,.loading{border-radius:.75rem;font-size:1.1rem;margin:2rem;padding:3rem;text-align:center}.loading{background:linear-gradient(135deg,#dbeafe,#f0f9ff);border:2px solid #93c5fd;color:#3b82f6}.error{background:linear-gradient(135deg,#fef2f2,#fef7f7);border:2px solid #fca5a5;color:#dc2626}@media (max-width:1200px){.guests-table{overflow-x:auto}table{min-width:900px}}@media (max-width:768px){.guest-list{padding:1rem}.page-header{align-items:stretch;flex-direction:column;gap:1rem}.page-header h1{font-size:2rem;text-align:center}.search-bar input{width:100%}.guests-table{border-radius:.5rem}tbody td,thead th{padding:1rem .75rem}.action-buttons{flex-direction:column;gap:.25rem}}.btn-survey:focus,.btn-view:focus{outline:3px solid #3b82f680;outline-offset:2px}@media print{.guest-list{background-color:#fff;padding:0}.action-buttons,.search-bar{display:none}.guests-table{border:1px solid #000;box-shadow:none}thead th{background:#f5f5f5!important;color:#000!important}}.guest-detail{background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.guest-detail .page-header{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2.5rem;padding:1.5rem 2rem}.guest-detail .page-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:2.25rem;font-weight:700;margin:0}.back-btn{align-items:center;background:linear-gradient(135deg,#64748b,#475569);border:2px solid #0000;border-radius:.75rem;color:#fff;display:inline-flex;font-size:.95rem;font-weight:500;padding:.75rem 1.25rem;text-decoration:none;transition:all .3s ease}.back-btn:hover{border-color:#fff3;box-shadow:0 4px 8px #64748b66;transform:translateY(-2px)}.btn-primary{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:2px solid #0000;border-radius:.75rem;box-shadow:0 2px 4px #10b98133;color:#fff;display:inline-flex;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-primary:hover{border-color:#fff3;box-shadow:0 6px 12px #10b98166;transform:translateY(-2px)}.guest-info-card{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:2.5rem;padding:2rem}.info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{color:#475569;font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.info-item span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#1e293b;font-size:1.125rem;font-weight:500;padding:.75rem 1rem}.priority-high{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border-color:#fca5a5!important;color:#dc2626!important;font-weight:700!important}.priority-normal{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)!important;border-color:#bae6fd!important;color:#0369a1!important}.surveys-section{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;padding:2rem}.surveys-section h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:1.75rem;font-weight:700;margin:0 0 2rem}.no-surveys{color:#64748b;padding:4rem 2rem;text-align:center}.no-surveys p{color:#64748b;font-size:1.125rem;margin-bottom:2rem}.surveys-table{border:1px solid #e2e8f0;border-radius:.75rem;overflow:hidden}.surveys-table table{border-collapse:collapse;font-size:.95rem;width:100%}.surveys-table thead th{background:linear-gradient(135deg,#1e293b,#334155);border-bottom:3px solid #3b82f6;color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:1.25rem 1rem;text-align:left;text-transform:uppercase}.surveys-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s ease}.surveys-table tbody tr:hover{background-color:#f8fafc;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.surveys-table tbody tr:last-child{border-bottom:none}.surveys-table tbody td{border-right:1px solid #f1f5f9;padding:1.25rem 1rem;vertical-align:middle}.surveys-table tbody td:last-child{border-right:none}.survey-type{border-radius:.5rem;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.025em;padding:.375rem .75rem;text-transform:uppercase}.survey-type.base{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;color:#1d4ed8}.survey-type.department{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border:1px solid #c4b5fd;color:#7c3aed}.department{border-radius:.5rem;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.025em;padding:.375rem .75rem;text-transform:capitalize}.department.nursing{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #86efac;color:#047857}.department.dietary{background:linear-gradient(135deg,#fff7ed,#fed7aa);border:1px solid #fdba74;color:#c2410c}.department.housekeeping{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;color:#d97706}.department.activities{background:linear-gradient(135deg,#fce7f3,#fbcfe8);border:1px solid #f9a8d4;color:#be185d}.department.maintenance{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid #cbd5e1;color:#475569}.rating{display:inline-block;font-size:1.1rem}.rating-1,.rating-2{filter:grayscale(50%) sepia(100%) hue-rotate(320deg)}.rating-3{filter:grayscale(20%) sepia(80%) hue-rotate(30deg)}.rating-4,.rating-5{filter:sepia(0)}.requirement{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:.375rem;color:#0369a1;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.btn-view{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:2px solid #0000;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.btn-view:hover{border-color:#ffffff4d;box-shadow:0 4px 8px #6366f166;transform:translateY(-2px)}.modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .3s ease;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 25px 50px #00000040;max-height:90vh;max-width:600px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h3{color:#1e293b;font-size:1.5rem;font-weight:700;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:.375rem;color:#64748b;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;line-height:1;padding:.25rem;transition:all .2s ease;width:40px}.close-btn:hover{background:#f1f5f9;color:#1e293b;transform:scale(1.1)}.modal-content{max-height:calc(90vh - 100px);overflow-y:auto;padding:2rem}.survey-detail .detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.survey-detail .detail-item{display:flex;flex-direction:column;gap:.5rem}.survey-detail .detail-item label{color:#475569;font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.survey-detail .detail-item span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#1e293b;font-size:1rem;font-weight:500;padding:.75rem 1rem}.review-section{border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:2rem}.review-section label{color:#475569;display:block;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.review-text{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:inset 0 1px 2px #0000000d;color:#475569;font-size:1rem;line-height:1.6;margin:0;padding:1.5rem;white-space:pre-wrap}.guest-detail .error,.guest-detail .loading{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;font-size:1.125rem;margin:2rem;padding:4rem 2rem;text-align:center}.guest-detail .loading{border:2px solid #93c5fd;color:#3b82f6}.guest-detail .error{border:2px solid #fca5a5;color:#dc2626}@media (max-width:1024px){.guest-detail{padding:1rem}.guest-detail .page-header{padding:1rem 1.5rem}.guest-info-card,.surveys-section{padding:1.5rem}.info-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.guest-detail .page-header{align-items:stretch;flex-direction:column;gap:1rem}.guest-detail .page-header h1{font-size:1.875rem;order:2;text-align:center}.back-btn{align-self:flex-start;order:1}.btn-primary{align-self:center;order:3}.surveys-table{overflow-x:auto}.surveys-table table{min-width:700px}.modal{margin:1rem;max-height:calc(100vh - 2rem)}.modal-content{padding:1.5rem}.survey-detail .detail-grid{gap:1rem;grid-template-columns:1fr}}@media print{.guest-detail{background-color:#fff;padding:0}.back-btn,.btn-primary,.btn-view{display:none}.guest-info-card,.surveys-section{border:1px solid #000;box-shadow:none}.surveys-table thead th{background:#f5f5f5!important;color:#000!important}.modal-overlay{display:none}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.back-btn:focus,.btn-primary:focus,.btn-view:focus,.close-btn:focus{outline:3px solid #3b82f680;outline-offset:2px}
/*# sourceMappingURL=main.0faf3817.css.map*/