.login-wrapper{align-items:center;background-blend-mode:multiply;background-color:#0000001a;background-image:url(/static/media/bt_aar.bc6e32a94ff12ea57d56.png);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;margin-top:0;min-height:100vh;overflow:hidden;padding-top:0;position:relative}.login-container{background:#fff;border:1px solid #00000014;border-radius:16px;box-shadow:0 4px 24px #0000000f;max-width:480px;padding:0 2.5rem 3rem;position:relative;width:100%;z-index:1}.login-header{margin:2rem auto;text-align:center}.login-logo{align-items:center;display:flex;justify-content:center;margin:0 auto 2rem}.login-logo img{height:auto;max-height:80px;max-width:200px;object-fit:contain;width:100%}.login-header h1{color:#212529;font-size:clamp(1.375rem,4vw,2rem);font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:.5rem}.login-subtitle{color:#495057;font-size:clamp(.8125rem,2.5vw,1rem);line-height:1.4;margin:0}.microsoft-signin-btn{align-items:center;background:#fff;border:2px solid #ced4da;border-radius:8px;color:#343a40;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;height:52px;justify-content:center;overflow:hidden;position:relative;transition:all .2s ease;white-space:nowrap;width:100%}.microsoft-signin-btn span{overflow:hidden;text-overflow:ellipsis}.microsoft-signin-btn:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.microsoft-signin-btn:active:not(:disabled){box-shadow:0 2px 6px #00000014;transform:translateY(0)}.microsoft-signin-btn:disabled{cursor:not-allowed;opacity:.7}.auth-divider{margin:2rem 0;position:relative;text-align:center}.auth-divider:before{background:#dee2e6;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.auth-divider span{background:#fff;color:#6c757d;font-size:.875rem;font-weight:500;letter-spacing:.1em;padding:0 1rem;position:relative;text-transform:uppercase}.email-auth-form{margin-bottom:1.5rem}.form-field{margin-bottom:1.75rem;position:relative}.form-field label{color:#343a40;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-field input{background:#fff;border:1px solid #ced4da;border-radius:8px;color:#343a40;font-size:1rem;height:56px;padding:1rem;transition:all .2s ease;width:100%}.form-field input:focus{border-color:#ccad39;box-shadow:0 0 0 3px #ccad391a;outline:none}.form-field input:focus+.floating-label,.form-field.focused label{color:#ccad39}.form-field.has-value input{border-color:#adb5bd}.form-field:has(.password-toggle) input{padding-right:3rem}.password-toggle{align-items:center;border-radius:4px;color:#6c757d;display:flex;justify-content:center;padding:.5rem;right:1rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.password-toggle:hover{color:#343a40}.submit-btn{align-items:center;background:#ccad39;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;height:52px;justify-content:center;overflow:hidden;position:relative;transition:all .2s ease;width:100%}.submit-btn:hover:not(:disabled){background:#b39a32;box-shadow:0 8px 20px #ccad394d;transform:translateY(-2px)}.submit-btn:active:not(:disabled){box-shadow:0 4px 12px #ccad3933;transform:translateY(0)}.submit-btn:disabled{background:#adb5bd;cursor:not-allowed;opacity:.7;transform:none}.spinner{animation:spin .8s linear infinite;border:3px solid #ffffff4d;border-top-color:#fff}.message{align-items:center;display:flex;font-size:.875rem;gap:.75rem;margin-top:1.5rem;padding:1rem 1.25rem}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#dc3545}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#28a745}.message svg{flex-shrink:0}@media (max-width:768px){.login-container{max-width:90%;padding:0 2rem 2.5rem}.login-logo img{max-height:70px;max-width:180px}}@media (max-width:640px){.login-wrapper{align-items:flex-start;min-height:100vh;padding:2rem 1rem 1rem}.login-container{border-radius:12px;box-shadow:0 4px 20px #00000014;margin:0 auto;max-width:100%;padding:1.5rem 1.25rem 2rem}.login-header{margin:1rem auto 1.5rem}.login-logo{margin-bottom:1rem}.login-logo img{max-height:50px;max-width:min(140px,60vw)}.form-field{margin-bottom:1.25rem}.form-field label{font-size:.8125rem;margin-bottom:.375rem}.form-field input{font-size:16px;height:48px;padding:.875rem}.microsoft-signin-btn,.submit-btn{font-size:clamp(.875rem,3vw,.9375rem);height:48px;padding:0 .75rem}.microsoft-signin-btn svg{flex-shrink:0}.auth-divider{margin:1.25rem 0}.message{font-size:.8125rem;margin-top:1.25rem;padding:.875rem 1rem}}@media (max-width:400px){.login-wrapper{padding:1.5rem .75rem .75rem}.login-container{padding:1.25rem 1rem 1.75rem}.login-header{margin:.75rem auto 1.25rem}.login-logo{margin-bottom:.875rem}.login-logo img{max-height:45px;max-width:min(120px,55vw)}.form-field{margin-bottom:1rem}.form-field label{font-size:.75rem}.microsoft-signin-btn,.submit-btn{font-size:clamp(.8125rem,3.5vw,.875rem);gap:.5rem;height:46px;padding:0 .5rem}.microsoft-signin-btn svg{height:18px;width:18px}.auth-divider{margin:1rem 0}.auth-divider span{font-size:.75rem}}@media (max-width:360px){.login-wrapper{padding:1rem .5rem .5rem}.login-container{padding:1rem .875rem 1.5rem}.login-header{margin:.5rem auto 1rem}.login-logo img{max-height:40px;max-width:min(100px,50vw)}.form-field input{height:46px;padding:.75rem}.microsoft-signin-btn,.submit-btn{font-size:.8125rem;height:44px}}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important}}.microsoft-signin-btn:focus-visible,.password-toggle:focus-visible,.submit-btn:focus-visible{outline:3px solid #ccad39;outline-offset:2px}@media (pointer:coarse){.form-field input,.microsoft-signin-btn,.submit-btn{min-height:48px}.password-toggle{min-height:48px;min-width:48px}}.dashboard-container{background-color:#f8f9fa;margin:0 auto;max-width:1400px;min-height:100vh;padding:32px 40px;width:100%}.dashboard-header-section{margin-bottom:32px}.dashboard-title-row{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:8px}.dashboard-title{color:#1a1a1a;flex:1 1;font-size:36px;font-weight:700;margin:0}.btn-check-in-dashboard{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;display:none;flex-shrink:0;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.btn-check-in-dashboard:hover{box-shadow:0 4px 16px #10b98166;transform:translateY(-2px)}.btn-check-in-dashboard:active{transform:translateY(0)}.dashboard-subtitle{color:#6b7280;font-size:16px;margin:0}.search-filter-bar{align-items:center;display:flex;flex-wrap:nowrap;gap:16px;margin-bottom:32px}.search-box-wrapper{align-items:center;display:flex;flex:1 1;min-width:0;position:relative}.search-icon{color:#9ca3af;font-size:18px;left:16px;position:absolute}.dashboard-search-input{background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:15px;padding:14px 16px 14px 48px;transition:all .2s ease;width:100%}.dashboard-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.dashboard-search-input::placeholder{color:#9ca3af}.filter-buttons{display:flex;flex-shrink:0;gap:12px}.btn-filter,.btn-today{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;color:#374151;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.btn-filter:hover,.btn-today:hover{background:#f9fafb;border-color:#d1d5db}.stats-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:32px}.stat-card{align-items:center;box-shadow:0 1px 3px #0000001a;cursor:pointer;justify-content:center;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.stat-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card.stat-total:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card.stat-checked-in:before{background:linear-gradient(90deg,#10b981,#059669)}.stat-card.stat-checked-out:before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-card.active{box-shadow:0 4px 16px #0003}.stat-icon-wrapper{align-items:center;align-self:center;border-radius:12px;display:flex;height:48px;justify-content:center;margin-bottom:16px;width:48px}.stat-icon-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.stat-icon-green{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.stat-icon-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.stat-icon{font-size:24px}.stat-content{align-items:center;display:flex;flex-direction:column;gap:4px;text-align:center}.stat-number{color:#1a1a1a;font-size:36px;font-weight:700;line-height:1}.section-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:24px}.section-title{color:#1a1a1a;font-size:20px;font-weight:700;margin:0}.view-toggle{background:#f3f4f6;border-radius:8px;gap:8px;padding:4px}.toggle-btn{border-radius:6px;font-size:14px;padding:8px 16px;transition:all .2s ease}.toggle-btn.active{background:#fff;box-shadow:0 1px 2px #0000001a;color:#1a1a1a}.guest-list-new{display:flex;flex-direction:column;gap:16px}.guest-card-new{align-items:center;background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:16px;padding:20px;position:relative;transition:all .2s ease}.guest-card-new:hover{background:#fff;box-shadow:0 2px 8px #00000014}.guest-card-new.previous{opacity:.85}.status-dot-new{border-radius:50%;flex-shrink:0;height:10px;width:10px}.status-dot-new.checked-in{background:#10b981;box-shadow:0 0 8px #10b98166}.status-dot-new.checked-out{background:#9ca3af}.guest-avatar-new{flex-shrink:0}.avatar-initials,.guest-avatar-new img{border-radius:50%;height:56px;object-fit:cover;width:56px}.avatar-initials{align-items:center;background:#667eea;color:#fff;display:flex;font-size:20px;font-weight:600;justify-content:center;letter-spacing:.5px;line-height:1;text-transform:uppercase}.guest-info-new{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:0}.guest-name-row{align-items:center;display:flex;gap:12px}.guest-name-new{color:#1a1a1a;font-size:18px;font-weight:600;margin-bottom:0}.guest-meta{display:flex;flex-wrap:wrap;gap:16px}.meta-item{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:4px}.guest-time-new{align-items:flex-end;display:flex;flex-direction:column;gap:4px;margin-right:20px}.time-large{color:#1a1a1a;font-size:18px;font-weight:600}.time-duration{color:#6b7280;font-size:13px}.guest-actions-new{align-items:center;display:flex;gap:12px}.btn-checkout{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease}.btn-checkout:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.btn-view-details{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-view-details:hover{background:#f9fafb;border-color:#d1d5db}.btn-message{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.btn-message:hover{background:#f9fafb;border-color:#d1d5db}.timeline-view{display:flex;flex-direction:column;gap:0;padding:20px 0}.timeline-item{grid-gap:20px;display:grid;gap:20px;grid-template-columns:120px 60px 1fr;position:relative}.timeline-time{align-items:flex-end;display:flex;flex-direction:column;gap:4px;padding-top:8px}.timeline-time-text{color:#1a1a1a;font-size:16px;font-weight:600}.timeline-duration-text{color:#6b7280;font-size:13px}.timeline-connector{align-items:center;display:flex;flex-direction:column;position:relative}.timeline-dot{border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #00000026;flex-shrink:0;height:16px;width:16px;z-index:2}.timeline-dot.checked-in{background:#10b981}.timeline-dot.checked-out{background:#9ca3af}.timeline-line{background:linear-gradient(180deg,#e5e7eb,#f3f4f6);flex:1 1;margin-top:8px;min-height:60px;width:2px}.timeline-content{padding-bottom:20px}.timeline-card{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;padding:16px;transition:all .2s ease}.timeline-card:hover{background:#fff;box-shadow:0 2px 12px #0000001a}.timeline-card-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.guest-avatar-small{flex-shrink:0}.avatar-initials-small,.guest-avatar-small img{border-radius:50%;height:44px;object-fit:cover;width:44px}.avatar-initials-small{align-items:center;background:#667eea;color:#fff;display:flex;font-size:16px;font-weight:600;justify-content:center;letter-spacing:.5px;line-height:1;text-transform:uppercase}.timeline-guest-info{flex:1 1;min-width:0}.timeline-guest-name{color:#1a1a1a;font-size:16px;font-weight:600;margin-bottom:4px}.timeline-guest-meta{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:8px}.timeline-card-actions{display:flex;gap:8px}.btn-timeline-action{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-timeline-action:hover{background:#f9fafb;border-color:#d1d5db}.btn-timeline-action.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-timeline-action.primary:hover{background:#2563eb;border-color:#2563eb}.empty-state{color:#9ca3af}@media (max-width:1024px){.stats-container{grid-template-columns:1fr}.guest-card-new{flex-wrap:wrap}.guest-actions-new{justify-content:flex-start;width:100%}}@media (max-width:768px){.dashboard-container{padding:16px 12px}.dashboard-header-section{margin-bottom:20px}.dashboard-title-row{gap:12px}.dashboard-title{font-size:clamp(20px,5vw,24px)}.btn-check-in-dashboard{display:flex;font-size:14px;padding:10px 16px}.dashboard-subtitle{font-size:14px}.search-filter-bar{flex-direction:row;gap:12px;margin-bottom:20px}.dashboard-search-input{font-size:14px;padding:12px 12px 12px 44px}.filter-buttons{flex-shrink:0}.btn-filter,.btn-today{font-size:14px;padding:12px 16px;white-space:nowrap}.stats-container{gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.stat-card{padding:10px 6px!important}.stat-icon-wrapper{height:28px!important;margin-bottom:6px!important;width:28px!important}.stat-icon{font-size:14px!important}.stat-number{font-size:20px!important}.stat-label{font-size:8.5px!important;letter-spacing:.2px!important;line-height:1.2!important}.section-container{margin-bottom:16px;padding:16px}.section-header{margin-bottom:16px}.section-title{font-size:18px}.guest-list-new{gap:12px}.guest-card-new{align-items:flex-start;flex-direction:column;gap:10px;padding:12px}.avatar-initials,.guest-avatar-new img{height:44px;width:44px}.avatar-initials{font-size:16px}.guest-name-new{font-size:16px;margin-bottom:6px}.guest-meta{gap:12px}.meta-item{font-size:12px}.guest-time-new{align-items:flex-start;gap:2px;margin-right:0}.time-large{font-size:16px}.time-duration{font-size:12px}.guest-actions-new{flex-direction:row;gap:8px;width:100%}.btn-checkout,.btn-view-details{flex:1 1;font-size:13px;padding:8px 12px}.timeline-item{gap:12px;grid-template-columns:80px 40px 1fr}.timeline-time-text{font-size:14px}.timeline-duration-text{font-size:12px}.timeline-card-actions{flex-direction:column}.btn-timeline-action{width:100%}}@media (max-width:480px){.dashboard-container{padding:12px 10px}.dashboard-title-row{gap:8px}.dashboard-title{font-size:clamp(18px,4.5vw,22px)}.btn-check-in-dashboard{font-size:13px;padding:8px 12px}.stats-container{gap:8px}.stat-card{padding:8px 5px!important}.stat-icon-wrapper{height:26px!important;margin-bottom:5px!important;width:26px!important}.stat-icon{font-size:13px!important}.stat-number{font-size:18px!important}.stat-label{font-size:7.5px!important;letter-spacing:.1px!important}.section-container{padding:12px}.section-title{font-size:16px}}@media (max-width:360px){.stats-container{gap:6px}.stat-card{padding:7px 3px!important}.stat-icon-wrapper{height:24px!important;margin-bottom:4px!important;width:24px!important}.stat-icon{font-size:12px!important}.stat-number{font-size:16px!important}.stat-label{font-size:7px!important;letter-spacing:0!important}}.modal-overlay{animation:fadeIn .3s ease}.add-note-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:95%}.add-note-modal .modal-header{align-items:center;background:linear-gradient(135deg,#1a5f7a,#144d61);border-bottom:2px solid #e0e0e0;border-radius:0;display:flex;flex-shrink:0;justify-content:space-between;padding:24px}.modal-body{padding:24px}.guest-info-section{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:16px;margin-bottom:24px;padding:16px}.guest-avatar-modal{border:3px solid #1a5f7a;border-radius:50%;height:80px;object-fit:cover;width:80px}.guest-details-modal h3{color:#1a5f7a;font-size:20px;font-weight:600;margin:0 0 8px}.guest-details-modal p{color:#6b7280;font-size:14px;margin:4px 0}.guest-email:before{content:"📧 "}.guest-phone:before{content:"📱 "}.add-note-section{margin-bottom:24px}.add-note-section h4{color:#1a5f7a;font-size:16px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.note-textarea{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:border-color .3s ease;width:100%}.note-textarea:focus{border-color:#1a5f7a;outline:none}.note-textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.notes-history-section{background:#f9fafb;border-radius:12px;padding:16px}.notes-history-section h4{border-bottom:2px solid #e5e7eb;font-size:16px;letter-spacing:.5px;margin:0 0 16px;padding-bottom:8px;text-transform:uppercase}.notes-timeline{gap:12px}.note-entry-compact{background:#fff;border-radius:8px;line-height:1.5;padding:10px}.note-author-avatar-compact{background:linear-gradient(135deg,#1a5f7a,#144d61);display:inline-flex;font-size:11px;font-weight:600;height:24px;width:24px}.note-author-name-compact{color:#1a5f7a}.note-separator{flex-shrink:0}.note-timestamp-compact{color:#9ca3af}.loading-text,.no-notes-text{color:#9ca3af;font-size:14px;font-style:italic;padding:20px;text-align:center}.message{margin:0 24px 16px}.message.success{background-color:#d1fae5;border-left:4px solid #10b981;color:#065f46}.message.error{background-color:#fee2e2;border-left:4px solid #ef4444;color:#991b1b}.modal-footer{background-color:#f9fafb;border-radius:0 0 16px 16px;border-top:2px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;justify-content:center;padding:20px 24px}.add-note-modal .modal-footer .btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;min-width:150px;padding:12px 24px;transition:all .3s ease;width:150px}.add-note-modal .modal-footer .btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563)!important;border:none!important;color:#fff!important}.add-note-modal .modal-footer .btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#4b5563,#374151)!important}.add-note-modal .modal-footer .btn-primary{background:linear-gradient(135deg,#1a5f7a,#144d61)!important;color:#fff!important}.add-note-modal .modal-footer .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#144d61,#0f3d4f)!important;box-shadow:0 4px 12px #1a5f7a66;transform:translateY(-2px)}.add-note-modal .modal-footer .btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.edit-section{margin-bottom:24px}.edit-section h4{border-bottom:2px solid #e5e7eb;color:#1a5f7a;font-size:16px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;text-transform:uppercase}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.form-group.full-width{grid-column:1/-1}.form-group label{color:#374151;font-size:13px;margin-bottom:6px}.form-group input,.form-group select{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{border-color:#1a5f7a;outline:none}.form-group input:disabled,.form-group select:disabled{background-color:#f3f4f6;cursor:not-allowed}.delete-modal{max-width:450px!important}.delete-warning{padding:20px 0;text-align:center}.delete-warning-icon{font-size:48px;margin-bottom:16px}.delete-warning h3{color:#dc2626;font-size:20px;margin:0 0 12px}.delete-warning p{color:#6b7280;font-size:14px;margin:0 0 8px}.delete-warning .guest-name{color:#1f2937;font-size:18px;font-weight:600;margin:16px 0}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c)!important;color:#fff!important}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b)!important;box-shadow:0 4px 12px #dc262666!important}@media (max-width:768px){.add-note-modal{max-height:90vh;width:95%}.modal-header{padding:16px}.modal-header h2{font-size:18px}.modal-body{padding:16px}.guest-info-section{flex-direction:column;text-align:center}.modal-footer{flex-direction:column-reverse;padding:16px}.modal-footer .btn{width:100%}.note-entry-compact{flex-wrap:wrap;font-size:12px}.note-content-compact{flex-basis:100%}}.add-note-modal .modal-header h2{color:#fff!important}.ccb-badge{align-items:center;background:#fffffff2;border-radius:4px;box-shadow:0 1px 3px #0003;color:#1a5f7a;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;letter-spacing:.5px;margin-left:12px;padding:4px 10px;text-transform:uppercase}.ccb-sync-notice{align-items:center;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-left:4px solid #059669;color:#065f46;display:flex;flex-wrap:wrap;font-size:13px;gap:8px;padding:12px 24px}.sync-status{font-weight:600}.sync-status.syncing{color:#d97706}.sync-status.success{color:#059669}.sync-status.error{color:#dc2626}.local-only-note{color:#9ca3af;font-size:12px;font-weight:400;letter-spacing:normal;margin-left:8px;text-transform:none}.message.warning{background-color:#fef3c7;border-left:4px solid #f59e0b;color:#92400e}.checkin-container{background-color:#f5f7fa;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px;width:100%}.checkin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.checkin-title{color:#333;flex:1 1;font-size:32px;margin:0;text-align:center}.checkin-content{margin:0 auto;max-width:1125px}.section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:28px}.section h2{color:#333;font-size:20px;font-weight:600;margin:0 0 20px}.section h3{color:#666;font-size:16px;font-weight:600;margin:0 0 16px}.guest-selection-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.guest-selection-header h2{color:#333;font-size:20px;font-weight:600;margin:0}.guest-selection-header .btn{font-size:14px;margin:0;padding:10px 20px;white-space:nowrap;width:auto!important}.search-box{margin-bottom:20px;position:relative}.search-input{border:2px solid #e0e0e0;font-size:15px;padding:12px 40px 12px 16px}.search-input:focus{border-color:#667eea}.search-clear-btn{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;font-size:20px;justify-content:center;line-height:1;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .2s ease}.search-clear-btn:hover{color:#667eea}.dropdown-guest-name{flex:1 1}.dropdown-checkin-badge{background:#10b981;border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;white-space:nowrap}.guest-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));max-height:400px;overflow-y:auto;padding:4px}.guest-option{align-items:center;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:16px;position:relative;transition:all .3s ease}.guest-option:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.guest-option.selected{background-color:#f0f4ff;border-color:#667eea}.checkin-status-dot{background:#10b981;border-radius:50%;box-shadow:0 0 8px #10b98166;flex-shrink:0;height:10px;margin-right:12px;width:10px}.guest-option-image{flex-shrink:0;position:relative}.guest-option-image img{border:2px solid #e0e0e0;border-radius:50%;height:45px;object-fit:cover;width:45px}.guest-avatar-placeholder{background:#667eea;font-size:16px;font-weight:600;height:45px!important;letter-spacing:.5px;line-height:1;max-height:45px!important;max-width:45px!important;min-height:45px!important;min-width:45px!important;text-transform:uppercase;width:45px!important}.guest-option-info{flex:1 1}.guest-option-name{color:#333;font-size:16px;font-weight:600;margin-bottom:4px}.guest-option-details{color:#666;font-size:13px}.edit-guest-btn{align-items:center;background:#fff;border:2px solid #667eea;border-radius:6px;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;padding:0;position:absolute;right:8px;top:8px;transition:all .2s ease;width:32px;z-index:10}.edit-guest-btn:hover{background:#667eea;transform:scale(1.1)}.edit-guest-btn:active{transform:scale(.95)}.no-results{color:#999;padding:40px 20px;text-align:center}.no-results p{font-size:15px;margin:0}.selected-guest-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:20px 0;padding:24px}.selected-guest-content{align-items:center;display:flex;gap:20px}.selected-guest-image{flex-shrink:0}.selected-guest-image img{border:none;border-radius:50%;height:80px;object-fit:cover;width:80px}.selected-guest-avatar-placeholder{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;display:flex;font-size:32px;font-weight:700;height:80px;justify-content:center;letter-spacing:-1px;line-height:1;text-transform:uppercase;width:80px}.selected-guest-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.selected-guest-name-row{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:4px}.selected-guest-name{color:#333;flex:1 1;font-size:24px;font-weight:700}.btn-change-guest{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.btn-change-guest:hover{background:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateY(-2px)}.selected-guest-detail{align-items:center;color:#666;display:flex;font-size:14px;gap:8px}.btn-edit-guest{background:none;border:none;border-radius:4px;cursor:pointer;font-size:18px;margin-left:8px;padding:4px 8px;transition:all .2s ease;vertical-align:middle}.btn-edit-guest:hover{background-color:#1a5f7a1a;transform:scale(1.1)}.new-guest-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.new-guest-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.or-divider{margin:24px 0;position:relative;text-align:center}.or-divider:before{background-color:#e0e0e0;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.or-divider span{background-color:#fff;color:#999;font-size:14px;font-weight:500;padding:0 15px;position:relative}.new-guest-form{background-color:#f9f9f9;border:2px dashed #d0d0d0;border-radius:8px;margin-top:20px;padding:20px}.form-row{margin-bottom:12px}.form-group{gap:8px;margin-bottom:16px}.help-text{margin:8px 0 0}.help-text-center{color:#999;font-size:14px;margin:16px 0 0;text-align:center}.service-select{cursor:pointer}.checkin-container .form-actions{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:28px;padding-top:20px}.checkin-container .form-actions .btn{flex:1 1 auto;max-width:-webkit-fit-content;max-width:fit-content;min-width:180px}.checkin-container .btn-primary{background:#0fa77d;color:#fff}.checkin-container .btn-primary:hover:not(:disabled){background:#0d8a6a;box-shadow:0 4px 12px #0fa77d66;transform:translateY(-2px)}.checkin-container .btn-primary:disabled{cursor:not-allowed;opacity:.6}.checkin-container .btn-secondary{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff;width:100%}.checkin-container .btn-secondary:hover:not(:disabled){box-shadow:0 4px 16px #10b98166;transform:translateY(-2px)}.checkin-container .btn-outline{background-color:#fff;border:2px solid #6b7280;color:#6b7280}.checkin-container .btn-outline:hover:not(:disabled){background-color:#6b7280;box-shadow:0 4px 12px #6b728066;color:#fff!important;transform:translateY(-2px)}.checkin-container .btn-outline:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.checkin-container{padding:16px}.checkin-header{align-items:flex-start;flex-direction:column;gap:12px;margin-bottom:20px}.checkin-title{font-size:clamp(22px,5vw,28px);text-align:left}.header-spacer{display:none}.section{margin-bottom:16px;padding:20px 16px}.form-row,.guest-grid{grid-template-columns:1fr}.guest-selection-header{align-items:flex-start;flex-direction:column;gap:12px;margin-bottom:20px}.guest-selection-header h2{text-align:left}.guest-selection-header .btn{align-self:flex-start;width:auto!important}.checkin-container .form-actions{flex-direction:column-reverse;gap:10px;margin-top:20px;padding-top:16px}.checkin-container .form-actions .btn{font-size:clamp(14px,3.5vw,16px);max-width:100%;min-width:0;padding:14px 20px;width:100%}.selected-guest-card{margin:16px 0;padding:16px}.selected-guest-content{align-items:center;flex-direction:row;gap:16px}.selected-guest-avatar-placeholder,.selected-guest-image img{height:60px;width:60px}.selected-guest-avatar-placeholder{font-size:22px}.selected-guest-name-row{align-items:flex-start;flex-direction:column;gap:10px}.selected-guest-name{font-size:clamp(18px,4.5vw,22px)}.btn-change-guest{font-size:14px;padding:10px 16px;width:100%}.new-guest-form{padding:16px}.new-guest-header{align-items:stretch;flex-direction:column;gap:12px}.new-guest-header .btn-change-guest{width:100%}}@media (max-width:480px){.checkin-container{padding:12px}.section{padding:16px 12px}.checkin-title{font-size:clamp(20px,5vw,24px)}.selected-guest-content{gap:12px}.selected-guest-avatar-placeholder,.selected-guest-image img{height:50px;width:50px}.selected-guest-avatar-placeholder{font-size:18px}.selected-guest-name{font-size:clamp(16px,4.5vw,20px)}.selected-guest-detail{font-size:13px}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:10px 14px}.checkin-container .form-actions .btn{font-size:14px;padding:12px 16px}.btn-change-guest{font-size:13px;padding:8px 14px}}.add-photo-btn{align-items:center;background:#667eea;border:2px solid #fff;border-radius:50%;bottom:-12px;box-shadow:0 2px 6px #0003;cursor:pointer;display:flex;font-size:13px;height:26px;justify-content:center;padding:0;position:absolute;right:-2px;transition:all .3s ease;width:26px;z-index:10}.add-photo-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea80;transform:scale(1.15)}.add-photo-btn-large{align-items:center;background:#667eea;border:2px solid #fff;border-radius:50%;bottom:-10px;box-shadow:0 2px 8px #0003;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;padding:0;position:absolute;right:-10px;transition:all .3s ease;width:36px;z-index:10}.add-photo-btn-large:hover{background:#5568d3;box-shadow:0 4px 12px #667eea80;transform:scale(1.15)}.modal-overlay{background:#0009}.modal-content{animation:modalSlideIn .3s ease-out;box-shadow:0 10px 40px #0000004d;max-width:400px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:#667eea;gap:16px;padding:20px}.modal-header h3{color:#fff;flex:1 1;font-size:18px;font-weight:600;margin:0}.modal-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.modal-close-btn:hover{background:#ffffff4d;color:#fff}.modal-body{flex:1 1;overflow-y:auto;padding:30px 24px}.modal-body .help-text-center{margin:0 0 20px}@media (max-width:768px){.modal-overlay{padding:10px}.modal-content{max-width:100%}.modal-header{padding:20px 20px 16px}.modal-body{padding:20px}}.checkout-container{background-color:#f5f7fa;margin:0 auto;max-width:1000px;min-height:100vh;padding:20px}.checkout-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.checkout-title{color:#333;flex:1 1;font-size:32px;font-weight:700;margin:0;text-align:center}.checkout-content{display:flex;flex-direction:column;gap:20px}.card-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.card-title{color:#333;font-size:20px;font-weight:700;margin:0}.status-badge-container{align-items:center;display:flex}.status-badge{font-size:13px;padding:6px 16px}.status-badge.checked-out{background:linear-gradient(135deg,#dc143c,#b22234);color:#fff}.guest-info-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 12px #00000014;padding:24px}.guest-profile{justify-content:space-between;margin-bottom:20px}.guest-profile,.guest-profile-left{align-items:center;display:flex;gap:20px}.guest-profile-left{flex:1 1}.guest-image{flex-shrink:0;position:relative}.guest-image img{object-fit:cover}.guest-avatar-placeholder,.guest-image img{border:3px solid #e5e7eb;border-radius:50%;height:80px;width:80px}.guest-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-weight:700;justify-content:center}.guest-details{display:flex;flex-direction:column;gap:4px}.guest-name{color:#1f2937;font-size:24px;font-weight:700;margin:0}.guest-contact{color:#6b7280;font-size:14px}.contact-item-inline,.guest-contact{align-items:center;display:flex;gap:8px}.contact-icon{font-size:16px}.contact-text{color:#4b5563}.contact-separator{color:#d1d5db;margin:0 8px}.info-divider{background:#e5e7eb;height:1px;margin:20px 0}.info-divider-thin{background:#f3f4f6;height:1px;margin:16px 0}.time-row-modern{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:12px;display:flex;gap:24px;padding:20px}.time-item-modern{align-items:center;display:flex;flex:1 1;gap:12px}.time-icon{flex-shrink:0;font-size:24px}.time-content{display:flex;flex-direction:column;gap:4px}.time-label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.time-value{color:#1f2937;font-size:14px;font-weight:600}.time-value.pending{color:#9ca3af;font-style:italic;font-weight:400}.time-by{color:#9ca3af;font-size:12px}.time-arrow{color:#3b82f6;flex-shrink:0;font-size:24px;font-weight:700}.service-pager-row-modern{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:0;padding:16px}.info-item-modern{align-items:center;display:flex;flex:1 1;gap:12px;padding:0 16px}.info-icon{flex-shrink:0;font-size:20px}.info-content{display:flex;flex-direction:column;gap:2px}.info-label-sm{color:#9ca3af;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value-sm{color:#1f2937;font-size:14px;font-weight:600}.info-value-sm.success-text{color:#10b981}.info-value-sm.warning-text{color:#f59e0b}.vertical-divider{background:#e5e7eb;flex-shrink:0;height:40px;width:1px}.notes-section-modern{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;padding:16px}.notes-label{color:#4b5563;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.notes-text{color:#6b7280;font-size:14px;line-height:1.6;margin:0;white-space:pre-wrap}.optional-text{color:#9ca3af;font-size:12px;font-style:italic;font-weight:400}.notes-textarea-modern{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;margin-top:8px;padding:12px;resize:vertical;transition:border-color .2s ease;width:100%}.notes-textarea-modern:focus{border-color:#667eea;outline:none}.pager-checkbox-modern{background:#fef3c7;border:1px solid #fde047;border-radius:12px;padding:16px}.checkbox-label-modern{align-items:center;cursor:pointer;display:flex;gap:12px;-webkit-user-select:none;user-select:none}.checkbox-input-modern{accent-color:#667eea;cursor:pointer;height:20px;width:20px}.checkbox-text-modern{color:#78350f;font-size:15px;font-weight:600}.form-actions-modern{display:flex;gap:12px;justify-content:center;padding-top:8px}.btn{min-width:140px;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #667eea66}.btn-outline{border:2px solid #667eea;color:#667eea}.btn-outline:hover:not(:disabled){background:#f0f4ff}.btn-back{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#667eea;padding:8px 16px;transition:all .2s ease}.btn-back:hover{background:#f9fafb;border-color:#667eea}.message{padding:16px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.loading{color:#6b7280}.error-page,.loading{padding:40px;text-align:center}.error-page{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014}.error-page h2{color:#dc2626;margin-bottom:16px}.error-page p{color:#6b7280;margin-bottom:24px}@media (max-width:768px){.checkout-container{padding:12px}.checkout-header{align-items:flex-start;flex-direction:column;gap:12px}.checkout-title{font-size:24px;text-align:left}.header-spacer{display:none}.guest-info-card{padding:20px 16px}.card-header{align-items:center;flex-direction:row;gap:12px;justify-content:space-between}.card-title{font-size:18px}.status-badge{font-size:11px;padding:4px 10px}.guest-profile{align-items:flex-start;flex-direction:row;gap:16px;justify-content:space-between}.guest-profile-left{align-items:center;flex:0 0 auto;flex-direction:column;gap:8px}.guest-image{align-self:center}.guest-details{align-items:center}.guest-name{font-size:20px;text-align:center}.guest-contact{align-items:flex-start;align-self:center;flex:1 1;flex-direction:column;gap:6px;justify-content:center;margin-left:10%}.contact-item-inline{align-items:center;flex-direction:row;gap:6px;text-align:left}.contact-text{font-size:13px}.contact-separator{display:none}.time-row-modern{align-items:flex-start;flex-direction:column;gap:16px;padding:16px}.time-item-modern{align-items:flex-start;flex-direction:row;gap:12px;width:100%}.time-icon{flex-shrink:0;font-size:24px;margin-top:2px}.time-content{align-items:flex-start;text-align:left}.time-label{font-size:12px}.time-value{font-size:14px;text-align:left}.time-by{font-size:12px}.time-arrow{display:none}.service-pager-row-modern{display:flex;flex-direction:row;gap:0;overflow-x:auto;padding:12px 8px}.info-item-modern{align-items:center;background:#0000;flex:1 1;flex-direction:column;gap:4px;min-width:0;padding:8px 6px;text-align:center}.info-icon{font-size:20px}.info-content{align-items:center}.info-label-sm{font-size:9px}.info-value-sm{font-size:11px;text-align:center;word-break:break-word}.vertical-divider{background:#e5e7eb;display:block;height:40px}.notes-section-modern{padding:14px}.notes-label{font-size:12px}.notes-text{font-size:13px}.notes-textarea-modern{font-size:14px;padding:10px}.pager-checkbox-modern{padding:14px}.checkbox-text-modern{font-size:14px}.form-actions-modern{flex-direction:row;gap:10px}.form-actions-modern .btn{flex:1 1;font-size:14px;min-width:0;padding:12px 16px}}@media (max-width:480px){.checkout-container{padding:8px}.guest-info-card{border-radius:12px;padding:16px 12px}.guest-profile{gap:12px}.guest-name{font-size:18px}.guest-avatar-placeholder,.guest-image img{font-size:22px;height:60px;width:60px}.contact-text{font-size:12px}.time-row-modern{padding:14px 12px}.time-icon{font-size:22px}.time-value{font-size:13px}.time-by{font-size:11px}.service-pager-row-modern{gap:10px;grid-template-columns:1fr 1fr;padding:12px}.info-item-modern{padding:10px 6px}.info-icon{font-size:20px}.info-label-sm{font-size:9px}.info-value-sm{font-size:12px}.form-actions-modern .btn{font-size:13px;padding:10px 12px}}.app-header{background:linear-gradient(135deg,#0d4d7a,#0a3a5e);box-shadow:0 2px 8px #0000001a;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:24px;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding:24px 50px;position:-webkit-sticky;position:sticky;top:0;width:100vw;z-index:1000}.app-header,.header-left{align-items:center;display:flex}.header-left{flex-direction:column}.header-logo-title{align-items:center;cursor:pointer;display:flex;gap:12px}.header-logo{border-radius:50%;flex-shrink:0;height:40px;object-fit:cover;width:auto}.header-left h1{color:#fff;font-size:22.4px;margin:0;transition:color .3s ease;white-space:nowrap}.header-left h1:hover{color:#e0e0e0}.header-subtitle{align-items:center;color:#fff;display:flex;font-size:11.2px;gap:12px;margin:0}.role-badge{align-self:center;background:#fff;border:1px solid #3498db;border-radius:4px;color:#3498db;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-align:center}.header-right{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.header-user-info{flex-direction:column;gap:8px;margin-right:10px}.greeting-section,.header-user-info{align-items:center;display:flex;justify-content:center}.greeting-section{gap:10px}.greeting-icon{align-items:center;display:flex;font-size:20px;justify-content:center;line-height:1}.greeting-message{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:500;white-space:nowrap}.role-datetime-row{align-items:center;display:flex;gap:10px;justify-content:center}.role-text{color:#fff;font-size:12px;font-weight:600;white-space:nowrap}.separator-pipe{color:#ffffff80;font-size:12px;font-weight:300}.datetime-section{align-items:center;display:flex}.datetime-text{color:#fff;display:inline-block;font-size:14px;font-weight:600;white-space:nowrap}.header-divider{background:#ffffff4d;height:40px;width:1px}.reports-dropdown{align-items:center;display:inline-flex;position:relative}.dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;left:-8px;min-width:180px;overflow:hidden;position:absolute;top:calc(100% + 12px);z-index:1001}.dropdown-menu:before{background:#0000;content:"";height:12px;left:0;position:absolute;right:0;top:-12px}.dropdown-item{color:#333;font-size:14px;font-weight:500;gap:8px;padding:12px 16px}.dropdown-item:hover{background-color:#f0f4f8;color:#0d4d7a}.dropdown-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.dropdown-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.notification-bell-container{align-items:center;cursor:pointer;display:inline-flex;justify-content:center;padding:4px;position:relative;transition:transform .2s ease}.notification-bell-container:hover{transform:scale(1.1)}.notification-bell{font-size:18px;line-height:1}.notification-badge{border-radius:10px;box-shadow:0 2px 4px #0003;font-size:11px;height:18px;min-width:18px;padding:2px 6px;position:absolute;right:-2px;top:-6px}.mobile-notification-badge,.notification-badge{align-items:center;background:#dc3545;color:#fff;display:flex;font-weight:700;justify-content:center}.mobile-notification-badge{border-radius:12px;font-size:12px;height:20px;min-width:20px;padding:2px 8px}.app-header .btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.app-header .btn-secondary{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.app-header .btn-secondary:hover{box-shadow:0 4px 16px #10b98166;transform:translateY(-2px)}.mobile-header-container{align-items:center;display:none;gap:12px;justify-content:space-between;width:100%}.mobile-header-left{align-items:center;display:flex;flex:0 0 auto;flex-shrink:0}.mobile-header-center{align-items:center;display:flex;flex:1 1;justify-content:center;min-width:0;padding:0 8px}.mobile-header-right{align-items:center;display:flex;flex:0 0 auto;flex-shrink:0;gap:8px}.header-logo-mobile{border-radius:50%;cursor:pointer;height:40px;object-fit:cover;transition:transform .2s ease;width:40px}.header-logo-mobile:hover{transform:scale(1.05)}.mobile-header-title{color:#fff;cursor:pointer;font-size:clamp(14px,4vw,22.4px);font-weight:700;letter-spacing:.5px;margin:0;overflow:hidden;text-overflow:ellipsis;transition:color .3s ease;white-space:nowrap}.mobile-header-title:hover{color:#e0e0e0}.btn-check-in-mobile{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 2px 6px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:clamp(11px,2.8vw,13px);font-weight:600;height:40px;justify-content:center;padding:10px 12px;transition:all .3s ease;white-space:nowrap}.btn-check-in-mobile:hover{box-shadow:0 3px 10px #10b98166;transform:translateY(-1px)}.btn-check-in-mobile:active{transform:translateY(0)}.hamburger-menu{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:30px;z-index:10}.hamburger-menu span{background:#fff;border-radius:2px;height:3px;transition:all .3s linear;width:30px}.mobile-menu-overlay{background:#00000080;display:none;left:0;z-index:1002}.mobile-menu,.mobile-menu-overlay{bottom:0;position:fixed;right:0;top:0}.mobile-menu{animation:slideIn .3s ease-out;background:#fff;box-shadow:-2px 0 8px #00000026;overflow-y:auto;padding:20px;width:280px}.mobile-menu-item{border-bottom:1px solid #f0f0f0;color:#333;cursor:pointer;display:block;font-size:16px;font-weight:500;padding:16px 12px;transition:all .2s ease}.mobile-menu-item:hover{background:#f5f7fa;color:#0d4d7a}.mobile-menu-item.active{background:#f0f4f8;color:#0d4d7a;font-weight:600}.mobile-submenu{background:#fafafa;padding-left:16px}.mobile-menu-item.submenu-item{border-bottom:1px solid #e5e7eb;font-size:14px;padding:12px}@media (max-width:768px){.app-header{gap:0;padding:14px 16px}.header-left,.header-right,.header-user-info{display:none}.mobile-header-container{display:flex;gap:10px}.mobile-menu-overlay{display:block}.mobile-menu{max-width:300px;width:75%}.hamburger-menu{height:22px;width:28px}.hamburger-menu span{height:2.5px;width:28px}}@media (max-width:480px){.app-header{padding:12px}.mobile-header-container{gap:8px}.mobile-header-center{padding:0 6px}.header-logo-mobile{height:36px;width:36px}.mobile-header-title{font-size:clamp(12px,3.5vw,18px)}.btn-check-in-mobile{font-size:clamp(10px,2.5vw,12px);height:36px;padding:8px 10px}.mobile-header-right{gap:6px}.mobile-menu{width:80%}.mobile-menu-item{font-size:15px;padding:14px 10px}.mobile-menu-item.submenu-item{font-size:13px;padding:10px}}@media (max-width:360px){.app-header{padding:10px 8px}.mobile-header-container{gap:6px}.mobile-header-center{padding:0 4px}.header-logo-mobile{height:32px;width:32px}.mobile-header-title{font-size:clamp(11px,3.5vw,16px)}.btn-check-in-mobile{border-radius:4px;font-size:10px;height:32px;padding:6px 8px}.mobile-header-right{gap:5px}.hamburger-menu{height:20px;width:24px}.hamburger-menu span{height:2px;width:24px}.mobile-menu{width:85%}}.admin-panel-container{background-color:#f5f7fa;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px;width:100%}.loading{min-height:100vh}.admin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.admin-title{color:#333}.admin-content{display:flex;flex-direction:column;gap:24px}.admin-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.admin-section h2{color:#333;font-size:24px;margin:0 0 16px}.admin-section p{color:#666;font-size:15px;margin:0 0 24px}.admin-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.admin-card{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:24px;transition:all .3s ease}.admin-card:hover{border-color:#667eea;box-shadow:0 4px 12px #0000001a}.card-icon{margin-bottom:16px}.admin-card h3{color:#333;font-size:20px;margin:0 0 8px}.admin-card p{color:#666;font-size:14px;margin:0 0 16px}.admin-card .btn{width:100%}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-item{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:10px;padding:20px;text-align:center}.stat-label{color:#666;font-size:14px;margin-bottom:8px}.stat-value{color:#333}.status-badge{border-radius:20px;font-size:14px;padding:6px 14px}.status-active{background-color:#d4edda;color:#28a745}.btn-secondary{background:linear-gradient(135deg,#10b981,#059669)}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 12px #10b98166}.btn-secondary:disabled{background:#adb5bd;cursor:not-allowed;opacity:.5;transform:none}.sync-progress-container{margin-top:15px;width:100%}.progress-bar-wrapper{background-color:#e0e0e0;border-radius:12px;height:24px;margin-bottom:8px;overflow:hidden;width:100%}.progress-bar-fill{align-items:center;background:linear-gradient(90deg,#667eea,#764ba2);color:#fff;display:flex;font-size:12px;font-weight:600;justify-content:flex-end;padding-right:8px}.progress-text{color:#333;font-size:14px;font-weight:500;margin-bottom:4px}.progress-details{color:#666;font-size:12px}.sync-message{margin-top:12px;padding:12px 16px;text-align:center}.sync-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.sync-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.sync-message.info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.sync-message.warning{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404;white-space:pre-line}@media (max-width:768px){.admin-header{align-items:flex-start;flex-direction:column;gap:12px}.admin-title{font-size:28px;text-align:left}.header-spacer{display:none}.admin-cards,.stats-grid{grid-template-columns:1fr}}.administration-container{background-color:#f5f6f8;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px;width:100%}.admin-header-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.admin-title{color:#1a5f7a;flex:1 1;font-size:32px;font-weight:600;margin:0;text-align:center}.message{animation:slideDown .3s ease-out;padding:14px 18px}.admin-tabs-container{align-items:flex-end;border-bottom:2px solid #e0e0e0;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px;padding-bottom:12px}.admin-tabs{display:flex;gap:8px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease}.tab:hover{background-color:#f9f9f9;color:#667eea}.tab.active{border-bottom-color:#1a5f7a;color:#1a5f7a}.admin-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.empty-state p{font-size:16px;margin:0}.users-table-container{overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead th{border-bottom:2px solid #e0e0e0;color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px;text-align:left;text-transform:uppercase}.users-table tbody td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:16px 12px}.users-table tbody tr:hover{background-color:#f9f9f9}.users-table tbody tr.disabled-row{background-color:#f5f5f5;opacity:.5}.user-name{font-weight:600}.date-cell{color:#666;font-size:13px}.role-select{background-color:#fff;border:2px solid;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s ease}.role-select:hover{opacity:.8}.status-badge.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.status-badge.disabled{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.action-buttons{gap:8px}.action-buttons .btn{min-width:80px;text-align:center}.btn-icon{background:none;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:16px;padding:6px 10px;transition:all .2s ease}.btn-icon:hover:not(:disabled){background-color:#f0f0f0;border-color:#999}.btn-icon.delete:hover:not(:disabled){background-color:#fee;border-color:#c33}.btn-icon:disabled{background-color:#f9f9f9;cursor:not-allowed;opacity:.3}.invitations-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.invitation-card{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:20px;transition:all .3s ease}.invitation-card:hover{border-color:#667eea;box-shadow:0 4px 12px #0000001a}.invitation-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.invitation-name{color:#333;font-size:18px;font-weight:700}.expiry-badge{background-color:#fff3cd;border-radius:12px;color:#856404;font-size:12px;font-weight:600;padding:4px 10px}.invitation-details{margin-bottom:16px}.detail-row{display:flex;font-size:14px;justify-content:space-between;margin-bottom:8px}.detail-label{color:#666;font-weight:600}.detail-value{color:#333;text-align:right}.invitation-actions{display:flex;gap:8px}.roles-section h2{color:#333;font-size:24px;font-weight:700;margin:0 0 24px}.roles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.role-card{border:3px solid;border-radius:12px;overflow:hidden;transition:all .3s ease}.role-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.role-header{color:#fff;padding:20px;text-align:center}.role-header h3{font-size:20px;font-weight:700;margin:0}.role-body{background:#fff;padding:20px}.role-description{color:#666;font-size:14px;line-height:1.6;margin:0 0 16px}.role-permissions{margin-top:16px}.role-permissions strong{color:#333;display:block;font-size:14px;margin-bottom:8px}.role-permissions ul{margin:0;padding-left:20px}.role-permissions li{color:#666;font-size:13px;margin-bottom:6px}.administration-container .btn-primary,.invite-modal .btn-primary{background:#1a5f7a!important;color:#fff}.administration-container .btn-primary:hover:not(:disabled),.invite-modal .btn-primary:hover:not(:disabled){background:#0f4d63!important;box-shadow:0 4px 12px #1a5f7a66;transform:translateY(-2px)}.administration-container .btn-primary:disabled,.invite-modal .btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#0fa77d}.btn-secondary:hover:not(:disabled){background:#0d8a6a;box-shadow:0 4px 12px #0fa77d66}.btn-invite{background:#1a5f7a;color:#fff}.btn-invite:hover:not(:disabled){background:#0f4d63;box-shadow:0 4px 12px #1a5f7a66;transform:translateY(-2px)}.btn-outline{background-color:#fff}.btn-outline:hover:not(:disabled){background-color:#1a5f7a;color:#fff}.btn-sm{padding:6px 14px}.modal-overlay{padding:20px}.modal-content{border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;width:100%}.modal-header{background:linear-gradient(135deg,#0d4d7a,#0a3a5e);border-bottom:2px solid #e0e0e0;border-radius:12px 12px 0 0;flex-shrink:0;padding:24px}.modal-header h2{color:#fff;font-size:24px;font-weight:700}.modal-close{color:#fffc;font-size:32px;transition:color .2s ease}.modal-close:hover{color:#fff}.invite-form{flex:1 1;overflow-y:auto;padding:24px}.form-row{grid-gap:16px;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group textarea{min-height:80px;resize:vertical}.modal-actions{border-top:2px solid #e0e0e0;justify-content:center}.modal-actions .btn{min-width:150px}.loading{font-size:18px}@media (max-width:1024px){.admin-header{align-items:stretch;flex-direction:column}.admin-header .btn{width:100%}.users-table{font-size:13px}.users-table tbody td,.users-table thead th{padding:10px 8px}}@media (max-width:768px){.administration-container{padding:15px}.admin-header-nav{align-items:flex-start;flex-direction:column;gap:12px}.admin-title{font-size:24px;text-align:left}.header-spacer{display:none}.admin-tabs-container{align-items:stretch;flex-direction:column;gap:12px}.admin-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab{padding:10px 16px;white-space:nowrap}.admin-tabs-container .btn-invite{width:100%}.form-row,.invitations-grid,.roles-grid{grid-template-columns:1fr}.users-table-container{margin:0 -24px;padding:0 24px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.invite-acceptance-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.invite-card{animation:slideIn .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;padding:40px;width:100%}.invite-header{margin-bottom:32px;text-align:center}.invite-header h1{color:#333;font-size:28px;font-weight:700;margin:0 0 12px}.invite-subtitle{color:#666;font-size:16px;margin:0}.invite-subtitle strong{color:#667eea;font-weight:600}.invite-info{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;margin-bottom:32px;padding:24px}.info-row{display:flex;justify-content:space-between;margin-bottom:12px}.info-row:last-child{margin-bottom:0}.info-label{color:#666}.info-value{color:#333;font-weight:500}.custom-message{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.message-label{color:#666;font-size:14px;font-weight:600;margin:0 0 8px}.message-text{background:#fff;border-left:4px solid #667eea;border-radius:8px;color:#333;font-size:15px;font-style:italic;margin:0;padding:12px}.invite-form{margin-bottom:24px}.invite-form h2{color:#333;font-size:20px;font-weight:600;margin:0 0 24px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;margin-bottom:8px}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{padding-right:48px}.password-toggle{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;position:absolute;right:12px;transition:opacity .2s ease}.password-toggle:hover{opacity:.7}.help-text{color:#666;display:block;font-size:13px;font-style:italic;margin-top:6px}.btn{font-size:15px;padding:12px 24px;text-decoration:none}.btn-primary{background:#1a5f7a}.btn-primary:hover:not(:disabled){background:#0f4d63;box-shadow:0 4px 12px #1a5f7a66}.btn-large{font-size:16px;padding:14px 24px;width:100%}.error-message,.success-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:20px;padding:14px 18px}.success-message{background-color:#e8f5e9;border-left:4px solid #4caf50;color:#2e7d32}.loading-spinner{margin:0 auto 20px}.invite-card p{color:#666;margin:0}.error-card,.invite-card p{text-align:center}.error-icon{font-size:64px;margin-bottom:20px}.error-card h1{color:#c33;font-size:24px;font-weight:700;margin:0 0 16px}.error-text{color:#666;font-size:15px;line-height:1.6;margin:0 0 24px}.success-card{text-align:center}.success-icon{align-items:center;animation:scaleIn .4s ease-out;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;color:#fff;display:flex;font-size:48px;height:80px;justify-content:center;margin:0 auto 24px;width:80px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-card h1{color:#10b981;font-size:26px;font-weight:700;margin:0 0 16px}.success-text{color:#333;font-size:16px;font-weight:500;margin:0 0 16px}.info-text{color:#666;font-size:14px;line-height:1.6;margin:0 0 16px}.redirect-text{color:#999;font-size:14px;font-style:italic;margin:0}.invite-footer{border-top:2px solid #e0e0e0;padding-top:24px;text-align:center}.invite-footer p{color:#666;font-size:14px;margin:0}.link{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s ease}.link:hover{color:#5568d3;text-decoration:underline}@media (max-width:768px){.invite-card{padding:30px 20px}.invite-header h1{font-size:24px}.invite-subtitle{font-size:15px}.info-row{flex-direction:column;gap:4px}.info-label{font-size:13px}.info-value{font-size:15px}}.reports-container{background-color:#f8f9fa;min-height:100vh;padding:32px 40px}.reports-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 24px;max-width:1400px}.reports-title{color:#333;flex:1 1;font-size:32px;font-weight:700;margin:0;text-align:center}.reports-content{margin:0 auto;max-width:1400px}.report-controls{grid-gap:16px;align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:grid;gap:16px;grid-template-columns:1fr 1fr auto;margin-bottom:20px;padding:20px}.button-group{align-items:center;display:flex;gap:12px}.button-group .btn{min-width:140px;white-space:nowrap}.search-wrapper{position:relative}.guest-search-input,.timeframe-select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px;padding:10px 14px;transition:border-color .3s ease;width:100%}.guest-search-input:focus,.timeframe-select:focus{border-color:#1a5f7a;outline:none}.search-dropdown{background:#fff;border:2px solid #e0e0e0;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 12px #0000001a;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.dropdown-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:12px;transition:background-color .2s ease}.dropdown-item:hover{background-color:#f5f7fa}.dropdown-guest-image img{border-radius:50%;height:40px;object-fit:cover;width:40px}.dropdown-guest-avatar{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;letter-spacing:.5px;line-height:1;text-transform:uppercase;width:40px}.dropdown-guest-name{color:#333;font-size:14px;font-weight:500}.summary-header{align-items:center;border-bottom:2px solid #f0f0f0;display:grid;grid-template-columns:1fr auto;margin-bottom:20px;padding-bottom:12px;position:relative}.summary-header h2{color:#333;font-size:20px;font-weight:700;margin:0}.summary-stats{background:#fff;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:20px}.summary-item{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:6px;padding:14px}.summary-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.summary-value{color:#333;font-size:16px;font-weight:700}.summary-value.highlight{color:#1a5f7a;font-size:24px}.report-data{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px}.mobile-status-badge{display:none}.report-data h3{color:#333;font-size:18px;font-weight:700;margin:0 0 20px}.no-data{color:#666;font-size:15px;padding:40px 20px;text-align:center}.guest-cards-container{display:flex;flex-direction:column;gap:24px}.guest-activity-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 4px 6px -1px #0000001a;margin-bottom:8px;overflow:hidden}.guest-card-header{background:#fafafa;border-bottom:1px solid #e5e7eb;padding:24px}.guest-profile-row{align-items:flex-start;display:flex;gap:20px}.guest-avatar-section{flex-shrink:0}.guest-card-image{object-fit:cover}.guest-card-avatar,.guest-card-image{border-radius:50%;height:70px;width:70px}.guest-card-avatar{align-items:center;background:#667eea;color:#fff;display:flex;font-size:24px;font-weight:600;justify-content:center;letter-spacing:.5px;line-height:1;text-transform:uppercase}.guest-details-section{display:flex;flex:0 0 250px;flex-direction:column;gap:8px}.guest-card-name{color:#1a1a1a;font-size:20px;font-weight:700;margin:0}.guest-contact-row{display:flex;flex-direction:column;gap:6px}.contact-item{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:6px}.guest-stats-row{grid-gap:12px;align-items:start;display:grid;flex:1 1;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stat-box{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:12px;text-align:center}.stat-box-label{color:#6b7280;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-box-value{color:#1a1a1a;font-size:14px;font-weight:600}.stat-box-value.highlight{color:#3b82f6;font-size:18px;font-weight:700}.visits-section{padding:20px 24px}.visits-data-table{border-collapse:collapse;table-layout:fixed;width:100%}.visits-data-table thead{background:#f8fafc}.visits-data-table th{border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:11px;font-weight:700;letter-spacing:.5px;padding:12px 14px;text-align:left;text-transform:uppercase;vertical-align:top}.visits-data-table th:first-child{width:25%}.visits-data-table th:nth-child(2){width:15%}.visits-data-table th:nth-child(3){width:25%}.visits-data-table th:nth-child(4){width:15%}.visits-data-table th:nth-child(5){width:20%}.visits-data-table td{border-bottom:1px solid #e5e7eb;color:#1a1a1a;font-size:13px;padding:12px 14px;vertical-align:top}.visits-data-table tbody tr{transition:background .2s ease}.visits-data-table tbody tr:hover{background:#f8fafc}.duration-cell{color:#1a5f7a;font-weight:600;vertical-align:top}.service-tag{background:#3b82f6;border-radius:6px;color:#fff;font-size:12px;font-weight:600}.service-tag,.status-badge{align-items:center;display:inline-flex;line-height:1;padding:5px 12px}.status-badge.checked_out{background:#10b981;color:#fff}.status-badge.checked_in{background:#f59e0b;color:#fff}.btn-secondary{background:linear-gradient(135deg,#0fa77d,#0d8a6a);box-shadow:0 2px 8px #0fa77d4d}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 16px #0fa77d66;transform:translateY(-2px)}@media (max-width:768px){.reports-container{padding:15px}.reports-header{align-items:flex-start;flex-direction:column;gap:12px}.reports-title{font-size:24px;text-align:left}.header-spacer{display:none}.report-controls{align-items:stretch;flex-direction:column;padding:16px}.control-group{min-width:100%}.btn{width:100%}.summary-header{align-items:center;display:flex;flex-direction:column;gap:12px;text-align:center}.summary-header h2{width:100%}.export-buttons{justify-content:center;width:100%}.summary-stats{grid-template-columns:1fr}.guest-activity-card{margin-bottom:24px}.guest-card-header{display:flex;flex-direction:column;gap:12px;padding:16px}.mobile-status-badge{display:flex;justify-content:flex-end;width:100%}.guest-profile-row{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:90px 1fr;grid-template-rows:auto auto}.guest-avatar-section{grid-column:1;grid-row:1/3}.guest-card-avatar,.guest-card-image{height:90px;width:90px}.guest-details-section{flex:0 0 auto;grid-column:2;grid-row:1}.guest-card-name{font-size:18px;margin-bottom:8px}.guest-contact-row{display:flex;flex-direction:column;gap:4px}.contact-item{font-size:12px}.guest-stats-row{display:flex;flex-wrap:wrap;gap:8px;grid-column:1/-1;grid-row:2;margin-top:12px}.stat-box{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1;min-width:120px}.stat-box-label{font-size:9px}.stat-box-value{font-size:10px}.stat-box-value.highlight{font-size:12px}.visits-section{overflow-x:visible;padding:16px}.visits-mobile-grid{display:flex;flex-direction:column;gap:16px}.visit-card-mobile{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.visit-grid-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:65% 35%;margin-bottom:12px}.visit-grid-row:last-child{margin-bottom:0}.visit-grid-cell{display:flex;flex-direction:column;gap:6px;overflow:hidden}.visit-cell-label{color:#6b7280;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.visit-cell-value{word-wrap:break-word;color:#1a1a1a;font-size:11px;font-weight:500}.visit-cell-value.duration-cell{color:#1a5f7a;font-weight:600}}.timeline-report-container{background-color:#f5f7fa;min-height:100vh;padding:20px}.timeline-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 24px;max-width:1400px}.timeline-title{color:#333;flex:1 1;font-size:32px;font-weight:700;margin:0;text-align:center}.header-spacer{flex-shrink:0;width:160px}.timeline-content{margin:0 auto;max-width:1400px}.timeline-controls{grid-gap:16px;align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:grid;gap:16px;grid-template-columns:1fr 1fr auto;margin-bottom:20px;padding:20px}.control-group{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:250px}.control-group label{color:#333;font-size:13px;font-weight:600}.service-select,.timeframe-select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px;padding:10px 14px;transition:border-color .3s ease;width:100%}.service-select:focus,.timeframe-select:focus{border-color:#1a5f7a;outline:none}.chart-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px}.chart-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.chart-header h2{color:#333;font-size:20px;font-weight:700;margin:0}.export-buttons{align-items:center;display:flex;gap:12px}.chart-info{grid-gap:15px;background:#f8fafc;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;padding:15px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item.stat-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px}.info-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#1a5f7a;font-size:18px;font-weight:700}.info-value.green{color:#10b981}.info-value.crimson{color:#dc2626}.chart-legend-custom{border-top:1px solid #e5e7eb;display:flex;gap:40px;justify-content:center;margin-top:20px;padding-top:15px}.legend-item{align-items:center;color:#333;display:flex;font-size:14px;font-weight:600;gap:10px}.legend-line{border-radius:2px;height:3px;width:40px}.legend-line.green{background:#10b981}.legend-line.crimson{background:#dc2626}.summary-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;gap:10px;padding:20px}.stat-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-value{font-size:28px}.stat-value.green{color:#10b981}.stat-value.crimson{color:#dc2626}.btn-primary{background:linear-gradient(135deg,#1a5f7a,#0a3a5e);box-shadow:0 2px 8px #1a5f7a4d}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #1a5f7a66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-export{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.btn-export:hover:not(:disabled){box-shadow:0 4px 16px #10b98166;transform:translateY(-2px)}.btn-pdf{background:linear-gradient(135deg,#dc2626,#991b1b);box-shadow:0 2px 8px #dc26264d;color:#fff}.btn-pdf:hover:not(:disabled){box-shadow:0 4px 16px #dc262666;transform:translateY(-2px)}.message{border-radius:8px;font-size:13px;font-weight:500;margin-bottom:16px;margin-left:auto;margin-right:auto;max-width:1400px;padding:12px 16px}.error-message{background-color:#fee;border-left:4px solid #c33;color:#c33}.loading{align-items:center;color:#666;display:flex;font-size:16px;justify-content:center;min-height:60vh}@media (max-width:768px){.timeline-report-container{padding:15px}.timeline-header{align-items:flex-start;flex-direction:column;gap:12px}.timeline-title{font-size:24px;text-align:left}.header-spacer{display:none}.timeline-controls{grid-template-columns:1fr;padding:16px}.control-group{min-width:100%}.btn{width:100%}.chart-info{flex-direction:column;gap:12px}.summary-stats{grid-template-columns:1fr}.chart-legend-custom{gap:15px}.chart-header,.chart-legend-custom{align-items:center;flex-direction:column}.chart-header{display:flex;gap:16px;padding-bottom:16px;text-align:center}.chart-header h2{width:100%}.export-buttons{justify-content:center;width:100%}.recharts-legend-wrapper{display:none!important}}.data-completeness-container{background-color:#f9fafb;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.data-completeness-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.data-completeness-header h1{color:#1a5f7a;font-size:28px;font-weight:600;margin:0}.btn-back,.btn-refresh{border:none;cursor:pointer;font-size:14px;transition:all .3s ease}.btn-refresh{background-color:#1a5f7a;border-radius:8px;color:#fff;font-weight:500;padding:10px 20px}.btn-refresh:hover{background-color:#144d61}.view-toggle{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:10px;margin-bottom:30px;padding:5px;width:-webkit-fit-content;width:fit-content}.toggle-btn{background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .3s ease}.toggle-btn.active{background:linear-gradient(135deg,#1a5f7a,#2d8ba8);box-shadow:0 4px 12px #1a5f7a4d;color:#fff}.toggle-btn:hover:not(.active){background-color:#f3f4f6}.summary-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.summary-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:16px;padding:24px;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{box-shadow:0 8px 16px #0000001f;transform:translateY(-4px)}.card-icon{font-size:48px;line-height:1}.card-content h3{color:#6b7280;font-size:14px;font-weight:500;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.card-value{color:#1a5f7a;font-size:32px;font-weight:700;margin:0}.category-section{margin-bottom:30px}.category-section h2{color:#1a5f7a;font-size:24px;font-weight:600;margin-bottom:20px}.category-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.category-card{background:#fff;border-left:4px solid #6b7280;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px;transition:transform .3s ease,box-shadow .3s ease}.category-card:hover{box-shadow:0 8px 16px #0000001f;transform:translateY(-4px)}.category-card h3{color:#374151;font-size:16px;font-weight:600;margin:0 0 12px}.category-percentage{color:#1a5f7a;font-size:36px;font-weight:700;margin-bottom:8px}.category-desc{color:#6b7280;font-size:14px;margin:0}.chart-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:30px;padding:24px}.chart-section h2{color:#1a5f7a;font-size:24px;font-weight:600;margin:0 0 20px}.custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:12px}.tooltip-label{color:#374151;font-weight:600;margin:0 0 4px}.tooltip-value{color:#6b7280;margin:0}.table-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:30px;padding:24px}.table-section h2{color:#1a5f7a;font-size:24px;font-weight:600;margin:0 0 20px}.data-table{border-collapse:collapse;font-size:14px;width:100%}.data-table thead{background:#f9fafb}.data-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #f3f4f6;color:#6b7280;padding:12px}.data-table tbody tr:hover{background-color:#f9fafb}.field-name{color:#374151;font-weight:500}.category-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px;text-transform:capitalize}.incomplete-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.section-header{margin-bottom:20px}.section-header h2{color:#1a5f7a;font-size:24px;font-weight:600}.profile-name{color:#374151;font-weight:600}.completeness-indicator{display:flex;flex-direction:column;gap:8px}.completeness-indicator span{font-size:16px;font-weight:600}.missing-fields{max-width:300px}.missing-list{display:flex;flex-wrap:wrap;gap:6px}.missing-badge{background-color:#fef3c7;color:#92400e;padding:4px 8px}.status-badges{display:flex;flex-direction:column;gap:6px}.status-badge{border-radius:6px;font-size:12px;font-weight:500;padding:4px 8px}@media (max-width:768px){.data-completeness-container{padding:10px}.data-completeness-header{flex-direction:column;gap:15px;text-align:center}.data-completeness-header h1{font-size:24px}.category-grid,.summary-grid{grid-template-columns:1fr}.view-toggle{width:100%}.toggle-btn{flex:1 1;font-size:13px;padding:10px}.section-header{align-items:flex-start;flex-direction:column;gap:15px}.data-table{font-size:12px}.data-table td,.data-table th{padding:8px}.card-value{font-size:24px}.category-percentage{font-size:28px}}.guest-profiles-container{background-color:#f9fafb;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.guest-profiles-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:10px 0}.guest-profiles-header h1{color:#1a5f7a;flex:1 1;font-size:28px;font-weight:600;margin:0;text-align:center}.header-spacer{min-width:-webkit-fit-content;min-width:fit-content;width:200px}.sync-message{animation:slideDown .3s ease-out;font-size:14px;font-weight:500;line-height:1.6;margin-bottom:16px;padding:14px 18px;white-space:pre-line}.controls-bar{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;flex-wrap:nowrap;gap:16px;margin-bottom:20px;padding:16px 20px}.controls-bar,.search-box{align-items:stretch;display:flex}.search-box{flex:1 1;min-width:250px}.search-input{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:14px;height:42px;padding:10px 14px;transition:border-color .3s ease;width:100%}.search-input:focus{border-color:#1a5f7a;outline:none}.filter-select{background:#fff;border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;cursor:pointer;font-size:14px;height:42px;min-width:180px;padding:10px 14px;transition:border-color .3s ease;white-space:nowrap}.filter-select:focus{border-color:#1a5f7a;outline:none}.stats-group{background:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;gap:12px;height:42px;padding:10px 16px;white-space:nowrap}.stat-item,.stats-group{align-items:center;display:flex}.stat-item{gap:6px}.stat-label{color:#6b7280;font-size:13px;font-weight:500}.stat-value{color:#1a5f7a;font-size:14px;font-weight:700}.stat-divider{color:#d1d5db;font-size:14px;margin:0 4px}.profiles-table-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.profiles-table{border-collapse:collapse;font-size:14px;width:100%}.profiles-table thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.profiles-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px 12px;text-align:left;text-transform:uppercase}.profiles-table td{border-bottom:1px solid #f3f4f6;color:#6b7280;padding:16px 12px;vertical-align:middle}.profiles-table tbody .guest-row{cursor:pointer;transition:background-color .2s ease}.profiles-table tbody .guest-row:hover{background-color:#f9fafb}.profiles-table tbody .guest-row.expanded{background-color:#f0f9ff}.guest-name{color:#374151;font-weight:600}.name-cell{gap:12px}.guest-avatar,.name-cell{align-items:center;display:flex}.guest-avatar{background-color:#e5e7eb;border-radius:50%;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;width:40px}.guest-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;font-size:14px;font-weight:600;height:100%;justify-content:center;text-transform:uppercase;width:100%}.name-text{font-size:15px}.contact-info{font-size:13px;gap:4px}.completeness-cell,.contact-info{display:flex;flex-direction:column}.completeness-cell{gap:8px;min-width:120px}.completeness-percentage{font-size:16px;font-weight:600}.progress-bar-container{background-color:#e5e7eb;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-bar-fill{border-radius:4px;height:100%;transition:width .3s ease}.status-cell{display:flex;flex-direction:column;gap:6px}.status-badge{letter-spacing:.5px;padding:4px 10px;width:-webkit-fit-content;width:fit-content}.status-badge.critical{background-color:#fee2e2;color:#991b1b}.status-badge.emergency{background-color:#fef3c7;color:#92400e}.status-badge.complete{background-color:#d1fae5;color:#065f46}.actions-column{text-align:center;width:120px}.action-buttons{align-items:center;display:flex;gap:4px;justify-content:center}.btn-add-note,.btn-delete,.btn-edit{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:inline-flex;font-size:18px;justify-content:center;padding:8px;transition:all .3s ease}.btn-add-note:hover{background-color:#e0f2fe;transform:scale(1.1)}.btn-edit:hover{background-color:#fef3c7;transform:scale(1.1)}.btn-delete:hover{background-color:#fee2e2;transform:scale(1.1)}.expand-column{text-align:center;width:50px}.expand-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:16px;padding:8px;transform:rotate(0deg);transition:all .3s ease}.expand-btn:hover{background-color:#f3f4f6;border-radius:4px;color:#1a5f7a}.expand-btn.expanded{color:#1a5f7a;transform:rotate(180deg)}.details-row{background-color:#f0f9ff;border-top:2px solid #bfdbfe}.details-row td{border-bottom:2px solid #e5e7eb;padding:0}.details-content{animation:slideDown .3s ease;padding:24px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:20px}.detail-section h4{border-bottom:2px solid #bfdbfe;color:#1a5f7a;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;text-transform:uppercase}.detail-fields{display:flex;flex-direction:column;gap:8px}.field-missing,.field-present{align-items:center;border-radius:6px;display:flex;font-size:13px;gap:8px;padding:8px 12px}.field-present{background-color:#d1fae5}.field-missing{background-color:#fee2e2}.field-icon{font-size:14px;font-weight:700}.field-present .field-icon{color:#065f46}.field-missing .field-icon{color:#991b1b}.field-label-prefix{color:#065f46;font-weight:600;margin-right:6px}.field-value{color:#065f46;font-weight:500}.field-label{color:#991b1b;font-weight:600;margin-right:6px}.field-missing-text{color:#991b1b;font-style:italic;font-weight:500}.missing-summary{background-color:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;margin-top:20px;padding:16px}.missing-summary h4{color:#92400e;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.missing-badges{display:flex;flex-wrap:wrap;gap:8px}.missing-badge{background-color:#fbbf24;border-radius:6px;color:#78350f;display:inline-block;font-size:12px;font-weight:500;padding:6px 12px}.btn{align-items:center;border-radius:8px;box-sizing:border-box;display:inline-flex;font-weight:500;height:42px;justify-content:center;transition:all .3s ease;white-space:nowrap;width:-webkit-fit-content;width:fit-content}.btn-primary{background:linear-gradient(135deg,#1a5f7a,#2d8ba8)}.btn-primary:hover{background:linear-gradient(135deg,#144d61,#236e87);box-shadow:0 4px 12px #1a5f7a4d}.btn-secondary{background:#f3f4f6;border:2px solid #d1d5db;color:#374151}.btn-secondary:hover{background:#e5e7eb;border-color:#9ca3af}.btn-outline{background:#fff;border:2px solid #1a5f7a;color:#1a5f7a}.btn-outline:hover{background:#f0f4f8}.filter-badge{background:#fff;border-radius:10px;color:#1a5f7a;font-size:11px;font-weight:700;min-width:18px;padding:2px 6px}.error-message,.loading-message{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:20px;padding:40px;text-align:center}.loading-message{font-size:16px}.error-message h3{color:#ef4444;margin-bottom:10px}.error-message p{color:#6b7280;margin-bottom:20px}.empty-state{color:#6b7280;font-size:16px;padding:60px 20px}.pagination-container{align-items:center;background:linear-gradient(180deg,#fff 0,#f9fafb);border-top:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:20px 24px}.pagination-container.top{background:linear-gradient(180deg,#f9fafb 0,#fff);border-bottom:1px solid #e5e7eb;border-top:none}.pagination-info{align-items:center;color:#4b5563;display:flex;font-size:14px;font-weight:600;gap:8px}.pagination-info:before{content:"📄";font-size:16px}.pagination-controls{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;gap:6px;padding:6px}.pagination-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:14px;font-weight:600;height:38px;justify-content:center;min-width:38px;padding:8px 14px;transition:all .2s ease}.pagination-btn:hover:not(:disabled):not(.active){background-color:#f3f4f6;color:#1a5f7a;transform:translateY(-1px)}.pagination-btn.active{background:linear-gradient(135deg,#1a5f7a,#2d8ba8);box-shadow:0 4px 12px #1a5f7a4d;color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-ellipsis{color:#9ca3af;font-size:16px;font-weight:700;padding:0 8px}@media (max-width:1024px){.details-grid{gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width:768px){.guest-profiles-container{padding:10px}.guest-profiles-header{align-items:center;flex-direction:row;gap:8px;justify-content:space-between}.guest-profiles-header h1{flex:1 1;font-size:clamp(18px,4.5vw,24px);min-width:0;text-align:left}.btn-back{font-size:clamp(12px,3vw,14px);padding:6px 0;white-space:nowrap}.header-spacer{display:none}.controls-bar{align-items:stretch;flex-direction:column;flex-wrap:wrap}.search-box{min-width:100%}.btn,.filter-select{width:100%}.stats-group{justify-content:center;margin-left:0}.profiles-table{font-size:12px}.profiles-table td,.profiles-table th{padding:10px 8px}.details-grid{grid-template-columns:1fr}.details-content{padding:16px}.profiles-table td:nth-child(2),.profiles-table td:nth-child(3),.profiles-table th:nth-child(2),.profiles-table th:nth-child(3){display:none}.pagination-container{align-items:center;flex-direction:column}.pagination-controls{flex-wrap:wrap;justify-content:center}}@media (max-width:480px){.guest-profiles-header h1{font-size:clamp(16px,4.5vw,20px)}.btn-back{font-size:12px;padding:4px 0}.completeness-cell{min-width:80px}.completeness-percentage{font-size:14px}.status-badge{font-size:10px;padding:3px 8px}}.notes-history-section{border-top:2px solid #e5e7eb;margin-top:30px;padding-top:30px}.notes-history-section h4{color:#1a5f7a;font-size:18px;font-weight:600;margin:0 0 20px}.notes-timeline{display:flex;flex-direction:column;gap:16px}.note-entry{background:#f9fafb;border-left:4px solid #1a5f7a;border-radius:8px;padding:16px;transition:all .2s ease}.note-entry:hover{background:#f3f4f6;box-shadow:0 2px 8px #00000014}.note-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:12px}.note-author{align-items:center;display:flex;gap:12px}.note-author-avatar{align-items:center;background:linear-gradient(135deg,#1a5f7a,#0f4d63);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.note-author-info{display:flex;flex-direction:column;gap:2px}.note-author-name{color:#1f2937;font-size:14px;font-weight:600}.note-service-type{color:#6b7280;font-size:12px}.note-timestamp{color:#6b7280;font-size:13px;white-space:nowrap}.note-content{word-wrap:break-word;color:#374151;font-size:14px;line-height:1.6;padding-left:52px;white-space:pre-wrap}.notes-column{text-align:center;width:80px}.notes-cell{align-items:center;display:flex;gap:4px;justify-content:center;transition:transform .2s ease}.notes-cell:hover{transform:scale(1.1)}.notes-bell{font-size:16px}.notes-count{color:#dc3545;font-size:14px;font-weight:700}.note-entry-compact{align-items:center;background:#f9fafb;border-left:3px solid #1a5f7a;border-radius:4px;display:flex;font-size:13px;gap:8px;line-height:1.4;margin-bottom:8px;padding:8px 12px}.note-entry-compact:hover{background:#f3f4f6}.note-author-avatar-compact{align-items:center;background:linear-gradient(135deg,#1a5f7a,#0f4d63);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.note-author-name-compact{color:#1f2937;flex-shrink:0;font-weight:600;white-space:nowrap}.note-content-compact{color:#374151;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-timestamp-compact{color:#6b7280;flex-shrink:0;font-size:12px;white-space:nowrap}.note-separator{color:#d1d5db;font-weight:400}@media (max-width:768px){.notes-history-section{margin-top:20px;padding-top:20px}.note-header{align-items:flex-start;flex-direction:column}.note-timestamp{padding-left:52px}.note-content{margin-top:8px;padding-left:0}}@media (max-width:480px){.notes-history-section h4{font-size:16px}.note-author-avatar{font-size:14px;height:36px;width:36px}.note-author-name{font-size:13px}.note-service-type{font-size:11px}.note-timestamp{font-size:12px}.note-content{font-size:13px}}.data-sync-container{margin:0 auto;max-width:1200px;padding:20px}.data-sync-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.data-sync-header h1{color:#1f2937;font-size:28px;margin:0}.btn-back{align-items:center;background:#0000;border:none;color:#333;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:14px;font-weight:600;gap:4px;padding:8px 0;transition:color .3s ease}.btn-back:hover{color:#0d4d7a}.header-spacer{width:120px}.sync-controls-card,.sync-info-card,.sync-status-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:24px}.sync-controls-card h2,.sync-info-card h2,.sync-status-card h2{color:#1f2937;font-size:20px;margin:0 0 20px}.loading-message{color:#6b7280;padding:20px;text-align:center}.sync-info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.sync-info-item{background-color:#f9fafb;border-radius:8px;display:flex;flex-direction:column;padding:12px}.sync-info-label{color:#6b7280;font-size:12px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.sync-info-value{color:#1f2937;font-size:20px;font-weight:600}.scheduled-sync-info{background-color:#eff6ff;border-left:4px solid #3b82f6;border-radius:6px;padding:16px}.scheduled-sync-info p{color:#1e40af;margin:0 0 8px}.scheduled-sync-info p:last-child{margin-bottom:0}.sync-description{color:#1e40af!important;font-size:14px;opacity:.9}.sync-message{border-radius:8px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin-bottom:24px;padding:16px;white-space:pre-wrap}.sync-message.success{background-color:#d1fae5;border-left:4px solid #10b981;color:#065f46}.sync-message.error{background-color:#fee2e2;border-left:4px solid #ef4444;color:#991b1b}.sync-message.warning{background-color:#fef3c7;border-left:4px solid #f59e0b;color:#92400e}.sync-message pre{word-wrap:break-word;font-family:inherit;margin:0;white-space:pre-wrap}.sync-controls-description{color:#6b7280;font-size:14px;line-height:1.6;margin-bottom:20px}.sync-buttons{display:flex;flex-wrap:wrap;gap:12px}.btn-force-resync,.btn-sync-now{border-radius:8px;font-size:16px;font-weight:600;padding:12px 32px}.btn-primary{background-color:#3b82f6}.btn-primary:hover:not(:disabled){background-color:#2563eb;box-shadow:0 4px 6px #3b82f64d;transform:translateY(-1px)}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background-color:#d97706;box-shadow:0 4px 6px #f59e0b4d;transform:translateY(-1px)}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563;box-shadow:0 4px 6px #6b72804d;transform:translateY(-1px)}.sync-progress-message{align-items:center;background-color:#eff6ff;border-radius:8px;color:#1e40af;display:flex;gap:12px;margin-top:16px;padding:12px}.spinner{border:3px solid #bfdbfe;border-top-color:#3b82f6;height:20px;width:20px}.sync-explanation{display:flex;flex-direction:column;gap:20px}.sync-step{align-items:flex-start;display:flex;gap:16px}.step-number{align-items:center;background-color:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:40px;justify-content:center;width:40px}.step-content h3{color:#1f2937;font-size:16px;margin:0 0 8px}.step-content p{color:#6b7280;font-size:14px;line-height:1.6;margin:0}@media (max-width:768px){.data-sync-header{align-items:flex-start;flex-direction:column;gap:12px}.header-spacer{display:none}.sync-info-grid{grid-template-columns:1fr}.data-sync-container{padding:12px}}.guest-activity-reports{padding:15px 20px}.guest-activity-reports,.page-container{margin:0 auto;max-width:1200px}.page-container .admin-header-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px 20px;position:relative}.page-container .btn-back{align-items:center;background:#0000;border:none;color:#333;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:4px;left:20px;padding:8px 0;position:absolute;transition:color .3s ease}.page-container .btn-back:hover{color:#8b2635}.page-container .admin-title{color:#333;font-size:28px;font-weight:700;margin:0 auto;text-align:center}.page-container .header-spacer{width:160px}.message{animation:slideIn .3s ease-out;border-radius:6px;font-size:14px;margin-bottom:20px;padding:15px 20px}.message-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.report-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.report-section h2{color:#333;font-size:18px;font-weight:600;margin:0 0 15px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.section-header h2{margin:0}.manual-send-form{display:flex;flex-direction:column;gap:15px}.manual-send-form .form-actions{display:flex;justify-content:flex-end;margin-top:5px}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 2fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#555;font-size:14px;font-weight:600}.form-group input[type=email],.form-group input[type=text],.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8b2635;outline:none}.form-group small{color:#777;font-size:12px;margin-top:-4px}.checkbox-wrapper{align-items:center;display:flex;gap:8px}.checkbox-wrapper input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-wrapper span{color:#555;font-size:14px}.btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-size:14px;font-weight:600;padding:10px 20px;text-align:center;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background-color:#8b2635;color:#fff}.btn-primary:hover:not(:disabled){background-color:#6d1d28}.btn-outline{background-color:initial;border:1px solid #ddd;color:#555}.btn-outline:hover:not(:disabled){background-color:#f5f5f5}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-sm{font-size:13px;padding:6px 12px}.schedules-table{border-collapse:collapse;width:100%}.schedules-table thead{background:#f5f5f5}.schedules-table th{border-bottom:2px solid #ddd;color:#555;font-size:13px;font-weight:600;padding:12px;text-align:left}.schedules-table td{border-bottom:1px solid #eee;color:#333;font-size:14px;padding:12px}.schedules-table tbody tr:hover{background-color:#f9f9f9}.schedules-table tbody tr.disabled{opacity:.6}.status-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;padding:4px 12px;text-transform:uppercase}.status-badge.enabled,.status-badge.success{background-color:#d4edda;color:#155724}.status-badge.disabled,.status-badge.error{background-color:#f8d7da;color:#721c24}.schedule-actions{display:flex;gap:8px;justify-content:flex-end}.email-logs-table{overflow-x:auto}.email-logs-table table{border-collapse:collapse;width:100%}.email-logs-table td,.email-logs-table th{border-bottom:1px solid #eee;font-size:14px;padding:12px;text-align:left}.email-logs-table th{background-color:#f5f5f5;color:#555;font-weight:600}.email-logs-table tbody tr:hover{background-color:#f9f9f9}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.modal-content.large{max-width:800px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h2{color:#333;font-size:20px;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background-color:#f5f5f5;color:#333}.schedule-form{padding:25px}.modal-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px}.empty-state{color:#999;font-size:14px;padding:40px 20px;text-align:center}.loading-spinner{align-items:center;color:#666;display:flex;font-size:16px;justify-content:center;padding:60px 20px}@media (max-width:768px){.form-row,.schedules-grid{grid-template-columns:1fr}.modal-content{max-height:95vh;width:95%}.email-logs-table{font-size:12px}.email-logs-table td,.email-logs-table th{padding:8px}}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#8b2635;height:40px;margin:0 auto;width:40px}*{box-sizing:border-box}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}.App,.app-loading{min-height:100vh}.app-loading{align-items:center;background-color:#f5f7fa;display:flex;flex-direction:column;gap:20px;justify-content:center}.app-loading p{color:#666;font-size:18px;margin:0}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}@media (max-width:768px){body{overflow-x:hidden}*{max-width:100%}.app-container,.main-container,.page-container{padding-left:12px!important;padding-right:12px!important}}@media (max-width:480px){.app-container,.main-container,.page-container{padding-left:10px!important;padding-right:10px!important}}
/*# sourceMappingURL=main.615ffb66.css.map*/