.fade-enter-active,.fade-leave-active{transition:opacity .25s}.fade-enter-from,.fade-leave-to{opacity:0}.user-menu-wrapper[data-v-e4576521]{position:relative}.user-menu-trigger[data-v-e4576521]{all:unset;display:flex;align-items:center;cursor:pointer}.user-menu[data-v-e4576521]{position:absolute;top:100%;right:0;margin-top:.5rem;padding:1rem;width:18rem;background-color:var(--card-bg, #fff);border:1px solid var(--card-border, #ddd);border-radius:.5rem;box-shadow:0 4px 8px #0000001a;z-index:1000}.user-info-section[data-v-e4576521]{margin-bottom:1rem}.user-info-layout[data-v-e4576521]{display:flex;align-items:center;gap:1rem}.user-avatar-container[data-v-e4576521]{flex-shrink:0}.user-text-info[data-v-e4576521]{flex:1;min-width:0}.user-name[data-v-e4576521]{font-weight:600;color:var(--text-primary, #111)}.user-email[data-v-e4576521]{font-size:.875rem;color:var(--text-muted, #666)}.menu-items[data-v-e4576521]{margin-bottom:1rem}.menu-item[data-v-e4576521]{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;transition:background-color .2s ease}.menu-item[data-v-e4576521]:hover{background-color:var(--item-hover-bg, #f5f5f5)}.menu-item-icon[data-v-e4576521]{font-size:1.25rem;color:var(--icon-color, #333)}.logout-section[data-v-e4576521]{text-align:center}.logout-button[data-v-e4576521]{width:100%;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-button[data-v-e4576521]:disabled{cursor:not-allowed;opacity:.6}.animate-spin[data-v-e4576521]{animation:spin-e4576521 1s linear infinite}@keyframes spin-e4576521{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.debug-console[data-v-7331d068]{position:fixed;bottom:20px;right:20px;width:90vw;max-width:500px;max-height:60vh;background:#000000f2;border:2px solid #00ff00;border-radius:12px;box-shadow:0 8px 32px #00ff004d;z-index:999999;display:flex;flex-direction:column;font-family:Courier New,monospace;color:#0f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.debug-header[data-v-7331d068]{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid #00ff00;background:#00ff001a}.debug-title[data-v-7331d068]{margin:0;font-size:16px;font-weight:700;color:#0f0}.debug-actions[data-v-7331d068]{display:flex;gap:8px}.debug-btn[data-v-7331d068]{background:#0f03;border:1px solid #00ff00;color:#0f0;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.debug-btn[data-v-7331d068]:hover{background:#00ff004d;transform:scale(1.05)}.debug-btn[data-v-7331d068]:active{transform:scale(.95)}.debug-body[data-v-7331d068]{flex:1;overflow-y:auto;padding:12px;font-size:12px;line-height:1.4}.debug-log[data-v-7331d068]{margin-bottom:8px;padding:8px;border-radius:6px;word-break:break-word;white-space:pre-wrap}.debug-log-log[data-v-7331d068]{background:#00ff001a;border-left:3px solid #00ff00}.debug-log-error[data-v-7331d068]{background:#ff00001a;border-left:3px solid #ff0000;color:#ff6b6b}.debug-log-warn[data-v-7331d068]{background:#ffa5001a;border-left:3px solid #ffa500;color:#fc0}.debug-timestamp[data-v-7331d068]{display:inline-block;margin-right:8px;color:#888;font-size:10px}.debug-message[data-v-7331d068]{color:inherit}.debug-empty[data-v-7331d068]{text-align:center;color:#666;padding:20px;font-style:italic}.debug-toggle-btn[data-v-7331d068]{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,#0f0,#0c0);color:#000;border:2px solid #00ff00;padding:14px 20px;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #0f06;z-index:999998;transition:all .3s;font-family:Courier New,monospace}.debug-toggle-btn[data-v-7331d068]:hover{transform:scale(1.1);box-shadow:0 6px 24px #0f09}.debug-toggle-btn[data-v-7331d068]:active{transform:scale(.95)}@media (max-width: 640px){.debug-console[data-v-7331d068]{width:95vw;max-height:70vh;bottom:10px;right:50%;transform:translate(50%)}.debug-toggle-btn[data-v-7331d068]{bottom:10px;right:10px;padding:12px 16px;font-size:14px}.debug-body[data-v-7331d068]{font-size:11px}.debug-btn[data-v-7331d068]{padding:4px 8px;font-size:12px}}.debug-body[data-v-7331d068]::-webkit-scrollbar{width:8px}.debug-body[data-v-7331d068]::-webkit-scrollbar-track{background:#00ff001a;border-radius:4px}.debug-body[data-v-7331d068]::-webkit-scrollbar-thumb{background:#0f0;border-radius:4px}.debug-body[data-v-7331d068]::-webkit-scrollbar-thumb:hover{background:#0c0}.page-header{text-align:center;padding:2rem 1rem;position:relative;overflow:hidden}.header-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.welcome-section{flex:1}.page-title{font-size:2.5rem;font-weight:700;color:var(--heading);margin-bottom:1rem;background:linear-gradient(135deg,var(--accent),#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:1.1rem;color:var(--muted);max-width:500px;margin:0 auto;line-height:1.6}@media (max-width: 640px){.page-title{font-size:2rem}}.notification-manager[data-v-b733c526]{max-width:600px;margin:0 auto}.notification-actions-section[data-v-b733c526]{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.notification-status-overview[data-v-b733c526]{margin-top:1rem}.notification-status-title[data-v-b733c526]{font-size:1rem;font-weight:600;color:var(--heading);margin-bottom:1rem}.notification-status-items[data-v-b733c526]{display:flex;flex-direction:column;gap:.75rem}.notification-status-item[data-v-b733c526]{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--card);border:1px solid var(--card-border);border-radius:8px;flex-wrap:wrap}.notification-status-indicator[data-v-b733c526]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface);color:var(--muted);flex-shrink:0}.notification-status-indicator.active[data-v-b733c526]{background:var(--accent);color:#fff}.notification-status-label[data-v-b733c526]{font-size:.875rem;color:var(--text);font-weight:500}.notification-status-value[data-v-b733c526]{margin-left:auto;font-size:.875rem;color:var(--muted);font-weight:500}.dark .notification-status-item[data-v-b733c526]{background:var(--surface);border-color:var(--card-border)}.notification-reg-error[data-v-b733c526]{margin-top:.75rem}.notification-reg-error-inner[data-v-b733c526]{padding:.75rem;border-radius:8px;background:#dc26260f;border:1px solid rgba(220,38,38,.12);color:var(--danger);font-size:.9rem}.debug-content[data-v-f9cd778f]{display:grid;gap:.75rem}.debug-item[data-v-f9cd778f]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--card-border)}.debug-label[data-v-f9cd778f]{font-weight:500;color:var(--text)}.debug-value[data-v-f9cd778f]{color:var(--muted);font-family:monospace;font-size:.875rem;text-align:right;max-width:50%;word-break:break-all}.scanner-login-container[data-v-b322796c]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card[data-v-b322796c]{width:100%;max-width:400px;padding:2rem}.logo-section[data-v-b322796c]{text-align:center;margin-bottom:2rem}.school-logo-container[data-v-b322796c]{display:flex;justify-content:center;margin-bottom:1rem}.school-logo[data-v-b322796c]{max-width:120px;max-height:120px;-o-object-fit:contain;object-fit:contain;border-radius:8px}.login-title[data-v-b322796c]{font-size:1.75rem;font-weight:700;margin:1rem 0 .5rem;color:var(--n-text-color)}.login-subtitle[data-v-b322796c]{font-size:.875rem;color:var(--n-text-color-2);margin:0}.error-alert[data-v-b322796c]{margin-bottom:1rem}.login-button[data-v-b322796c]{margin-top:1.5rem;font-weight:600;height:48px}.info-section[data-v-b322796c]{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--n-divider-color);display:flex;align-items:center;gap:.5rem}.info-text[data-v-b322796c]{font-size:.75rem;color:var(--n-text-color-3);line-height:1.4}@media (max-width: 480px){.login-card[data-v-b322796c]{padding:1.5rem}.login-title[data-v-b322796c]{font-size:1.5rem}}.attendance-scanner-fullscreen[data-v-a9d723ab]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.attendance-scanner[data-v-a9d723ab]{padding:1.5rem;max-width:600px;margin:0 auto}.scanner-header[data-v-a9d723ab]{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a}.tenant-logo[data-v-a9d723ab]{width:120px;height:120px;-o-object-fit:contain;object-fit:contain;margin-bottom:1rem;border-radius:20px;background:#fff;padding:10px;box-shadow:0 4px 16px #00000026}.default-logo[data-v-a9d723ab]{display:inline-block;padding:20px;background:#fff;border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 16px #00000026}.scanner-title[data-v-a9d723ab]{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.scanner-subtitle[data-v-a9d723ab]{font-size:1.25rem;font-weight:600;color:#ffffffe6;margin:0}.action-selection[data-v-a9d723ab]{margin-bottom:2rem}.selection-card[data-v-a9d723ab]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:2rem 1.5rem}.selection-title[data-v-a9d723ab]{text-align:center;font-size:1.5rem;font-weight:700;color:#333;margin:0 0 2rem}.selection-buttons[data-v-a9d723ab]{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.selection-btn[data-v-a9d723ab]{background:#fff;border:3px solid transparent;border-radius:16px;padding:2rem 1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #0000001a;text-align:center}.selection-btn[data-v-a9d723ab]:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.entry-selection[data-v-a9d723ab]{border-color:#18a058}.entry-selection[data-v-a9d723ab]:hover{background:linear-gradient(135deg,#18a058,#0e8044)}.entry-selection:hover .btn-icon[data-v-a9d723ab],.entry-selection:hover .btn-title[data-v-a9d723ab],.entry-selection:hover .btn-subtitle[data-v-a9d723ab]{color:#fff}.exit-selection[data-v-a9d723ab]{border-color:#d03050}.exit-selection[data-v-a9d723ab]:hover{background:linear-gradient(135deg,#d03050,#b02040)}.exit-selection:hover .btn-icon[data-v-a9d723ab],.exit-selection:hover .btn-title[data-v-a9d723ab],.exit-selection:hover .btn-subtitle[data-v-a9d723ab]{color:#fff}.btn-icon[data-v-a9d723ab]{margin-bottom:1rem;color:inherit;transition:color .3s ease}.btn-title[data-v-a9d723ab]{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:#333;transition:color .3s ease}.btn-subtitle[data-v-a9d723ab]{font-size:.875rem;color:#666;margin:0;transition:color .3s ease}.scanner-card[data-v-a9d723ab]{margin-bottom:1rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #00000026}.scanner-action-header[data-v-a9d723ab]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.1)}.qr-scanner-container[data-v-a9d723ab]{position:relative;width:100%;min-height:300px;border-radius:12px;overflow:hidden;background-color:#000}.qr-camera[data-v-a9d723ab]{width:100%;height:100%;min-height:300px}.scanner-overlay[data-v-a9d723ab]{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#00000080;color:#fff}.overlay-text[data-v-a9d723ab]{margin-top:1rem;font-size:.875rem}.scanner-paused[data-v-a9d723ab]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--n-text-color)}.paused-icon[data-v-a9d723ab]{margin-bottom:1rem;color:var(--n-primary-color)}.scanner-alert[data-v-a9d723ab]{margin-top:1rem}.user-card[data-v-a9d723ab]{margin-bottom:1rem;text-align:center}.user-info[data-v-a9d723ab]{text-align:center}.user-name[data-v-a9d723ab]{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;color:var(--n-text-color)}.scan-time[data-v-a9d723ab]{display:flex;align-items:center;gap:.5rem;color:var(--n-text-color-2);font-size:.875rem}.time-icon[data-v-a9d723ab]{color:var(--n-primary-color)}.action-buttons[data-v-a9d723ab]{margin-top:1.5rem;width:100%}.action-btn[data-v-a9d723ab]{min-width:140px;font-weight:600}.toggle-list-btn[data-v-a9d723ab]{margin-top:1rem;margin-bottom:1rem;font-weight:600}.recent-entries-card[data-v-a9d723ab]{margin-bottom:1rem}.entry-item[data-v-a9d723ab]{padding:.5rem 0}.entry-header[data-v-a9d723ab]{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.entry-name[data-v-a9d723ab]{font-weight:500;color:var(--n-text-color)}.entry-time[data-v-a9d723ab]{font-size:.875rem;color:var(--n-text-color-3)}.floating-qr-btn[data-v-a9d723ab]{position:fixed;bottom:2rem;right:2rem;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 16px #667eea66;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:1000;color:#fff}.floating-qr-btn[data-v-a9d723ab]:hover{transform:scale(1.1);box-shadow:0 6px 24px #667eea99}.floating-qr-btn[data-v-a9d723ab]:active{transform:scale(.95)}.qr-dialog-content[data-v-a9d723ab]{text-align:center;padding:1rem}.qr-code-container[data-v-a9d723ab]{display:flex;justify-content:center;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:12px}.qr-code-container canvas[data-v-a9d723ab]{border-radius:8px}.qr-url[data-v-a9d723ab]{font-size:.875rem;color:#666;word-break:break-all;margin:1rem 0;padding:.75rem;background:#f5f5f5;border-radius:8px;font-family:monospace}.copy-btn[data-v-a9d723ab]{margin:1rem 0}.qr-hint[data-v-a9d723ab]{font-size:.75rem;color:#999;margin:1rem 0 0;font-style:italic}@media (max-width: 640px){.attendance-scanner[data-v-a9d723ab]{padding:1rem}.scanner-header[data-v-a9d723ab]{padding:1.5rem 1rem}.scanner-title[data-v-a9d723ab]{font-size:1.5rem}.scanner-subtitle[data-v-a9d723ab]{font-size:1rem}.selection-buttons[data-v-a9d723ab]{grid-template-columns:1fr;gap:1.5rem}.selection-btn[data-v-a9d723ab]{padding:2.5rem 1.5rem}.btn-title[data-v-a9d723ab]{font-size:2rem}.btn-subtitle[data-v-a9d723ab]{font-size:1rem}.action-buttons[data-v-a9d723ab]{flex-direction:column}.action-btn[data-v-a9d723ab]{width:100%}}.attendance-history-page[data-v-04e9d389]{min-height:100vh;background:#f5f5f5;padding-bottom:2rem}.page-header[data-v-04e9d389]{background:#fff;padding:1rem;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem}.header-title[data-v-04e9d389]{font-size:1.25rem;font-weight:600;color:#333}.summary-section[data-v-04e9d389]{padding:1rem}.summary-card[data-v-04e9d389]{text-align:center;padding:1rem!important;border-radius:12px}.entry-card[data-v-04e9d389]{border-left:4px solid #10b981}.exit-card[data-v-04e9d389]{border-left:4px solid #ef4444}.summary-icon[data-v-04e9d389]{font-size:2rem;margin-bottom:.5rem}.summary-value[data-v-04e9d389]{font-size:2rem;font-weight:700;color:#333;margin-bottom:.25rem}.summary-label[data-v-04e9d389]{font-size:.875rem;color:#666}.filters-section[data-v-04e9d389]{padding:0 1rem 1rem}.loading-container[data-v-04e9d389]{display:flex;justify-content:center;align-items:center;min-height:300px}.error-alert[data-v-04e9d389]{margin:1rem}.empty-state[data-v-04e9d389]{margin-top:4rem}.empty-icon[data-v-04e9d389]{font-size:4rem}.attendance-list[data-v-04e9d389]{padding:0 1rem}.date-group[data-v-04e9d389]{margin-bottom:1.5rem}.date-header[data-v-04e9d389]{margin-bottom:.75rem;display:flex;justify-content:center}.attendance-item[data-v-04e9d389]{background:#fff;margin-bottom:.5rem}.type-icon[data-v-04e9d389]{font-size:1.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%}.type-icon.entry[data-v-04e9d389]{background:#d1fae5}.type-icon.exit[data-v-04e9d389]{background:#fee2e2}.record-content[data-v-04e9d389]{flex:1;display:flex;flex-direction:column;gap:.25rem}.record-time[data-v-04e9d389]{font-size:1.125rem;font-weight:600;color:#333}.record-type[data-v-04e9d389]{font-size:.875rem;font-weight:500}.entry-text[data-v-04e9d389]{color:#10b981}.exit-text[data-v-04e9d389]{color:#ef4444}.record-duration[data-v-04e9d389]{font-size:.875rem;color:#666}.day-summary[data-v-04e9d389]{margin-top:.75rem;text-align:center}.load-more-section[data-v-04e9d389]{padding:1rem}@media (max-width: 480px){.summary-icon[data-v-04e9d389],.summary-value[data-v-04e9d389]{font-size:1.5rem}.summary-label[data-v-04e9d389]{font-size:.75rem}}.route-card[data-v-711cb925]{border-left:4px solid var(--primary-color);transition:all .2s}.route-card[data-v-711cb925]:hover{box-shadow:0 4px 12px #0000001a}.active-route[data-v-711cb925]{border-left-color:var(--success-color);background:linear-gradient(to right,rgba(24,160,88,.05),transparent)}.route-content[data-v-711cb925]{display:flex;flex-direction:column;gap:1rem}.route-header[data-v-711cb925]{display:flex;justify-content:space-between;align-items:flex-start}.route-icon[data-v-711cb925]{font-size:1.5rem}.route-name[data-v-711cb925]{font-size:1.125rem;font-weight:600;color:var(--text-color-1);margin:0}.route-vehicle[data-v-711cb925]{font-size:.875rem;color:var(--text-color-3);margin:.25rem 0 0}.route-details[data-v-711cb925]{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--color-target-modal);border-radius:.5rem}.detail-item[data-v-711cb925]{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.detail-icon[data-v-711cb925]{font-size:1rem}.detail-label[data-v-711cb925]{color:var(--text-color-2);font-weight:500}.detail-value[data-v-711cb925]{color:var(--text-color-1);font-weight:600;margin-left:auto}.route-actions[data-v-711cb925]{margin-top:.5rem}.driver-dashboard[data-v-0c87f556]{padding:1rem;max-width:1200px;margin:0 auto}.dashboard-header[data-v-0c87f556]{margin-bottom:1.5rem}.routes-container[data-v-0c87f556]{margin-top:1rem}.stats-grid[data-v-0c87f556]{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-value[data-v-0c87f556]{font-size:2rem;font-weight:700;color:var(--primary-color);text-align:center;padding:1rem 0}.empty-state[data-v-0c87f556]{background:var(--card-color, white);border-radius:.5rem;padding:2rem}.active-route[data-v-41eafa43]{padding:1rem 1rem 2rem;max-width:800px;margin:0 auto}.route-header[data-v-41eafa43]{margin-bottom:1.5rem}.back-button[data-v-41eafa43]{font-size:.875rem}.route-info[data-v-41eafa43]{padding:1rem;background:var(--card-color, white);border-radius:.5rem}.gps-status[data-v-41eafa43]{display:flex;flex-direction:column;gap:.75rem}.status-row[data-v-41eafa43]{display:flex;justify-content:space-between;align-items:center}.status-label[data-v-41eafa43]{font-weight:500;color:var(--text-color-2)}.stop-info h3[data-v-41eafa43]{margin-bottom:.25rem}.students-list[data-v-41eafa43]{border-top:1px solid var(--divider-color);padding-top:1rem}.student-item[data-v-41eafa43]{padding:.75rem;background:var(--color-target-modal);border-radius:.5rem}.student-avatar[data-v-41eafa43]{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.stop-card[data-v-41eafa43]{padding:1rem;background:var(--color-target-modal);border-radius:.5rem}.stop-number[data-v-41eafa43]{width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.action-buttons[data-v-41eafa43]{margin-top:2rem}.conference-status-fullscreen[data-v-c2830ae2]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.conference-status[data-v-c2830ae2]{padding:1.5rem;max-width:600px;margin:0 auto}.status-header[data-v-c2830ae2]{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a}.header-icon[data-v-c2830ae2]{display:inline-block;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 16px #00000026}.status-title[data-v-c2830ae2]{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.status-subtitle[data-v-c2830ae2]{font-size:1.25rem;font-weight:600;color:#ffffffe6;margin:0}.empty-state-card[data-v-c2830ae2]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.empty-text h2[data-v-c2830ae2]{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 .5rem}.empty-text p[data-v-c2830ae2]{font-size:1rem;color:#666;margin:0}.conference-card[data-v-c2830ae2]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;margin-bottom:1.5rem}.conference-header[data-v-c2830ae2]{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.1)}.conference-title[data-v-c2830ae2]{font-size:1.5rem;font-weight:700;color:#333;margin:0}.conference-details[data-v-c2830ae2]{display:flex;flex-direction:column;gap:.75rem}.detail-row[data-v-c2830ae2]{display:flex;align-items:center;gap:.75rem}.detail-text[data-v-c2830ae2]{font-size:1rem;color:#555;font-weight:500}.queues-card[data-v-c2830ae2]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;margin-bottom:1.5rem}.queue-item[data-v-c2830ae2]{padding:.75rem 0}.queue-header[data-v-c2830ae2]{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.25rem}.teacher-name[data-v-c2830ae2]{font-weight:600;font-size:1rem;color:#333}.queue-details[data-v-c2830ae2]{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#666}.room-text[data-v-c2830ae2]{font-weight:500}.wait-time[data-v-c2830ae2]{display:flex;align-items:center;gap:.375rem;color:#f59e0b;font-weight:500}.loading-card[data-v-c2830ae2]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.loading-text[data-v-c2830ae2]{font-size:1rem;color:#666;margin:0}.error-alert[data-v-c2830ae2]{margin-bottom:1rem}.refresh-indicator[data-v-c2830ae2]{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#fff;font-size:.875rem}@media (max-width: 640px){.conference-status[data-v-c2830ae2]{padding:1rem}.status-header[data-v-c2830ae2]{padding:1.5rem 1rem}.status-title[data-v-c2830ae2]{font-size:1.5rem}.status-subtitle[data-v-c2830ae2]{font-size:1rem}.conference-title[data-v-c2830ae2]{font-size:1.25rem}.conference-header[data-v-c2830ae2]{flex-direction:column;align-items:flex-start}}.conference-checkin-fullscreen[data-v-7d55f1b3]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.conference-checkin[data-v-7d55f1b3]{padding:1.5rem;max-width:600px;margin:0 auto}.checkin-header[data-v-7d55f1b3]{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a}.header-icon[data-v-7d55f1b3]{display:inline-block;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 16px #00000026}.checkin-title[data-v-7d55f1b3]{font-size:1.75rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.checkin-subtitle[data-v-7d55f1b3]{font-size:1.125rem;font-weight:600;color:#ffffffe6;margin:0 0 .25rem}.checkin-location[data-v-7d55f1b3]{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1rem;color:#ffffffd9;margin:0}.scanner-card[data-v-7d55f1b3]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026}.scanner-instructions[data-v-7d55f1b3]{text-align:center;margin-bottom:1.5rem}.scanner-instructions h2[data-v-7d55f1b3]{font-size:1.5rem;font-weight:700;color:#333;margin:0 0 .5rem}.scanner-instructions p[data-v-7d55f1b3]{font-size:.875rem;color:#666;margin:0}.qr-scanner-container[data-v-7d55f1b3]{position:relative;width:100%;min-height:300px;border-radius:12px;overflow:hidden;background-color:#000;margin-bottom:1rem}.qr-camera[data-v-7d55f1b3]{width:100%;height:100%;min-height:300px}.scanner-overlay[data-v-7d55f1b3]{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#00000080;color:#fff}.overlay-text[data-v-7d55f1b3]{margin-top:1rem;font-size:.875rem}.success-state[data-v-7d55f1b3]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);text-align:center;padding:2rem}.success-state h3[data-v-7d55f1b3]{font-size:1.5rem;font-weight:700;color:#065f46;margin:1rem 0 .5rem}.success-state p[data-v-7d55f1b3]{font-size:1rem;color:#047857;margin:0}.scanner-paused[data-v-7d55f1b3]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:#666}.paused-icon[data-v-7d55f1b3]{margin-bottom:1rem;color:#667eea}.scanner-alert[data-v-7d55f1b3]{margin-bottom:1rem}.cancel-btn[data-v-7d55f1b3]{font-weight:600}@media (max-width: 640px){.conference-checkin[data-v-7d55f1b3]{padding:1rem}.checkin-header[data-v-7d55f1b3]{padding:1.5rem 1rem}.checkin-title[data-v-7d55f1b3]{font-size:1.5rem}.checkin-subtitle[data-v-7d55f1b3]{font-size:1rem}}.conference-queue-fullscreen[data-v-4d9774f0]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.conference-queue[data-v-4d9774f0]{padding:1.5rem;max-width:600px;margin:0 auto}.queue-header[data-v-4d9774f0]{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a}.header-icon[data-v-4d9774f0]{display:inline-block;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 16px #00000026}.queue-title[data-v-4d9774f0]{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.queue-subtitle[data-v-4d9774f0]{font-size:1rem;color:#ffffffe6;margin:0}.info-card[data-v-4d9774f0]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 4px 16px #0000001a;margin-bottom:1.5rem;padding:.75rem 1rem}.info-details[data-v-4d9774f0]{display:flex;flex-direction:column;gap:.5rem}.info-row[data-v-4d9774f0]{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#555}.empty-state-card[data-v-4d9774f0]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.empty-text h2[data-v-4d9774f0]{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 .5rem}.empty-text p[data-v-4d9774f0]{font-size:1rem;color:#666;margin:0}.queues-list[data-v-4d9774f0]{display:flex;flex-direction:column;gap:1rem}.queue-card[data-v-4d9774f0]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;transition:all .3s ease}.queue-almost-ready[data-v-4d9774f0]{border:2px solid #10b981;box-shadow:0 8px 32px #10b9814d}.queue-completed[data-v-4d9774f0]{opacity:.75}.queue-card-header[data-v-4d9774f0]{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.1);margin-bottom:1rem}.teacher-info[data-v-4d9774f0]{display:flex;align-items:center;gap:1rem}.teacher-details[data-v-4d9774f0]{flex:1}.teacher-name[data-v-4d9774f0]{font-size:1.125rem;font-weight:700;color:#333;margin:0 0 .25rem}.teacher-room[data-v-4d9774f0]{font-size:.875rem;color:#666;margin:0}.queue-card-body[data-v-4d9774f0]{display:flex;flex-direction:column;gap:1rem}.queue-stat[data-v-4d9774f0]{display:flex;align-items:center;gap:1rem}.stat-icon[data-v-4d9774f0]{flex-shrink:0}.stat-content[data-v-4d9774f0]{flex:1}.stat-label[data-v-4d9774f0]{font-size:.75rem;color:#999;margin:0 0 .25rem;text-transform:uppercase;letter-spacing:.5px}.stat-value[data-v-4d9774f0]{font-size:1.25rem;font-weight:700;color:#333;margin:0}.ready-alert[data-v-4d9774f0],.completed-alert[data-v-4d9774f0]{margin-top:1rem}.loading-card[data-v-4d9774f0]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.loading-text[data-v-4d9774f0]{font-size:1rem;color:#666;margin:0}.error-alert[data-v-4d9774f0]{margin-bottom:1rem}.refresh-indicator[data-v-4d9774f0]{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#fff;font-size:.875rem}@media (max-width: 640px){.conference-queue[data-v-4d9774f0]{padding:1rem}.queue-header[data-v-4d9774f0]{padding:1.5rem 1rem}.queue-title[data-v-4d9774f0]{font-size:1.5rem}.queue-card-header[data-v-4d9774f0]{flex-direction:column;align-items:flex-start}}.teacher-queue-fullscreen[data-v-9f0f63a7]{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.teacher-queue[data-v-9f0f63a7]{padding:1.5rem;max-width:600px;margin:0 auto}.teacher-header[data-v-9f0f63a7]{text-align:center;margin-bottom:2rem;padding:2rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a}.header-icon[data-v-9f0f63a7]{display:inline-block;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 16px #00000026}.teacher-title[data-v-9f0f63a7]{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.teacher-subtitle[data-v-9f0f63a7]{font-size:1rem;color:#ffffffe6;margin:0}.stats-grid[data-v-9f0f63a7]{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.stat-card[data-v-9f0f63a7]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 4px 16px #0000001a}.stat-content[data-v-9f0f63a7]{display:flex;align-items:center;gap:1rem}.stat-text[data-v-9f0f63a7]{flex:1}.stat-label[data-v-9f0f63a7]{font-size:.75rem;color:#999;margin:0 0 .25rem;text-transform:uppercase;letter-spacing:.5px}.stat-value[data-v-9f0f63a7]{font-size:2rem;font-weight:700;color:#333;margin:0}.empty-state-card[data-v-9f0f63a7]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.empty-text h2[data-v-9f0f63a7]{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 .5rem}.empty-text p[data-v-9f0f63a7]{font-size:1rem;color:#666;margin:0}.parents-card[data-v-9f0f63a7]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;margin-bottom:1.5rem}.parent-item[data-v-9f0f63a7]{padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.05)}.parent-item[data-v-9f0f63a7]:last-child{border-bottom:none}.position-badge[data-v-9f0f63a7]{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;box-shadow:0 2px 8px #667eea4d}.parent-header[data-v-9f0f63a7]{margin-bottom:.5rem}.parent-info[data-v-9f0f63a7]{flex:1}.parent-name[data-v-9f0f63a7]{font-size:1.125rem;font-weight:700;color:#333;margin:0 0 .25rem}.student-info[data-v-9f0f63a7]{font-size:.875rem;color:#666;margin:0}.parent-details[data-v-9f0f63a7]{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#666}.detail-item[data-v-9f0f63a7]{display:flex;align-items:center;gap:.375rem}.loading-card[data-v-9f0f63a7]{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 8px 32px #00000026;padding:3rem 2rem}.loading-text[data-v-9f0f63a7]{font-size:1rem;color:#666;margin:0}.error-alert[data-v-9f0f63a7]{margin-bottom:1rem}.refresh-indicator[data-v-9f0f63a7]{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#fff;font-size:.875rem}@media (max-width: 640px){.teacher-queue[data-v-9f0f63a7]{padding:1rem}.teacher-header[data-v-9f0f63a7]{padding:1.5rem 1rem}.teacher-title[data-v-9f0f63a7]{font-size:1.5rem}.stats-grid[data-v-9f0f63a7]{grid-template-columns:1fr}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-left-1{left:-.25rem}.bottom-0{bottom:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.list-item{display:list-item}.hidden{display:none}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-full{height:100%}.w-1{width:.25rem}.w-10{width:2.5rem}.w-11\/12{width:91.666667%}.w-12{width:3rem}.w-16{width:4rem}.w-3{width:.75rem}.w-32{width:8rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.min-w-full{min-width:100%}.max-w-3xl{max-width:48rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-r-sm{border-top-right-radius:.125rem;border-bottom-right-radius:.125rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}.border-l-blue-400{--tw-border-opacity: 1;border-left-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.border-l-gray-400{--tw-border-opacity: 1;border-left-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.border-l-green-400{--tw-border-opacity: 1;border-left-color:rgb(74 222 128 / var(--tw-border-opacity, 1))}.border-l-purple-400{--tw-border-opacity: 1;border-left-color:rgb(192 132 252 / var(--tw-border-opacity, 1))}.border-l-red-400{--tw-border-opacity: 1;border-left-color:rgb(248 113 113 / var(--tw-border-opacity, 1))}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-purple-100{--tw-bg-opacity: 1;background-color:rgb(243 232 255 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-4{padding:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-2{padding-bottom:.5rem}.pt-3{padding-top:.75rem}.text-right{text-align:right}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.tracking-tight{letter-spacing:-.025em}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-purple-700{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.opacity-75{opacity:.75}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-opacity-50{--tw-ring-opacity: .5}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}html,body,#app{height:100%;width:100%;overflow-x:hidden}body{background-color:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;margin:0;padding:0;overscroll-behavior-y:none;touch-action:manipulation}.app{min-height:100%;min-height:100dvh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}#app{min-height:100%!important;position:relative}.app main{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;position:relative}.app-scroll{min-height:100%;position:relative}:root{--bg: #f5f7fa;--surface: #ffffff;--card: #fefefe;--text: #0f1724;--muted: #5c6a7f;--heading: #0a0e1a;--accent: #2563eb;--accent-contrast: #ffffff;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--card-border: rgba(2, 6, 23, .04);--card-radius: .75rem;--shadow-sm: 0 2px 8px rgba(2, 6, 23, .04);--shadow-md: 0 4px 16px rgba(2, 6, 23, .08);--shadow-lg: 0 10px 40px rgba(2, 6, 23, .12);--avatar-bg: linear-gradient( 180deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, .95) );--initials-color: #2563eb;--btn-bg: #ffffff;--btn-fg: #2563eb;--btn-border: rgba(2, 6, 23, .08);--avatar-border: rgba(2, 6, 23, .06);--overlay-bg: rgba(2, 6, 23, .6);--toast-top: calc(var(--top-nav-height, 64px) + env(safe-area-inset-top, 0px) + 1rem);--n-title-text-color: var(--text);--n-thing-text-color: var(--text);--n-thing-description-text-color: var(--muted)}.dark{--bg: #0a0e1a;--surface: #0f1724;--card: #141b2b;--text: #e6eefb;--muted: #8996ad;--heading: #f0f5ff;--accent: #3b82f6;--accent-contrast: #ffffff;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--card-border: rgba(255, 255, 255, .04);--heading: #e6eefb;--avatar-bg: linear-gradient( 180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, .01) );--initials-color: #e6eefb;--btn-bg: #0f1724;--btn-fg: #e6eefb;--btn-border: rgba(255, 255, 255, .04);--avatar-border: rgba(255, 255, 255, .06);--overlay-bg: rgba(0, 0, 0, .78);--n-title-text-color: var(--text);--n-thing-text-color: var(--text);--n-thing-description-text-color: var(--muted)}:root{--card-radius: 12px;--card-padding: 1rem}.bg-bg{background-color:var(--bg)!important}.bg-surface{background-color:var(--surface)!important}.bg-card{background-color:var(--card)!important}.bg-accent{background-color:var(--accent)!important}.text-text{color:var(--text)!important}.text-muted{color:var(--muted)!important}.text-heading{color:var(--heading)!important}.text-accent-contrast{color:var(--accent-contrast)!important}.bg-avatar{background:var(--avatar-bg)!important}.text-initials{color:var(--initials-color)!important}.border-card{border-color:var(--card-border)!important}.card{background:var(--surface);color:var(--text);border-radius:var(--card-radius);padding:var(--card-padding);box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem .9rem;border-radius:10px;border:1px solid transparent;font-weight:600;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.btn-primary{background-color:var(--accent);color:var(--accent-contrast);border-color:transparent;box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--surface);color:var(--muted);border-color:#0000000f}.btn-ghost{background:transparent;color:var(--muted);border:1px solid rgba(0,0,0,.06)}.btn-muted{background:var(--surface);color:var(--text);border:1px solid var(--card-border);padding:.45rem .7rem;border-radius:9999px}.btn-muted:hover{background:color-mix(in srgb,var(--surface) 88%,transparent)}.btn-muted:focus{outline:3px solid rgba(37,99,235,.12)}.dark .btn-secondary{border-color:#ffffff0a}.dark .btn-ghost{border:1px solid rgba(255,255,255,.04);color:var(--muted)}.dark .btn-muted{background:#ffffff05;color:var(--text);border:1px solid var(--card-border)}.dark .btn-muted:hover{background:#ffffff08}.dark .btn-muted:focus{outline:3px solid rgba(59,130,246,.12)}.action-outline{background:transparent;border:1px solid rgba(0,0,0,.06);border-radius:8px;padding:.45rem .65rem}.dark .action-outline{border:1px solid rgba(255,255,255,.04)}.action-primary{background:var(--accent);color:var(--accent-contrast);border-radius:18px;padding:.45rem .85rem}.btn:active{transform:translateY(1px) scale(.997)}.theme-toggle-pill{display:inline-flex;align-items:center;gap:8px}.theme-toggle .track{position:relative;width:44px;height:26px;padding:3px;border-radius:999px;background:color-mix(in srgb,var(--card) 92%,transparent);box-sizing:border-box;border:1px solid var(--card-border)}.theme-toggle .knob{position:absolute;left:3px;top:50%;width:20px;height:20px;border-radius:999px;transform:translateY(-50%);background:linear-gradient(180deg,#fff,#f2f5ff);box-shadow:0 2px 6px #02061714;transition:left .22s cubic-bezier(.2,.9,.2,1),background .18s linear;z-index:2;border:1px solid rgba(2,6,23,.12);box-sizing:border-box}.theme-toggle .knob.dark{left:calc(100% - 23px);background:linear-gradient(180deg,#e6eef8,#cfe6ff);border:1px solid rgba(255,255,255,.12)}.theme-toggle:focus-visible{outline:none}.theme-toggle:focus-visible .track{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 16%,transparent)}html.dark{color-scheme:dark}html:not(.dark){color-scheme:light}.n-message-container{top:var(--toast-top)!important}.dark .n-message{background:var(--surface)!important;border:1px solid var(--card-border)!important;box-shadow:0 8px 24px #0006!important}.dark .n-message--info-type{background:#3b82f626!important;border-color:#3b82f64d!important;color:#93c5fd!important}.dark .n-message--success-type{background:#22c55e26!important;border-color:#22c55e4d!important;color:#86efac!important}.dark .n-message--warning-type{background:#f59e0b26!important;border-color:#f59e0b4d!important;color:#fcd34d!important}.dark .n-message--error-type{background:#ef444426!important;border-color:#ef44444d!important;color:#fca5a5!important}.dark .n-message__icon{color:inherit!important}.dark .n-message__close{color:var(--muted)!important}.dark .n-message__close:hover{background:#ffffff1a!important;color:var(--text)!important}.dark .card,.dark .status-card,.dark .profile-card,.dark .list-card,.dark .notification-card,.dark .qr-inner,.dark .qr-placeholder,.dark .qr-large img,.dark .notification-manager,.dark .notifications-page,.dark .header-card{background:var(--surface)!important;color:var(--text)!important;border:1px solid var(--card-border)!important;box-shadow:none!important}.dark .profile-card,.dark .profile-page,.dark .profile-header,.dark .profile-info-list,.dark .header-card,.dark .list-card,.dark .status-card,.dark .notifications-page,.dark .notification-manager,.dark .notification-card,.dark .notification-item-wrapper,.dark .qr-overlay,.dark .qr-placeholder,.dark .qr-large img,.dark .n-card,.dark .n-card__content,.dark .n-card__header,.dark .n-list-item,.dark .n-thing,.dark .n-thing__header,.dark .n-thing__description,.dark .n-list,.dark .n-button,.dark .n-modal__body,.dark .n-collapse-item,.dark .n-divider,.dark .n-collapse{background:var(--surface)!important;color:var(--text)!important;border-color:var(--card-border)!important;box-shadow:none!important}.dark .profile-card h2,.dark .profile-heading,.dark .academic-title,.dark .header-card .label,.dark .header-card .for{color:var(--heading)!important}.dark pre,.dark code,.dark .notification-manager pre,.dark .notification-manager ::v-deep pre{background:var(--surface)!important;color:var(--text)!important;border:1px solid var(--card-border)!important}.dark .notification-manager ::v-deep .n-button,.dark .notification-manager ::v-deep .n-button--default,.dark .notification-manager ::v-deep .n-button--ghost,.dark .notification-manager ::v-deep .n-button--primary{background:var(--surface)!important;color:var(--text)!important;border-color:var(--card-border)!important;box-shadow:none!important}.dark .bg-surface{background-color:var(--surface)!important}.dark .profile-info-list >>> .n-list-item,.dark .list-card .notification-content,.dark .notification-content{background:var(--card)!important;border-bottom:1px solid var(--card-border)!important;color:var(--text)!important}.dark .qr-overlay{background:#020617c7!important}.dark .qr-large img,.dark .qr-placeholder{background:var(--surface)!important;color:var(--text)!important;border:1px solid var(--card-border)!important;box-shadow:0 28px 80px #0009!important}.dark .top-bar,.dark .bottom-nav-bar .container{background:var(--bg)!important;border-color:var(--card-border)!important;box-shadow:0 10px 24px #00000073!important}.dark .avatar-circle,.dark .avatar-area img{border:1px solid var(--avatar-border)!important}.dark .qr-close-btn{background:var(--accent-contrast)!important;border:2px solid var(--card-border)!important}.dark .btn-secondary,.dark .btn-ghost{border-color:var(--card-border)!important;color:var(--muted)!important;background:var(--surface)!important}.dark pre,.dark code,.dark .notification-manager pre{background:var(--surface)!important;color:var(--text)!important}@media (max-width: 640px){.dark .qr-close-btn{top:8px;right:8px;padding:6px}}.bg-accent-50{background-color:color-mix(in srgb,var(--accent) 8%,transparent)}.text-accent-700{color:color-mix(in srgb,var(--accent) 90%,black)}.bg-error-50{background-color:color-mix(in srgb,var(--danger) 8%,transparent)}.text-error-700{color:color-mix(in srgb,var(--danger) 90%,black)}.dark .bg-accent-50{background-color:color-mix(in srgb,var(--accent) 15%,transparent)}.dark .text-accent-700{color:color-mix(in srgb,var(--accent) 70%,white)}.dark .bg-error-50{background-color:color-mix(in srgb,var(--danger) 15%,transparent)}.dark .text-error-700{color:color-mix(in srgb,var(--danger) 70%,white)}:root{--type-base-size: 16px;--type-scale-ratio: 1.125;--leading-base: 1.45}html,body{font-size:var(--type-base-size);line-height:var(--leading-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}h1,.h1{font-size:1.75rem;line-height:1.12;margin:0 0 .5rem;color:var(--heading);font-weight:700}h2,.h2{font-size:1.375rem;line-height:1.15;margin:0 0 .5rem;color:var(--heading);font-weight:700}h3,.h3{font-size:1.125rem;line-height:1.2;margin:0 0 .5rem;color:var(--heading);font-weight:600}h4,.h4{font-size:1rem;line-height:1.25;margin:0 0 .5rem;color:var(--heading);font-weight:600}h5,.h5{font-size:.95rem;line-height:1.25;margin:0 0 .5rem;color:var(--heading);font-weight:600}h6,.h6{font-size:.85rem;line-height:1.25;margin:0 0 .5rem;color:var(--heading);font-weight:600}p{margin:0 0 1rem;color:var(--text)}small,.small{font-size:.85rem;color:var(--muted)}a{color:var(--accent);text-decoration:none}a:hover,a:focus{text-decoration:underline}code,kbd,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Roboto Mono,Courier New,monospace;font-size:.875rem;color:var(--text);background:color-mix(in srgb,var(--card) 92%,transparent);padding:.08rem .25rem;border-radius:6px}pre{background:var(--card);padding:.75rem;border-radius:8px;overflow:auto}ul,ol{margin:0 0 1rem 1.25rem;color:var(--text)}.lead{font-size:1.0625rem;color:var(--muted)}.row{display:flex;flex-wrap:nowrap;align-items:center}.col{display:flex;flex-direction:column}.center{display:flex;align-items:center;justify-content:center}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.text-center{text-align:center}.hidden{display:none!important}.visible{display:block!important}.focus-ring:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 16%,transparent);outline-offset:2px}:root{--top-nav-height: 64px;--safe-area-top: min(env(safe-area-inset-top, 0px), 44px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--bottom-nav-height: calc(56px + var(--safe-area-bottom));--bottom-nav-icon-size: 28px;--standalone-nav-offset: 12px}.top-bar{height:calc(var(--top-nav-height) + var(--safe-area-top));padding-top:var(--safe-area-top);box-shadow:0 6px 18px #0206170f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--surface);position:fixed;top:0;left:0;right:0;z-index:1000;transform:translateZ(0);will-change:auto}@media (display-mode: standalone){.top-bar{height:calc(var(--top-nav-height) + var(--safe-area-top));padding-top:var(--safe-area-top)}}@media (display-mode: standalone){.bottom-nav-bar{padding-bottom:calc(env(safe-area-inset-bottom,0px) + var(--standalone-nav-offset));max-height:calc(24px + env(safe-area-inset-bottom,0px))}.bottom-nav-bar .nav-content,.nav-content{margin-bottom:max(calc(env(safe-area-inset-bottom,0px) - var(--standalone-nav-offset)),4px)}}.is-standalone .bottom-nav-bar{padding-bottom:calc(env(safe-area-inset-bottom,0px) + var(--standalone-nav-offset));max-height:calc(24px + env(safe-area-inset-bottom,0px))}.is-standalone .bottom-nav-bar .nav-content,.is-standalone .nav-content{margin-bottom:max(calc(env(safe-area-inset-bottom,0px) - var(--standalone-nav-offset)),4px)}@supports ((-webkit-backdrop-filter: blur(1px)) and (height: env(safe-area-inset-top))){.top-bar{height:calc(var(--top-nav-height) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top)}}.bottom-nav-bar{position:fixed;left:0;right:0;bottom:0;box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);background:var(--bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 -6px 20px #0000001f;max-height:calc(68px + env(safe-area-inset-bottom,0px));overflow:visible;transform:none;will-change:auto;z-index:1000}.bottom-nav-bar .nav-content,.nav-content{min-height:68px;height:68px;display:flex;align-items:center;justify-content:space-around;margin-bottom:max(calc(env(safe-area-inset-bottom,0px) - 8px),0px);padding-left:max(.75rem,env(safe-area-inset-left,.75rem));padding-right:max(.75rem,env(safe-area-inset-right,.75rem));box-sizing:border-box}.bottom-nav-bar .container{max-width:48rem;margin:0 auto;padding-left:0;padding-right:0}.bottom-nav-bar .nav-link{box-sizing:border-box;min-height:52px;padding:.35rem;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;background:transparent;font:inherit;line-height:1}.bottom-nav-bar .nav-link:hover,.bottom-nav-bar .nav-link:focus,.bottom-nav-bar .nav-link:active{text-decoration:none;color:var(--muted);outline:none}.bottom-nav-bar .nav-link[aria-current=page],.bottom-nav-bar .nav-link.active{color:var(--accent)}.bottom-nav-bar .nav-link[aria-current=page] .icon,.bottom-nav-bar .nav-link.active .icon{color:var(--accent);transform:translateY(-2px)}.bottom-nav-bar .icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%}.bottom-nav-bar .icon{font-size:var(--bottom-nav-icon-size);width:var(--bottom-nav-icon-size);height:var(--bottom-nav-icon-size);display:inline-flex;align-items:center;justify-content:center}.bottom-nav-bar .label{font-size:.8125rem;line-height:1.2}.bottom-nav-bar .nav-link[aria-current=page] .label,.bottom-nav-bar .nav-link.active .label{color:var(--accent);font-weight:600}.bottom-nav-bar .badge{position:absolute;top:-8px;right:calc(50% - 20px);min-width:20px;height:20px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;background:var(--badge-bg, #c2410c);color:var(--badge-fg, #fff);border-radius:999px;font-size:.65rem;font-weight:700;box-shadow:0 6px 14px #0206171f;border:2px solid var(--bg)}.bottom-nav-bar .nav-link,.bottom-nav-bar .nav-link .icon-wrapper{pointer-events:auto;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,0);transform:translateZ(0)}.bottom-nav-bar .badge{pointer-events:auto;touch-action:manipulation}.bottom-nav-bar .container ul{display:flex;justify-content:space-between;align-items:center;list-style:none;margin:0;padding:.5rem 0;width:100%}.dark .top-bar{background:var(--surface);box-shadow:0 6px 18px #0000004d}.dark .bottom-nav-bar{background:var(--bg);box-shadow:0 -6px 20px #00000040}.app-content{width:100%;max-width:48rem;margin:0 auto;box-sizing:border-box;padding-top:calc(var(--top-nav-height) + var(--safe-area-top) + .5rem);padding-bottom:calc(60px + env(safe-area-inset-bottom,0px));padding-left:1rem;padding-right:1rem;min-height:100vh;min-height:100dvh;overscroll-behavior-y:contain}.app-content.no-shell{padding-top:calc(var(--safe-area-top) + .75rem);padding-bottom:calc(var(--safe-area-bottom) + .75rem)}.top-bar .container{height:var(--top-nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;max-width:48rem;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:2.25rem;padding:.5rem .75rem;border-radius:.75rem;font-weight:600;font-size:.95rem;line-height:1;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease,color .12s ease;border:1px solid transparent;box-sizing:border-box}.btn-sm{min-height:1.75rem;padding:.35rem .6rem;font-size:.85rem;border-radius:.5rem}.btn-lg{min-height:2.75rem;padding:.75rem 1rem;font-size:1rem}.btn-block{width:100%;display:inline-flex}.btn-primary,.action-primary,.action-button{color:var(--accent-contrast, #fff);background:linear-gradient(135deg,var(--accent),#3b82f6);border-color:transparent;box-shadow:0 6px 18px #3b82f61f}.btn-secondary{color:var(--text);background:var(--surface);border-color:var(--card-border)}.btn-muted{color:var(--muted);background:transparent;border-color:transparent}.btn-ghost{color:var(--accent);background:transparent;border-color:transparent}.btn-outline,.action-outline{color:var(--text);background:transparent;border-color:var(--card-border)}.btn[disabled],.btn.disabled{opacity:.5;pointer-events:none;transform:none}.btn:hover:not([disabled]){transform:translateY(-1px)}.btn:active:not([disabled]){transform:translateY(0)}.btn:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 18%,transparent);outline-offset:2px}.btn--icon{padding:.4rem;width:2.25rem;height:2.25rem;min-width:2.25rem;justify-content:center;border-radius:.5rem}.n-button{--n-color: var(--surface) !important;--n-color-hover: var(--card) !important;--n-color-pressed: var(--card) !important;--n-color-focus: var(--card) !important;--n-color-disabled: var(--surface) !important;--n-border: 1px solid var(--card-border) !important;--n-border-hover: 1px solid var(--card-border) !important;--n-border-pressed: 1px solid var(--card-border) !important;--n-border-focus: 1px solid var(--card-border) !important;--n-border-disabled: 1px solid var(--card-border) !important;--n-ripple-color: var(--accent) !important;--n-text-color: var(--text) !important;--n-text-color-hover: var(--text) !important;--n-text-color-pressed: var(--text) !important;--n-text-color-focus: var(--text) !important;--n-text-color-disabled: var(--text) !important;border-radius:8px!important;font-weight:500!important;transition:all .18s ease!important}.n-button--primary-type{--n-color: var(--accent) !important;--n-color-hover: #1d4ed8 !important;--n-color-pressed: #1d4ed8 !important;--n-color-focus: #1d4ed8 !important;--n-color-disabled: var(--accent) !important;--n-border: 1px solid var(--accent) !important;--n-border-hover: 1px solid #1d4ed8 !important;--n-border-pressed: 1px solid #1d4ed8 !important;--n-border-focus: 1px solid #1d4ed8 !important;--n-border-disabled: 1px solid var(--accent) !important;--n-ripple-color: var(--accent) !important;--n-text-color: var(--accent-contrast, #fff) !important;--n-text-color-hover: var(--accent-contrast, #fff) !important}.n-button--default-type,.n-button--secondary-type{--n-color: var(--surface) !important;--n-color-hover: var(--card) !important;--n-color-pressed: var(--card) !important;--n-color-focus: var(--card) !important;--n-color-disabled: var(--surface) !important;--n-border: 1px solid var(--card-border) !important;--n-border-hover: 1px solid var(--card-border) !important;--n-border-pressed: 1px solid var(--card-border) !important;--n-border-focus: 1px solid var(--card-border) !important;--n-border-disabled: 1px solid var(--card-border) !important;--n-ripple-color: var(--accent) !important;--n-text-color: var(--text) !important;--n-text-color-hover: var(--text) !important}.n-button--ghost-type{--n-color: transparent !important;--n-color-hover: var(--card) !important;--n-color-pressed: var(--card) !important;--n-color-focus: var(--card) !important;--n-color-disabled: transparent !important;--n-border: 1px solid var(--card-border) !important;--n-border-hover: 1px solid var(--card-border) !important;--n-text-color: var(--text) !important;--n-ripple-color: var(--accent) !important}.n-button--success-type,.n-button--warning-type,.n-button--info-type{--n-color: var(--surface) !important;--n-color-hover: var(--card) !important;--n-border: 1px solid var(--card-border) !important;--n-text-color: var(--text) !important;--n-ripple-color: var(--accent) !important}.n-button--small-type{padding:.25rem .75rem!important;font-size:.875rem!important}.n-button--medium-type{padding:.5rem 1rem!important;font-size:.95rem!important}.n-button--large-type{padding:.75rem 1.25rem!important;font-size:1rem!important}.n-button.btn{display:inline-flex;align-items:center;justify-content:center}@media (max-width: 640px){.btn{padding:.5rem .75rem;font-size:.95rem}}.base-card{background:var(--surface);color:var(--text);border-radius:12px;padding:1rem;box-shadow:var(--shadow-sm)}.status-card{padding:.75rem;border-radius:.5rem;border:1px solid var(--card-border);background:var(--card);color:var(--text)}.status-grid>.status-card{min-height:64px}.notification-card{border-radius:14px;box-shadow:var(--shadow-md);transition:transform .18s ease,box-shadow .18s ease;padding:0}.notification-card:active{transform:translateY(1px)}.notification-card:hover{box-shadow:0 14px 40px #0206171a;transform:translateY(-2px)}.notification-card .w-9,.notification-card .w-10{border-radius:9999px;box-shadow:var(--shadow-sm)}.header-card{background:var(--surface);padding:0;border-bottom:1px solid var(--card-border)}.header-card .header-row{padding-left:1.25rem;padding-right:1.25rem}.list-card{background:var(--surface);border-top:1px solid var(--card-border);padding:.5rem 1.25rem}.list-card .notification-content{border-bottom:1px solid var(--card-border);padding-left:0}.profile-card{max-width:48rem;box-sizing:border-box;width:100%;background:var(--card);border:1px solid var(--card-border);padding:0 12px 12px;color:var(--text);margin-bottom:0}@media (max-width: 640px){.profile-card{padding:16px}}.profile-card+.profile-card{margin-top:0!important}.form-input{border:1px solid var(--card-border);border-radius:8px;background:transparent;box-shadow:none;transition:border-color .14s ease,box-shadow .14s ease;padding:.5rem;color:inherit}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 8%,transparent)}.form-input-error{border:1px solid var(--danger)!important;box-shadow:none!important}.form-input-error:focus{outline:none;border-color:var(--danger)!important;box-shadow:0 0 0 6px color-mix(in srgb,var(--danger) 8%,transparent)!important}.form-input:-webkit-autofill,.form-input:-webkit-autofill:focus{box-shadow:0 0 0 30px var(--surface) inset!important}:root{--icon-primary: #374151;--icon-secondary: #6b7280;--icon-accent: var(--accent);--icon-success: #16a34a;--icon-warning: #ca8a04;--icon-danger: var(--danger)}.dark{--icon-primary: #d1d5db;--icon-secondary: #9ca3af;--icon-accent: #60a5fa;--icon-success: #22c55e;--icon-warning: #eab308;--icon-danger: #ef4444}.app-icon{color:var(--icon-primary);fill:currentColor;stroke:currentColor;transition:color .2s ease}.app-icon--secondary{color:var(--icon-secondary)}.app-icon--accent{color:var(--icon-accent)}.app-icon--success{color:var(--icon-success)}.app-icon--warning{color:var(--icon-warning)}.app-icon--danger{color:var(--icon-danger)}.settings-section-icon{color:var(--icon-accent)!important;width:24px;height:24px}.settings-group-icon{color:var(--icon-accent)!important;width:20px;height:20px}.notification-page-icon{color:var(--icon-accent)!important}.status-icon{color:var(--icon-secondary)}.status-icon--active,.app-icon:hover{color:var(--icon-accent)}.app-icon--interactive{cursor:pointer;transition:all .2s ease}.app-icon--interactive:hover{color:var(--icon-accent);transform:scale(1.1)}.app-icon--xs{width:12px;height:12px}.app-icon--sm{width:16px;height:16px}.app-icon--md{width:20px;height:20px}.app-icon--lg{width:24px;height:24px}.app-icon--xl{width:32px;height:32px}.iconify,.iconify svg{color:inherit!important;fill:currentColor!important;stroke:currentColor!important}svg:not([fill]){fill:currentColor}svg:not([stroke]){stroke:currentColor}.notification-manager{max-width:600px;margin:0 auto;background:var(--card);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:2rem;box-shadow:var(--shadow-md)}.notification-manager-header{display:flex;align-items:center;justify-content:between;width:100%}.notification-manager-title{font-size:1.125rem;font-weight:600;color:var(--heading);margin:0}.notification-actions-section{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.notification-status-overview{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--card-border)}.status-title{font-size:1rem;font-weight:600;color:var(--heading);margin-bottom:1rem}.notification-status-items{display:flex;flex-direction:column;gap:.75rem}.notification-status-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface);border:1px solid var(--card-border);border-radius:8px;transition:all .2s ease}.notification-status-item:hover{background:var(--card)}.status-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface);color:var(--muted);flex-shrink:0;transition:all .2s ease}.status-indicator.active{background:var(--accent);color:var(--accent-contrast)}.notification-status-label{flex:1;font-size:.95rem;color:var(--text);font-weight:500}.status-value{margin-left:auto;font-size:.875rem;color:var(--muted);font-weight:500}.notification-token-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--card-border)}.notification-token-display{background:var(--surface);border:1px solid var(--card-border);border-radius:8px;padding:1rem}.token-label{display:block;font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.token-actions{margin-bottom:.75rem}.notification-token-value{font-family:SF Mono,Monaco,Roboto Mono,monospace;font-size:.8rem;color:var(--muted);background:var(--bg);padding:.5rem;border-radius:4px;word-break:break-all;line-height:1.4}.dark .notification-manager{background:var(--card);border-color:var(--card-border);box-shadow:var(--shadow-md)}.dark .notification-status-item,.dark .notification-token-display{background:var(--surface);border-color:var(--card-border)}.dark .notification-token-value{background:var(--bg);color:var(--muted)}@media (max-width: 640px){.notification-manager{padding:1.5rem;margin:0 1rem}.notification-actions-section{gap:.5rem}.notification-status-item{padding:.5rem}.notification-token-value{font-size:.75rem}}.pull-to-refresh-indicator{position:fixed;top:0;left:0;right:0;height:80px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-bottom:1px solid var(--card-border);z-index:1000;opacity:0;transform:translateY(-100%);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.pull-to-refresh-indicator.visible{opacity:1;transform:translateY(0)}.refresh-content{display:flex;flex-direction:column;align-items:center;gap:8px;transition:transform .1s ease,opacity .1s ease}.refresh-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--card);border:2px solid var(--card-border);transition:all .3s cubic-bezier(.25,.46,.45,.94)}.refresh-icon.ready{background:var(--accent);border-color:var(--accent);transform:rotate(180deg)}.refresh-icon .icon{width:16px;height:16px;color:var(--text);transition:all .3s ease}.refresh-icon.ready .icon{color:var(--accent-contrast)}.refresh-icon .icon.rotate{transform:rotate(180deg)}.refresh-spinner{width:32px;height:32px;display:flex;align-items:center;justify-content:center}.spinner{width:20px;height:20px;border:2px solid var(--card-border);border-top:2px solid var(--accent);border-radius:50%;animation:spin .8s linear infinite}.refresh-text{font-size:.875rem;font-weight:500;color:var(--muted);text-align:center;transition:color .2s ease}.pull-refresh-wrapper{position:relative;height:100%;overflow:hidden}.pull-refresh-content{height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain!important;overscroll-behavior-x:none;-webkit-overscroll-behavior-y:contain}.refresh-icon{animation:bounce-in .4s cubic-bezier(.68,-.55,.265,1.55)}@keyframes bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@media (max-width: 640px){.pull-to-refresh-indicator{height:70px}.refresh-icon{width:28px;height:28px}.refresh-icon .icon{width:14px;height:14px}.refresh-text{font-size:.8rem}}.dark .pull-to-refresh-indicator{background:var(--surface);border-bottom-color:var(--card-border)}.dark .refresh-icon{background:var(--card);border-color:var(--card-border)}.dark .spinner{border-color:var(--card-border);border-top-color:var(--accent)}:root{--accent: #2563eb;--refresh-btn-bg: linear-gradient(150deg, rgba(59,130,246,.18) 0%, rgba(59,130,246,.04) 100%);--refresh-btn-hover-bg: linear-gradient(150deg, rgba(59,130,246,.25) 0%, rgba(59,130,246,.08) 100%);--refresh-btn-color: #2563eb;--refresh-btn-refreshing-bg: linear-gradient(135deg, #2563eb, #60a5fa)}.dark{--accent: #60a5fa;--refresh-btn-bg: linear-gradient(155deg, rgba(59,130,246,.22) 0%, rgba(15,23,42,.55) 100%);--refresh-btn-hover-bg: linear-gradient(150deg, rgba(96,165,250,.32) 0%, rgba(12,74,110,.55) 100%);--refresh-btn-color: #bfdbfe;--refresh-btn-refreshing-bg: linear-gradient(135deg, #2563eb, #60a5fa)}.refresh-button-container{position:fixed;right:1rem;bottom:calc(var(--bottom-nav-height, 56px) + 1rem);z-index:999;pointer-events:auto;transition:opacity .3s ease,transform .3s ease}.refresh-button{position:relative;width:58px;height:58px;border-radius:18px;border:1px solid rgba(37,99,235,.28);background:var(--refresh-btn-bg, #ecf6fd);color:var(--refresh-btn-color, #2563eb);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);box-shadow:0 12px 30px #0f172a2e,0 2px 6px #2563eb47;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .35s cubic-bezier(.34,1.56,.64,1);-webkit-tap-highlight-color:transparent;overflow:hidden;background-clip:padding-box}.refresh-button:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:radial-gradient(circle at 25% 20%,rgba(255,255,255,.55),transparent 65%);opacity:.45;pointer-events:none}.refresh-button:hover:not(:disabled){transform:translateY(-3px) scale(1.04);box-shadow:0 16px 38px #0f172a38,0 6px 14px #2563eb59;background:var(--refresh-btn-hover-bg, #e0f2ff);color:#1e40af}.refresh-button:active:not(:disabled){transform:translateY(0) scale(.98)}.refresh-button.is-refreshing{background:var(--refresh-btn-refreshing-bg, linear-gradient(135deg,#2563eb,#60a5fa));border-color:#2563eb99;box-shadow:0 18px 42px #2563eb66,0 6px 16px #2563eb59;color:#f5f7ff}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{width:26px;height:26px;display:block;color:inherit;filter:drop-shadow(0 2px 4px rgba(15,23,42,.18));transition:transform .35s ease,color .35s ease}.refresh-icon svg,.refresh-icon svg path{fill:currentColor!important;stroke:currentColor!important}.refresh-button:hover:not(:disabled) .refresh-icon{transform:rotate(-20deg)}.refresh-icon.spinning{animation:refresh-spin 1.05s ease-in-out infinite}@keyframes refresh-spin{0%{transform:rotate(0)}55%{transform:rotate(210deg)}to{transform:rotate(360deg)}}.dark .refresh-button{border-color:#94a3b847;box-shadow:0 16px 36px #070d1c8c,0 4px 12px #2563eb52;color:var(--refresh-btn-color, #bfdbfe)}.dark .refresh-button:hover:not(:disabled){color:#e0f2ff;background:var(--refresh-btn-hover-bg, #155e84);box-shadow:0 20px 44px #070d1c99,0 8px 18px #3b82f666}.dark .refresh-button.is-refreshing{color:#f8fbff;border-color:#94a3b873;box-shadow:0 22px 48px #070d1cad,0 10px 22px #3b82f673;background:var(--refresh-btn-refreshing-bg, linear-gradient(135deg,#2563eb,#60a5fa))}.dark .refresh-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}@media (min-width: 768px){.refresh-button-container{right:1.5rem;bottom:calc(var(--bottom-nav-height, 56px) + 1.5rem)}.refresh-button{width:64px;height:64px;border-radius:20px}.refresh-icon{width:28px;height:28px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.refresh-button-container{bottom:calc(var(--bottom-nav-height, 56px) + 1rem + env(safe-area-inset-bottom))}@media (min-width: 768px){.refresh-button-container{bottom:calc(var(--bottom-nav-height, 56px) + 1.5rem + env(safe-area-inset-bottom))}}}.page-container .page-content{padding:2rem 1rem}.page-container .card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1000px;margin:0 auto}.page-container .feature-card{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;box-shadow:0 4px 20px #00000014;transition:all .3s ease;cursor:pointer}.page-container .feature-card:hover{box-shadow:0 8px 30px #0000001f;border-color:var(--accent)}.page-container .feature-card .feature-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#fff;font-size:2rem;box-shadow:0 8px 25px #2563eb4d;transition:all .3s ease}.page-container .card-title{font-size:1.25rem;font-weight:600;color:var(--heading);margin-bottom:.75rem}.page-container .card-description{color:var(--muted);font-size:.9rem;line-height:1.5;margin-bottom:1.5rem}.page-container .action-button{background:linear-gradient(135deg,var(--accent) 0%,#3b82f6 100%);border:none;border-radius:.75rem;color:var(--accent-contrast, white);font-weight:600;transition:all .3s ease;position:relative;overflow:hidden;margin-top:1rem}.page-container .action-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.page-container .action-button:hover:before{left:100%}.page-container .feature-card .n-button.action-button,.page-container .feature-card .action-button.n-button,.page-container .n-button.action-button{background:linear-gradient(135deg,var(--accent) 0%,#3b82f6 100%)!important;border:none!important;border-radius:.75rem!important;color:var(--accent-contrast, white)!important;font-weight:600!important;position:relative!important;overflow:hidden!important}.page-container .n-button.action-button .n-button__content,.page-container .feature-card .n-button.action-button .n-button__content{color:inherit!important}.page-container .n-button.action-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;pointer-events:none;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transition:left .6s ease;display:block}.page-container .n-button.action-button:hover:before{left:100%}@media (max-width: 640px){.page-container .card-grid{grid-template-columns:1fr;gap:1rem}.page-container .feature-card{padding:1.5rem}.page-container .feature-card .feature-icon{width:60px;height:60px;font-size:1.5rem}}.dark .page-container .feature-card{background:var(--surface);border-color:var(--card-border)}.dark .page-container .feature-card .feature-icon{box-shadow:0 8px 25px #2563eb80}.page-container .page-content .modern-card{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;box-shadow:0 4px 20px #00000014;transition:all .3s ease}.page-container .page-content .modern-card .feature-icon{width:60px;height:60px;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#fff;font-size:1.5rem;box-shadow:0 8px 25px #2563eb4d;transition:all .3s ease}.page-container .page-content .card-title{font-size:1.25rem;font-weight:600;color:var(--heading);margin-bottom:.75rem;text-align:center}.page-container .page-content .card-description{color:var(--muted);font-size:.9rem;line-height:1.5;margin-bottom:1rem;text-align:center}.page-container .page-content .A2HSButton{display:inline-flex;justify-content:center;margin-top:.75rem}@media (max-width: 640px){.page-container .page-content .feature-icon{width:60px;height:60px;font-size:1.5rem}.page-container .page-content .modern-card{padding:1.5rem}}.dark .page-container .page-content .modern-card{background:var(--surface);border-color:var(--card-border)}.dark .page-container .page-content .feature-icon{box-shadow:0 8px 25px #2563eb80}.notifications-list .list-item{background:var(--card);border:1px solid var(--card-border);border-radius:.75rem;padding:1rem;transition:all .3s ease;position:relative;overflow:hidden;cursor:pointer}.notifications-list .list-item:hover{border-color:var(--accent);box-shadow:0 4px 15px #2563eb1a;transform:translateY(-1px)}.notifications-list .list-item.unread{border-left:4px solid var(--accent);background:linear-gradient(90deg,rgba(37,99,235,.03) 0%,var(--card) 50%)}.notifications-list .list-item.important{background:linear-gradient(135deg,var(--card) 0%,rgba(37,99,235,.02) 100%);border-left:4px solid var(--danger)}.dark .notifications-list .list-item{background:var(--surface);border-color:var(--card-border)}.dark .notifications-list .list-item:hover{background:var(--card);border-color:var(--accent);box-shadow:0 4px 15px #3b82f633}.dark .notifications-list .list-item.unread{border-left-color:var(--accent);background:linear-gradient(90deg,rgba(59,130,246,.08) 0%,var(--surface) 50%)}.dark .notifications-list .list-item.important{background:linear-gradient(135deg,var(--surface) 0%,rgba(59,130,246,.08) 100%);border-left-color:var(--danger)}.notification-layout{display:flex;align-items:flex-start;gap:.75rem}.notification-content{flex:1;min-width:0}.notification-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.5rem;gap:.75rem}.notification-title{font-weight:600;color:var(--heading);margin:0;font-size:1rem;line-height:1.4;flex:1}.notification-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.important-icon{color:var(--accent);font-size:1rem}.notification-body{display:flex;flex-direction:column;gap:.25rem}.notification-subtitle{font-size:.875rem;color:var(--text);font-weight:500;margin:0}.notification-preview{font-size:.875rem;color:var(--muted);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-right-column{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;min-width:80px;flex-shrink:0}.notification-time{font-size:.75rem;color:var(--muted);white-space:nowrap;text-align:right}.notification-actions{display:flex;align-items:center;justify-content:center;min-height:28px}.notification-actions .action-button{transition:opacity .2s ease,transform .2s ease}.dark .notification-title{color:var(--heading)}.dark .notification-subtitle{color:var(--text)}.dark .notification-preview,.dark .notification-time{color:var(--muted)}.dark .important-icon{color:#93c5fd}@media (max-width: 640px){.notification-layout{gap:.5rem}.notification-right-column{min-width:70px}.notification-header{gap:.5rem}}.qr-inline{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--muted);transition:color .2s ease;border-radius:50%}.profile-avatar-container .qr-inline{position:absolute;top:-8px;right:-10px;z-index:60;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--accent-contrast);border:2px solid rgba(255,255,255,.12);box-shadow:0 8px 20px #0206172e;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.qr-inline:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 12px 30px #02061738}.qr-icon{width:1.25rem;height:1.25rem;display:block;color:currentColor}.qr-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.qr-overlay-inner{padding:1rem}.qr-large{position:relative;background:var(--surface);padding:1.5rem;border-radius:1rem;box-shadow:var(--shadow-md);border:1px solid var(--card-border)}.qr-large img{display:block;width:100%;max-width:256px;height:auto;border-radius:.5rem}.qr-close-btn{position:absolute;top:8px;right:8px;width:36px;height:36px;background:var(--surface);border:1px solid var(--card-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .2s ease}.qr-close-btn:hover{transform:scale(1.06);background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.qr-close-icon{width:1.25rem;height:1.25rem}@media (max-width: 480px){.profile-avatar-container .qr-inline{top:6px;right:6px;width:32px;height:32px}}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.25rem;border:none;background:transparent;cursor:pointer;border-radius:50%;transition:background-color .2s ease}.user-menu-trigger:hover{background-color:#0000000d}.dark .user-menu-trigger:hover{background-color:#ffffff0d}.user-menu-trigger:focus{outline:2px solid var(--accent);outline-offset:2px}.user-menu{background:var(--surface);color:var(--text);z-index:60;max-height:calc(100vh - 6rem);overflow:auto;border:1px solid var(--card-border);box-shadow:0 20px 60px #00000026;position:absolute;right:0;top:calc(100% + .5rem);width:280px;border-radius:12px}.user-info-section{padding:1rem;border-bottom:1px solid var(--card-border)}.user-info-layout{display:flex;gap:.75rem;align-items:flex-start}.user-avatar-container{flex-shrink:0}.user-menu-avatar{box-shadow:0 4px 12px #2563eb4d}.dark .user-menu-avatar{box-shadow:0 4px 12px #2563eb80}.user-text-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.user-name{font-size:1rem;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark .user-name{color:#e6eef8}.user-email{font-size:.875rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:.8125rem;color:var(--accent);font-weight:500}.user-school{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--muted);margin-top:.125rem;overflow:hidden}.user-school .school-icon{flex-shrink:0;font-size:1rem}.user-school span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-items{padding:.5rem 0}.menu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;border:none;background:transparent;cursor:pointer;transition:background-color .2s ease;text-decoration:none;color:var(--text);font-size:.9375rem}.menu-item:hover{background-color:var(--card)}.menu-item:focus{outline:2px solid var(--accent);outline-offset:-2px}.menu-item-icon{font-size:1.25rem;color:var(--accent);flex-shrink:0}.logout-section{padding:.75rem 1rem 1rem;border-top:1px solid var(--card-border)}.logout-button{width:100%;min-height:44px;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:8px;background:var(--danger);color:#fff;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#dc2626;transform:translateY(-1px)}.logout-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.logout-button .animate-spin{animation:spin 1s linear infinite}.dark .user-menu{background:var(--surface);border-color:var(--card-border);box-shadow:0 20px 60px #0009}.dark .user-info-section{border-color:var(--card-border)}.dark .menu-item{color:var(--text)}.dark .menu-item:hover{background-color:var(--card)}.dark .logout-section{border-color:var(--card-border)}.dropdown-enter-active,.dropdown-leave-active{transition:all .2s ease}.dropdown-enter-from,.dropdown-leave-to{opacity:0;transform:translateY(-10px) scale(.95)}@media (max-width: 480px){.user-menu{width:260px}.user-name{font-size:.9375rem}.user-email{font-size:.8125rem}.menu-item{padding:.625rem .875rem;font-size:.875rem}}.base-avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;transition:all .3s ease}.base-avatar.clickable{cursor:pointer}.base-avatar.clickable:hover{transform:scale(1.05);box-shadow:0 12px 35px #2563eb66}.base-avatar.clickable:focus{outline:2px solid var(--accent);outline-offset:2px}.avatar-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--avatar-bg)}.avatar-initials{color:var(--initials-color);font-weight:700;-webkit-user-select:none;-moz-user-select:none;user-select:none}.avatar-xs{width:24px;height:24px}.avatar-xs .avatar-initials{font-size:.625rem}.avatar-sm{width:32px;height:32px}.avatar-sm .avatar-initials{font-size:.75rem}.avatar-md{width:48px;height:48px}.avatar-md .avatar-initials{font-size:1rem}.avatar-lg{width:80px;height:80px}.avatar-lg .avatar-initials{font-size:1.5rem}.avatar-xl{width:120px;height:120px;box-shadow:0 8px 25px #2563eb4d}.avatar-xl .avatar-initials{font-size:2rem}.dark .base-avatar.clickable:hover{box-shadow:0 12px 35px #2563eb99}.dark .avatar-xl{box-shadow:0 8px 25px #2563eb80}.base-avatar[style*=border]{box-shadow:0 8px 25px #2563eb4d}.dark .base-avatar[style*=border]{box-shadow:0 8px 25px #2563eb80}.update-prompt{position:fixed;left:0;right:0;bottom:0;padding:0 1rem calc(env(safe-area-inset-bottom,0px) + 1rem);display:flex;justify-content:center;pointer-events:none;z-index:1200}.update-prompt__surface{width:min(480px,100%);display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;border-radius:1rem;background:var(--surface);border:1px solid var(--card-border);box-shadow:0 18px 48px #0206172e;pointer-events:all}.update-prompt__icon{width:44px;height:44px;border-radius:999px;background:#2563eb1f;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.35rem;flex-shrink:0}.update-prompt__body{flex:1;min-width:0}.update-prompt__title{margin:0;font-size:.95rem;font-weight:600;color:var(--heading)}.update-prompt__message{margin:.15rem 0 0;font-size:.85rem;color:var(--muted)}.update-prompt__version{display:inline-block;margin-left:.35rem;font-weight:600;color:var(--accent)}.update-prompt__actions{flex-shrink:0}.update-prompt-enter-active,.update-prompt-leave-active{transition:transform .25s ease,opacity .2s ease}.update-prompt-enter-from,.update-prompt-leave-to{transform:translateY(20px);opacity:0}.dark .update-prompt__surface{background:var(--surface);border-color:var(--card-border);box-shadow:0 18px 48px #00000059}.home-page{min-height:100%;background:linear-gradient(135deg,var(--bg) 0%,var(--surface) 100%);padding-bottom:2rem}.home-school-section{padding:2rem 1rem 1rem}.school-card{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;box-shadow:0 4px 20px #00000014}.school-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.school-logo-container{flex-shrink:0}.school-logo{width:80px;height:80px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid var(--accent);box-shadow:0 4px 15px #2563eb4d}.school-logo-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#3b82f6);display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;box-shadow:0 4px 15px #2563eb4d}.school-info{flex:1;min-width:0}.school-name{font-size:1.5rem;font-weight:700;color:var(--heading);margin:0 0 .25rem;background:linear-gradient(135deg,var(--accent),#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.school-tagline{font-size:.875rem;color:var(--muted);margin:0}.school-description{font-size:.9375rem;color:var(--text);line-height:1.6;margin-bottom:1.5rem;padding:1rem;background:var(--surface);border-radius:.5rem;border-left:3px solid var(--accent)}.school-details{display:grid;gap:1rem;margin-bottom:1.5rem}.school-detail-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:var(--surface);border-radius:.5rem;transition:all .2s ease;text-decoration:none;color:inherit}.school-detail-link:hover{background:var(--bg);transform:translate(4px);box-shadow:0 2px 8px #2563eb26}.school-detail-link:active{transform:translate(2px)}.detail-icon{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:#2563eb1a;border-radius:.5rem;color:var(--accent);font-size:1.125rem}.detail-content{flex:1;min-width:0}.detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--muted);letter-spacing:.05em;margin-bottom:.25rem}.detail-value{font-size:.9375rem;color:var(--text);word-break:break-word;transition:color .2s ease}.school-detail-link:hover .detail-value{color:var(--accent)}.school-hours{background:var(--surface);border-radius:.5rem;padding:1rem;border:1px solid var(--card-border)}.hours-header{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--heading);margin-bottom:.75rem;font-size:.9375rem}.hours-header svg{color:var(--accent);font-size:1.125rem}.hours-list{display:grid;gap:.5rem}.hours-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--card-border)}.hours-item:last-child{border-bottom:none}.hours-label{font-size:.875rem;color:var(--muted);font-weight:500;flex-shrink:0}.hours-value{font-size:.875rem;color:var(--text);font-weight:600;text-align:right}.home-teachers-section{padding:2rem 1rem}.section-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:2rem;gap:0}.section-icon{width:4rem;height:4rem;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;font-size:2rem;color:#fff;box-shadow:0 8px 25px #2563eb4d}.section-title{font-size:1.75rem;font-weight:700;color:var(--heading);margin:0 0 .5rem;background:linear-gradient(135deg,var(--accent),#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:1rem;color:var(--muted);margin:0}.teachers-loading,.teachers-empty{text-align:center;padding:3rem 1rem;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:1rem}.teachers-loading svg,.teachers-empty svg{font-size:3rem;color:var(--accent)}.teachers-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.teacher-card{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 20px #00000014;transition:all .3s ease;cursor:pointer}.teacher-card:hover{box-shadow:0 8px 30px #2563eb26;border-color:var(--accent)}.teacher-avatar-container{text-align:center;margin-bottom:1rem;display:flex;justify-content:center;align-items:center}.teacher-avatar{width:80px;height:80px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid var(--accent);box-shadow:0 4px 15px #2563eb4d}.teacher-avatar-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#3b82f6);display:inline-flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;box-shadow:0 4px 15px #2563eb4d}.teacher-info{text-align:center}.teacher-name{font-size:1.125rem;font-weight:600;color:var(--heading);margin:0 0 .75rem}.teacher-specializations{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:.75rem}.specialization-tag{display:inline-block;padding:.25rem .75rem;background:#2563eb1a;color:var(--accent);border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.teacher-bio{font-size:.875rem;color:var(--muted);line-height:1.5;margin:0 0 1rem}.teacher-details{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--card-border)}.teacher-detail{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;color:var(--text);padding:.5rem .75rem;background:var(--surface);border-radius:.5rem;line-height:1.4;text-align:center}.teacher-detail .detail-icon{color:var(--accent);font-size:1rem;flex-shrink:0;width:auto;height:auto;background:none;border-radius:0}.teacher-detail .detail-text{font-weight:500;flex:1}.teacher-contact{display:flex;justify-content:center;gap:.75rem}.teacher-contact-btn{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:#2563eb1a;color:var(--accent);border-radius:50%;transition:all .2s ease;font-size:1.125rem;text-decoration:none}.teacher-contact-btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.teacher-contact-btn:active{transform:translateY(0)}.teachers-by-specialization{max-width:100%}.specialization-group{margin-bottom:1.5rem;border:1px solid var(--card-border);border-radius:12px;overflow:visible;background:var(--card);box-shadow:0 2px 8px #0000000a}.specialization-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--card-border);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;z-index:2}.specialization-header:hover{background:var(--card)}.specialization-header:focus{outline:none;box-shadow:0 0 0 4px #2563eb1f;border-radius:12px 12px 0 0}.specialization-info{display:flex;flex-direction:column;gap:.25rem}.specialization-title{font-size:1.125rem;font-weight:600;color:var(--heading);margin:0}.teacher-count{font-size:.875rem;color:var(--muted);font-weight:500}.expand-icon{font-size:1.25rem;color:var(--accent);transition:transform .2s ease}.specialization-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.specialization-content.expanded{max-height:2000px;transition:max-height .5s ease-in}.specialization-content .teachers-grid{padding:1.25rem;gap:1.25rem}.teachers-summary{text-align:center;padding:2rem 1rem;background:var(--surface);border-radius:12px;border:1px solid var(--card-border);margin-top:1rem}.summary-text{font-size:.95rem;color:var(--muted);margin:0}.specialization-content .teacher-card{background:var(--surface);border:1px solid var(--card-border)}.specialization-content .teacher-card:hover{background:var(--card);border-color:var(--accent)}.dark .school-card,.dark .teacher-card{background:var(--surface);border-color:var(--card-border)}.dark .school-detail-link:hover,.dark .teacher-card:hover,.dark .school-hours,.dark .teacher-detail{background:var(--card)}.dark .specialization-group{background:var(--surface);border-color:var(--card-border)}.dark .specialization-header{background:var(--card)}.dark .specialization-header:hover{background:var(--surface)}.dark .teachers-summary{background:var(--card)}@media (max-width: 640px){.home-school-section{padding:1rem}.school-card{padding:1.5rem}.school-header{flex-direction:column;text-align:center;gap:1rem}.school-logo,.school-logo-placeholder{width:70px;height:70px}.school-name{font-size:1.25rem}.school-tagline{font-size:.8125rem}.school-description{font-size:.875rem;padding:.75rem}.school-detail-item{padding:.625rem}.detail-icon{width:1.75rem;height:1.75rem;font-size:1rem}.detail-label{font-size:.6875rem}.detail-value{font-size:.875rem}.school-hours{padding:.875rem}.hours-header{font-size:.875rem;margin-bottom:.5rem}.hours-item{gap:.75rem;padding:.375rem 0}.hours-label,.hours-value{font-size:.8125rem}.teachers-grid{grid-template-columns:1fr}.section-title{font-size:1.5rem}.specialization-header{padding:.875rem 1rem}.specialization-title{font-size:1rem}.teacher-count{font-size:.8125rem}.specialization-content .teachers-grid{padding:1rem;grid-template-columns:1fr;gap:1rem}.teachers-summary{padding:1.5rem 1rem}}.animate-spin{animation:spin 1s linear infinite}.text-muted{color:var(--muted)}.fab{position:fixed;right:1rem;bottom:4.5rem;z-index:40}.a2hs-ios{max-width:520px}.a2hs-btn{font-weight:600}.login-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));background:linear-gradient(135deg,var(--bg) 0%,var(--surface) 100%);position:relative;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;box-sizing:border-box}.login-container{width:100%;max-width:400px;position:relative;z-index:10;margin:auto;padding:1rem 0}.login-header{text-align:center;margin-bottom:2rem;position:relative}.logo-container{margin-bottom:1.5rem}.logo-circle{width:80px;height:80px;background:linear-gradient(135deg,var(--accent) 0%,#3b82f6 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 10px 30px #2563eb4d;transition:all .3s ease}.logo-circle:hover{transform:translateY(-2px);box-shadow:0 15px 40px #2563eb66}.logo-text{font-size:2rem;font-weight:700;color:#fff}.login-title{font-size:1.75rem;font-weight:600;color:var(--heading);margin-bottom:.5rem}.login-subtitle{color:var(--muted);font-size:.95rem}.floating-shapes{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.shape{position:absolute;border-radius:50%;background:linear-gradient(45deg,var(--accent),#3b82f6);opacity:.1}.shape-1{width:20px;height:20px;top:20%;right:10%;animation:float 6s ease-in-out infinite}.shape-2{width:15px;height:15px;top:60%;left:5%;animation:float 8s ease-in-out infinite reverse}.shape-3{width:25px;height:25px;top:10%;left:15%;animation:float 10s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.login-form{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;box-shadow:0 20px 60px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:0}.form-container{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-label{font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:.25rem}.login-input{transition:all .3s ease}.login-input.focused{transform:translateY(-1px)}.input-icon{color:var(--muted);font-size:1.125rem}.password-toggle-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:.25rem;border-radius:.25rem;transition:all .2s ease}.password-toggle-btn:hover{color:var(--accent);background:#2563eb1a}.error-message{color:var(--danger);font-size:.8rem;display:flex;align-items:center;gap:.25rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.remember-group{display:flex;align-items:center;gap:.5rem}.submit-btn{height:48px;font-weight:600;background:linear-gradient(135deg,var(--accent) 0%,#3b82f6 100%);border:none;border-radius:.75rem;transition:all .3s ease;position:relative;overflow:hidden}.submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.submit-btn:hover:before{left:100%}.general-error{background:#b91c1c1a;color:var(--danger);padding:.75rem;border-radius:.5rem;border:1px solid rgba(185,28,28,.2);display:flex;align-items:center;gap:.5rem;font-size:.875rem}.error-icon{flex-shrink:0}.login-footer{text-align:center;margin-top:2rem}.footer-links{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.footer-link{padding:.5rem 1rem;border:none;background:transparent;color:var(--accent);text-decoration:none;border-radius:8px;transition:all .2s ease;font-size:.875rem;font-weight:500;min-height:44px;display:flex;align-items:center;justify-content:center}.footer-link:hover{background:#2563eb1a;color:var(--accent);transform:translateY(-1px)}.footer-link:focus{outline:2px solid rgba(37,99,235,.3);outline-offset:2px}.footer-link:active{transform:translateY(0)}.divider{color:var(--muted);font-size:.875rem;margin:0 .5rem}.footer-note{font-size:.8rem;color:var(--muted);padding:1rem;background:#2563eb0d;border-radius:.5rem;border:1px solid rgba(37,99,235,.1);line-height:1.5}.footer-demo-accounts{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.demo-account{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:var(--bg-elevated);border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.demo-account strong{color:var(--text-primary);font-family:var(--font-mono, "Courier New", monospace);font-size:.8125rem}.demo-role{font-size:.75rem;color:var(--text-tertiary)}.footer-settings-controls{position:relative;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 0;margin-top:.5rem;background:transparent;border-top:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:1}.dark .footer-link{color:var(--accent)}.dark .footer-link:hover{background:#2563eb26;color:var(--accent)}.dark .footer-settings-controls{background:var(--card);border-color:var(--card-border);box-shadow:0 -4px 12px #0000004d}@media (max-width: 480px){.footer-settings-controls{gap:.5rem;padding:.5rem 0;margin-top:.5rem}.footer-links{flex-direction:column;gap:.5rem}.divider{display:none}.footer-link{width:100%;max-width:200px}}.background-decoration{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.bg-circle{position:absolute;border-radius:50%;background:linear-gradient(135deg,var(--accent),#3b82f6)}.bg-circle-1{width:300px;height:300px;top:-150px;right:-150px}.bg-circle-2{width:200px;height:200px;bottom:-100px;left:-100px}.bg-circle-3{width:400px;height:400px;top:50%;left:50%;transform:translate(-50%,-50%)}.dark .login-form{background:#0f1724cc;border-color:#ffffff0f;box-shadow:0 20px 60px #0006}.dark .logo-circle{box-shadow:0 10px 30px #2563eb80}.dark .footer-note{background:#2563eb14;border-color:#2563eb26}.dark .general-error{background:#b91c1c26;border-color:#b91c1c4d}@media (max-width: 480px){.login-page{padding:.5rem;padding-top:max(.5rem,env(safe-area-inset-top,0px));padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px))}.login-form{padding:1.5rem;border-radius:.75rem}.logo-circle{width:60px;height:60px}.logo-text,.login-title{font-size:1.5rem}.bg-circle-1{width:200px;height:200px}.bg-circle-2{width:150px;height:150px}.bg-circle-3{width:300px;height:300px}}@media (max-height: 700px){.login-page{padding-top:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px))}.login-container{padding:.5rem 0}.login-form{padding:1.5rem}.login-header{margin-bottom:1.5rem}.logo-circle{width:60px;height:60px}.logo-text{font-size:1.5rem}}@media (prefers-reduced-motion: reduce){.login-page *,.login-page *:before,.login-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.floating-shapes .shape{animation:none}}.login-input:focus-within{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb26}.submit-btn:focus{outline:3px solid rgba(37,99,235,.3);outline-offset:2px}.footer-link:focus{outline:2px solid rgba(37,99,235,.5);outline-offset:2px;border-radius:.25rem}.school-selection-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));background:linear-gradient(135deg,var(--bg) 0%,var(--surface) 100%);position:relative;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.school-selection-container{width:100%;max-width:500px;margin:auto;padding:1rem 0}.selection-header{text-align:center;margin-bottom:2rem;position:relative}.selection-header .logout-button{position:absolute;top:0;right:0;width:44px;height:44px;border-radius:50%;background:var(--card);border:2px solid var(--card-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:var(--text);font-size:1.25rem;box-shadow:0 2px 8px #00000014}.selection-header .logout-button:hover:not(:disabled){background:var(--surface);border-color:var(--accent);color:var(--accent);transform:scale(1.05);box-shadow:0 4px 12px #2563eb33}.selection-header .logout-button:active:not(:disabled){transform:scale(.95)}.selection-header .logout-button:disabled{opacity:.5;cursor:not-allowed}.selection-header .logout-button .animate-spin{animation:spin 1s linear infinite}.selection-header .header-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;box-shadow:0 10px 30px #2563eb4d}.selection-header .selection-title{font-size:1.75rem;font-weight:600;color:var(--heading);margin:0 0 .5rem}.selection-header .selection-subtitle{font-size:.95rem;color:var(--muted);margin:0}.school-selection-page .schools-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;min-height:220px}.school-selection-page .school-card{background:var(--card);border:2px solid var(--card-border);border-radius:1rem;padding:1.25rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .3s ease;min-height:88px}.school-selection-page .school-card:hover{background:var(--surface);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 25px #2563eb26}.school-selection-page .school-card:focus{outline:2px solid var(--accent);outline-offset:2px}.school-selection-page .school-card.selected{border-color:var(--accent);background:#2563eb0d;box-shadow:0 4px 20px #2563eb33}.school-selection-page .school-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.school-selection-page .school-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:600;flex-shrink:0;box-shadow:0 4px 15px #2563eb4d}.school-selection-page .school-details{flex:1;min-width:0}.school-selection-page .school-name{font-size:1.125rem;font-weight:600;color:var(--heading);margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-word;line-height:1.4}.school-selection-page .school-role{font-size:.875rem;color:var(--muted);margin:0}.school-selection-page .school-check{color:var(--accent);font-size:1.5rem;flex-shrink:0;margin-left:.5rem}.school-selection-page .no-schools{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1rem;color:var(--muted);gap:.5rem;width:100%}.school-selection-page .no-schools svg{font-size:3rem;margin-bottom:1rem;color:var(--accent)}.school-selection-page .no-schools p{margin:0;font-size:1rem}.school-selection-page .continue-section{margin-top:2rem}.school-selection-page .continue-btn{height:56px;font-size:1rem;font-weight:600;background:linear-gradient(135deg,var(--accent) 0%,#3b82f6 100%);border:none;border-radius:.75rem;transition:all .3s ease;position:relative;overflow:hidden}.school-selection-page .continue-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.school-selection-page .continue-btn:hover:before{left:100%}.school-selection-page .continue-btn:disabled{opacity:.5;cursor:not-allowed}.dark .school-selection-page .school-card{background:var(--surface);border-color:var(--card-border)}.dark .school-selection-page .school-card:hover{background:var(--card)}.dark .school-selection-page .school-card.selected{background:#2563eb1f}@media (max-width: 480px){.school-selection-page{padding:.5rem}.selection-header .selection-title{font-size:1.5rem}.selection-header .header-icon{width:64px;height:64px;font-size:2rem}.school-selection-page .school-card{padding:1rem}.school-selection-page .school-avatar{width:48px;height:48px;font-size:1.125rem}.school-selection-page .school-name{font-size:1rem}}@media (prefers-reduced-motion: reduce){.school-selection-page *,.school-selection-page *:before,.school-selection-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.calendar-page{min-height:100vh;background:var(--bg)}.calendar-header-container{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--card-border)}.calendar-content{padding:.25rem}.calendar-header{background:var(--surface)}.btn-today{background:transparent;border:1px solid var(--card-border);color:var(--text);transition:all .2s ease}.btn-today:hover,.btn-today-active{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.calendar-day-button{min-width:80px;padding:.75rem 1rem;border-radius:12px;border:1px solid var(--card-border);background:var(--surface);transition:all .2s ease;cursor:pointer;position:relative}.calendar-day-button:hover{background:#2563eb0d;border-color:var(--accent)}.calendar-day-button:focus{outline:2px solid var(--accent);outline-offset:2px}.calendar-day.calendar-day-selected{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent);box-shadow:0 4px 12px #2563eb26}.calendar-day.calendar-day-today:not(.calendar-day-selected){border-color:var(--accent);color:var(--accent);font-weight:600}.calendar-day-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.day-name{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.day-number{font-size:1.125rem;font-weight:600}.today-indicator{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.calendar-day-selected .today-indicator{background:var(--accent-contrast)}.calendar-grid-container{max-width:48rem;margin:0 auto}.calendar-grid{padding:.5rem;min-height:300px}.calendar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem}.loading-spinner{width:32px;height:32px;border:3px solid var(--card-border);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.calendar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-icon{opacity:.6}.calendar-events{padding:.5rem}.events-header{margin-bottom:.75rem;text-align:center}.events-list{max-width:100%}.calendar-class-card{background:var(--card-color, var(--surface));border:1px solid var(--card-border);border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0206170a;position:relative;overflow:hidden}.calendar-class-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0206171f;border-color:var(--accent)}.calendar-class-card:focus{outline:2px solid var(--accent);outline-offset:2px}.class-card-content{display:flex;flex-direction:column;gap:.75rem}.class-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.class-time{display:flex;align-items:center;gap:.375rem;font-weight:600;color:var(--accent)}.class-room{display:flex;align-items:center;gap:.25rem;font-size:.875rem}.class-title{font-size:1.125rem;font-weight:600;color:var(--heading);margin:0}.class-description{font-size:.875rem;color:var(--muted);line-height:1.4}.class-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.875rem}.class-instructor{display:flex;align-items:center;gap:.25rem}.class-level-badge{background:#2563eb1a;color:var(--accent);padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}.class-main{flex:1}.class-student{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#2563eb0d;border-radius:8px;border:1px solid rgba(37,99,235,.1)}.class-status{display:flex;align-items:center}.calendar-class-card.status-missed{border-left:4px solid #ef4444}.calendar-class-card.status-checked-in{border-left:4px solid #22c55e}.calendar-class-card.status-canceled{border-left:4px solid #6b7280;opacity:.75}.calendar-class-card .current-time-indicator{position:absolute;left:-1px;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0;animation:pulse 2s infinite}.calendar-event-enter-active,.calendar-event-leave-active{transition:all .3s ease}.calendar-event-enter-from{opacity:0;transform:translateY(20px)}.calendar-event-leave-to{opacity:0;transform:translate(-20px)}@media (max-width: 640px){.calendar-content{padding:.25rem}.calendar-grid{padding:.5rem}.calendar-day-button{min-width:70px;padding:.5rem .75rem}.day-number{font-size:1rem}.class-header,.class-footer{flex-direction:column;align-items:flex-start}}.dark .calendar-class-card{background:var(--surface);border-color:var(--card-border)}.dark .loading-spinner{border-color:var(--card-border);border-top-color:var(--accent)}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.no-scrollbar::-webkit-scrollbar{display:none}.notifications-page{min-height:100vh;background:var(--bg);overscroll-behavior-y:contain}.notifications-scroll-container{height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.notifications-content{padding:1rem;min-height:calc(100vh - var(--top-nav-height) - var(--bottom-nav-height))}.page-header{padding:1.5rem 1rem;background:var(--surface);border-bottom:1px solid var(--card-border);box-shadow:0 2px 10px #0000000d}.header-content{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-info{display:flex;align-items:center;gap:1rem}.header-icon{width:50px;height:50px;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;box-shadow:0 4px 15px #2563eb4d;flex-shrink:0}.header-text{display:flex;flex-direction:column;gap:.25rem}.page-title{font-size:1.5rem;font-weight:600;color:var(--heading);margin:0}.page-subtitle{color:var(--muted);margin:.25rem 0 0;font-size:.9rem}.filter-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:12px;border:2px solid var(--card-border);background:var(--card);color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap;flex-shrink:0}.filter-toggle:hover{border-color:var(--accent);background:var(--surface);transform:translateY(-1px)}.filter-toggle.active{border-color:var(--accent);background:linear-gradient(135deg,var(--accent),#3b82f6);color:#fff;box-shadow:0 4px 12px #2563eb4d}.filter-icon{font-size:1.25rem;flex-shrink:0}.filter-label{font-weight:600}.notifications-list{display:flex;flex-direction:column;gap:.75rem}.notification-item{background:var(--card);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:1rem;transition:all .2s ease;cursor:pointer}.notification-item:hover{background:var(--surface);transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:var(--accent)}.notification-item--unread{border-left:4px solid var(--accent);background:linear-gradient(90deg,rgba(37,99,235,.03) 0%,var(--card) 50%)}.notification-item--important{border-left:4px solid var(--danger);background:linear-gradient(90deg,rgba(239,68,68,.03) 0%,var(--card) 50%)}.notifications-empty{padding:4rem 1rem;text-align:center}.empty-content{max-width:400px;margin:0 auto}.notifications-empty-icon{width:80px;height:80px;background:var(--surface);border:2px solid var(--card-border);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--muted);font-size:2rem}.notifications-empty-title{font-size:1.25rem;font-weight:600;color:var(--heading);margin-bottom:.75rem}.notifications-empty-description{color:var(--muted);line-height:1.5}.notifications-loading{display:flex;justify-content:center;align-items:center;padding:1.25rem 0;width:100%;box-sizing:border-box}.load-more-trigger{width:100%;height:1px;visibility:hidden}.dark .notifications-page{background:var(--bg)}.dark .page-header{background:var(--surface);border-color:var(--card-border);box-shadow:0 2px 10px #0000004d}.dark .header-icon{box-shadow:0 4px 15px #3b82f680}.dark .notifications-empty-icon{background:var(--card);border-color:var(--card-border)}.dark .filter-toggle{background:var(--surface);border-color:var(--card-border);color:var(--text)}.dark .filter-toggle:hover{background:var(--card);border-color:var(--accent)}.dark .filter-toggle.active{background:linear-gradient(135deg,var(--accent),#3b82f6);color:#fff;box-shadow:0 4px 12px #3b82f680}.dark .notification-item{background:var(--surface);border-color:var(--card-border)}.dark .notification-item:hover{background:var(--card);border-color:var(--accent);box-shadow:0 4px 12px #3b82f626}.dark .notification-item--unread{border-left-color:var(--accent);background:linear-gradient(90deg,rgba(59,130,246,.08) 0%,var(--surface) 50%)}.dark .notification-item--important{border-left-color:var(--danger);background:linear-gradient(90deg,rgba(239,68,68,.08) 0%,var(--surface) 50%)}.notification-image-wrapper{width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:12px;background:var(--card)}.notification-image{width:100%;max-width:900px;max-height:420px;-o-object-fit:cover;object-fit:cover;display:block;border-radius:12px}@media (max-width: 640px){.notifications-content{padding:.5rem}.page-header{padding:1rem}.header-content{flex-direction:column;align-items:stretch}.header-info{flex-direction:row;justify-content:flex-start}.header-icon{width:60px;height:60px;font-size:1.75rem}.filter-toggle{justify-content:center;width:100%}}.profile-page{min-height:100%;background:linear-gradient(135deg,var(--bg) 0%,var(--surface) 100%)}.profile-header-section{background:var(--surface);padding-top:2rem;text-align:center;border-bottom:1px solid var(--card-border);position:relative;overflow:visible}.profile-identity-container{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.profile-avatar-container{position:relative;display:inline-block;padding:6px}.profile-avatar{width:120px;height:120px;border-radius:50%;border:4px solid var(--accent);box-shadow:0 8px 25px #2563eb4d;transition:all .3s ease}.profile-avatar:hover{transform:scale(1.05);box-shadow:0 12px 35px #2563eb66}.profile-status-tag{margin-top:0;padding:.1rem .6rem}.profile-name{font-size:1.75rem;font-weight:700;color:var(--heading)}.profile-role{color:var(--muted);font-size:.9rem;font-weight:500;margin-top:.25rem}.profile-meta{display:none}.profile-sections{padding:2rem 1rem}.profile-section{margin-bottom:2rem}.section-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1rem;text-align:center}.section-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-item{background:var(--card);border:1px solid var(--card-border);border-radius:.75rem;padding:1rem;transition:all .3s ease}.info-item:hover{border-color:var(--accent);transform:translateY(-1px)}.info-label{font-size:.875rem;color:var(--muted);margin-bottom:.25rem}.info-value{font-weight:500;color:var(--text)}.info-link{color:var(--accent);text-decoration:none;transition:all .2s ease}.info-link:hover{color:#1d4ed8;text-decoration:underline}.profile-name-wrapper{display:flex;align-items:center;justify-content:center;gap:.75rem}@media (max-width: 640px){.profile-avatar{width:100px;height:100px}.profile-name{font-size:1.5rem}.info-grid{grid-template-columns:1fr}}.dark .profile-header-section{background:var(--surface);border-color:var(--card-border)}.dark .profile-avatar{border-color:var(--accent);box-shadow:0 8px 25px #2563eb80}.dark .info-item{background:var(--surface);border-color:var(--card-border)}.settings-page{min-height:100%;background:linear-gradient(135deg,var(--bg) 0%,var(--surface) 100%);padding:2rem 1rem}.settings-header{text-align:center;margin-bottom:3rem}.page-title{font-size:2rem;font-weight:700;color:var(--heading);margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent),#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{color:var(--muted);font-size:1rem;max-width:500px;margin:0 auto;line-height:1.5}.settings-content{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--card);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;box-shadow:0 4px 20px #00000014}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.settings-section-icon{width:24px;height:24px;color:var(--accent)}.section-title{font-size:1.25rem;font-weight:600;color:var(--heading);margin:0}.settings-card{background:var(--surface);border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.setting-group{display:flex;flex-direction:column;gap:1rem}.setting-group-header{display:flex;align-items:center;gap:.5rem}.settings-group-icon{width:20px;height:20px;color:var(--accent)}.setting-group-title{font-size:1rem;font-weight:500;color:var(--heading);margin:0}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:1rem}.setting-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.setting-label{font-weight:500;color:var(--text)}.setting-description{font-size:.875rem;color:var(--muted)}@media (max-width: 640px){.settings-page{padding:1rem}.settings-section{padding:1.5rem}.setting-item{flex-direction:column;align-items:stretch;text-align:center}}.dark .settings-section{background:var(--surface);border-color:var(--card-border)}.dark .settings-card{background:var(--card);border-color:var(--card-border)}.not-found-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--top-nav-height) - var(--bottom-nav-height));padding:2rem}.not-found-content{text-align:center;max-width:500px}.not-found-icon{display:flex;justify-content:center;align-items:center;font-size:6rem;color:var(--muted);margin-bottom:1.5rem}.not-found-icon svg{display:block;width:6rem;height:6rem;vertical-align:middle}.not-found-title{font-size:2rem;font-weight:700;color:var(--text);margin-bottom:1rem}.not-found-description{font-size:1rem;color:var(--muted);margin-bottom:2rem}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.notification-setup{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0 2.5rem}.notification-setup__hero{text-align:center;padding:1.5rem 1rem;border-radius:1.25rem;background:var(--surface);border:1px solid var(--card-border);box-shadow:var(--shadow-md, 0 10px 40px rgba(2, 6, 23, .08))}.notification-setup__hero-icon{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;background:#2563eb1f;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.75rem}.notification-setup__hero h1{margin:0 0 .5rem;font-size:1.5rem;color:var(--heading)}.notification-setup__hero p{margin:0;color:var(--muted);font-size:.95rem}.notification-setup__steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.notification-step{display:flex;gap:1rem;padding:1rem 1.25rem;border-radius:1rem;border:1px solid var(--card-border);background:var(--card);align-items:flex-start}.notification-step__icon{width:44px;height:44px;border-radius:50%;background:#2563eb1a;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.25rem}.notification-step__body h3{margin:0;font-size:1rem;color:var(--heading)}.notification-step__body p{margin:.35rem 0 0;color:var(--muted);font-size:.9rem}.notification-step__actions{margin-left:auto;display:flex;align-items:center}.notification-step__status{font-size:.85rem;color:var(--muted)}.notification-step__status.is-success{color:var(--success)}.notification-step__status.is-error{color:var(--danger)}.notification-step__error{margin-top:.35rem;color:var(--danger);font-size:.85rem}.notification-step__hint{margin-top:.35rem;color:var(--muted);font-size:.85rem}.notification-step--locked{opacity:.7}.notification-setup__footer{margin-top:1rem}.notification-setup__fallback{display:flex;flex-direction:column;gap:.75rem;text-align:center}.notification-setup__fallback p{margin:0;color:var(--muted)}.notification-setup__hint-text{margin:0;text-align:center;color:var(--muted);font-size:.9rem}@media (min-width: 768px){.notification-step{padding:1.5rem}}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.dark\:text-gray-400:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.dark\:text-white:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:w-56{width:14rem}}
