*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.login-container{align-items:center;background-color:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-box{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;max-width:400px;padding:2rem;width:100%}.login-title{color:#1e293b;font-size:1.875rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.alert-title{font-size:.875rem;font-weight:500;margin:0 0 .25rem}.alert-text{font-size:.875rem;margin:0}.login-form{margin-top:2rem}.accept-invite-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.accept-invite-card{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:450px;padding:2rem;width:100%}.accept-invite-header{margin-bottom:2rem;text-align:center}.accept-invite-icon{color:#667eea;height:48px;margin:0 auto 1rem;width:48px}.accept-invite-title{color:#1a202c;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.accept-invite-subtitle{color:#718096;font-size:.875rem;margin:0}.alert{gap:.5rem;margin-bottom:1.5rem}.alert-error{border:1px solid #fecaca}.accept-invite-form{margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-label{align-items:center;color:#4a5568;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:.5rem}.form-icon{color:#a0aec0;height:16px;width:16px}.form-input{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;padding:.625rem .875rem;transition:all .2s;width:100%}.form-input:focus{background-color:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled{background-color:#edf2f7;cursor:not-allowed}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1rem;transition:all .2s;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-1px)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.accept-invite-footer{color:#718096;font-size:.875rem;text-align:center}.link{color:#667eea;font-weight:500;text-decoration:none;transition:color .2s}.link:hover{color:#764ba2;text-decoration:underline}@media (max-width:640px){.accept-invite-container{padding:1rem}.accept-invite-card{padding:1.5rem}}.notifications-container{display:inline-block;position:relative}.notifications-button{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;color:#64748b;cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;transition:all .2s;width:40px}.notifications-button:hover{background-color:#f1f5f9;color:#374151}.notifications-badge{align-items:center;background-color:#ef4444;border-radius:10px;color:#fff;display:flex;font-size:.7rem;font-weight:600;height:18px;justify-content:center;line-height:1;min-width:18px;padding:2px 6px;position:absolute;right:-4px;top:-4px}.notifications-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:500px;overflow:hidden;position:absolute;right:0;top:50px;width:400px;z-index:2000}.notifications-header{align-items:center;background-color:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:1rem 1.5rem}.notifications-title{align-items:center;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0}.notifications-header-count{color:#ef4444;font-size:.8rem;font-weight:500}.notifications-header-actions{align-items:center;display:flex;gap:.5rem}.notifications-clear-all{background:none;border:none;border-radius:.25rem;color:#3b82f6;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .2s}.notifications-clear-all:hover{background-color:#eff6ff}.notifications-close{align-items:center;background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .2s;width:24px}.notifications-close:hover{background-color:#f3f4f6;color:#374151}.notifications-content{max-height:400px;overflow-y:auto}.notifications-loading{font-size:.875rem;padding:2rem;text-align:center}.notifications-empty{padding:3rem 2rem}.notifications-empty-icon{color:#d1d5db;height:48px;margin:0 auto 1rem;width:48px}.notifications-list{display:flex;flex-direction:column}.notification-item{border-bottom:1px solid #f1f5f9;cursor:pointer;padding:1rem 1.5rem;position:relative}.notification-item-compact{padding:.75rem 1rem}.notification-item:hover{background-color:#f8fafc}.notification-item:last-child{border-bottom:none}.notification-unread{background-color:#eff6ff;border-left:3px solid #3b82f6}.notification-unread:hover{background-color:#dbeafe}.notification-header{align-items:flex-start;display:flex;gap:.75rem;margin-bottom:.75rem}.notification-header-compact{gap:.5rem;margin-bottom:.5rem}.notification-icon{align-items:center;background-color:#dbeafe;border-radius:50%;color:#3b82f6;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.notification-icon-compact{height:24px;width:24px}.notification-meta{flex:1 1}.notification-title{color:#1e293b;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.notification-title-compact{font-size:.8rem;margin-bottom:.125rem}.notification-time{align-items:center;color:#6b7280;display:flex;font-size:.75rem;gap:.25rem}.notification-time-compact{font-size:.7rem}.notification-unread-dot{background-color:#3b82f6;border-radius:50%;flex-shrink:0;height:8px;margin-top:.25rem;width:8px}.notification-unread-dot-compact{height:6px;width:6px}.notification-body{margin-left:2.5rem}.notification-body-compact{margin-left:1.75rem}.notification-student{color:#1e293b;font-size:.875rem;margin-bottom:.5rem}.notification-student-compact{font-size:.8rem;margin-bottom:.375rem}.notification-school{align-items:center;color:#6b7280;display:flex;font-size:.8rem;gap:.375rem;margin-bottom:.5rem}.notification-school-compact{font-size:.75rem;gap:.25rem;margin-bottom:.375rem}.notification-changed-by{color:#9ca3af;font-size:.75rem;margin-bottom:.75rem}.notification-changed-by-compact{font-size:.7rem;margin-bottom:.5rem}.notification-changes-container{background-color:#f8fafc;border:1px solid #f1f5f9;border-radius:.375rem;font-size:.8rem;padding:.75rem}.notification-changes-container-compact{font-size:.75rem;padding:.5rem}.notification-change{color:#374151;line-height:1.4}.notification-changes-summary{color:#374151;font-weight:500;margin-bottom:.5rem}.notification-changes-list{display:flex;flex-wrap:wrap;gap:.5rem}.notification-change-item{background-color:#e0e7ff;border-radius:.25rem;color:#3730a3;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.change-field{font-weight:600}.notifications-footer{background-color:#f8fafc;border-top:1px solid #f1f5f9;padding:.75rem 1.5rem;text-align:center}.notifications-footer-text{color:#6b7280;font-size:.75rem}.notifications-content::-webkit-scrollbar{width:6px}.notifications-content::-webkit-scrollbar-track{background:#f1f5f9}.notifications-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.notifications-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.header{background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;width:100%;z-index:1000}.header-content{height:70px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 1.5rem;width:100%}.header-content,.logo{align-items:center;display:flex}.logo{gap:.75rem}.logo-image{height:80px;object-fit:contain;width:auto}.title{color:#1e293b;font-size:1.5rem;font-weight:700;margin:0}.school-selector{align-items:center;display:flex;gap:1rem}.school-label{color:#64748b;font-size:.875rem;font-weight:500}.school-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;font-size:.875rem;min-width:200px;padding:.5rem 1rem}.school-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.school-select-readonly{background-color:#f8fafc;border:1px solid #e2e8f0;color:#1e293b;cursor:default;font-weight:500}.user-info{align-items:center;display:flex;gap:1rem}.user-text{color:#64748b;font-size:.875rem}.sidebar{background-color:#fff;border-right:1px solid #e2e8f0;height:calc(100vh - 70px);overflow-y:auto;padding:1.5rem 0;position:-webkit-sticky;position:sticky;top:70px;transition:width .3s ease;width:280px}.sidebar.yearbook-compact{min-width:60px;padding:1rem 0;width:60px}.sidebar.yearbook-compact .nav-section,.sidebar.yearbook-compact .warning-card{display:none}.sidebar.yearbook-compact .sidebar-nav{padding:0 .5rem}.sidebar.yearbook-compact .nav-item{border-radius:.5rem;gap:0;justify-content:center;margin:.25rem 0;min-height:40px;padding:.75rem .25rem}.sidebar.yearbook-compact .nav-item svg{flex-shrink:0;height:20px!important;width:20px!important}.sidebar.yearbook-compact .nav-item-lock{display:none}.warning-card{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;color:#92400e;font-size:.875rem;margin:0 1rem 1rem;padding:1rem}.warning-title{margin-bottom:.25rem}.warning-text{margin:0}.sidebar-nav{padding:0 1rem}.nav-item{align-items:center;border-radius:.5rem;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;transition:all .2s}.nav-item:hover{background-color:#f1f5f9}.nav-item-active{background-color:#dbeafe;color:#1d4ed8}.nav-item-disabled{color:#9ca3af;cursor:not-allowed;opacity:.5}.nav-item-lock{font-size:.75rem;margin-left:auto}.nav-section{border-top:1px solid #f1f5f9;margin-top:1rem;padding:1rem}.nav-section-title{color:#9ca3af;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.export-dropdown{display:inline-block;position:relative}.export-button{align-items:center;background-color:#8b5cf6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s}.export-button:hover{background-color:#7c3aed}.export-menu{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;left:0;margin-top:.25rem;min-width:200px;position:absolute;top:100%;z-index:1000}.export-menu-item{align-items:center;border-bottom:1px solid #f1f5f9;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;transition:all .2s}.export-menu-item:hover{background-color:#f8fafc}.export-menu-item:last-child{border-bottom:none}.progress-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;max-width:400px;min-width:320px;padding:1.5rem;position:fixed;right:20px;top:90px;z-index:1000}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.progress-text{color:#1e293b;font-weight:500;margin-bottom:.25rem}.progress-cancel{font-size:.75rem;padding:.5rem .75rem}.progress-bar{background-color:#f1f5f9;margin-top:.5rem}.progress-fill{background-color:#3b82f6}.progress-stats{display:flex;justify-content:space-between;margin-top:.5rem}.progress-detail{color:#64748b}.progress-detail,.progress-status{font-size:.75rem;margin-top:.25rem}.progress-status{color:#94a3b8}.instruction-steps{margin:1rem 0}.instruction-step{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;display:flex;gap:.75rem;margin-bottom:1rem;padding:.75rem}.step-number{align-items:center;background-color:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:24px;justify-content:center;width:24px}.step-content{flex:1 1}.step-title{color:#1e293b;font-size:.875rem;font-weight:600;margin-bottom:.125rem}.step-description{color:#64748b;font-size:.8rem;line-height:1.3;margin-bottom:.5rem}.popup-example{align-items:center;display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.popup-screenshot{border:1px solid #3b82f6;border-radius:.375rem;box-shadow:0 2px 4px #0000001a;height:auto;max-width:300px}.click-indicator{border-radius:.25rem;color:#3b82f6;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.click-indicator,.instruction-note{background-color:#dbeafe;border:1px solid #93c5fd}.instruction-note{align-items:flex-start;border-radius:.375rem;color:#1e40af;display:flex;font-size:.8rem;gap:.5rem;line-height:1.4;margin-top:1rem;padding:.75rem}.instruction-note svg{color:#3b82f6;flex-shrink:0;margin-top:.125rem}.export-result-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:5000}.export-result-modal-container{animation:modalSlideIn .3s ease-out;background-color:#fff;border:1px solid #f1f5f9;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-height:80vh;max-width:500px;overflow-y:auto;width:100%}.export-result-modal-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem;padding:2rem 2rem 0}.export-result-modal-icon-container{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.export-result-modal-success-icon{background-color:#d1fae5;color:#059669}.export-result-modal-warning-icon{background-color:#fef3c7;color:#d97706}.export-result-modal-info-icon{background-color:#dbeafe;color:#2563eb}.export-result-modal-title{color:#111827;font-size:1.5rem;font-weight:700;line-height:1.3;margin:0}.export-result-modal-body{padding:0 2rem}.export-result-modal-text{color:#4b5563;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.export-result-modal-stats{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-bottom:1.5rem;padding:1.25rem}.export-result-modal-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.export-result-modal-stat-item{text-align:center}.export-result-modal-stat-number{font-size:1.75rem;font-weight:700;line-height:1;margin:0}.export-result-modal-stat-label{color:#6b7280;font-size:.875rem;font-weight:500;margin-top:.25rem}.export-result-modal-success-number{color:#059669}.export-result-modal-failed-number{color:#dc2626}.export-result-modal-total-number{color:#3b82f6}.export-result-modal-details{background-color:#fafbfc;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.export-result-modal-details-title{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.export-result-modal-details-list{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.export-result-modal-detail-item{margin-bottom:.5rem}.export-result-modal-folder-info{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;gap:.5rem;padding:.75rem}.export-result-modal-folder-path{color:#1f2937;flex:1 1;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:.875rem}.export-result-modal-copy-button{align-items:center;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.25rem;color:#374151;cursor:pointer;display:inline-flex;font-size:.75rem;justify-content:center;padding:.5rem;transition:all .2s}.export-result-modal-copy-button:hover{background-color:#e5e7eb}.export-result-modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem 2rem}.export-result-modal-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s}.export-result-modal-button-primary{background-color:#3b82f6;color:#fff}.export-result-modal-button-primary:hover{background-color:#2563eb}.export-result-modal-button-secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.export-result-modal-button-secondary:hover{background-color:#e5e7eb}.missing-students-list{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;max-height:200px;overflow-y:auto;padding:.75rem}.missing-student-item{color:#374151;font-size:.875rem;margin-bottom:.25rem;padding:.25rem 0}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:5000}.modal-container{animation:modalSlideIn .3s ease-out;background-color:#fff;border:1px solid #f1f5f9;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-height:85vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{gap:1rem;margin-bottom:1.5rem;padding:2rem 2rem 0}.modal-icon-container{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.modal-info-icon{background-color:#dbeafe;color:#2563eb}.modal-title{color:#111827;font-size:1.5rem;font-weight:700;line-height:1.3;margin:0}.modal-body{padding:0 2rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem 2rem}.modal-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s}.modal-button-primary{background-color:#3b82f6;color:#fff}.modal-button-primary:hover{background-color:#2563eb}.modal-button-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.modal-button-secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.modal-button-secondary:hover{background-color:#e5e7eb}.modal-container-compact{max-height:85vh;max-width:600px}.modal-header-compact{margin-bottom:1rem;padding:1.5rem 1.5rem 0}.modal-body-compact{padding:0 1.5rem}.modal-content-compact{font-size:.875rem;margin-bottom:1rem}.modal-footer-compact{padding:1rem 1.5rem 1.5rem}.data-source-selection{background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:.5rem}.data-source-selection,.data-source-selection-compact{margin:1rem 0;padding:1rem}.data-source-title{color:#0c4a6e;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.data-source-options{display:flex;flex-direction:column;gap:.5rem}.data-source-option{align-items:flex-start;background-color:#fff;border:2px solid #e0e7ff;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s}.data-source-option-compact{padding:.5rem}.data-source-option:hover{background-color:#f8fafc;border-color:#3b82f6}.data-source-option:has(.data-source-radio:checked){background-color:#eff6ff;border-color:#3b82f6}.data-source-radio{accent-color:#3b82f6;flex-shrink:0;height:16px;margin:.125rem 0 0;width:16px}.data-source-label{flex:1 1;font-size:.875rem;line-height:1.4}.data-source-label strong{color:#1e293b;font-weight:600}.data-source-label small{color:#64748b;display:block;font-size:.75rem;margin-top:.125rem}.sort-fields-container{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem}.sort-fields-container,.sort-fields-container-compact{margin:1rem 0;padding:1rem}.sort-fields-title{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.sort-fields-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.sort-field-row{align-items:center;display:flex;gap:.75rem}.sort-field-row-compact{gap:.5rem}.sort-field-number{align-items:center;background-color:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:24px;justify-content:center;width:24px}.sort-field-number-compact{font-size:.7rem;height:20px;width:20px}.sort-field-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.sort-field-label{color:#374151;font-size:.875rem;font-weight:500}.sort-field-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;flex:1 1;font-size:.8rem;padding:.5rem;transition:all .2s}.sort-field-select-compact{font-size:.75rem;padding:.375rem}.sort-field-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.sort-preview{background-color:#dbeafe;border:1px solid #93c5fd;border-radius:.375rem;margin:1rem 0 0;padding:.75rem}.sort-preview-compact{margin:.75rem 0 0;padding:.5rem}.sort-preview-title{color:#1e40af;font-size:.875rem;font-weight:600;margin:0 0 .5rem}.sort-preview-text{color:#1e40af;font-size:.8rem;line-height:1.4}.export-info{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;margin:1rem 0;padding:1rem}.export-info-title{color:#166534;font-size:.875rem;font-weight:600;margin:0 0 .5rem}.export-info-text{color:#166534;font-size:.875rem;line-height:1.4;margin:0}.export-info-list{color:#166534;margin:0;padding-left:1.25rem}.export-info-list li{font-size:.875rem;line-height:1.4;margin-bottom:.25rem}.export-info-list li:last-child{margin-bottom:0}.page-break-container{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin:1rem 0;padding:1rem}.page-break-title{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.page-break-content{display:flex;flex-direction:column;gap:.5rem}.page-break-label{color:#4b5563;font-size:.875rem;font-weight:500}.page-break-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.5rem;transition:all .2s}.page-break-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.page-break-help{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.25rem}.no-photos-warning{padding:2rem;text-align:center}.warning-icon{display:flex;justify-content:center;margin-bottom:1rem}.warning-title{color:#92400e;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.warning-text{color:#78350f;font-size:.875rem;margin:0 0 1rem}.warning-list{color:#92400e;font-size:.875rem;list-style:none;margin:0;padding:0}.warning-list li{padding:.25rem 0}.warning-list li:before{content:"• ";font-weight:700;margin-right:.5rem}.user-management-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-management-modal-content{background-color:#fff;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.user-management-modal{max-height:85vh;max-width:600px;overflow-y:auto;width:90%}.user-management-modal-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;color:#1e293b;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.user-management-modal-title-section{align-items:center;display:flex;gap:.75rem}.user-management-modal-icon{color:#3b82f6;height:24px;width:24px}.user-management-modal-title{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.user-management-modal-close{background:none;border:none;border-radius:.375rem;color:#64748b;cursor:pointer;padding:.5rem;transition:all .2s}.user-management-modal-close:hover{background:#f1f5f9;color:#1e293b}.user-management-modal-body{background:#f8fafc;padding:1.5rem}.alert{align-items:center;animation:slideDown .3s ease;display:flex;gap:.75rem;margin:1rem 1.5rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{background-color:#fee2e2;border-left:4px solid #dc2626;color:#dc2626}.alert-success{background-color:#dcfce7;border-left:4px solid #16a34a;color:#16a34a}.alert-icon{flex-shrink:0;height:18px;width:18px}.alert-content{align-items:center;display:flex;gap:1rem;justify-content:space-between;width:100%}.copy-link-button{align-items:center;background:#fff;border:1px solid;border-radius:.375rem;color:inherit;cursor:pointer;display:flex;font-size:.813rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s;white-space:nowrap}.copy-link-button:hover{background:#0000000d}.action-bar{margin-bottom:1.5rem}.invite-form{align-items:flex-end;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-wrap:wrap;gap:.75rem;padding:1.25rem}.invite-form .input{border:1px solid #e2e8f0;border-radius:.375rem;flex:1 1 250px;font-size:.875rem;padding:.625rem .875rem;transition:all .2s}.invite-form .input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.invite-form select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;flex:0 1 140px;font-size:.875rem;padding:.625rem 2rem .625rem .875rem;transition:all .2s}.invite-form select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.invite-form-buttons{display:flex;flex:0 0 auto;gap:.5rem}.button{border-radius:.375rem;justify-content:center;min-width:-webkit-fit-content;min-width:fit-content;padding:.625rem 1rem;white-space:nowrap}.button-primary{background:#3b82f6}.button-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.button-outline{background:#fff;border:1px solid #e2e8f0;color:#64748b}.button-outline:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.button:disabled{cursor:not-allowed;opacity:.5}.section-title{color:#64748b;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.invitations-section,.users-section{margin-bottom:2rem}.invitations-list,.users-list{display:flex;flex-direction:column;gap:.5rem}.user-management-modal-invitation-item,.user-management-modal-user-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;gap:1rem;min-height:72px;padding:1rem;transition:all .2s}.invitation-item:hover,.user-item:hover{box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.user-management-modal-user-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-management-modal-invitation-info,.user-management-modal-user-info{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.user-management-modal-user-name{align-items:center;color:#1e293b;display:flex;flex-wrap:wrap;font-size:.9375rem;font-weight:500;gap:.5rem}.current-user-badge{background:#e0e7ff;border-radius:.25rem;color:#3730a3;font-size:.75rem;font-weight:500;padding:.125rem .375rem}.user-management-modal-invitation-email,.user-management-modal-user-email{color:#64748b;font-size:.813rem;word-break:break-word}.invitation-meta{align-items:center;color:#94a3b8;display:flex;font-size:.75rem;gap:.25rem;margin-top:.25rem}.meta-icon{height:14px;width:14px}.user-management-modal-invitation-actions,.user-management-modal-user-actions{align-items:center;display:flex;flex-shrink:0;gap:.5rem;margin-left:auto}.user-management-modal-user-role{align-items:center;display:flex;gap:.5rem}.role-icon{height:18px;width:18px}.role-icon.admin{color:#7c3aed}.role-icon.editor{color:#2563eb}.role-icon.viewer{color:#10b981}.role-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .25rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;font-size:.813rem;min-width:90px;padding:.375rem 1.75rem .375rem .5rem;transition:all .2s}.role-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.role-label{border-radius:.25rem;font-size:.813rem;font-weight:500;gap:.375rem;padding:.25rem .625rem}.button-icon,.role-label{align-items:center;display:flex}.button-icon{background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;justify-content:center;padding:.5rem;transition:all .2s}.button-icon:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.button-icon.button-danger{background:#fef2f2;border-color:#fee2e2;color:#dc2626}.button-icon.button-danger:hover:not(:disabled){background:#fee2e2;border-color:#fecaca;transform:scale(1.05)}.button-text{background:none;border:none;border-radius:.25rem;color:#3b82f6;cursor:pointer;font-size:.813rem;font-weight:500;padding:.375rem .625rem;transition:all .2s}.button-text:hover{background:#eff6ff}.button-text.button-danger{color:#dc2626}.button-text.button-danger:hover{background:#fef2f2}.empty-state{padding:3rem 2rem}.empty-icon{color:#cbd5e1;height:48px;margin:0 auto 1rem;width:48px}.loading{color:#64748b;font-size:.875rem;padding:2rem;text-align:center}@media (max-width:768px){.user-management-modal-user-item{flex-wrap:wrap}.user-management-modal-user-info{flex:1 1 200px}.user-management-modal-user-actions{flex:0 0 auto}}@media (max-width:640px){.user-management-modal{max-height:90vh;width:95%}.invite-form{align-items:stretch;flex-direction:column}.invite-form .input,.invite-form select{flex:1 1 auto;width:100%}.invite-form-buttons{flex-direction:column;width:100%}.invite-form-buttons .button{width:100%}.user-management-modal-invitation-item,.user-management-modal-user-item{align-items:flex-start;flex-direction:column;gap:.75rem;padding:.75rem}.user-management-modal-user-avatar{font-size:.75rem;height:36px;width:36px}.user-management-modal-user-info{width:100%}.user-management-modal-invitation-actions,.user-management-modal-user-actions{justify-content:space-between;margin-left:0;width:100%}}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1.5rem}.dashboard-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.dashboard-stat{align-items:center;display:flex;gap:1rem}.dashboard-stat-icon{height:32px;width:32px}.dashboard-stat-icon-blue{color:#3b82f6}.dashboard-stat-icon-green{color:#10b981}.dashboard-stat-label{color:#374151;font-size:1.125rem;font-weight:600;margin:0}.dashboard-stat-number{font-size:2rem;font-weight:700;margin:0}.dashboard-stat-number-blue{color:#3b82f6}.dashboard-stat-number-green{color:#10b981}.dashboard-school-info{margin-left:1rem}.dashboard-school-name{color:#64748b;font-size:1.125rem;margin:0}.dashboard-school-org{color:#94a3b8;font-size:.875rem;margin:.25rem 0 0}.upload-view{margin:0 auto;max-width:1200px}.upload-section-title{align-items:center;color:#111827;display:flex;font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;font-size:1.25rem;font-weight:600;gap:.5rem;margin:2rem 0 1.5rem}.upload-section-title:first-child{margin-top:0}.upload-section-divider{background:linear-gradient(90deg,#0000,#e5e7eb,#0000);height:1px;margin:2.5rem 0 1.5rem}.upload-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.upload-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s ease}.upload-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a}.upload-card-title{color:#111827;font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;font-size:1.125rem;font-weight:600;line-height:1.3;margin:0;padding:1.5rem 1.5rem 0}.upload-card-content{padding:1rem 1.5rem 1.5rem}.upload-alert{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:8px;margin-bottom:1.5rem;padding:1rem;position:relative}.upload-alert:before{background:linear-gradient(90deg,#0ea5e9,#06b6d4);border-radius:8px 8px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.upload-alert-info{background:linear-gradient(135deg,#fefbff,#f3f4f6);border-color:#6b7280}.upload-alert-info:before{background:linear-gradient(90deg,#6b7280,#9ca3af)}.upload-alert-text{color:#374151;font-size:.9375rem;line-height:1.5;margin:0}.upload-alert-text strong{color:#111827;font-weight:600}.upload-input{background:#fafbfc;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.9375rem;padding:1rem;position:relative;transition:all .2s ease;width:100%}.upload-input:hover{background:#f3f4f6;border-color:#9ca3af}.upload-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.upload-input::-webkit-file-upload-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-right:1rem;padding:.5rem 1rem;-webkit-transition:all .2s ease;transition:all .2s ease}.upload-input::file-selector-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-right:1rem;padding:.5rem 1rem;transition:all .2s ease}.upload-input::-webkit-file-upload-button:hover{background:#2563eb}.upload-input::file-selector-button:hover{background:#2563eb}.upload-file-info{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;justify-content:space-between;margin-top:1rem;padding:1rem}.upload-file-name{color:#374151;flex:1 1;font-family:Inter,system-ui,sans-serif;font-size:.9375rem;font-weight:500;word-break:break-all}.upload-file-info .button{flex-shrink:0;margin:0}.upload-card .button{border-radius:8px;box-shadow:0 1px 2px #0000000d;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.upload-card .button-primary{background:linear-gradient(135deg,#3b82f6,#2563eb)}.upload-card .button-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #2563eb40;transform:translateY(-1px)}.upload-card .button-secondary{background:linear-gradient(135deg,#10b981,#059669)}.upload-card .button-secondary:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #05966940;transform:translateY(-1px)}.upload-input.drag-over{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;color:#1e40af}.upload-input.has-files{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#10b981;border-style:solid;color:#047857}.upload-progress{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin-top:1rem;padding:1rem}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin:.5rem 0;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#6b7280;font-size:.875rem;text-align:center}@media (max-width:1024px){.upload-grid{gap:1.25rem;grid-template-columns:1fr}.upload-card-title{font-size:1.0625rem}.upload-section-title{font-size:1.125rem}}@media (max-width:768px){.upload-view{padding:0 1rem}.upload-card-title{font-size:1rem;padding:1rem 1rem 0}.upload-card-content{padding:.875rem 1rem 1rem}.upload-file-info{align-items:stretch;flex-direction:column;gap:.75rem}.upload-file-info .button{justify-content:center;width:100%}.upload-input{font-size:.875rem;padding:.875rem}.upload-input::-webkit-file-upload-button{font-size:.8125rem;margin-right:.75rem;padding:.5rem .875rem}.upload-input::file-selector-button{font-size:.8125rem;margin-right:.75rem;padding:.5rem .875rem}.upload-section-title{font-size:1.0625rem;margin:1.5rem 0 1rem}.upload-section-divider{margin:2rem 0 1rem}}.upload-loading{align-items:center;color:#6b7280;display:flex;justify-content:center;padding:2rem}.upload-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:32px;margin-right:.75rem;width:32px}.upload-success{color:#059669}.upload-error,.upload-success{align-items:center;display:flex;font-size:.9375rem;font-weight:500;gap:.5rem;margin-top:.75rem}.upload-error{color:#dc2626}.file-type-icon{color:#6b7280;display:inline-flex;margin-right:.5rem}.students-summary{color:#64748b;font-size:.875rem;margin:.5rem 0 0}.students-actions{align-items:center;display:flex;gap:.75rem}.search-filter-bar{align-items:center;background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1.5rem}.search-section{align-items:center;display:flex;flex:0 0 400px;gap:.75rem;min-width:300px}.search-input{border:2px solid #e5e7eb;border-radius:.5rem;flex:1 1;font-size:.875rem;padding:.75rem;transition:all .2s}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.clear-filters-button{background-color:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .2s}.clear-filters-button:hover{background-color:#dc2626}.filter-section{align-items:center;display:flex;flex:1 1;gap:1rem;justify-content:flex-end}.filter-dropdown{position:relative}.filter-dropdown-button{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:space-between;min-width:120px;padding:.75rem 1rem;text-align:left}.filter-dropdown-button:focus{border-color:#3b82f6;outline:none}.filter-dropdown-arrow{color:#6b7280;font-size:.75rem;transition:transform .2s}.filter-dropdown-arrow.open{transform:rotate(180deg)}.filter-dropdown-menu{background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;margin-top:.25rem;max-height:350px;min-width:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.filter-dropdown-item{align-items:center;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;transition:background-color .15s}.filter-dropdown-item:hover{background-color:#f9fafb}.filter-dropdown-item.selected{background-color:#f0f9ff}.filter-dropdown-item:last-child{border-bottom:none}.filter-checkbox{accent-color:#3b82f6;height:16px;margin:0;width:16px}.filter-label{color:#374151;flex:1 1;font-size:.875rem}.student-count-display{background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:.5rem;color:#1e40af;font-size:.875rem;font-weight:600;min-width:-webkit-fit-content;min-width:fit-content;padding:.75rem 1rem;white-space:nowrap}.collapse-all-button{align-self:flex-end;background-color:#8b5cf6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;height:48px;padding:.75rem 1rem;transition:all .2s}.collapse-all-button:hover{background-color:#7c3aed}.students-controls{background-color:#fafbfc;border:1px solid #f1f5f9;border-radius:.75rem;margin-bottom:1rem;padding:1.5rem}.controls-grid{align-items:flex-end;display:flex;flex-wrap:wrap;gap:2rem}.control-group{min-width:150px}.control-group-flex{flex:1 1;max-width:400px;min-width:250px}.control-label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.control-select{background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem;width:100%}.control-select:focus{border-color:#3b82f6;outline:none}.sort-controls{display:flex;gap:.5rem}.sort-order-button{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:center;min-width:48px;padding:.75rem;transition:all .2s}.sort-order-button:hover{background-color:#f9fafb}.groups-dropdown{position:relative}.groups-dropdown-button{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;justify-content:space-between;padding:.75rem;text-align:left;width:100%}.groups-dropdown-button:focus{border-color:#3b82f6;outline:none}.groups-dropdown-arrow{color:#6b7280;font-size:.75rem;transition:transform .2s}.groups-dropdown-arrow.open{transform:rotate(180deg)}.groups-dropdown-menu{background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;left:0;margin-top:.25rem;max-height:250px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.groups-dropdown-all{align-items:center;background-color:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;gap:.75rem;padding:.75rem 1rem}.groups-dropdown-item{align-items:center;cursor:pointer;display:flex;gap:.75rem;padding:.5rem 1rem;transition:background-color .15s}.groups-dropdown-item:hover{background-color:#f9fafb}.groups-dropdown-item.selected{background-color:#f0f9ff}.groups-checkbox{accent-color:#3b82f6;height:16px;margin:0;width:16px}.groups-label{color:#374151;flex:1 1;font-size:.875rem}.groups-label-all{color:#374151;font-size:.875rem;font-weight:500}.groups-count{background-color:#f3f4f6;border-radius:.25rem;color:#6b7280;font-size:.75rem;font-weight:500;padding:.125rem .375rem}.students-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.group-header{border-bottom:1px solid #f1f5f9;cursor:pointer;margin-bottom:1.5rem;padding-bottom:.75rem;-webkit-user-select:none;user-select:none}.group-title{align-items:center;color:#1e293b;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0}.group-arrow{color:#6b7280;font-size:.75rem;transition:transform .2s}.group-arrow.open{transform:rotate(90deg)}.group-count{background-color:#f1f5f9;border-radius:.25rem;color:#64748b;font-size:.875rem;font-weight:500;padding:.25rem .5rem}.students-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.student-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;position:relative}.student-delete-button,.student-edit-button{align-items:center;background:#ffffffe6;border:1px solid #e5e7eb;border-radius:.25rem;cursor:pointer;display:flex;justify-content:center;padding:.25rem;position:absolute;top:.5rem;transition:all .2s;z-index:10}.student-edit-button{left:.5rem}.student-delete-button{left:2.5rem}.student-edit-button:hover{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.student-delete-button:hover{background-color:#ef4444;border-color:#ef4444;color:#fff}.student-photo-container{position:relative}.student-photo{cursor:pointer;height:200px;object-fit:cover;object-position:center 20%;width:100%}.student-no-photo{align-items:center;background-color:#f8fafc;color:#94a3b8;display:flex;flex-direction:column;font-size:.875rem;gap:.5rem;height:200px;justify-content:center}.photo-replace-overlay{opacity:0;position:absolute;right:.5rem;top:.5rem;transition:opacity .2s}.student-card:hover .photo-replace-overlay{opacity:1}.replace-photo-button{align-items:center;background:#3b82f6e6;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:all .2s;width:32px}.replace-photo-button:hover{background:#2563eb;transform:scale(1.1)}.photo-history-overlay{opacity:0;position:absolute;right:.5rem;top:3rem;transition:opacity .2s}.student-card:hover .photo-history-overlay{opacity:1}.photo-history-overlay.photo-history-only{top:.5rem}.photo-history-button{align-items:center;background:#ef4444e6;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:all .2s;width:32px}.photo-history-button:hover{background:#dc2626;transform:scale(1.1)}.add-photo-button{background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;margin-top:.5rem;padding:.5rem 1rem;transition:all .2s}.add-photo-button:hover{background-color:#2563eb}.student-missing-badge{position:absolute;right:.5rem;top:.5rem}.missing-label{background-color:#fef2f2;border-radius:.25rem;color:#dc2626;font-size:.7rem;font-weight:500;padding:.2rem .4rem}.photo-type-badge-bottom{bottom:0;left:0;position:absolute;z-index:10}.photo-type-label{border-radius:.25rem;font-size:.7rem;font-weight:600;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase}.photo-type-retake{background-color:#ddd6fe;border:1px solid #a855f7;color:#6b21a8}.photo-type-makeup{background-color:#fef3c7;border:1px solid #f59e0b;color:#92400e}.student-info{padding:.75rem}.student-name{color:#1e293b;font-size:.95rem;font-weight:600;margin:0 0 .5rem}.photo-type-indicator{font-size:.8rem;font-weight:600;margin-left:.25rem}.photo-type-indicator.photo-type-retake{color:#9333ea}.photo-type-indicator.photo-type-makeup{color:#d97706}.student-detail{color:#64748b;font-size:.8rem;margin:.2rem 0}.student-email{color:#94a3b8;font-size:.75rem;margin:.2rem 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-lightbox{align-items:center;background-color:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:3000}.photo-lightbox-content{background-color:#fff;border-radius:.5rem;box-shadow:0 25px 50px -12px #00000080;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.photo-lightbox-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;width:40px;z-index:10}.photo-lightbox-image{height:auto;max-height:90vh;object-fit:contain;width:100%}.photo-lightbox-info{background:linear-gradient(#0000,#000c);bottom:0;color:#fff;left:0;padding:2rem 1.5rem 1.5rem;position:absolute;right:0;text-align:center}.photo-lightbox-name{font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.photo-lightbox-details{font-size:1rem;margin:0;opacity:.9}.edit-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:2000}.edit-modal-content{background-color:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:100%}.edit-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.edit-modal-title{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.edit-modal-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.25rem}.edit-modal-form{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.edit-modal-field{margin-bottom:.5rem}.edit-modal-label{color:#374151;display:block;font-size:.8rem;font-weight:500;margin-bottom:.25rem}.edit-modal-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:.8rem;padding:.5rem;transition:all .2s;width:100%}.edit-modal-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.edit-modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-button-danger{background-color:#ef4444;color:#fff}.modal-button-danger:hover{background-color:#dc2626}.schools-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.schools-form-title{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.schools-form-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.schools-form-actions{display:flex;gap:1rem}.schools-list-title{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.schools-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.school-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;transition:border-color .15s ease}.school-item:hover{border-color:#d1d5db}.school-main{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.school-header{flex:1 1}.school-title{color:#111827;font-size:1.125rem;font-weight:600;line-height:1.2;margin:0 0 .25rem}.school-org{color:#6b7280;font-size:.875rem}.school-actions{display:flex;gap:.25rem;margin-left:.75rem}.action-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:all .1s ease}.action-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.school-details{margin-bottom:.75rem}.detail{color:#6b7280;font-size:.8125rem;line-height:1.3;margin:.125rem 0}.school-link{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:.5rem;margin-bottom:.75rem;padding:.5rem .625rem}.portal-link{color:#3b82f6;flex:1 1;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500;text-decoration:none}.portal-link:hover{text-decoration:underline}.copy-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:all .1s ease}.copy-button:hover{background:#f9fafb}.school-tags{display:flex;flex-wrap:wrap;gap:.375rem}.tag{background:#eff6ff;border:1px solid #dbeafe;border-radius:4px;color:#2563eb;font-size:.6875rem;font-weight:500;padding:.125rem .375rem}.export-settings-section{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.export-settings-title{color:#374151;font-size:1rem;font-weight:600;margin:0 0 .5rem}.export-settings-description{color:#64748b;font-size:.875rem;margin:0 0 1rem}.export-settings-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.export-setting-item{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.export-setting-item input[type=checkbox]{cursor:pointer}@media (max-width:768px){.schools-grid{gap:.5rem;grid-template-columns:1fr}.school-item{padding:.875rem}.school-title{font-size:1rem}.school-details,.school-link,.school-main{margin-bottom:.5rem}}.notifications-summary{color:#64748b;font-size:.875rem;margin:.5rem 0 0}.notifications-filters{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{background-color:#fff;border:2px solid #e5e7eb;border-radius:.5rem;color:#6b7280;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.filter-button:hover{background-color:#f9fafb;border-color:#d1d5db}.filter-button.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.notifications-card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.school-filter{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;gap:1rem;padding:.75rem}.school-filter-label{color:#374151;font-size:.875rem;font-weight:500;white-space:nowrap}.school-filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem}.school-filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.notifications-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:3rem}.loading-icon{color:#3b82f6;height:48px;margin-bottom:1rem;width:48px}.notifications-empty{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.empty-icon{color:#d1d5db;height:64px;margin-bottom:1rem;width:64px}.notifications-empty h3{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.notifications-empty p{font-size:.875rem;margin:0}.notifications-list-view{display:flex;flex-direction:column;gap:1rem}.notification-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;max-width:600px;padding:0 .75rem .75rem;transition:all .2s}.notification-item:hover{box-shadow:0 4px 6px #0000000d;transform:translateY(-1px)}.notification-unread{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-left:5px solid #3b82f6}.notification-applied{background:linear-gradient(135deg,#f0fdf4,#ecfdf5)!important;border-left:5px solid #059669!important}.student-header{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr auto;margin:-.25rem 0 .25rem}.student-name{color:#111827;font-size:1.5rem;font-weight:700;letter-spacing:-.025em;line-height:.9;margin:.15rem 0 .25rem;padding-top:0}.student-details{color:#6b7280;font-size:1rem;font-weight:500;line-height:1.2}.notification-badges{align-items:flex-start;display:flex;gap:.5rem}.applied-badge,.unread-badge{border-radius:.5rem;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.375rem .75rem;text-transform:uppercase;white-space:nowrap}.unread-badge{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 2px 4px #dc26264d;color:#fff}.applied-badge{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 2px 4px #0596694d;color:#fff}.changes-section{margin-bottom:1rem}.changes-title{align-items:center;color:#374151;display:flex;font-size:1.125rem;font-weight:700;gap:.5rem;margin-bottom:.75rem}.changes-title:before{content:"🔄";font-size:1.25rem}.notification-change-detailed{grid-gap:1rem;align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:.5rem;display:grid;gap:1rem;grid-template-columns:140px 1fr;padding:.75rem}.change-field-detailed{word-wrap:break-word;font-size:.85rem;font-weight:700;letter-spacing:.05em;line-height:1.2;text-transform:uppercase}.change-values{font-size:1rem;gap:.75rem;min-width:0}.new-value,.old-value{border-radius:.375rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:.95rem;font-weight:600;max-width:180px;overflow:hidden;padding:.375rem .75rem;text-overflow:ellipsis;white-space:nowrap}.old-value{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;color:#dc2626}.new-value{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0}.change-arrow{flex-shrink:0;font-size:1.125rem;font-weight:900}.notification-changes-more{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:.375rem;font-size:.875rem;font-weight:500;padding:.5rem}.notification-footer{grid-gap:1rem;align-items:center;border-top:2px solid #f1f5f9;display:grid;gap:1rem;grid-template-columns:1fr auto;padding-top:1rem}.notification-meta{align-items:center;color:#6b7280;display:flex;font-size:.9rem;font-weight:500;gap:.5rem}.notification-meta:before{content:"⏰";font-size:1rem}.notification-actions{align-items:center;display:flex;gap:.75rem}.mark-read-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.5rem;box-shadow:0 2px 4px #3b82f64d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s;width:36px}.mark-read-btn:hover{box-shadow:0 4px 8px #3b82f666;transform:translateY(-1px)}.applied-checkbox{align-items:center;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid #e5e7eb;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.5rem .75rem;transition:all .2s;white-space:nowrap}.applied-checkbox:hover{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-color:#059669;transform:translateY(-1px)}.applied-checkbox input{display:none}.checkbox-icon{background-color:#fff;border:2px solid #d1d5db;border-radius:.25rem;box-shadow:0 1px 2px #0000000d;color:#0000;flex-shrink:0;height:18px;transition:all .2s;width:18px}.checkbox-icon.checked{background:linear-gradient(135deg,#059669,#10b981);border-color:#059669;box-shadow:0 2px 4px #0596694d;color:#fff}.applied-checkbox:hover .checkbox-icon{border-color:#059669;transform:scale(1.05)}.notification-changes-detailed{display:flex;flex-direction:column;gap:.5rem}.notification-changes-detailed-compact{gap:.375rem}.notification-change-detailed{background-color:#f8fafc;border-radius:.375rem;display:flex;flex-direction:column;gap:.25rem;padding:.5rem}.notification-change-detailed-compact{border-radius:.25rem;gap:.125rem;padding:.375rem}.change-field-detailed{color:#374151;font-size:.8rem;font-weight:600}.change-field-detailed-compact{font-size:.75rem}.change-values{align-items:center;display:flex;font-size:.8rem;gap:.5rem}.change-values-compact{font-size:.75rem;gap:.375rem}.old-value{background-color:#fef2f2;border-radius:.25rem;color:#ef4444;font-family:Monaco,Menlo,Ubuntu Mono,monospace;padding:.125rem .375rem}.old-value-compact{font-size:.7rem;padding:.1rem .25rem}.new-value{background-color:#f0fdf4;border-radius:.25rem;color:#059669;font-family:Monaco,Menlo,Ubuntu Mono,monospace;padding:.125rem .375rem}.new-value-compact{font-size:.7rem;padding:.1rem .25rem}.change-arrow{color:#6b7280;font-weight:600}.notification-changes-more{background-color:#f1f5f9;border-radius:.25rem;color:#6b7280;font-size:.75rem;font-style:italic;padding:.25rem .5rem;text-align:center}.notification-studio-status{background-color:#fafbfc;border:1px solid #e5e7eb;border-radius:.5rem;margin-top:.75rem;padding:.75rem}.studio-status-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem}.studio-status-checkbox{opacity:0;pointer-events:none;position:absolute}.studio-status-icon{background-color:#fff;border:2px solid #d1d5db;border-radius:.25rem;color:#0000;flex-shrink:0;height:20px;transition:all .2s;width:20px}.studio-status-icon.checked{background-color:#22c55e;border-color:#22c55e;color:#fff}.studio-status-label:hover .studio-status-icon{border-color:#22c55e}.studio-status-text{-webkit-user-select:none;user-select:none}.files-view .card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.25rem}.files-view .card-title{color:#1e293b;font-size:1rem;font-weight:600;line-height:1.2;margin:0 0 .125rem}.files-summary{color:#64748b;font-size:.6875rem;line-height:1.3;margin:0}.files-actions{align-items:center;display:flex;gap:.75rem}.files-empty-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.files-empty-state .empty-state-icon{color:#d1d5db;height:64px;margin-bottom:1rem;width:64px}.files-empty-state .empty-state-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.files-empty-state .empty-state-text{color:#6b7280;font-size:.875rem;margin:0}.folder-tabs{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.25rem;display:flex;margin-bottom:.5rem;padding:.125rem}.folder-tab{align-items:center;background:none;border:none;border-radius:.25rem;color:#64748b;cursor:pointer;display:flex;flex:1 1;font-size:.75rem;font-weight:500;gap:.25rem;justify-content:center;padding:.375rem .5rem;position:relative;transition:all .2s}.folder-tab:hover{background-color:#f1f5f9}.folder-tab.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#3b82f6}.read-only-badge{background-color:#fef3c7;border-radius:.1875rem;color:#d97706;font-size:.625rem;margin-left:.375rem;padding:.0625rem .25rem}.files-toolbar-container{margin-bottom:.5rem;min-height:70px}.files-toolbar{background-color:#fff;border:1px solid #e5e7eb;border-radius:.25rem}.files-toolbar,.files-toolbar-secondary{align-items:center;display:flex;gap:.5rem;min-height:32px;padding:.375rem .625rem}.files-toolbar-secondary{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:0 0 .25rem .25rem;border-top:none;justify-content:space-between;margin-top:-1px}.toolbar-empty-message{align-items:center;color:#9ca3af;display:flex;font-size:.75rem;height:24px;justify-content:center;text-align:center;width:100%}.toolbar-section{align-items:center;display:flex;gap:.25rem}.toolbar-divider{background-color:#e5e7eb;height:16px;margin:0 .25rem;width:1px}.toolbar-button{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:.1875rem;color:#374151;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.1875rem;height:26px;padding:.25rem .5rem;transition:all .15s ease;white-space:nowrap}.toolbar-button-small{font-size:.6875rem;height:24px;padding:.1875rem .375rem}.toolbar-button:hover{background-color:#f9fafb;border-color:#d1d5db}.toolbar-button:active{background-color:#f3f4f6}.toolbar-button-icon{justify-content:center;min-width:26px;padding:.25rem}.toolbar-button-primary{background-color:#fafbfc;border-color:#d1d5db;color:#1f2937}.toolbar-button-primary:hover{background-color:#f3f4f6;border-color:#9ca3af}.toolbar-button-danger{color:#dc2626}.toolbar-button-danger:hover{background-color:#fef2f2;border-color:#fecaca;color:#b91c1c}.toolbar-button:disabled{cursor:not-allowed;opacity:.5}.toolbar-button:disabled:hover{background-color:#fff;border-color:#e5e7eb}.selection-badge{align-items:center;background-color:#e0e7ff;border:1px solid #c7d2fe;border-radius:.1875rem;color:#3730a3;display:inline-flex;font-size:.6875rem;font-weight:600;height:24px;padding:.1875rem .375rem}.toolbar-search{flex:1 1;margin:0 auto;max-width:240px}.search-box{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.1875rem;display:flex;height:26px;padding:0 .375rem;position:relative;transition:all .15s ease}.search-box:focus-within{background-color:#fff;border-color:#9ca3af;box-shadow:0 0 0 3px #9ca3af1a}.search-box svg{color:#9ca3af;flex-shrink:0;height:12px;width:12px}.search-input{background:none;border:none;color:#111827;font-size:.75rem;outline:none;padding:0 .25rem;width:100%}.search-input::placeholder{color:#9ca3af}.view-toggle{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.1875rem;display:flex;height:26px;padding:1px}.view-toggle-button{align-items:center;background:none;border:none;border-radius:.0625rem;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:0 .375rem;transition:all .15s ease}.view-toggle-button:hover{color:#374151}.view-toggle-button.active{background-color:#fff;box-shadow:0 1px 2px #0000000d;color:#111827}.view-toggle-button svg{height:12px;width:12px}.breadcrumbs{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.25rem;margin-bottom:.5rem;overflow-x:auto;padding:.375rem .75rem}.breadcrumb-item,.breadcrumbs{align-items:center;display:flex;gap:.0625rem}.breadcrumb-item{background:none;border:none;border-radius:.125rem;color:#64748b;cursor:pointer;font-size:.75rem;padding:.1875rem .25rem;transition:all .2s;white-space:nowrap}.breadcrumb-item:hover{background-color:#e2e8f0}.breadcrumb-item.active{color:#3b82f6;font-weight:500}.breadcrumb-separator{color:#9ca3af;flex-shrink:0}.parent-navigation{align-items:center;background:linear-gradient(90deg,#f8fafc,#fff);border:1px solid #e2e8f0;border-radius:.375rem;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;margin:.5rem 0;overflow:hidden;padding:.75rem 1rem;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.parent-navigation:hover{background:linear-gradient(90deg,#eff6ff,#f0f9ff);border-color:#3b82f6;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.parent-navigation:active{box-shadow:0 1px 2px #0000000d;transform:translateY(0)}.parent-navigation svg{color:#3b82f6;flex-shrink:0}.parent-nav-text{flex:1 1}.parent-nav-text strong{color:#1f2937;font-weight:600}.drop-hint{color:#6b7280;font-size:.75rem;font-style:italic;position:absolute;right:1rem}.parent-navigation.drop-zone-active{background:#f8fafc;border-style:dashed;border-width:2px}.parent-navigation.drop-zone-active:hover{background:#f3f4f6;border-color:#9ca3af}.parent-navigation.drag-over{background:linear-gradient(90deg,#dbeafe,#eff6ff)!important;border-color:#3b82f6!important;box-shadow:0 4px 6px -1px #3b82f633;color:#1e40af;transform:scale(1.02)}.parent-navigation.drag-over .drop-hint{color:#1e40af;font-weight:500}.upload-progress{background-color:#eff6ff;border:1px solid #bae6fd;border-radius:.25rem;margin-bottom:.5rem;padding:.5rem}.upload-progress-bar{background-color:#e0e7ff;border-radius:2px;height:4px;margin-bottom:.25rem;overflow:hidden;width:100%}.upload-progress-fill{background-color:#3b82f6;border-radius:2px;height:100%;transition:width .3s ease}.upload-progress-text{color:#1e40af;font-size:.75rem;font-weight:500}.files-container{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;min-height:400px;overflow:hidden;position:relative}.files-container.drag-over{background-color:#eff6ff;border-color:#3b82f6}.files-container.drag-over .drop-zone-overlay{opacity:1;pointer-events:auto}.drop-zone-overlay{align-items:center;background-color:#3b82f61a;border:2px dashed #3b82f6;border-radius:.375rem;bottom:0;display:flex;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:all .2s;z-index:10}.drop-zone-content{color:#3b82f6;text-align:center}.drop-zone-content svg{margin-bottom:1rem}.drop-zone-content h3{font-size:1.25rem;font-weight:600;margin:0}.files-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.loading-spinner{color:#3b82f6}.zip-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.zip-loading-content{align-items:center;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-width:400px;min-width:300px;padding:2rem}.zip-loading-content .loading-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:48px;margin-bottom:1.5rem;width:48px}.zip-loading-text{color:#1f2937;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.zip-loading-progress{color:#6b7280;font-size:.875rem;text-align:center}.files-empty{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.files-empty .empty-icon{color:#d1d5db;height:48px;margin-bottom:1rem;width:48px}.files-empty h3{color:#374151;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.files-empty p{font-size:.875rem;margin:0}.files-grid{background-color:#fafbfc;min-height:300px;padding:.75rem;-webkit-user-select:none;user-select:none}.files-grid.grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.files-grid.list{gap:.5rem}.file-item,.files-grid.list{display:flex;flex-direction:column}.file-item{background-color:#fff;border:1px solid #e8eaed;border-radius:8px;box-shadow:0 1px 2px 0 #3c40434d,0 1px 3px 1px #3c404326;cursor:pointer;overflow:hidden;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.file-item:hover{border-color:#dadce0;box-shadow:0 1px 3px 0 #3c40434d,0 4px 8px 3px #3c404326;transform:translateY(-1px)}.file-item-selected{background-color:#e8f0fe;border-color:#e8eaed;box-shadow:0 1px 2px 0 #3c40434d,0 1px 3px 1px #3c404326}.file-item-selected .file-header{background-color:#e8f0fe;border-bottom:1px solid #d1e7fd}.file-item-selected .file-preview-area{background-color:#f0f7ff}.file-item-selected .file-header-name{color:#1565c0;font-weight:500}.files-grid.grid .file-item{height:180px;width:100%}.files-grid.list .file-item{align-items:center;flex-direction:row;gap:12px;height:48px;min-height:auto;padding:8px 16px}.files-grid.list .file-item-selected{background-color:#e8f0fe}.file-item.dragging{animation:pickupFloat .8s ease-in-out infinite!important;background-color:#eff6ff!important;border:2px solid #3b82f6!important;box-shadow:0 8px 16px #3b82f666!important;opacity:.6!important;position:relative;transform:scale(.95) rotate(3deg)!important;transition:none!important;z-index:9999!important}@keyframes pickupFloat{0%,to{transform:scale(.95) rotate(3deg) translateY(0)}50%{transform:scale(.95) rotate(3deg) translateY(-2px)}}.file-item.dragging .file-header,.file-item.dragging .file-preview-area{background-color:#dbeafe!important}.file-item.dragging:after{animation:movingTextFloat 1s ease-in-out infinite;background-color:#3b82f6e6;border-radius:.5rem;color:#fff;content:"Moving...";font-size:.875rem;font-weight:600;left:50%;padding:.5rem 1rem;pointer-events:none;position:absolute;text-shadow:0 1px 2px #0000004d;top:50%;transform:translate(-50%,-50%);z-index:10001}@keyframes movingTextFloat{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-3px)}}.file-item.drag-over-folder{background-color:#eff6ff!important;border:2px dashed #3b82f6!important;box-shadow:0 8px 16px #3b82f633!important;transform:scale(1.02)!important;transition:all .2s ease!important;z-index:100}.file-item.drag-over-folder .file-header,.file-item.drag-over-folder .file-preview-area{background-color:#dbeafe!important}.file-item.moving{background-color:#fef3c7!important;border:2px solid #f59e0b!important;opacity:.6!important;pointer-events:none!important;position:relative;transform:scale(.98)!important;transition:all .3s ease!important}.file-item.moving:after{animation:pulse 1.5s ease-in-out infinite;background-color:#f59e0be6;border-radius:.375rem;color:#fff;content:"Moving...";font-size:.75rem;font-weight:600;left:50%;padding:.25rem .75rem;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1000}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.file-item.moving .file-header,.file-item.moving .file-preview-area{background-color:#fef3c7!important}.file-item[draggable=true]{cursor:move!important}.file-item[draggable=true]:hover:not(.dragging):not(.moving){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.files-container.internal-drag .drop-zone-overlay{display:none!important}.files-container.internal-drag{background-color:#f8fafc!important;border-color:#e2e8f0!important}.file-header{align-items:center;background-color:#fff;border-bottom:1px solid #f1f3f4;display:flex;flex-shrink:0;gap:4px;min-height:28px;padding:6px 8px}.files-grid.list .file-header{display:none}.file-header-icon{flex-shrink:0;height:12px;width:12px}.file-header-name{color:#202124;flex:1 1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:500;letter-spacing:-.01em;line-height:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-count-indicator{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffffe6;border:1px solid #e5e7ebcc;border-radius:6px;box-shadow:0 1px 2px #0000000d;display:flex;gap:6px;padding:3px 6px;position:absolute;right:4px;top:4px;z-index:1}.count-item{align-items:center;display:flex;gap:2px}.count-icon{color:#9ca3af;flex-shrink:0;height:10px;width:10px}.count-number{color:#6b7280;font-size:10px;font-weight:500;line-height:12px}.file-item:hover .folder-count-indicator{background-color:#e5e7ebf2}.file-item:hover .count-icon{color:#6b7280}.file-item:hover .count-number{color:#4b5563}.file-item-selected .folder-count-indicator{background-color:#3b82f626}.file-item-selected .count-icon{color:#3b82f6}.file-item-selected .count-number{color:#2563eb}.file-preview-area{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #f1f3f4;border-left:1px solid #f1f3f4;border-radius:0 0 4px 4px;border-right:1px solid #f1f3f4;display:flex;flex:1 1;justify-content:center;margin:0 4px 4px;overflow:hidden;position:relative}.files-grid.list .file-preview-area{border:1px solid #f1f3f4;border-radius:4px;flex-shrink:0;flex:none;height:32px;margin:0;width:32px}.file-type-icon{align-items:center;display:flex;height:48px;justify-content:center;position:relative;width:48px}.files-grid.list .file-type-icon{height:20px;width:20px}.file-header .file-type-icon{height:12px;width:12px}.file-type-icon svg{height:100%;width:100%}.file-type-icon.pdf{color:#ea4335}.file-type-icon.doc,.file-type-icon.docx{color:#4285f4}.file-type-icon.xls,.file-type-icon.xlsx{color:#0f9d58}.file-type-icon.ppt,.file-type-icon.pptx{color:#ff6d00}.file-type-icon.gif,.file-type-icon.jpeg,.file-type-icon.jpg,.file-type-icon.png,.file-type-icon.webp{color:#4285f4}.file-type-icon.rar,.file-type-icon.zip{color:#9aa0a6}.file-type-icon.txt{color:#5f6368}.file-type-icon.folder{color:#1a73e8}.file-type-icon.default{color:#5f6368}.file-thumbnail{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.file-info-list{align-items:center;display:flex;flex:1 1;gap:12px;min-height:0}.file-name-list{color:#202124;flex:1 1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:500;letter-spacing:-.01em;margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-selected .file-name-list{color:#1565c0;font-weight:600}.file-meta-list{color:#5f6368;display:flex;font-size:10px;gap:12px;white-space:nowrap}.file-menu-button{align-items:center;background:none;border:none;color:#5f6368;cursor:pointer;display:flex;height:20px;justify-content:center;opacity:1;position:absolute;right:2px;top:2px;transition:all .2s;width:20px}.file-menu-button:hover{background-color:#3c404314;border-radius:50%;color:#202124}.files-grid.list .file-menu-button{background:none;height:18px;margin-left:auto;opacity:1;position:static;width:18px}.files-grid.list .file-menu-button:hover{background-color:#3c404314;border-radius:50%}.rename-input{background-color:#fff;border:2px solid #1a73e8;border-radius:4px;font-family:inherit;font-size:11px;outline:none;padding:2px 4px;width:calc(100% - 24px)}.context-menu{background-color:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 2px 10px #0003;min-width:160px;padding:8px 0;position:fixed;z-index:1000}.context-menu-item{align-items:center;background:none;border:none;color:#202124;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:8px 16px;text-align:left;transition:all .2s;width:100%}.context-menu-item:hover{background-color:#f8f9fa}.context-menu-item.danger{color:#d93025}.context-menu-item.danger:hover{background-color:#fce8e6}.folder-name-input{border:1px solid #dadce0;border-radius:4px;font-family:inherit;font-size:14px;outline:none;padding:12px;transition:all .2s;width:100%}.folder-name-input:focus{border-color:#1a73e8;box-shadow:0 0 0 1px #1a73e8}@media (max-width:1024px){.toolbar-search{max-width:180px}}@media (max-width:768px){.files-toolbar{flex-wrap:wrap;gap:.375rem;padding:.5rem}.files-toolbar-secondary{align-items:stretch;flex-direction:column;gap:.375rem}.toolbar-section{flex-wrap:wrap;justify-content:center}.toolbar-search{flex:1 1 100%;margin-bottom:.125rem;max-width:none;order:-1}.files-grid.grid{gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.breadcrumbs{padding:.25rem .5rem}.folder-tabs{flex-direction:column;gap:.125rem}.folder-tab{flex:none}}@media (max-width:480px){.files-grid.grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));padding:.5rem}.file-preview-area{height:100px}.file-header{padding:4px 6px}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.download-result-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:5000}.download-result-modal-container{animation:modalSlideIn .3s ease-out;background-color:#fff;border:1px solid #f1f5f9;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-height:80vh;max-width:500px;overflow-y:auto;width:100%}.download-result-modal-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem;padding:2rem 2rem 0}.download-result-modal-icon-container{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.download-result-modal-success-icon{background-color:#d1fae5;color:#059669}.download-result-modal-warning-icon{background-color:#fef3c7;color:#d97706}.download-result-modal-error-icon{background-color:#fee2e2;color:#dc2626}.download-result-modal-info-icon{background-color:#dbeafe;color:#2563eb}.download-result-modal-title{color:#111827;font-size:1.5rem;font-weight:700;line-height:1.3;margin:0}.download-result-modal-body{padding:0 2rem}.download-result-modal-message{color:#4b5563;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.download-result-modal-stats{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-bottom:1.5rem;padding:1.25rem}.download-result-modal-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.download-result-modal-stat-item{text-align:center}.download-result-modal-stat-number{font-size:1.75rem;font-weight:700;line-height:1;margin:0}.download-result-modal-stat-label{color:#6b7280;font-size:.875rem;font-weight:500;margin-top:.25rem}.download-result-modal-success-number{color:#059669}.download-result-modal-failed-number{color:#dc2626}.download-result-modal-total-number{color:#3b82f6}.download-result-modal-details{background-color:#fafbfc;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.download-result-modal-details-title{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.download-result-modal-details-list{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.download-result-modal-detail-item{margin-bottom:.5rem}.download-result-modal-detail-item:last-child{margin-bottom:0}.download-result-modal-file-info{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;gap:.75rem;margin-bottom:1rem;padding:.75rem}.download-result-modal-file-icon{color:#6b7280;flex-shrink:0;height:20px;width:20px}.download-result-modal-file-name{color:#1f2937;flex:1 1;font-size:.875rem;font-weight:500}.download-result-modal-folder-info{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;gap:.5rem;padding:.75rem}.download-result-modal-folder-path{color:#1f2937;flex:1 1;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:.875rem}.download-result-modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem 2rem}.download-result-modal-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s}.download-result-modal-button-primary{background-color:#3b82f6;color:#fff}.download-result-modal-button-primary:hover{background-color:#2563eb}.download-result-modal-button-secondary{background-color:#f3f4f6;border:1px solid #d1d5db;color:#374151}.download-result-modal-button-secondary:hover{background-color:#e5e7eb}.download-result-modal-loading{align-items:center;display:flex;flex-direction:column;padding:1rem}.download-result-modal-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:32px;margin-bottom:1rem;width:32px}.download-result-modal-loading-text{color:#6b7280;font-size:.875rem;text-align:center}@media (max-width:640px){.download-result-modal-container{border-radius:.75rem;margin:1rem;max-width:calc(100vw - 2rem)}.download-result-modal-header{margin-bottom:1rem;padding:1.5rem 1.5rem 0}.download-result-modal-body{padding:0 1.5rem}.download-result-modal-footer{flex-direction:column;padding:1rem 1.5rem 1.5rem}.download-result-modal-button{justify-content:center;width:100%}.download-result-modal-stats-grid{gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.download-result-modal-stat-number{font-size:1.5rem}}.yearbook-proofing-view{display:flex;flex-direction:column;height:calc(100vh - 70px);overflow:hidden}.yearbook-proofing-view.fullscreen{background-color:#1a1a1a;bottom:0;height:100vh;left:0;position:fixed;right:0;top:0;z-index:9999}.yearbook-proofing-view.fullscreen .yearbook-header{display:none}.yearbook-proofing-view.fullscreen .yearbook-content{flex:1 1;gap:1rem;padding:1rem}.yearbook-proofing-view.fullscreen .yearbook-main{flex:1 1}.yearbook-proofing-view.fullscreen .pdf-spread-container{background-color:#2a2a2a;border:none;border-radius:0;padding:1rem}.yearbook-proofing-view.fullscreen .comments-sidebar{background-color:#333;border-color:#555;color:#fff}.yearbook-proofing-view.fullscreen .comments-sidebar .comments-header h3{color:#fff}.yearbook-proofing-view.fullscreen .comment-item{background-color:#444;color:#fff}.fullscreen-exit{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .2s ease;width:48px;z-index:10000}.fullscreen-exit:hover{background-color:#000000e6;transform:scale(1.05)}.fullscreen-zoom-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000d9;border:1px solid #ffffff26;border-radius:8px;box-shadow:0 4px 20px #00000080;display:flex;gap:8px;left:20px;padding:10px 14px;position:fixed;top:20px;z-index:10001}.fullscreen-zoom-btn{align-items:center;background:#ffffff26;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:34px;justify-content:center;transition:background-color .2s ease;width:34px}.fullscreen-zoom-btn:hover{background:#ffffff40}.fullscreen-zoom-btn:active{background:#ffffff59}.fullscreen-zoom-display{color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:600;min-width:50px;text-align:center}.fullscreen-zoom-help{color:#ffffffbf;font-size:12px;font-weight:500;margin-left:8px}.fullscreen-nav-indicator{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;border-radius:2rem;bottom:20px;color:#fff;display:flex;font-size:.875rem;font-weight:500;gap:1rem;left:50%;padding:.75rem 1.5rem;pointer-events:none;position:fixed;transform:translateX(-50%);z-index:10000}.yearbook-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:.125rem;padding:.25rem 0 .125rem}.yearbook-header-left{flex:1 1}.yearbook-title{color:#1e293b;font-size:1.125rem;font-weight:700;line-height:1.1;margin:0 0 .0625rem}.yearbook-info{align-items:center;color:#64748b;display:flex;font-size:.6875rem;gap:.375rem;line-height:1.2}.yearbook-filename{color:#374151;font-weight:500}.yearbook-pages{color:#64748b}.fullscreen-button,.yearbook-controls,.yearbook-header-right{align-items:center;display:flex;gap:.375rem}.fullscreen-button{background-color:#6366f1;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.5rem .75rem;transition:all .2s}.fullscreen-button:hover{background-color:#4f46e5}.zoom-controls{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;gap:.375rem;padding:.125rem}.zoom-button,.zoom-controls{align-items:center;display:flex}.zoom-button{background:none;border:none;border-radius:.1875rem;color:#6b7280;cursor:pointer;height:28px;justify-content:center;transition:all .2s;width:28px}.zoom-button:hover{background-color:#f3f4f6;color:#374151}.zoom-level{color:#374151;font-size:.8125rem;font-weight:500;min-width:40px;text-align:center}.loading-state{align-items:center;color:#64748b;display:flex;flex:1 1;flex-direction:column;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:32px;margin-bottom:1rem;width:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.yearbook-content{gap:1rem;overflow:hidden}.yearbook-content,.yearbook-main{display:flex;flex:1 1;min-height:0}.yearbook-main{flex-direction:column;min-width:0}.yearbook-navigation{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.75rem 1rem}.nav-button{align-items:center;background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .75rem;transition:all .2s}.nav-button:hover:not(:disabled){background-color:#2563eb}.nav-button:disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.spread-indicator{align-items:center;display:flex;flex-direction:column;gap:.1875rem}.spread-current{color:#1e293b;font-size:1rem;font-weight:600}.spread-total{color:#64748b;font-size:.8125rem}.page-numbers{align-items:center;color:#64748b;display:flex;font-size:.6875rem;gap:.375rem;margin-top:.1875rem}.page-separator{opacity:.5}.pdf-spread-container{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem;flex:1 1;min-height:0;min-width:0;overflow:auto;padding:.5rem;position:relative}.nav-button-modern,.pdf-spread-container{align-items:center;display:flex;justify-content:center}.nav-button-modern{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#fffffff2;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;cursor:pointer;height:40px;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s ease;width:40px;z-index:30}.nav-button-modern:hover:not(:disabled){background-color:#fff;box-shadow:0 6px 20px #00000040;transform:translateY(-50%) scale(1.05)}.nav-button-modern:disabled{background-color:#e2e8f0f2;cursor:not-allowed;opacity:.6}.nav-button-modern:disabled:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-50%)}.pdf-spread-container .nav-button-left{left:10px}.pdf-spread-container .nav-button-right{right:10px}.pdf-page{align-items:center;background-color:#fff;border-radius:4px;cursor:crosshair;display:flex;justify-content:center;min-height:700px;overflow:hidden;position:relative;width:525px}.pdf-page img{display:block;height:auto;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%}.pdf-page-left{border-radius:4px 0 0 4px}.pdf-page-right{border-radius:0 4px 4px 0}.blank-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px dashed #cbd5e1}.blank-page-content{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:1rem;font-weight:500;gap:1rem}.comment-marker{align-items:center;background-color:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #ef444466;color:#fff;cursor:pointer;display:flex;height:20px;justify-content:center;position:absolute;transform:translate(-50%,-50%);transition:all .2s;width:20px;z-index:10}.comment-marker:hover{background-color:#dc2626;box-shadow:0 4px 12px #ef444499;transform:translate(-50%,-50%) scale(1.1)}.comment-marker.resolved{background-color:#10b981}.comment-marker.resolved:hover{background-color:#059669}.comments-sidebar{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;transition:width .3s ease,transform .3s ease;width:300px}.comments-sidebar.collapsed{width:50px}.comments-sidebar.collapsed .comments-content{opacity:0;pointer-events:none}.comments-header{border-bottom:1px solid #e2e8f0;min-height:60px;padding:1rem 1rem .75rem;position:relative}.comments-header h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 .5rem}.comments-summary{display:flex;gap:.75rem}.collapse-toggle{align-items:center;background-color:#f8fafc;border:none;border-radius:.25rem;color:#64748b;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:28px}.collapse-toggle:hover{background-color:#e2e8f0;color:#374151}.comments-content{display:flex;flex:1 1;flex-direction:column;transition:opacity .3s ease}.collapsed-indicator{color:#64748b;font-size:.75rem;font-weight:600;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%) rotate(-90deg);transition:opacity .3s ease .2s;white-space:nowrap}.comments-sidebar.collapsed .collapsed-indicator{opacity:1}.comment-count{border-radius:.1875rem;font-size:.6875rem;font-weight:500;padding:.1875rem .375rem}.comment-count.open{background-color:#fef2f2;color:#dc2626}.comment-count.resolved{background-color:#f0fdf4;color:#16a34a}.comments-list{flex:1 1;overflow-y:auto;padding:.75rem}.comment-item{background-color:#f8fafc;border-left:4px solid #e5e7eb;border-radius:.375rem;margin-bottom:.75rem;padding:.75rem}.comment-item.open{border-left-color:#ef4444}.comment-item.resolved{border-left-color:#10b981}.comment-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.comment-meta{display:flex;flex-direction:column;gap:.1875rem}.comment-page{color:#3b82f6;font-size:.6875rem;font-weight:500}.comment-author{color:#64748b;font-size:.6875rem}.comment-actions{display:flex;gap:.375rem}.action-button{align-items:center;background:none;border:none;border-radius:.1875rem;color:#6b7280;cursor:pointer;display:flex;height:20px;justify-content:center;transition:all .2s;width:20px}.action-button:hover{background-color:#e5e7eb;color:#374151}.action-button.resolve{color:#10b981}.action-button.resolve:hover{background-color:#f0fdf4;color:#059669}.action-button.delete{color:#ef4444}.action-button.delete:hover{background-color:#fef2f2;color:#dc2626}.comment-text{color:#374151;font-size:.8125rem;line-height:1.4;white-space:pre-wrap;word-break:break-word}.comment-form{background-color:#fafafa;border-top:1px solid #e2e8f0;padding:.75rem}.form-title{color:#374151;font-size:.8125rem;font-weight:500;margin-bottom:.5rem}.form-group{margin-bottom:.75rem}.form-group label{color:#374151;display:block;font-size:.6875rem;font-weight:500;margin-bottom:.1875rem}.form-input,.form-textarea{border:1px solid #d1d5db;border-radius:.25rem;font-size:.8125rem;padding:.375rem;transition:border-color .2s;width:100%}.form-input:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-textarea{min-height:60px;resize:vertical}.form-actions{justify-content:space-between}.button,.form-actions{display:flex;gap:.375rem}.button{border-radius:.25rem;font-size:.8125rem;padding:.375rem .75rem}.button-outline{background-color:initial;color:#6b7280}.button-outline:hover{color:#374151}.yearbook-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.yearbook-modal-content{background-color:#fff;border-radius:.5rem;max-height:80vh;max-width:500px;overflow-y:auto;padding:1rem;width:90%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.modal-title{color:#1e293b;font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.1875rem}.modal-close:hover{color:#374151}.comment-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{align-items:flex-start;display:flex;gap:.5rem}.detail-row strong{color:#374151;font-weight:600;min-width:70px}.status-badge{border-radius:.1875rem;font-size:.6875rem;font-weight:500;padding:.1875rem .375rem}.status-badge.open{background-color:#fef2f2;color:#dc2626}.status-badge.resolved{background-color:#f0fdf4;color:#16a34a}.comment-text-full{background-color:#f8fafc;border-radius:.375rem;flex:1 1;font-size:.8125rem;line-height:1.4;padding:.5rem;white-space:pre-wrap;word-break:break-word}.empty-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:3rem 1.5rem}.empty-state svg{color:#d1d5db;margin-bottom:.75rem}.empty-state h3{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 .375rem}.empty-state p{font-size:.8125rem;margin:0}@media (max-width:1200px){.comments-sidebar{width:250px}.pdf-page{min-height:520px;width:380px}}@media (max-width:1024px){.yearbook-content{flex-direction:column}.comments-sidebar{height:250px;width:100%}.pdf-page{min-height:450px;width:330px}.yearbook-header{align-items:stretch;flex-direction:column;gap:.75rem}.yearbook-controls{justify-content:space-between}}@media (max-width:768px){.pdf-spread{flex-direction:column;gap:1rem}.pdf-page{min-height:360px;width:280px}.pdf-page-left,.pdf-page-right{border-radius:4px}.yearbook-navigation{flex-direction:column;gap:.75rem;text-align:center}.nav-button{justify-content:center;width:100%}.yearbook-modal-content{margin:.75rem;max-width:calc(100vw - 1.5rem)}.nav-button-modern{height:36px;width:36px}.nav-button-left{left:10px}.nav-button-right{right:10px}}.button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.button-primary{background-color:#3b82f6;color:#fff}.button-primary:hover{background-color:#2563eb}.button-secondary{background-color:#10b981;color:#fff}.button-secondary:hover{background-color:#059669}.button-danger{background-color:#ef4444;color:#fff}.button-danger:hover{background-color:#dc2626}.button-outline{background-color:#fff;border:1px solid #d1d5db;color:#374151}.button-outline:hover{background-color:#f9fafb}.button-full{justify-content:center;padding:.75rem;width:100%}.card{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.card,.card-header{margin-bottom:1.5rem}.card-header{align-items:center;display:flex;justify-content:space-between}.card-title{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.input{border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;padding:.75rem;transition:all .2s;width:100%}.input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.input-group{margin-bottom:1rem}.input-with-icon{position:relative}.icon-button{background:none;border:none;color:#6b7280;cursor:pointer;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.icon-button:hover{color:#374151}.grid{grid-gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid,.grid-three{display:grid;gap:1.5rem}.grid-three{grid-gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat{align-items:center;display:flex;gap:1rem}.stat-number{font-size:2rem;font-weight:700;margin:0}.stat-label{color:#374151;font-size:1.125rem;font-weight:600;margin:0}.alert{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;color:#92400e;margin-bottom:1rem;padding:.75rem 1rem}.empty-state{color:#6b7280;padding:4rem 2rem;text-align:center}.empty-state-icon{color:#d1d5db;height:64px;margin:0 auto 1rem;width:64px}.empty-state-title{color:#374151;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.empty-state-text{color:#6b7280;font-size:.875rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.app{font-feature-settings:"cv01","cv02","cv03","cv04";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;display:flex;flex-direction:column;font-family:Inter,Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;min-height:100vh}.main-layout{display:flex;flex:1 1;width:100%}.content{background-color:#f8fafc;flex:1 1;padding:2rem}
/*# sourceMappingURL=main.12640eef.css.map*/