@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#014099;--primary-hover:#012d6c;--bg-color:#f1f3f7;--text-primary:#1f2937;--text-secondary:#4b5563;--panel-bg:#fff;--border-color:#e5e7eb;--panel-shadow:0 4px 12px #0000000d;--error-color:#dc2626;--success-color:#059669}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-primary);background-color:var(--bg-color);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:flex-start;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow-x:hidden}#root{width:100%;max-width:100%;margin:0 auto;padding:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.glass-panel{background:var(--panel-bg);border:1px solid var(--border-color);box-shadow:var(--panel-shadow);border-radius:.75rem;padding:1.5rem;animation:.4s ease-out forwards fadeIn}.title{text-align:center;color:var(--primary);letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.form-group{flex-direction:column;margin-bottom:1rem;display:flex}.form-group label{color:var(--text-secondary);margin-bottom:.4rem;font-size:.85rem;font-weight:600}.input-field{color:var(--text-primary);background:#fff;border:1px solid #d1d5db;border-radius:.375rem;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px #01409926}.input-field::placeholder{color:#9ca3af}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.375rem;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:1.5rem;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.app-container{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 2rem);display:flex}.login-form-container{width:100%;max-width:400px}.results-container{width:100%;max-width:500px}.alert-error{border-left:4px solid var(--error-color);color:#b91c1c;background:#fef2f2;border-radius:4px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;line-height:1.4}.dashboard-grid{flex-direction:column;gap:.75rem;margin-bottom:2rem;display:flex}.stat-card{border:1px solid var(--border-color);background:#f8fafc;border-radius:.5rem;flex-direction:column;padding:1rem 1.25rem;display:flex}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;font-weight:600}.stat-value{color:var(--primary);font-size:1.25rem;font-weight:700}.stat-subtitle{color:var(--text-secondary);margin-top:.2rem;font-size:.8rem}.badge{color:#475569;background:#f1f5f9;border-radius:9999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge.success{color:#047857;background:#d1fae5;border:1px solid #a7f3d0}.seating-chart-img{width:100%;height:auto;display:block}.seating-image-toggle{border:1px solid var(--border-color);border-radius:.5rem;margin:0 0 1.5rem;overflow:hidden}.seating-toggle-btn{cursor:pointer;width:100%;color:var(--text-primary);background:#f8fafc;border:none;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.seating-toggle-btn:hover{background:#f1f5f9}.seating-toggle-btn:active{background:#e2e8f0}.seating-toggle-indicator{color:var(--text-secondary);font-size:.75rem;font-weight:500}.seat-viewer-card{background:linear-gradient(135deg,#dbeafe 0%,#e0eaff 100%);border:1px solid #93c5fd;border-radius:.75rem;margin-bottom:1.5rem;padding:1.25rem}.seat-viewer-title{text-transform:uppercase;letter-spacing:.07em;color:#014099;margin-bottom:1rem;font-size:.7rem;font-weight:700}.seat-info-row{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.seat-section-box{color:#fff;background:#014099;border-radius:.625rem;flex-direction:column;align-items:center;min-width:64px;padding:.625rem 1rem;display:flex}.seat-number-box{background:var(--primary);color:#fff;border-radius:.625rem;flex-direction:column;align-items:center;min-width:64px;padding:.625rem 1rem;display:flex}.seat-big-value{font-size:2.25rem;font-weight:800;line-height:1}.seat-meta-label{opacity:.85;letter-spacing:.02em;white-space:nowrap;margin-top:.3rem;font-size:.6rem;font-weight:500}.seat-divider-vertical{background:#93c5fd;flex-shrink:0;width:1px;height:56px}.seat-location-box{flex-direction:column;flex-shrink:1;align-items:flex-end;gap:.4rem;min-width:0;margin-left:auto;display:flex}.seat-floor-pill{color:#0369a1;background:#e0f2fe;border-radius:9999px;padding:.25rem .75rem;font-size:.8rem;font-weight:700}.seat-room-text{color:var(--text-secondary);text-align:right;word-break:keep-all;overflow-wrap:break-word;min-width:0;font-size:.68rem;font-weight:500;line-height:1.35}.chapel-mini-map{border-top:1px solid #bfdbfe;padding-top:1rem}.chapel-mini-label-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.chapel-mini-label{color:#014099;text-transform:uppercase;letter-spacing:.06em;font-size:.65rem;font-weight:700}.view-reset-btn{color:#014099;cursor:pointer;background:#dbeafe;border:1px solid #93c5fd;border-radius:9999px;padding:.15rem .6rem;font-size:.65rem;font-weight:600}.chapel-floors-container{border:1px solid #bfdbfe;border-radius:.5rem;margin-bottom:.75rem;overflow:hidden}.chapel-stage-bar{color:#fff;text-align:center;letter-spacing:.15em;background:#011a45;padding:.35rem;font-size:.72rem;font-weight:700}.chapel-floor-row{border-top:1px solid #e0eaff;align-items:center;gap:.4rem;display:flex}.active-floor{background:#fff;padding:.5rem}.inactive-floor{background:#f0f7ff;padding:.25rem .5rem}.chapel-floor-label{text-align:right;white-space:nowrap;flex-shrink:0;width:32px;font-weight:700}.active-floor .chapel-floor-label{color:#014099;font-size:.75rem}.inactive-floor .chapel-floor-label{color:#93c5fd;font-size:.6rem}.chapel-floor-sections{flex:1;gap:3px;display:flex}.chapel-section-cell{border-radius:4px;flex:1;justify-content:center;align-items:center;font-weight:700;transition:all .15s;display:flex;position:relative}.chapel-section-cell.clickable{cursor:pointer}.chapel-section-cell.clickable:hover{filter:brightness(.93)}.active-floor .chapel-section-cell{color:#93c5fd;background:#eff6ff;border:1px solid #bfdbfe;padding:.55rem 0;font-size:.9rem}.active-floor .chapel-section-cell.active{color:#fff;background:#014099;border-color:#014099;font-size:1rem;box-shadow:0 2px 6px #01409966}.active-floor .chapel-section-cell.user-marker{color:#014099;background:#dbeafe;border:2px solid #60a5fa}.inactive-floor .chapel-section-cell{color:#d1d5db;background:#f3f4f6;border:1px solid #e0eaff;padding:.2rem 0;font-size:.6rem}.inactive-floor .chapel-section-cell.active{color:#012d6c;background:#bfdbfe;border-color:#60a5fa}.inactive-floor .chapel-section-cell.user-marker{color:#014099;background:#dbeafe;border:1px solid #60a5fa}.user-dot{background:#014099;border-radius:50%;width:5px;height:5px;position:absolute;top:3px;right:4px}.seat-floor-corridor{color:#60a5fa;background:#eff6ff;border-top:1px dashed #93c5fd;border-bottom:1px dashed #93c5fd;justify-content:center;align-items:center;gap:.5rem;margin:2px 0;padding:.3rem 0;font-size:.55rem;font-weight:700;display:flex}.corridor-hint{color:#93c5fd;font-size:.5rem;font-weight:500}.seat-section-floor-tag{color:#014099;vertical-align:middle;background:#dbeafe;border:1px solid #93c5fd;border-radius:9999px;margin-left:.4rem;padding:.05rem .4rem;font-size:.55rem;font-weight:600;display:inline-block}.section-browser-card{background:#f0f7ff;border:1px solid #bfdbfe;border-radius:.625rem;margin-bottom:1.5rem;padding:1rem}.section-browser-title{color:#014099;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.25rem;font-size:.75rem;font-weight:700}.section-browser-desc{color:var(--text-secondary);margin-bottom:.875rem;font-size:.78rem}.section-browser-map .inactive-floor .chapel-section-cell{color:#93c5fd;background:#eff6ff;border:1px solid #bfdbfe;padding:.55rem 0;font-size:.9rem}.section-btn-groups{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.section-btn-group{flex-direction:column;gap:.35rem;display:flex}.section-group-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-size:.6rem;font-weight:700}.section-btn-row{gap:.3rem;display:flex}.section-btn{color:#9ca3af;cursor:pointer;background:#fff;border:1.5px solid #bfdbfe;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;transition:all .15s;display:flex}.section-btn:hover{color:#014099;background:#eff6ff;border-color:#60a5fa}.section-btn.active{color:#fff;background:#014099;border-color:#014099;box-shadow:0 2px 6px #01409959}.seat-section-map{border-top:1px solid #bfdbfe;margin-top:.25rem;margin-bottom:.5rem;padding-top:.75rem}.seat-section-title{color:#014099;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem;font-size:.65rem;font-weight:700}.seat-section-stage-hint{text-align:center;color:#60a5fa;letter-spacing:.05em;margin-bottom:.3rem;font-size:.58rem;font-weight:600}.seat-section-scroll{-webkit-overflow-scrolling:touch;flex-direction:column;align-items:center;display:flex;overflow-x:auto}.seat-grid-header{align-items:center;gap:2px;margin-bottom:2px;display:flex}.seat-label-spacer{flex-shrink:0;width:20px}.seat-col-label{text-align:center;color:#93c5fd;flex-shrink:0;width:22px;font-size:.48rem;font-weight:700}.seat-col-label.my-col{color:#014099}.seat-grid-row{align-items:center;gap:2px;margin-bottom:2px;display:flex}.seat-row-label{color:#93c5fd;text-align:right;flex-shrink:0;width:20px;padding-right:2px;font-size:.48rem;font-weight:700}.seat-row-label.my-row{color:#014099}.seat-cell{color:#0000;background:#f0f7ff;border:1.5px solid #60a5fa;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:18px;font-size:.4rem;display:flex}.seat-cell.my-seat{color:#fff;background:#014099;border-color:#012d6c;font-size:.6rem;box-shadow:0 1px 5px #01409980}.seat-cell-void{pointer-events:none;background:0 0;border-color:#0000}.seat-wheelchair-row{color:#64748b;white-space:nowrap;background:#f1f5f9;border:1px dashed #94a3b8;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:.6rem;display:flex}.chapel-mini-footer{text-align:center;margin-top:.5rem}.you-badge{color:#012d6c;background:#dbeafe;border:1px solid #93c5fd;border-radius:9999px;padding:.3rem .875rem;font-size:.8rem;font-weight:600;display:inline-block}.attendance-list{flex-direction:column;gap:.75rem;display:flex}.empty-state{text-align:center;color:#64748b;border:1px dashed var(--border-color);background:#f8fafc;border-radius:.5rem;padding:2rem 1rem;font-size:.9rem}.attendance-card{border:1px solid var(--border-color);background:#fff;border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.attendance-header{justify-content:space-between;align-items:center;display:flex}.attendance-date{color:var(--text-primary);font-size:.9rem;font-weight:600}.attendance-status{background:#f1f5f9;border-radius:.25rem;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.status-present{color:#059669}.status-absent{color:#dc2626}.status-late{color:#d97706}.status-unknown{color:#64748b}.attendance-details{color:var(--text-secondary);justify-content:space-between;align-items:flex-start;font-size:.85rem;display:flex}.attendance-category{color:#4b5563}.attendance-instructor{text-align:right;color:#6b7280;max-width:60%;line-height:1.3}.header-action{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.btn-icon{color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:#f8fafc;border-radius:.375rem;padding:.4rem .8rem;font-size:.8rem;transition:all .2s}.btn-icon:active{background:#e2e8f0;transform:scale(.95)}.section-title{color:var(--text-primary);margin-top:.25rem;margin-bottom:1rem;font-size:.95rem;font-weight:700}.login-prompt-card{border:1px dashed var(--border-color);text-align:center;background:#f8fafc;border-radius:.5rem;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:2rem 1.5rem;display:flex}.login-prompt-icon{margin-bottom:.25rem;font-size:2rem}.login-prompt-text{color:var(--text-primary);font-size:1rem;font-weight:600}.login-prompt-sub{color:var(--text-secondary);margin-bottom:.5rem;font-size:.8rem;line-height:1.5}.btn-login-prompt{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.375rem;margin-top:.25rem;padding:.625rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.btn-login-prompt:hover{background:var(--primary-hover)}.btn-login-prompt:active{transform:scale(.97)}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out forwards fadeIn;display:flex;position:fixed;inset:0}.modal-panel{width:100%;max-width:400px;position:relative}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-title{color:var(--primary);font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:1rem;line-height:1;transition:background .15s}.modal-close:hover{color:var(--text-primary);background:#f1f5f9}@media (width>=640px){#root{padding:2rem}.dashboard-grid{flex-flow:wrap}.stat-card{flex:1;min-width:140px}.glass-panel{padding:2.5rem}.title{font-size:1.75rem}}
