:root{--primary: #004b87;--primary-dark: #003a6b;--primary-light: #f0f6ff;--green: #22c55e;--red: #dc2626;--yellow: #f59e0b;--purple: #6d28d9;--text: #0d1b2a;--text-secondary: #5a6480;--text-muted: #9ca3af;--border: #e2e8f0;--bg-page: #f4f6fb;--bg-card: #fff;--radius: 12px;--shadow: 0 1px 4px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--auth-ink-900: oklch(22% .05 252);--auth-ink-800: oklch(28% .08 252);--auth-ink-700: oklch(35% .1 250);--auth-ink-600: oklch(45% .12 250);--auth-ink-500: oklch(55% .13 248);--auth-accent: oklch(62% .16 240);--auth-paper-0: #ffffff;--auth-paper-1: #f8f9fb;--auth-paper-2: #eef1f6;--auth-line: rgba(20, 30, 60, .1);--auth-line-2: rgba(20, 30, 60, .18);--auth-text: oklch(20% .02 250);--auth-muted: oklch(48% .02 250);--auth-muted-2: oklch(60% .02 250);--auth-danger: oklch(58% .18 25);--auth-success: oklch(58% .13 155)}@keyframes auth-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes auth-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes auth-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}html,body{overflow-x:clip;max-width:100vw;width:100%}body{font-family:Inter,Arial,sans-serif;background:var(--bg-page);color:var(--text);line-height:1.5}#root,.app-shell{width:100%;max-width:100vw;overflow-x:clip}button{cursor:pointer;font-family:inherit}a{text-decoration:none;color:inherit}img,svg{max-width:100%;display:block}input,select,textarea{font-family:inherit;max-width:100%}body{overflow-wrap:break-word}.container{max-width:1120px;margin:0 auto;padding:0 20px}.app-shell{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:32px 20px}.page-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-inner{max-width:1120px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:32px}.header-right{display:flex;align-items:center;gap:12px}.logo-svg{height:36px;width:auto}.nav-desktop{display:flex;gap:4px}.nav-link{padding:6px 14px;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:background .15s,color .15s}.nav-link:hover,.nav-link.active{background:var(--primary-light);color:var(--primary)}.nav-mobile{display:flex;flex-direction:column;border-top:1px solid var(--border);padding:8px 20px 12px;background:#fff}.nav-mobile .nav-link{display:block;padding:10px 0;border-radius:0;border-bottom:1px solid var(--border)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px}.user-menu{position:relative}.avatar-btn{background:none;border:none;padding:0}.avatar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;font-size:.8rem;font-weight:700}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:200px;z-index:200}.dropdown-header{padding:14px 16px}.dropdown-header strong{display:block;font-size:.95rem;color:var(--text)}.dropdown-header small{display:block;font-size:.8rem;color:var(--text-muted);margin-top:2px}.user-dropdown hr{border:none;border-top:1px solid var(--border);margin:0}.dropdown-item{display:block;width:100%;text-align:left;padding:10px 16px;font-size:.9rem;color:var(--text);background:none;border:none;transition:background .15s}.dropdown-item:hover{background:var(--bg-page)}.site-footer{background:#fff;border-top:1px solid var(--border);padding:24px 0;margin-top:40px}.footer-inner{max-width:1120px;margin:0 auto;padding:0 20px;display:flex;align-items:center;flex-wrap:wrap;gap:16px;justify-content:space-between}.footer-brand{display:flex;align-items:center;gap:12px}.footer-tagline{font-size:.82rem;color:var(--text-muted)}.footer-links{display:flex;gap:16px}.footer-links a{font-size:.85rem;color:var(--text-secondary)}.footer-links a:hover{color:var(--primary)}.footer-copy{font-size:.8rem;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:600;border:none;transition:background .15s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#d1d9e6}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:7px 14px;font-size:.85rem}.btn-xs{padding:4px 10px;font-size:.78rem;border-radius:6px}.btn-auth{width:100%;padding:12px;font-size:1rem;margin-top:8px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text);background:#fff;transition:border-color .15s}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #004b8722}.form-control:disabled{background:var(--bg-page);color:var(--text-muted);cursor:not-allowed}textarea.form-control{resize:vertical}.form-error{color:var(--red);font-size:.85rem;margin-top:-8px;margin-bottom:8px}.form-success{color:#065f46;font-size:.85rem;margin-top:-8px;margin-bottom:8px}.form-check{display:flex;align-items:center;gap:8px;margin-top:8px}.form-check input{width:16px;height:16px;cursor:pointer}.form-check label{font-size:.9rem;cursor:pointer}.toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 18px;border-radius:10px;font-size:.9rem;font-weight:500;box-shadow:var(--shadow-md);animation:slideIn .25s ease;max-width:340px}.toast-success{background:#dcfce7;color:#166534}.toast-error{background:#fee2e2;color:#991b1b}.toast-info{background:#dbeafe;color:#1e40af}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}.modal{background:#fff;border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1.05rem;font-weight:700;margin:0}.modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-muted);line-height:1;padding:4px 8px}.modal-close:hover{color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 24px 20px}.auth-split-body{min-height:100vh;background:var(--bg-page);display:flex;align-items:stretch}.auth-split{display:flex;width:100%;min-height:100vh}.auth-left{width:42%;background:var(--primary);display:flex;align-items:center}.auth-left-inner{padding:60px 48px}.auth-left-headline{font-family:Barlow,sans-serif;font-size:2.4rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:16px}.auth-left-sub{color:#ffffffbf;font-size:1rem;margin-bottom:28px;line-height:1.6}.auth-left-features{list-style:none;display:flex;flex-direction:column;gap:10px}.auth-left-features li{color:#ffffffd9;font-size:.95rem;display:flex;align-items:center;gap:10px}.auth-left-features li:before{content:"✓";font-weight:700;color:#7dd3fc;flex-shrink:0}.auth-right{flex:1;display:flex;align-items:center;justify-content:center;background:#fff}.auth-right-inner{width:100%;max-width:420px;padding:40px 48px}.auth-form-logo{text-align:center;margin-bottom:28px}.auth-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}.auth-tab{background:none;border:none;padding:8px 16px;font-size:.88rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s}.auth-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.booking-page{max-width:800px;margin:0 auto}.date-selector{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.date-btn{display:flex;flex-direction:column;align-items:center;padding:10px 18px;border:2px solid var(--border);border-radius:10px;background:#fff;min-width:80px;transition:border-color .15s,background .15s}.date-btn.active{border-color:var(--primary);background:var(--primary-light)}.date-day{font-size:.78rem;font-weight:500;color:var(--text-muted);text-transform:uppercase}.date-num{font-size:1.1rem;font-weight:700;color:var(--text)}.date-btn.active .date-day,.date-btn.active .date-num{color:var(--primary)}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.slot-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:box-shadow .2s}.slot-card:hover{box-shadow:var(--shadow-md)}.slot-card.slot-booked{border-color:var(--primary);background:var(--primary-light)}.slot-card.slot-blocked{opacity:.5;pointer-events:none}.slot-card.slot-cert-blocked{opacity:.5;filter:grayscale(.5)}.slot-card.slot-past{opacity:.4;filter:grayscale(.7);pointer-events:none}.slots-blocked-overlay{position:relative}.slot-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.slot-time{font-size:1.25rem;font-weight:700;color:var(--primary)}.slot-period{font-size:.75rem;background:var(--primary-light);color:var(--primary);padding:2px 7px;border-radius:20px;font-weight:500}.slot-count{margin-left:auto;font-size:.88rem;font-weight:600}.slot-bar-wrap{background:var(--border);border-radius:4px;height:5px;margin-bottom:6px;overflow:hidden}.slot-bar{height:100%;border-radius:4px;transition:width .4s}.slot-remaining{font-size:.8rem;color:var(--text-muted);margin-bottom:6px}.slot-actions{margin-top:10px}.waitlist-badge{font-size:.75rem;background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:20px;font-weight:600}.slot-attendees{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0 8px}.attendee-chip{display:inline-flex;align-items:center;gap:5px;background:#f1f5f9;color:#334155;border-radius:20px;padding:2px 8px 2px 2px;font-size:.72rem;font-weight:500;max-width:100%}.attendee-chip.attendee-self{background:var(--primary-light);color:var(--primary)}.attendee-avatar{width:18px;height:18px;border-radius:50%;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;flex-shrink:0}.attendee-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.booked-today-banner{background:#d1fae5;color:#065f46;padding:10px 16px;border-radius:10px;font-weight:500;display:flex;align-items:center;gap:8px;margin-bottom:16px}.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--green);display:inline-block;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.upcoming-section{margin-bottom:20px}.upcoming-title{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.upcoming-list{display:flex;gap:8px;flex-wrap:wrap}.upcoming-item{background:#fff;border:1px solid var(--border);border-radius:8px;padding:6px 12px;display:flex;gap:8px;align-items:center}.upcoming-date{font-size:.85rem;font-weight:600;color:var(--text)}.upcoming-time{font-size:.85rem;color:var(--primary);font-weight:600}.announcement-item{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}.announcement-urgent{border-left:4px solid var(--red)}.announcement-content{flex:1}.announcement-content strong{display:block;margin-bottom:4px;color:var(--text)}.announcement-content p{font-size:.88rem;color:var(--text-secondary);margin:0}.announcement-close{background:none;border:none;font-size:1.1rem;color:var(--text-muted);padding:0 4px}.announcement-icon{font-size:1.1rem;flex-shrink:0}.history-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.hstat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center}.hstat-value{display:block;font-size:1.6rem;font-weight:700;color:var(--primary)}.hstat-label{display:block;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.filter-bar{display:flex;align-items:center;gap:6px;margin-bottom:16px}.filter-btn{background:none;border:1px solid var(--border);padding:6px 14px;border-radius:20px;font-size:.85rem;color:var(--text-secondary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.history-info{display:flex;gap:16px}.history-date{font-weight:600;color:var(--text);font-size:.9rem}.history-time{color:var(--primary);font-weight:600;font-size:.9rem}.status-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.78rem;font-weight:600}.badge-active{background:#d1fae5;color:#065f46}.badge-cancelled{background:#fee2e2;color:#991b1b}.pagination{display:flex;align-items:center;gap:12px;margin-top:20px;justify-content:center}.admin-wrap{max-width:1100px;margin:0 auto;padding:32px 20px}.admin-header{margin-bottom:20px}.admin-title{font-size:1.75rem;font-weight:700}.admin-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:24px;flex-wrap:wrap}.admin-tab{background:none;border:none;padding:9px 16px;font-size:.88rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:6px 6px 0 0}.admin-tab:hover{color:var(--primary)}.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-light)}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}.kpi-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px}.kpi-value{font-size:1.8rem;font-weight:700;color:var(--primary)}.kpi-label{font-size:.78rem;color:var(--text-muted);margin-top:4px}.admin-chart-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.admin-chart-card h3{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:16px}.admin-export-row{display:flex;gap:10px;flex-wrap:wrap}.admin-filter-row{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th{text-align:left;padding:9px 12px;background:var(--bg-page);border-bottom:2px solid var(--border);font-weight:600;color:var(--text-secondary);white-space:nowrap}.admin-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-page)}.empty-state{text-align:center;color:var(--text-muted);padding:32px;font-size:.9rem}.prof-wrap{max-width:1100px;margin:0 auto;padding:32px 20px}.prof-header{margin-bottom:24px}.prof-title{font-size:1.75rem;font-weight:700;color:var(--text);margin-bottom:4px}.prof-subtitle{color:var(--text-secondary);font-size:.95rem}.prof-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:24px}.prof-tab{background:none;border:none;padding:10px 20px;font-size:.9rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:6px 6px 0 0}.prof-tab:hover{color:var(--primary)}.prof-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-light)}.prof-tab-content{display:none}.prof-tab-content.active{display:block}.prof-day-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.prof-day-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.prof-date-input{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem}.prof-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.prof-slot-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px}.prof-slot-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}.prof-slot-time{font-size:1.3rem;font-weight:700;color:var(--primary)}.prof-slot-period{font-size:.75rem;background:var(--primary-light);color:var(--primary);padding:2px 8px;border-radius:20px}.prof-slot-count{margin-left:auto;font-weight:600;font-size:.9rem}.prof-slot-bar-wrap{background:var(--border);border-radius:4px;height:6px;margin-bottom:6px;overflow:hidden}.prof-slot-bar{background:var(--primary);height:100%;border-radius:4px;transition:width .4s}.prof-slot-remaining{font-size:.8rem;color:var(--text-muted);margin-bottom:10px}.prof-slot-participants{border-top:1px solid var(--bg-page);padding-top:10px;display:flex;flex-direction:column;gap:6px}.prof-participant{display:flex;flex-direction:column}.prof-participant-name{font-size:.9rem;font-weight:500}.prof-participant-email{font-size:.8rem;color:var(--text-muted)}.prof-no-participants{font-size:.85rem;color:var(--text-muted);margin:0}.prof-search-bar{margin-bottom:18px}.prof-students-grid{display:flex;flex-direction:column;gap:10px}.prof-student-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;cursor:pointer;transition:box-shadow .2s,border-color .2s}.prof-student-card:hover{box-shadow:var(--shadow-md);border-color:#b6d0f7}.prof-student-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.prof-student-info{flex:1;min-width:0}.prof-student-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prof-student-email{font-size:.82rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prof-student-stats{display:flex;gap:16px;flex-shrink:0}.prof-student-stat{text-align:center}.prof-stat-val{display:block;font-size:1.1rem;font-weight:700;color:var(--primary)}.prof-stat-lbl{display:block;font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.prof-student-arrow{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.prof-profile-grid{display:flex;flex-direction:column;gap:20px}.prof-profile-stats{display:flex;gap:12px}.prof-pstat{flex:1;background:var(--primary-light);border-radius:10px;padding:14px;text-align:center}.prof-pstat-val{display:block;font-size:1.4rem;font-weight:700;color:var(--primary)}.prof-pstat-lbl{display:block;font-size:.78rem;color:var(--text-muted);margin-top:2px}.prof-section-label{font-size:.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}.prof-history-table{width:100%;border-collapse:collapse;font-size:.88rem}.prof-history-table th{text-align:left;padding:6px 10px;color:var(--text-secondary);font-weight:600;border-bottom:1px solid var(--border)}.prof-history-table td{padding:7px 10px;border-bottom:1px solid var(--bg-page)}.prof-note{background:var(--bg-page);border-left:3px solid var(--primary);border-radius:0 8px 8px 0;padding:10px 12px;margin-bottom:8px}.prof-note-meta{font-size:.78rem;color:var(--text-muted);margin-bottom:4px}.prof-note-body{font-size:.9rem;white-space:pre-wrap}.prof-note-delete{background:none;border:none;color:var(--red);font-size:.78rem;cursor:pointer;margin-top:4px;padding:0}.prof-note-delete:hover{text-decoration:underline}.prof-section-actions{margin-bottom:16px}.prof-ann-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px}.prof-ann-urgent{border-left:4px solid var(--red)}.prof-ann-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.prof-ann-badge{background:#fee2e2;color:var(--red);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:20px}.prof-ann-date{font-size:.82rem;color:var(--text-muted)}.prof-ann-author{font-size:.82rem;color:var(--text-secondary);margin-left:auto}.prof-ann-title{font-size:1rem;font-weight:600;margin-bottom:4px}.prof-ann-body{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px;white-space:pre-wrap}.prof-ann-actions{display:flex;gap:8px;align-items:center}.prof-reports-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.prof-report-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px}.prof-report-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:8px}.prof-report-title{font-size:1rem;font-weight:700;margin:0}.prof-report-sub{font-size:.82rem;color:var(--text-muted)}.prof-period-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.prof-period-btn{background:none;border:none;padding:5px 12px;font-size:.82rem;cursor:pointer;color:var(--text-secondary)}.prof-period-btn.active{background:var(--primary);color:#fff}.prof-freq-total{font-size:2rem;font-weight:700;color:var(--primary);margin-top:8px}.prof-freq-label{font-size:.82rem;color:var(--text-muted);margin-bottom:12px}.prof-ranking-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.prof-rank-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--bg-page)}.prof-rank-row:last-child{border-bottom:none}.prof-rank-pos{width:28px;height:28px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:var(--text-secondary);flex-shrink:0}.prof-rank-top{background:var(--primary);color:#fff}.prof-rank-info{flex:1;min-width:0}.prof-rank-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prof-rank-email{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prof-rank-nums{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.prof-rank-last30{font-size:.88rem;font-weight:600;color:var(--primary)}.prof-rank-total{font-size:.78rem;color:var(--text-muted)}.skeleton-card{background:#e8edf2;border-radius:var(--radius);min-height:100px;animation:shimmer 1.5s infinite}.skeleton-line{height:16px;background:#e8edf2;border-radius:6px;margin-bottom:10px;animation:shimmer 1.5s infinite}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border)}.table-responsive .admin-table{border:none;border-radius:0;min-width:520px}@media (max-width: 1024px){.auth-left{display:none}.auth-right{flex:1}}@media (max-width: 768px){.nav-desktop{display:none}.hamburger{display:flex}.main-content{padding:20px 16px}.container{padding:0 16px}.admin-wrap{padding:20px 16px}.admin-title{font-size:1.35rem}.admin-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:0;gap:0}.admin-tabs::-webkit-scrollbar{display:none}.admin-tab{white-space:nowrap;flex-shrink:0;padding:9px 14px;font-size:.82rem}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-value{font-size:1.5rem}.admin-filter-row{flex-direction:column;align-items:flex-start}.prof-wrap{padding:20px 16px}.prof-title{font-size:1.35rem}.prof-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:0}.prof-tabs::-webkit-scrollbar{display:none}.prof-tab{white-space:nowrap;flex-shrink:0;padding:10px 14px;font-size:.85rem}.prof-reports-row,.prof-slots-grid{grid-template-columns:1fr}.prof-student-stats,.prof-student-arrow{display:none}.history-info{flex-direction:column;gap:2px}.history-stats{grid-template-columns:repeat(3,1fr)}.auth-right-inner{padding:32px 24px}}@media (max-width: 640px){.main-content{padding:16px 12px}.container{padding:0 12px;max-width:100%}.header-inner{padding:0 12px;height:56px;gap:8px}.header-left{gap:12px;min-width:0;flex:1}.header-right{gap:8px;flex-shrink:0}.logo-svg{height:30px;max-width:60vw}.date-selector{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px;margin-bottom:20px}.date-selector::-webkit-scrollbar{display:none}.date-btn{flex-shrink:0;min-width:68px}.slots-grid{grid-template-columns:1fr;gap:12px}.slot-card{padding:16px;display:flex;flex-direction:column;gap:10px}.slot-header{gap:10px;margin-bottom:0;min-width:0}.slot-time{font-size:1.4rem}.slot-period{font-size:.72rem;padding:3px 9px}.slot-count{font-size:.92rem}.slot-bar-wrap{margin-bottom:0;height:6px}.slot-remaining{margin-bottom:0;font-size:.82rem}.slot-actions{margin-top:4px}.slot-actions .btn{width:100%;min-height:44px}.slot-actions span{display:block;text-align:center;padding:8px}.toast-container{bottom:16px;left:12px;right:12px;align-items:stretch}.toast{max-width:100%}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;max-height:92vh}.profile-cards-grid{grid-template-columns:1fr!important}.history-stats{grid-template-columns:repeat(2,1fr)}.hstat-value{font-size:1.4rem}.auth-right-inner{padding:24px 20px}.footer-inner{justify-content:center;text-align:center}.footer-links{justify-content:center}.upcoming-list,.prof-profile-stats{flex-wrap:wrap}.prof-pstat{flex:0 0 calc(50% - 6px)}.announcement-item{flex-wrap:wrap}}@media (max-width: 480px){.main-content{padding:12px 10px}.kpi-grid{grid-template-columns:1fr}.history-stats{grid-template-columns:repeat(3,1fr)}.hstat-value{font-size:1.2rem}.hstat-label{font-size:.68rem}.prof-rank-email{display:none}.admin-table th,.admin-table td{padding:8px;font-size:.82rem}.admin-table .btn-xs{padding:3px 7px;font-size:.73rem}.admin-tab{padding:7px 10px;font-size:.78rem}.prof-tab{padding:8px 11px;font-size:.8rem}.table-responsive .admin-table{min-width:460px}.prof-ann-author{display:none}}
