:root{--brand-navy: #1a3a5c;--brand-navy-light: #2a5a8c;--brand-sky: #4fc3f7;--brand-sky-light: #81d4fa;--brand-sky-lighter: #b3e5fc;--brand-gradient: linear-gradient(135deg, #1a3a5c 0%, #2a5a8c 50%, #4fc3f7 100%);--brand-gradient-soft: linear-gradient(135deg, #e8f4fd 0%, #f0f9ff 100%);--status-present: #43a047;--status-present-bg: #e8f5e9;--status-present-border: #a5d6a7;--status-delegated: #fb8c00;--status-delegated-bg: #fff3e0;--status-delegated-border: #ffcc80;--status-absent: #e53935;--status-absent-bg: #ffebee;--status-absent-border: #ef9a9a;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #eeeeee;--gray-300: #e0e0e0;--gray-400: #bdbdbd;--gray-500: #9e9e9e;--gray-600: #757575;--gray-700: #616161;--gray-800: #424242;--gray-900: #212121;--white: #ffffff;--font-family: "Tajawal", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 700;--font-weight-extra-bold: 800;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50%;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .08), 0 4px 10px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .1), 0 8px 16px rgba(0, 0, 0, .06);--shadow-glow: 0 0 20px rgba(79, 195, 247, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-modal: 200;--z-toast: 300;--z-tooltip: 400;--sidebar-width: 260px;--topbar-height: 64px;--content-max-width: 1400px}.landing-page{min-height:100vh;background:linear-gradient(135deg,#e8f4fd,#f0f9ff 30%,#e8fdf0 70%,#f5f5f5);overflow-x:hidden}.lang-switcher-bar{display:flex;justify-content:flex-end;padding:var(--space-4) var(--space-8)}.lang-switcher{display:flex;background:var(--white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.lang-btn{padding:var(--space-2) var(--space-5);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--gray-500);transition:all var(--transition-fast);cursor:pointer;border:none;background:none;font-family:var(--font-family)}.lang-btn.active{background:var(--brand-sky);color:var(--white)}.lang-btn:hover:not(.active){background:var(--gray-50);color:var(--gray-700)}.hero-section{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:var(--space-8) var(--space-8) var(--space-16);gap:var(--space-12)}.hero-content{flex:1;max-width:550px}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:#4fc3f71a;border:1px solid rgba(79,195,247,.2);border-radius:var(--radius-xl);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--brand-navy);margin-bottom:var(--space-6);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.1s}.hero-brand-name{font-size:4rem;font-weight:var(--font-weight-extra-bold);color:var(--brand-navy);line-height:1.1;margin-bottom:var(--space-4);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.2s}.hero-brand-name span{background:var(--brand-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[dir=rtl] .hero-brand-name span{display:inline-block;line-height:1.25;background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:var(--brand-navy);color:var(--brand-navy)}.hero-tagline{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--gray-800);margin-bottom:var(--space-3);line-height:1.6;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.3s}.hero-description{font-size:var(--font-size-base);color:var(--gray-500);line-height:1.8;margin-bottom:var(--space-8);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.4s}.hero-ctas{display:flex;gap:var(--space-3);flex-wrap:wrap;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.5s}.cta-primary{padding:var(--space-4) var(--space-8);background:var(--brand-gradient);color:var(--white);border-radius:var(--radius-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);box-shadow:0 4px 15px #1a3a5c4d;transition:all var(--transition-fast);cursor:pointer;border:none;font-family:var(--font-family);white-space:nowrap}.cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #1a3a5c66}.cta-secondary{padding:var(--space-3) var(--space-6);background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-fast);cursor:pointer;font-family:var(--font-family);white-space:nowrap}.cta-secondary:hover{background:var(--gray-50);border-color:var(--brand-sky);color:var(--brand-navy)}.hero-preview{flex:1;max-width:480px;animation:popIn .8s cubic-bezier(.16,1,.3,1) both;animation-delay:.3s}.preview-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;position:relative}.preview-header{background:var(--brand-gradient);padding:var(--space-4) var(--space-6);color:var(--white)}.preview-header h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin-bottom:var(--space-1)}.preview-header p{font-size:var(--font-size-xs);opacity:.8}.preview-body{padding:var(--space-6)}.preview-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--gray-600);margin-bottom:var(--space-3);text-align:center}.preview-tags{display:flex;gap:var(--space-2);flex-wrap:wrap;justify-content:center;margin-bottom:var(--space-4)}.preview-tag{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border:none;cursor:default}.preview-tag.green{background:var(--status-present-bg);color:var(--status-present);border:1px solid var(--status-present-border)}.preview-tag.orange{background:var(--status-delegated-bg);color:var(--status-delegated);border:1px solid var(--status-delegated-border)}.preview-tag.blue{background:#4fc3f71a;color:var(--brand-navy);border:1px solid var(--brand-sky-lighter)}.preview-tag.red{background:var(--status-absent-bg);color:var(--status-absent);border:1px solid var(--status-absent-border)}.preview-mini-rows{display:flex;flex-direction:column;gap:var(--space-2)}.preview-mini-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--gray-50);border-radius:var(--radius-sm);font-size:var(--font-size-xs);animation:slideUp calc(.5s + var(--row-delay, 0s)) ease}.preview-mini-row .mini-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.preview-mini-row .mini-dot.green{background:var(--status-present)}.preview-mini-row .mini-dot.red{background:var(--status-absent)}.preview-mini-row .mini-dot.orange{background:var(--status-delegated)}.preview-mini-row .mini-name{flex:1;font-weight:var(--font-weight-medium);color:var(--gray-700)}.preview-mini-row .mini-status{font-size:10px;color:var(--gray-500)}.features-section{max-width:1200px;margin:0 auto;padding:0 var(--space-8) var(--space-12)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.feature-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);box-shadow:var(--shadow-md);text-align:center;transition:all .3s cubic-bezier(.25,.8,.25,1);cursor:default;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) both}.feature-card:nth-child(1){animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 32px #1a3a5c1a}.feature-icon{width:56px;height:56px;margin:0 auto var(--space-4);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.8rem}.feature-icon.green{background:var(--status-present-bg)}.feature-icon.blue{background:#4fc3f726}.feature-icon.purple{background:#f3e8fd}.feature-card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--brand-navy);margin-bottom:var(--space-2)}.feature-card p{font-size:var(--font-size-sm);color:var(--gray-500);line-height:1.8}.stats-bar{max-width:1200px;margin:0 auto;padding:var(--space-8) var(--space-8) var(--space-12)}.stats-bar-inner{display:flex;justify-content:center;gap:var(--space-16);padding:var(--space-8);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.stats-bar-item{text-align:center}.stats-bar-item .big-number{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extra-bold);background:var(--brand-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--space-2)}.stats-bar-item .big-label{font-size:var(--font-size-sm);color:var(--gray-500);font-weight:var(--font-weight-medium)}.landing-footer{text-align:center;padding:var(--space-8);border-top:1px solid var(--gray-200);background:var(--white)}.landing-footer p{color:var(--gray-500);font-size:var(--font-size-sm)}.landing-footer p:first-child{font-weight:var(--font-weight-bold);color:var(--brand-navy);margin-bottom:var(--space-2)}[dir=ltr] .hero-section{flex-direction:row-reverse}[dir=ltr] .hero-content{text-align:left}@media(max-width:1024px){.hero-section{flex-direction:column;text-align:center;padding:var(--space-6) var(--space-6) var(--space-10)}[dir=ltr] .hero-section{flex-direction:column}.hero-content{max-width:100%}[dir=ltr] .hero-content{text-align:center}.hero-ctas{justify-content:center}.hero-preview{max-width:400px;margin:0 auto}.hero-brand-name{font-size:3rem}}@media(max-width:768px){.features-grid{grid-template-columns:1fr}.stats-bar-inner{flex-direction:column;gap:var(--space-6)}.hero-brand-name{font-size:2.5rem}.lang-switcher-bar{padding:var(--space-3) var(--space-4)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px) scale(.98);filter:blur(4px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.8) translateY(10px)}60%{opacity:1;transform:scale(1.03) translateY(-3px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}html,body{animation:fadeIn .8s cubic-bezier(.16,1,.3,1) both}@keyframes fadeIn{0%{opacity:0;filter:blur(2px)}to{opacity:1;filter:blur(0)}}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);color:var(--gray-800);background:var(--gray-100);direction:rtl;text-align:right;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:var(--font-family);font-size:var(--font-size-base)}input,select,textarea{font-family:var(--font-family);font-size:var(--font-size-base)}img{max-width:100%;display:block}ul,ol{list-style:none}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.wrap{flex-wrap:wrap}.grid{display:grid}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.hidden{display:none!important}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-6);transition:transform var(--transition-bounce),box-shadow var(--transition-base);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both}.card:hover{box-shadow:var(--shadow-xl);transform:translateY(-5px) scale(1.01)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:var(--font-weight-bold);transition:transform var(--transition-bounce),box-shadow var(--transition-base),background-color var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:active{transform:scale(.93)}.btn-primary{background:var(--brand-gradient);color:var(--white);box-shadow:0 4px 12px #1a3a5c33;border:1px solid rgba(255,255,255,.1)}.btn-primary:hover{box-shadow:0 8px 16px #4fc3f766;transform:translateY(-2px) scale(1.02)}.btn-primary:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:all .4s ease;transform:skew(-20deg)}.btn-primary:hover:after{left:150%}.btn-secondary{background:var(--gray-100);color:var(--gray-800);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--white);box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--brand-light)}.btn-danger{background:var(--status-absent);color:var(--white)}.btn-danger:hover{background:#c62828}.btn-success{background:var(--status-present);color:var(--white)}.btn-success:hover{background:#2e7d32}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center}.input-group{display:flex;flex-direction:column;gap:5px}.input-group label{font-weight:700;font-size:var(--font-size-xs);color:#1e3a5f;letter-spacing:.03em;text-transform:uppercase;padding-right:2px}.input{padding:11px var(--space-4);border:1.5px solid #dde3ee;border-radius:12px;background:#fff;color:#1a2744;font-size:var(--font-size-base);font-weight:500;font-family:var(--font-family);transition:border-color .2s,box-shadow .2s;outline:none;width:100%;box-shadow:0 1px 3px #1a3a5c0f}.input:focus{border-color:#4fc3f7;background:#fff;box-shadow:0 0 0 3px #4fc3f72e,0 1px 4px #1a3a5c14}.input::placeholder{color:#b0bec8;font-weight:400}.input-telegram{direction:ltr!important;text-align:left!important}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.badge-present{background:var(--status-present-bg);color:var(--status-present);border:1px solid var(--status-present-border)}.badge-delegated{background:var(--status-delegated-bg);color:var(--status-delegated);border:1px solid var(--status-delegated-border)}.badge-absent{background:var(--status-absent-bg);color:var(--status-absent);border:1px solid var(--status-absent-border)}.confirm-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;pointer-events:none;transition:opacity .2s ease}.confirm-modal-overlay.open{opacity:1;pointer-events:all}.confirm-modal{background:#fff;width:90%;max-width:400px;border-radius:16px;padding:24px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;transform:scale(.95) translateY(10px);transition:all .2s cubic-bezier(.175,.885,.32,1.275);text-align:center}.confirm-modal-overlay.open .confirm-modal{transform:scale(1) translateY(0)}.confirm-icon{width:56px;height:56px;background:#fff1f2;color:#e11d48;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px}.confirm-title{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:8px}.confirm-message{font-size:15px;color:#64748b;margin-bottom:24px;line-height:1.5}.confirm-actions{display:flex;gap:12px}.confirm-btn{flex:1;padding:12px;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:.2s ease;font-family:inherit;font-size:15px}.confirm-btn-cancel{background:#f1f5f9;color:#64748b}.confirm-btn-cancel:hover{background:#e2e8f0;color:#334155}.confirm-btn-danger{background:#e11d48;color:#fff}.confirm-btn-danger:hover{background:#be123c}.status-dot{width:10px;height:10px;border-radius:var(--radius-full);display:inline-block;flex-shrink:0}.status-dot.present{background:var(--status-present)}.status-dot.delegated{background:var(--status-delegated)}.status-dot.absent{background:var(--status-absent)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--brand-gradient);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-xl)}.table-container{overflow-x:auto;border-radius:var(--radius-md)}table{width:100%;border-collapse:collapse}table thead th{background:var(--gray-50);padding:var(--space-3) var(--space-4);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--gray-600);text-align:right;border-bottom:2px solid var(--gray-200);white-space:nowrap}table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--gray-100);font-size:var(--font-size-sm);vertical-align:middle}table tbody tr{transition:background var(--transition-fast)}table tbody tr:hover{background:var(--gray-50)}.modal-overlay{position:fixed;inset:0;background:#0f1e328c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast);padding:24px}.modal{background:var(--white);border-radius:var(--radius-xl);box-shadow:0 24px 60px #0000002e,0 8px 20px #0000001a;padding:var(--space-8);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) both}.modal-content{background:var(--white);border-radius:24px;box-shadow:0 28px 70px #1a3a5c38,0 8px 24px #00000014;padding:0;width:min(640px,calc(100vw - 48px));max-height:92vh;overflow-y:auto;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) both;display:flex;flex-direction:column}.modal-content.modal-lg{max-width:820px}.teacher-edit-modal-overlay{align-items:flex-start;justify-content:center;padding:8px 16px 16px;overflow-y:auto;z-index:1200}.teacher-edit-modal-content{width:min(640px,calc(100vw - 32px));max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px);margin:0 auto;overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr)}.modal-content h3{font-size:var(--font-size-lg);font-weight:800;color:#fff;background:linear-gradient(135deg,#1a3a5c,#2d5a8c 55%,#4fc3f7);padding:var(--space-5) var(--space-6);margin:0;border-radius:24px 24px 0 0;letter-spacing:.01em;text-shadow:0 1px 3px rgba(0,0,0,.15)}.modal-content form{padding:28px 32px 0;display:flex;flex-direction:column;gap:1.25rem;flex:1;background:#f3f7fb}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem 1.5rem}.form-grid .full-width{grid-column:span 2}@media(max-width:560px){.form-grid{grid-template-columns:1fr}.form-grid .full-width{grid-column:span 1}}.modal-content::-webkit-scrollbar{width:5px}.modal-content::-webkit-scrollbar-thumb{background:#c8d6e5;border-radius:4px}.teacher-edit-modal-content form{padding:20px 22px 0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:14px;min-height:0;overflow:hidden}.teacher-edit-modal-content .form-grid{min-height:0;overflow-y:auto;padding-inline-end:2px}.teacher-edit-modal-content .modal-actions{margin-top:0;flex-shrink:0}.modal-content>div#scheduleGrid{padding:var(--space-4) var(--space-6);overflow-x:auto}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding:20px 32px 24px;border-top:1px solid #dde6f0;background:#f3f7fb;border-radius:0 0 24px 24px;margin-top:1.5rem}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--brand-navy)}.period-times-btn{background:linear-gradient(135deg,#1a3a5c,#2d5a8c);color:#fff;border:none;border-radius:var(--radius-lg);padding:10px 20px;font-size:var(--font-size-sm);font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:opacity .2s,transform .15s}.period-times-btn:hover{opacity:.88;transform:translateY(-1px)}.period-times-modal{background:var(--white);border-radius:var(--radius-xl);box-shadow:0 24px 60px #0003;width:90%;max-width:540px;max-height:88vh;overflow-y:auto;animation:slideUp var(--transition-base);display:flex;flex-direction:column}.period-times-modal .modal-header{background:linear-gradient(135deg,#1a3a5c,#2d5a8c 60%,#4fc3f7);padding:var(--space-5) var(--space-6);border-radius:var(--radius-xl) var(--radius-xl) 0 0;margin-bottom:0}.period-times-modal .modal-header h3{color:#fff;font-size:var(--font-size-lg);font-weight:800;margin:0}.modal-close{background:#ffffff26;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:#ffffff4d}.modal-hint{font-size:var(--font-size-sm);color:#64748b;margin:var(--space-4) var(--space-6) 0;text-align:center}.period-times-grid{padding:var(--space-4) var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.period-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:#f8fafc;border-radius:var(--radius-md);border:1px solid #e2e8f0}.period-lbl{font-weight:700;color:var(--brand-navy);min-width:70px;font-size:var(--font-size-sm)}.period-inputs{display:flex;align-items:center;gap:var(--space-3);flex:1;flex-wrap:wrap}.period-inputs label{font-size:var(--font-size-xs);color:#64748b;font-weight:600;white-space:nowrap}.period-input{border:1.5px solid #cbd5e1;border-radius:var(--radius-md);padding:6px 10px;font-size:var(--font-size-sm);color:var(--brand-navy);background:#fff;transition:border-color .2s;width:110px}.period-input:focus{outline:none;border-color:#4fc3f7}.modal-footer{padding:var(--space-4) var(--space-6) var(--space-5);display:flex;justify-content:center;border-top:1px solid #e9edf2;background:#f8fafc;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.btn-save-periods{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:var(--radius-lg);padding:12px 32px;font-size:var(--font-size-base);font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}.btn-save-periods:hover{opacity:.88;transform:translateY(-1px)}#toast-container{position:fixed;top:var(--space-5);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);pointer-events:none;width:max-content;max-width:90vw}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6) var(--space-3) var(--space-4);border-radius:40px;color:var(--white);font-weight:600;font-size:var(--font-size-sm);box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto;min-width:220px;max-width:480px;text-align:start;white-space:nowrap;border:1px solid rgba(255,255,255,.15);animation:toastEnter var(--transition-base) cubic-bezier(.34,1.56,.64,1) both}.toast.toast--hide{animation:toastLeave .28s ease-in forwards}.toast:before{font-size:1.1rem;flex-shrink:0}.toast-success{background:linear-gradient(135deg,#059669,#10b981)}.toast-success:before{content:""}.toast-error{background:linear-gradient(135deg,#dc2626,#ef4444)}.toast-error:before{content:""}.toast-warning{background:linear-gradient(135deg,#d97706,#f59e0b)}.toast-warning:before{content:""}.toast-info{background:linear-gradient(135deg,#1a3a5c,#2d5a8c)}.toast-info:before{content:"ℹ"}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes toastEnter{0%{opacity:0;transform:translateY(-14px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastLeave{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.94)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes countUp{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@media(max-width:768px){html{font-size:14px}.card{padding:var(--space-4)}.modal{width:95%;padding:var(--space-6)}}.lang-switcher-row{display:flex;justify-content:center;margin-bottom:var(--space-4)}.lang-switcher-row .lang-switcher{display:inline-flex}.card-footer-links{text-align:center;margin-top:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.card-footer-hint{font-size:var(--font-size-sm);color:var(--gray-500)}.btn-link{color:var(--brand-sky);font-weight:var(--font-weight-bold);background:none;border:none;cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);text-decoration:underline;padding:0}.btn-link:hover{opacity:.8}.btn-back-home{font-size:var(--font-size-sm)}.modal-overlay{display:none}.modal-overlay.modal-overlay--open{display:flex}.onboard-page{min-height:100vh;padding:var(--space-6) var(--space-4);align-items:flex-start;background:#f0f4fa;display:flex;justify-content:center}.nav-brand-school{font-size:var(--font-size-sm);color:var(--gray-500);font-weight:500}.nav-brand-name{font-size:var(--font-size-lg);font-weight:800;color:var(--brand-navy)}.nav-brand-row{display:flex;align-items:center;gap:6px}.app-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:#f5f6fa;font-family:var(--font-family)}.app-loader__logo{margin-bottom:20px;animation:spin 2s linear infinite}.app-loader__title{font-size:1.4rem;font-weight:800;color:#1a3a5c}.app-loader__subtitle{font-size:.9rem;color:#718096;margin-top:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.periods-hint{color:#6b7280;font-size:12px;margin-top:4px;display:block}.register-card-title{font-size:var(--font-size-xl)}.login-card.register-card{max-width:480px}.notification-dropdown{display:none}.notification-dropdown.notification-dropdown--open{display:block}@keyframes cardShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.login-card.card--shake{animation:cardShake .35s ease both!important}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--brand-gradient);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;right:-30%;width:600px;height:600px;background:radial-gradient(circle,rgba(79,195,247,.15) 0%,transparent 70%);border-radius:50%;animation:pulse 6s ease-in-out infinite}.login-page:after{content:"";position:absolute;bottom:-40%;left:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;animation:pulse 8s ease-in-out infinite reverse}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-10);width:90%;max-width:420px;position:relative;z-index:1;animation:slideUp var(--transition-slow)}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo img{height:80px;margin:0 auto var(--space-4)}.login-logo h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extra-bold);color:var(--brand-navy);margin-bottom:var(--space-1)}.login-logo p{font-size:var(--font-size-sm);color:var(--gray-500)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-form .input-group .input-wrapper{position:relative}.login-form .input-group .input-wrapper .input{width:100%;padding-right:var(--space-12)}.login-form .input-group .input-wrapper .input-icon{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:var(--font-size-lg)}.login-role-selector{display:flex;gap:var(--space-2);background:var(--gray-100);border-radius:var(--radius-md);padding:var(--space-1)}.login-role-btn{flex:1;padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-weight:var(--font-weight-medium);color:var(--gray-500);transition:all var(--transition-fast);text-align:center}.login-role-btn.active{background:var(--white);color:var(--brand-navy);box-shadow:var(--shadow-sm)}.login-role-btn:hover:not(.active){color:var(--gray-700)}.login-btn{width:100%;padding:var(--space-4);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);border-radius:var(--radius-md);background:var(--brand-gradient);color:var(--white);box-shadow:var(--shadow-md);transition:all var(--transition-fast);position:relative;overflow:hidden}.login-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.login-btn:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-btn:hover:after{left:100%}.login-error{background:var(--status-absent-bg);color:var(--status-absent);border:1px solid var(--status-absent-border);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;animation:slideDown var(--transition-fast);display:none}.login-error.show{display:block}.login-demo-hint{text-align:center;font-size:var(--font-size-xs);color:var(--gray-500);margin-top:var(--space-4);padding:var(--space-3);background:var(--gray-50);border-radius:var(--radius-sm);line-height:1.8}.login-demo-hint strong{color:var(--brand-navy)}.login-page{padding:var(--space-8) var(--space-4)}.onboard-card{background:#fff;border-radius:var(--radius-xl);box-shadow:0 20px 60px #00000026;width:90%;max-width:620px;margin:0 auto;overflow:hidden;position:relative;z-index:1;animation:slideUp var(--transition-slow)}.onboard-header{background:linear-gradient(135deg,#1a3a5c,#2d5a8c 55%,#4fc3f7);padding:var(--space-8) var(--space-8) var(--space-6);text-align:center;color:#fff}.onboard-check{font-size:3rem;margin-bottom:var(--space-3);animation:countUp .5s ease}.onboard-header h2{font-size:var(--font-size-xl);font-weight:800;color:#fff;margin-bottom:var(--space-2)}.onboard-header p{font-size:var(--font-size-sm);color:#ffffffd9}.onboard-header code{background:#fff3;padding:2px 10px;border-radius:6px;font-family:monospace;font-size:1rem;font-weight:700}.onboard-steps-title{font-size:var(--font-size-base);font-weight:800;color:#1a3a5c;padding:var(--space-5) var(--space-6) var(--space-3);border-bottom:2px solid #f0f4fa}.onboard-steps{padding:var(--space-4) var(--space-6) 0;display:flex;flex-direction:column;gap:var(--space-4)}.onboard-step{display:flex;flex-direction:column;gap:6px}.onboard-step-num{font-size:10px;font-weight:800;color:#4fc3f7;text-transform:uppercase;letter-spacing:.08em}.onboard-step-body{display:flex;align-items:flex-start;gap:var(--space-3);background:#f8fafd;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);border-right:4px solid #4fc3f7}.onboard-step-icon{font-size:1.5rem;flex-shrink:0;line-height:1;margin-top:2px}.onboard-step-body h4{font-size:var(--font-size-sm);font-weight:800;color:#1a3a5c;margin-bottom:4px}.onboard-step-body p{font-size:var(--font-size-sm);color:#4b5563;line-height:1.55;margin:0}.onboard-tip{display:flex;align-items:flex-start;gap:var(--space-3);margin:var(--space-5) var(--space-6) 0;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:#78350f;line-height:1.55}.onboard-tip-icon{font-size:1.2rem;flex-shrink:0}.onboard-card .login-btn{margin:var(--space-5) var(--space-6) var(--space-6);width:calc(100% - var(--space-12))}.periods-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);margin-top:6px}.period-option{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3) var(--space-2);border:2px solid #e5e7eb;border-radius:var(--radius-md);background:#f9fafb;cursor:pointer;transition:all .2s;font-family:var(--font-family);gap:2px}.period-option:hover{border-color:#93c5fd;background:#eff6ff}.period-option.active{border-color:#2d5a8c;background:linear-gradient(135deg,#1a3a5c,#2d5a8c);box-shadow:0 4px 12px #2d5a8c4d}.period-num{font-size:1.6rem;font-weight:900;color:#374151;line-height:1}.period-option.active .period-num{color:#fff}.period-lbl{font-size:10px;font-weight:600;color:#6b7280;letter-spacing:.03em}.period-option.active .period-lbl{color:#ffffffd9}.dashboard-page{min-height:100vh;background:#f5f6fa;padding-top:64px}.top-nav{background:var(--white);height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);box-shadow:0 1px 3px #0000000f;position:fixed;top:0;left:0;right:0;z-index:100}.nav-brand{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-base);font-weight:800;color:var(--brand-navy);order:-1;text-decoration:none;position:relative}.nav-brand svg{flex-shrink:0}.nav-links{display:flex;align-items:center;gap:var(--space-1)}.nav-link{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--gray-500);cursor:pointer;transition:all .2s;text-decoration:none}.nav-link:hover{color:var(--brand-navy);background:#f0f7ff}.nav-link.active{color:var(--brand-navy);background:#4fc3f71a;font-weight:var(--font-weight-bold)}.nav-link.logout{color:var(--gray-400)}.nav-link.logout:hover{color:#e53e3e;background:#fff5f5}.nav-user{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--gray-700);position:relative}.user-role{font-size:var(--font-size-xs);color:var(--gray-400)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--brand-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.user-menu{position:relative}.user-menu-trigger{border:none;cursor:pointer}.user-menu-trigger:focus-visible{outline:2px solid #4fc3f7;outline-offset:2px}.user-menu-dropdown{position:absolute;top:44px;left:0;right:auto;min-width:180px;max-width:min(220px,calc(100vw - 24px));background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 28px #0f172a26;padding:6px;z-index:210;display:none}html[dir=ltr] .user-menu-dropdown{left:auto;right:0}.user-menu-dropdown.user-menu-dropdown--open{display:block}.user-menu-item{width:100%;border:none;background:transparent;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;color:#334155;font-size:13px;font-weight:700;cursor:pointer;text-align:right}html[dir=ltr] .user-menu-item{text-align:left}.user-menu-item:hover{background:#f1f5f9}.user-menu-item.danger{color:#dc2626}.user-menu-item.danger:hover{background:#fef2f2}.bot-status-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--gray-200);border-radius:999px;background:#f8fafc;color:var(--gray-500)}.status-dot-mini{width:8px;height:8px;border-radius:50%;background:#94a3b8}.status-dot-mini.green{background:#22c55e}.status-dot-mini.red{background:#ef4444}.notification-bell{width:38px;height:38px;border-radius:var(--radius-full);background:#f0f7ff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;cursor:pointer;position:relative;color:var(--gray-400);transition:all .2s}.notification-bell:hover{background:#e0efff}.notif-badge{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:var(--radius-full);background:#e53e3e;color:#fff;font-size:9px;font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center}.notification-dropdown{position:absolute;top:50px;left:0;width:320px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 10px 30px #00000026;z-index:150;max-height:400px;overflow-y:auto;padding:var(--space-4)}.notification-dropdown h4{font-size:var(--font-size-sm);color:var(--brand-navy);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--gray-200)}.notif-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-1);font-size:var(--font-size-xs);cursor:default}.notif-item.unread{background:#eff8ff}.notif-item p{margin:0;color:var(--gray-700)}.notif-item small{color:var(--gray-400)}.notif-empty{text-align:center;color:var(--gray-400);font-size:var(--font-size-sm);padding:var(--space-6)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6);padding:var(--space-6) var(--space-8);max-width:1400px;margin:0 auto}.stat-card{background:var(--white);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-5);box-shadow:0 2px 8px #0000000a;text-align:center;position:relative;overflow:hidden;transition:transform var(--transition-bounce),box-shadow var(--transition-base);border:1px solid rgba(0,0,0,.04);animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) both}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 32px #00000014}.stat-bar{position:absolute;top:0;right:0;left:0;height:4px;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.stat-bar.green{background:#48bb78}.stat-bar.red{background:#fc8181}.stat-bar.blue{background:#63b3ed}.stat-value{font-size:3rem;font-weight:800;line-height:1.1;margin:var(--space-3) 0 var(--space-2)}.stat-green .stat-value{color:#2f855a}.stat-red .stat-value{color:#c53030}.stat-blue .stat-value{color:#2b6cb0}.stat-label{font-size:var(--font-size-sm);color:var(--gray-500);font-weight:var(--font-weight-medium)}.stat-icon{position:absolute;bottom:var(--space-3);left:var(--space-3);font-size:2rem;opacity:.06}.dashboard-content{display:grid;grid-template-columns:1fr 1.6fr;gap:var(--space-5);padding:0 var(--space-8) var(--space-8);max-width:1400px;margin:0 auto}.panel{background:var(--white);border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000a;overflow:hidden;border:1px solid rgba(0,0,0,.04);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both;animation-delay:.2s}.panel h3{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--brand-navy);padding:var(--space-5) var(--space-5) var(--space-2)}.panel small{display:block;font-size:var(--font-size-xs);color:var(--gray-400);padding:0 var(--space-5) var(--space-3)}.teacher-panel-header{display:grid;grid-template-columns:1fr auto;gap:var(--space-4);padding:var(--space-3) var(--space-5);font-size:var(--font-size-xs);color:var(--gray-500);font-weight:var(--font-weight-bold);border-bottom:2px solid var(--gray-100);background:var(--gray-50)}.teacher-list{max-height:520px;overflow-y:auto}.teacher-row{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);align-items:center;padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--gray-100);transition:transform var(--transition-bounce),background-color var(--transition-base),border-left var(--transition-base),box-shadow var(--transition-base);position:relative;animation:fadeInUp .4s cubic-bezier(.16,1,.3,1) both}.teacher-row:nth-child(1){animation-delay:.1s}.teacher-row:nth-child(2){animation-delay:.15s}.teacher-row:nth-child(3){animation-delay:.2s}.teacher-row:nth-child(4){animation-delay:.25s}.teacher-row:nth-child(5){animation-delay:.3s}.teacher-row:nth-child(n+6){animation-delay:.35s}.teacher-row:hover{background:#f8fbff;transform:translate(-6px);border-left:2px solid var(--status-present);box-shadow:4px 4px 12px #00000008;z-index:10}.teacher-row .teacher-info-cell{display:flex;align-items:center;gap:var(--space-3)}.teacher-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);color:#fff;flex-shrink:0;background:var(--brand-gradient)}.teacher-info{flex:1;min-width:0}.teacher-info strong{display:block;font-size:var(--font-size-sm);color:var(--gray-800);font-weight:var(--font-weight-medium)}.teacher-info small{display:block;font-size:11px;color:var(--gray-400);padding:0}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:var(--font-weight-bold);white-space:nowrap}.status-badge.present{background:#f0fff4;color:#276749}.status-badge.absent{background:#fff5f5;color:#c53030}.status-badge.delegated{background:#fffbeb;color:#b7791f}.status-dot{width:8px;height:8px;border-radius:var(--radius-full);display:inline-block;flex-shrink:0}.status-dot.green{background:#48bb78}.status-dot.red{background:#fc8181}.status-dot.orange{background:#f6ad55}.status-select{border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:11px;font-family:var(--font-family);background:var(--white);cursor:pointer;appearance:none;-webkit-appearance:none;padding:4px 10px 4px 22px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24'%3E%3Cpath fill='%23757575' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 6px center;color:var(--gray-600)}.action-bar{display:flex;justify-content:center;padding:var(--space-4) var(--space-8) 0;max-width:1400px;margin:0 auto}.auto-assign-global-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;background:linear-gradient(135deg,#3182ce,#2b6cb0);color:#fff;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);font-family:var(--font-family);cursor:pointer;border:none;transition:transform var(--transition-bounce),box-shadow var(--transition-base),background var(--transition-base);box-shadow:0 4px 14px #3182ce4d}.auto-assign-global-btn:hover:not(:disabled){background:linear-gradient(135deg,#2b6cb0,#1a4971);transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #3182ce66}.auto-assign-global-btn:disabled{background:var(--gray-300);cursor:not-allowed;box-shadow:none}.action-badge{background:#ffffff4d;padding:2px 10px;border-radius:20px;font-size:var(--font-size-sm)}.substitute-tag{display:block;margin-top:3px;font-size:10px;color:#2b6cb0;background:#ebf4ff;padding:2px 8px;border-radius:var(--radius-sm);font-weight:var(--font-weight-medium);line-height:1.4}.sub-counter-tag{display:inline-block;margin-top:2px;font-size:10px;color:#975a16;background:#fffbeb;padding:1px 8px;border-radius:var(--radius-sm);font-weight:var(--font-weight-medium)}.panel-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.panel-header h3{padding:0;margin:0;font-size:var(--font-size-base)}.absence-table{width:100%;border-collapse:collapse}.absence-table thead th{background:#fafbfd;padding:var(--space-3) var(--space-4);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);color:var(--gray-500);text-align:right;border-bottom:2px solid var(--gray-100);white-space:nowrap}.absence-table tbody td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);border-bottom:1px solid var(--gray-100);vertical-align:middle;color:var(--gray-700)}.absence-table tbody tr{transition:transform var(--transition-bounce),background-color var(--transition-base),box-shadow var(--transition-base);animation:slideInRight .5s cubic-bezier(.16,1,.3,1) both}.absence-table tbody tr:nth-child(1){animation-delay:.1s}.absence-table tbody tr:nth-child(2){animation-delay:.15s}.absence-table tbody tr:nth-child(3){animation-delay:.2s}.absence-table tbody tr:nth-child(4){animation-delay:.25s}.absence-table tbody tr:nth-child(n+5){animation-delay:.3s}.absence-table tbody tr:hover{background:#f8fbff;transform:translate(-4px) translateY(-1px);box-shadow:0 4px 12px #0000000a}.teacher-mini{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm)}.mini-avatar{width:30px;height:30px;border-radius:var(--radius-full);background:var(--brand-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-weight-bold);flex-shrink:0}.mini-avatar.sub{background:linear-gradient(135deg,#63b3ed,#3182ce)}.expand-cell{display:flex;align-items:center;gap:var(--space-2)}.expand-btn{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--gray-100);color:var(--gray-500);font-size:10px;transition:all .2s;cursor:pointer;border:none}.expand-btn:hover{background:var(--gray-200)}.empty-state{text-align:center;padding:var(--space-10) var(--space-6);color:var(--gray-400)}.empty-icon{font-size:3rem;margin-bottom:var(--space-3);opacity:.6}.empty-state p{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--gray-500);margin-bottom:var(--space-2)}.empty-state small{font-size:var(--font-size-sm);color:var(--gray-400);padding:0}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:var(--font-weight-bold)}.badge-success{background:#f0fff4;color:#276749}.badge-danger{background:#fff5f5;color:#c53030}.badge-warning{background:#fffbeb;color:#b7791f}.badge-info{background:#ebf4ff;color:#2b6cb0}.analytics-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.analytics-controls{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.analytics-controls label{font-size:var(--font-size-sm);color:var(--gray-600);display:flex;align-items:center;gap:var(--space-2)}.analytics-controls input[type=week]{padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);color:var(--gray-800);outline:none;transition:all .2s}.analytics-controls input[type=week]:focus,.analytics-controls input[type=month]:focus,.analytics-controls input[type=date]:focus,.analytics-controls select:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px #4fc3f733}.compare-toggle{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--gray-700);cursor:pointer;background:var(--bg-color);padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s}.compare-toggle:hover{background:var(--gray-50)}.compare-toggle input[type=checkbox]{accent-color:var(--brand-primary);width:16px;height:16px;cursor:pointer}.analytics-actions{margin-top:var(--space-3);display:flex;justify-content:flex-start}.message-test-panel{margin-top:var(--space-4);padding:var(--space-4);border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#f8fbff}.message-test-panel h4{margin:0 0 6px;font-size:var(--font-size-base);color:var(--brand-navy)}.message-test-panel p{margin:0 0 var(--space-3);color:var(--gray-600);font-size:var(--font-size-sm)}.message-test-controls{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.message-test-controls .input{min-width:220px;flex:1}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr;padding:0 var(--space-4) var(--space-4)}.stats-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));padding:var(--space-4)}.top-nav{padding:0 var(--space-4)}.analytics-controls{flex-wrap:wrap;gap:var(--space-2)}.analytics-controls .input,.analytics-controls select{flex:1 1 120px;min-width:120px}}@media(max-width:768px){.stats-row{grid-template-columns:1fr 1fr;gap:var(--space-3)}.analytics-header,.analytics-controls{flex-direction:column;align-items:stretch}.analytics-controls .input,.analytics-controls select,.analytics-controls button{width:100%}.analytics-actions{justify-content:stretch}.analytics-actions button{width:100%}.message-test-controls{flex-direction:column;align-items:stretch}.message-test-controls .input,.message-test-controls button{width:100%}.compare-toggle{width:100%;justify-content:flex-start}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.teachers-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-8);max-width:1400px;margin:0 auto}.teachers-header h2{font-size:var(--font-size-2xl);font-weight:800;color:var(--brand-navy)}.teacher-count{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--gray-500);margin-right:var(--space-2)}.teachers-actions{display:flex;align-items:center;gap:var(--space-3)}.search-input{padding:10px var(--space-4);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-sm);background:var(--white);width:240px;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--brand-sky);box-shadow:0 0 0 3px #4fc3f726}.teachers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:var(--space-5);padding:0 var(--space-8) var(--space-8);max-width:1400px;margin:0 auto}.teacher-card{background:var(--white);border-radius:20px;box-shadow:0 2px 12px #1a3a5c12;border:1px solid rgba(26,58,92,.06);overflow:hidden;transition:transform var(--transition-bounce),box-shadow var(--transition-base),border-color var(--transition-base);position:relative;animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) both}.teacher-card:nth-child(1){animation-delay:.1s}.teacher-card:nth-child(2){animation-delay:.15s}.teacher-card:nth-child(3){animation-delay:.2s}.teacher-card:nth-child(4){animation-delay:.25s}.teacher-card:nth-child(n+5){animation-delay:.3s}.teacher-card:hover{box-shadow:0 16px 32px #1a3a5c1f;transform:translateY(-8px) scale(1.02);border-color:#4fc3f766}.teacher-card:before{content:"";display:block;height:5px;background:linear-gradient(90deg,#1a3a5c,#4fc3f7)}.teacher-card-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5) var(--space-2)}.teacher-card-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#1a3a5c,#2d6ca2,#4fc3f7);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--font-size-base);flex-shrink:0;box-shadow:0 4px 12px #1a3a5c40;letter-spacing:.02em}.teacher-card-name{flex:1;min-width:0}.teacher-card-name strong{display:block;font-size:var(--font-size-base);font-weight:800;color:#1a2744;line-height:1.3}.teacher-card-name small{display:block;font-size:var(--font-size-xs);color:#64748b;margin-top:3px;font-weight:500}.teacher-email-badge{display:inline-block;margin-top:5px;font-size:10px;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;padding:2px 8px;font-weight:500;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-delete{background:none;border:none;cursor:pointer;font-size:var(--font-size-base);opacity:0;transition:opacity var(--transition-base),transform var(--transition-bounce);padding:var(--space-1);border-radius:var(--radius-md)}.teacher-card:hover .btn-delete{opacity:.45}.btn-delete:hover{opacity:1!important;transform:scale(1.15)}.teacher-card-divider{height:1px;background:linear-gradient(90deg,transparent,#e2e8f0,transparent);margin:var(--space-2) var(--space-5)}.teacher-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:var(--space-3) var(--space-5)}.mini-stat{background:#f8fafc;border:1px solid #e9edf3;padding:10px var(--space-3);border-radius:12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px;transition:background .2s,border-color .2s}.teacher-card:hover .mini-stat{background:#f1f6fc;border-color:#d0def0}.mini-stat-value{font-size:var(--font-size-xl);font-weight:800;color:var(--brand-navy);line-height:1}.mini-stat-label{font-size:10px;color:#94a3b8;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;letter-spacing:.01em}.mini-stat.stat-periods{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.mini-stat.stat-periods .mini-stat-value{color:#1d4ed8}.mini-stat.stat-periods .mini-stat-label{color:#3b82f6}.mini-stat.stat-free{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.mini-stat.stat-free .mini-stat-value{color:#15803d}.mini-stat.stat-free .mini-stat-label{color:#22c55e}.mini-stat.stat-subs{background:linear-gradient(135deg,#fff7ed,#ffedd5);border-color:#fed7aa}.mini-stat.stat-subs .mini-stat-value{color:#c2410c}.mini-stat.stat-subs .mini-stat-label{color:#f97316}.mini-stat.stat-id{background:linear-gradient(135deg,#fafafa,#f1f5f9);border-color:#e2e8f0}.mini-stat.stat-id .mini-stat-value{font-size:var(--font-size-sm);color:#475569;font-weight:700}.mini-stat.stat-id .mini-stat-label{color:#94a3b8}.teacher-card-actions{display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-5) var(--space-5)}.teacher-card-actions .btn{min-width:0}.teacher-card-actions .btn{flex:1;text-align:center;border-radius:12px;font-weight:700;font-size:var(--font-size-sm);padding:9px var(--space-3);transition:all .2s}.teacher-card-actions .btn-primary{background:linear-gradient(135deg,#1a3a5c,#2d6ca2);color:#fff;border:none;box-shadow:0 2px 8px #1a3a5c33}.teacher-card-actions .btn-primary:hover{box-shadow:0 4px 14px #1a3a5c52;transform:translateY(-1px)}.teacher-card-actions .btn-secondary{background:#f8fafc;color:#475569;border:1.5px solid #e2e8f0}.teacher-card-actions .btn-secondary:hover{background:#e9edf3;border-color:#cbd5e1}.schedule-table{width:100%;border-collapse:separate;border-spacing:3px;margin-top:var(--space-4)}.schedule-table th{background:linear-gradient(135deg,#1a3a5c,#2d5a8c);color:#fff;padding:10px var(--space-3);font-size:var(--font-size-xs);font-weight:700;text-align:center;border-radius:8px;letter-spacing:.02em;white-space:nowrap}.schedule-table td.schedule-cell{padding:10px var(--space-2);text-align:center;font-size:var(--font-size-xs);min-height:52px;cursor:pointer;border-radius:8px;transition:all .18s;vertical-align:middle;border:none}.schedule-table td.schedule-cell.free{background:#f1f5f9;color:#94a3b8;font-style:italic}.schedule-table td.schedule-cell.free:hover{background:#e0f2fe;color:#0ea5e9}.schedule-table td.schedule-cell.busy{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1d4ed8;font-weight:600;border:1px solid #bfdbfe}.schedule-table td.schedule-cell.busy:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 2px 8px #1d4ed826}.schedule-table td.period-label{background:linear-gradient(135deg,#f8fafc,#f1f5f9);font-weight:700;font-size:var(--font-size-xs);color:#475569;text-align:center;padding:10px var(--space-2);border-radius:8px;white-space:nowrap;border:1px solid #e2e8f0}.free-label{color:#94a3b8;font-size:var(--font-size-xs)}.class-label{display:block;font-weight:800;font-size:var(--font-size-sm);color:#1e40af}.subject-label{display:block;font-size:10px;color:#64748b;margin-top:1px}@media(max-width:768px){.teachers-header{flex-direction:column;gap:var(--space-4);align-items:stretch;padding:var(--space-4)}.teachers-grid{grid-template-columns:1fr;padding:0 var(--space-4) var(--space-4)}.search-input{width:100%}}.teacher-portal-page{min-height:100vh;background:#f0f4fa;font-family:var(--font-family);padding-top:64px}.portal-nav{background:var(--white);height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);box-shadow:0 2px 8px #1a3a5c14;position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:2px solid rgba(79,195,247,.15)}.portal-brand{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--brand-navy)}.portal-brand span{font-size:1rem;color:var(--brand-navy);font-weight:700}.portal-nav .btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600}.portal-user{display:flex;align-items:center;gap:10px}.portal-user-name{font-size:13px;color:#334155;font-weight:700}.portal-welcome{background:linear-gradient(135deg,#1a3a5c,#2d5a8c 55%,#4fc3f7);margin:var(--space-6) var(--space-8);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-10);color:#fff;position:relative;overflow:hidden;max-width:1400px;margin-left:auto;margin-right:auto;box-shadow:0 8px 32px #1a3a5c40;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both}.portal-welcome:before{content:"";position:absolute;top:-50px;left:-50px;width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.12) 0%,transparent 70%);border-radius:50%}.portal-welcome:after{content:"";position:absolute;bottom:-70px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 70%);border-radius:50%}.portal-welcome h1{font-size:var(--font-size-2xl);font-weight:800;margin-bottom:var(--space-2);position:relative;z-index:1;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.15)}.portal-welcome p{font-size:var(--font-size-base);color:#ffffffe0;position:relative;z-index:1;font-weight:500}.portal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);padding:0 var(--space-8) var(--space-5);max-width:1400px;margin:0 auto}.portal-stat{background:var(--white);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-5) var(--space-5);text-align:center;box-shadow:0 2px 10px #0000000f;border:1px solid rgba(0,0,0,.05);position:relative;overflow:hidden;transition:all .3s cubic-bezier(.25,.8,.25,1);animation:fadeInUp .5s cubic-bezier(.16,1,.3,1) both}.portal-stat:nth-child(1){animation-delay:.1s}.portal-stat:nth-child(2){animation-delay:.2s}.portal-stat:nth-child(3){animation-delay:.3s}.portal-stat:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #0000001f}.portal-stat-bar{position:absolute;top:0;left:0;right:0;height:5px;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.portal-stat-bar.blue{background:linear-gradient(90deg,#3b82f6,#64b5f6)}.portal-stat-bar.orange{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.portal-stat-bar.red{background:linear-gradient(90deg,#ef4444,#f87171)}.portal-stat-value{font-size:2.8rem;font-weight:900;line-height:1.1;margin-bottom:var(--space-2);margin-top:var(--space-1);letter-spacing:-1px}.portal-stat:nth-child(1) .portal-stat-value{color:#1d4ed8}.portal-stat:nth-child(2) .portal-stat-value{color:#b45309}.portal-stat:nth-child(3) .portal-stat-value{color:#b91c1c}.portal-stat-label{font-size:var(--font-size-sm);color:#4b5563;font-weight:600;letter-spacing:.01em}.portal-stat-icon{position:absolute;bottom:var(--space-3);left:var(--space-3);font-size:1.8rem;opacity:.08}.portal-section{padding:0 var(--space-8) var(--space-6);max-width:1400px;margin:0 auto}.portal-section h2{font-size:var(--font-size-lg);font-weight:800;color:#1a3a5c;margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:2px solid #e2e8f0}.portal-export-actions{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);justify-content:flex-start}.portal-export-actions .btn{border-radius:10px;font-weight:700}.assignments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:var(--space-4)}.assignment-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:0 4px 12px #0000000f;border:1px solid rgba(0,0,0,.05);overflow:hidden;border-right:5px solid #f59e0b;transition:all .3s cubic-bezier(.25,.8,.25,1);animation:popIn .5s cubic-bezier(.16,1,.3,1) both}.assignment-card:nth-child(1){animation-delay:.2s}.assignment-card:nth-child(2){animation-delay:.3s}.assignment-card:nth-child(3){animation-delay:.4s}.assignment-card:nth-child(n+4){animation-delay:.5s}.assignment-card:hover{box-shadow:0 12px 24px #f59e0b26;transform:translateY(-4px)}.assignment-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a}.assignment-header h4{font-size:var(--font-size-base);font-weight:800;color:#92400e;margin:0}.assignment-details{padding:var(--space-3) var(--space-5) var(--space-4)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid #f1f5f9;font-size:var(--font-size-sm);gap:var(--space-3)}.detail-row:last-child{border-bottom:none}.detail-label{color:#64748b;font-size:var(--font-size-sm);font-weight:600;white-space:nowrap}.detail-value{color:#1e293b;font-weight:700;text-align:start}.schedule-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 4px 12px #0000000f;border:1px solid rgba(0,0,0,.05);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both;animation-delay:.3s}.schedule-table th{background:#1a3a5c;color:#fff;padding:var(--space-3) var(--space-3);font-size:var(--font-size-sm);font-weight:700;text-align:center;white-space:nowrap;letter-spacing:.02em}.schedule-table th.today-col{background:#4fc3f7;color:#1a3a5c;font-weight:800;position:relative}.schedule-table th.today-col:after{content:"";font-size:10px;display:block;margin-top:2px}.schedule-table td{padding:var(--space-3) var(--space-3);text-align:center;border:1px solid #e2e8f0;vertical-align:middle;min-height:54px;font-size:var(--font-size-sm);transition:background .15s}.schedule-table td.period-label{background:#f8fafc;font-weight:700;color:#334155;white-space:nowrap;font-size:var(--font-size-sm)}.schedule-table td.schedule-cell.free{background:#fbfcfd}.schedule-table td.schedule-cell.busy{background:#4fc3f712}.schedule-table td.schedule-cell.busy .class-label{font-weight:700;color:#1a3a5c;font-size:var(--font-size-sm)}.schedule-table td.schedule-cell.today{background:#4fc3f71f;border-bottom:2px solid #4fc3f7}.schedule-table td.schedule-cell.substitute{background:linear-gradient(135deg,#fff8ed,#fffbf0);border:1.5px solid #fcd34d;border-right:3px solid #f59e0b;border-bottom:2px solid #f59e0b}.schedule-table td.schedule-cell.substitute.today{background:linear-gradient(135deg,#fef3c7,#fff8ed);border:1.5px solid #fbbf24;border-right:4px solid #d97706}.schedule-table td.schedule-cell.busy-sub{background:#fef9f0;border-right:4px solid #f59e0b}.busy-sub .substitute-label.small{font-size:9px;margin-top:3px;color:#92400e}.substitute-label{display:block;font-weight:800;color:#92400e;font-size:10px;letter-spacing:.01em;margin-bottom:4px}.sub-class-name{display:block;font-size:var(--font-size-sm);font-weight:800;color:#1a3a5c;background:#ffffffbf;border-radius:var(--radius-sm);padding:2px 6px;margin:0 auto;max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.free-label{color:#94a3b8;font-size:var(--font-size-xs);font-weight:500}.class-label{display:block;font-weight:700;font-size:var(--font-size-sm);color:#1a3a5c}.history-list{background:var(--white);border-radius:var(--radius-xl);box-shadow:0 2px 10px #0000000f;border:1px solid rgba(0,0,0,.05);overflow:hidden}.history-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid #f1f5f9;font-size:var(--font-size-sm);transition:all .2s;animation:slideInRight .4s ease-out both}.history-item:nth-child(1){animation-delay:.1s}.history-item:nth-child(2){animation-delay:.2s}.history-item:nth-child(3){animation-delay:.3s}.history-item:nth-child(4){animation-delay:.4s}.history-item:nth-child(n+5){animation-delay:.5s}.history-item:last-child{border-bottom:none}.history-item:hover{background:#f8fafc;transform:translate(-4px)}.history-date{min-width:100px;color:#475569;font-size:var(--font-size-sm);font-weight:700;background:#f1f5f9;padding:3px 10px;border-radius:20px;text-align:center;white-space:nowrap}.history-detail{flex:1;color:#1e293b;font-weight:500;line-height:1.5}.empty-state{text-align:center;padding:var(--space-10) var(--space-6);color:#64748b;background:var(--white);border-radius:var(--radius-xl);box-shadow:0 2px 10px #0000000f}.empty-icon{font-size:3rem;margin-bottom:var(--space-3)}.empty-state p{font-size:var(--font-size-base);font-weight:600;color:#475569}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}.badge-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.text-muted{color:#64748b;font-size:var(--font-size-sm);font-weight:500;text-align:center;padding:var(--space-6)}@media(max-width:1024px){.portal-welcome,.portal-section{padding-left:var(--space-5);padding-right:var(--space-5);margin-left:var(--space-5);margin-right:var(--space-5)}.portal-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding-left:var(--space-5);padding-right:var(--space-5)}.portal-nav{padding:0 var(--space-5)}.assignments-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.portal-stats{grid-template-columns:1fr 1fr;gap:var(--space-3);padding-left:var(--space-4);padding-right:var(--space-4)}.portal-stats .portal-stat:last-child{grid-column:1 / -1}.portal-welcome{margin:var(--space-4);padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg)}.portal-welcome h1{font-size:var(--font-size-xl)}.portal-welcome p{font-size:var(--font-size-sm)}.assignments-grid{grid-template-columns:1fr}.schedule-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:11px}.schedule-table th,.schedule-table td{padding:var(--space-2) 6px;font-size:11px;min-width:48px}.portal-section{padding-left:var(--space-4);padding-right:var(--space-4)}.portal-export-actions{flex-wrap:wrap}.portal-export-actions .btn{flex:1 1 160px}.portal-nav{padding:0 var(--space-4)}.portal-nav .btn{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.assignment-card{padding:var(--space-3) var(--space-4)}}@media(max-width:480px){.portal-stats{grid-template-columns:1fr}.portal-stats .portal-stat:last-child{grid-column:auto}}.archive-page{padding:var(--space-5) var(--space-6);max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-5)}.archive-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.archive-title{font-size:1.6rem;font-weight:900;color:var(--brand-navy);margin:0}.archive-subtitle{margin:var(--space-1) 0 0;color:var(--gray-500);font-size:var(--font-size-sm)}.export-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,#1d7a3a,#22a94d);color:#fff;font-weight:700;font-size:var(--font-size-sm);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #1d7a3a59;white-space:nowrap}.export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1d7a3a73}.export-btn:active{transform:translateY(0)}.archive-filters{display:flex;align-items:flex-end;gap:var(--space-3);flex-wrap:wrap;background:var(--white);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.filter-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}.filter-label{font-size:12px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em}.filter-input{padding:var(--space-2) var(--space-3);border:2px solid var(--gray-200);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--gray-800);background:var(--gray-50);transition:border-color .2s;width:100%}.filter-input:focus{outline:none;border-color:var(--brand-sky);background:var(--white)}.filter-reset-btn{padding:var(--space-2) var(--space-4);border:2px solid var(--gray-300);border-radius:var(--radius-md);background:var(--white);color:var(--gray-600);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;align-self:flex-end}.filter-reset-btn:hover{border-color:var(--brand-navy);color:var(--brand-navy);background:#f0f4fa}.archive-stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.archive-stat{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:transform .2s}.archive-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.archive-stat-num{font-size:2rem;font-weight:900;color:var(--brand-navy);line-height:1}.archive-stat-lbl{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;text-align:center}.archive-stat.covered-stat .archive-stat-num{color:#059669}.archive-stat.uncovered-stat .archive-stat-num{color:#dc2626}.archive-stat.rate-stat .archive-stat-num{color:#2d5a8c}.archive-table-wrapper{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);overflow:hidden}.archive-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.archive-table thead tr{background:linear-gradient(135deg,#1a3a5c,#2d5a8c)}.archive-table thead th{padding:var(--space-3) var(--space-4);color:#fffffff2;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em;text-align:start;white-space:nowrap}.archive-table thead th:first-child{text-align:center;width:48px}.archive-row{border-bottom:1px solid var(--gray-100);animation:rowFadeIn .3s calc(var(--row-delay, 0s)) both;transition:background .15s}@keyframes rowFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.archive-row:hover{background:#f8faff}.archive-row:last-child{border-bottom:none}.archive-table td{padding:var(--space-3) var(--space-4);color:var(--gray-700);vertical-align:middle}.archive-num{text-align:center;color:var(--gray-400);font-weight:600;font-size:11px}.archive-date{font-weight:600;color:var(--gray-600);white-space:nowrap}.archive-teacher.absent-teacher{font-weight:700;color:var(--brand-navy)}.archive-teacher.sub-teacher{color:#059669;font-weight:600}.archive-period{white-space:nowrap}.archive-period small{display:block;font-size:10px;color:var(--gray-400);margin-top:2px}.period-pill{display:inline-block;background:#e0f2fe;color:#0369a1;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700}.archive-class{font-weight:600;color:var(--gray-600)}.archive-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.archive-badge.covered{background:#dcfce7;color:#15803d}.archive-badge.uncovered{background:#fee2e2;color:#b91c1c}.archive-loading,.archive-empty{text-align:center;padding:var(--space-10) var(--space-4);color:var(--gray-400);font-size:var(--font-size-base)}.archive-empty-icon{font-size:3rem;margin-bottom:var(--space-3)}.archive-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex-wrap:wrap}.pg-btn{min-width:38px;height:38px;padding:0 var(--space-2);border:2px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);color:var(--gray-700);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.pg-btn:hover:not(.disabled):not(.active){border-color:var(--brand-sky);color:var(--brand-sky)}.pg-btn.active{background:var(--brand-navy);border-color:var(--brand-navy);color:var(--white)}.pg-btn.disabled{opacity:.35;cursor:default}.pg-ellipsis{color:var(--gray-400);padding:0 var(--space-1)}@media(max-width:768px){.archive-page{padding:var(--space-4) var(--space-3)}.archive-stats-strip{grid-template-columns:repeat(2,1fr)}.archive-header{flex-direction:column;align-items:flex-start}.archive-filters{flex-direction:column}.filter-group{min-width:100%}.archive-table-wrapper{overflow-x:auto}.archive-table{min-width:640px}}.timetable-preview-table{border-collapse:collapse;border-spacing:0;table-layout:fixed;margin-top:0}.timetable-preview-table th,.timetable-preview-table td{border:1px solid #d6e0eb}.timetable-preview-table td.schedule-cell,.timetable-preview-table td.period-label{min-height:64px;height:64px;padding:10px 8px;vertical-align:middle}.timetable-preview-table td.schedule-cell{line-height:1.3}.timetable-preview-table td.schedule-cell.busy .class-label{margin-bottom:2px}.timetable-preview-table td.schedule-cell.free .free-label{font-weight:600}@media(max-width:768px){.timetable-preview-table td.schedule-cell,.timetable-preview-table td.period-label{min-height:56px;height:56px;padding:8px 6px}}.master-timetable-wrap{margin-top:14px;border:1px solid #d6e0eb;border-radius:14px;overflow:auto;background:#fff;box-shadow:0 3px 10px #0f172a0f}.master-timetable-outer{max-width:1400px;margin:0 auto;padding:0 var(--space-8) var(--space-8)}.download-menu{position:relative;min-width:0}.download-menu>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}.download-menu>summary::-webkit-details-marker{display:none}.download-menu>summary:after{content:"";width:6px;height:6px;border-inline-end:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);opacity:.7;transition:transform .2s ease}.download-menu[open]>summary:after{transform:rotate(225deg)}.download-menu-list{position:absolute;top:calc(100% + 8px);inset-inline-start:0;min-width:220px;z-index:15;background:#fff;border:1px solid #d4e0eb;border-radius:10px;box-shadow:0 8px 18px #0f172a1f;padding:6px;display:none;gap:6px;flex-direction:column}.download-menu[open] .download-menu-list{display:flex}.download-menu-item{width:100%;justify-content:flex-start;text-align:start;border-radius:8px;min-height:36px;font-weight:700}.timetable-toolbar{flex:1;max-width:980px;display:flex;flex-direction:column;align-items:stretch;gap:10px}.timetable-toolbar-main{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.timetable-chip-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.timetable-view-group{padding:4px;border:1px solid #d7e2ee;background:#f4f8fc;border-radius:12px}.timetable-view-btn{padding:8px 13px;border-radius:8px;font-size:12px;font-weight:700}.timetable-view-group .timetable-view-btn.btn-secondary{background:transparent;border-color:transparent;box-shadow:none}.timetable-view-group .timetable-view-btn.btn-secondary:hover{background:#fff;border-color:#c9d9ea;box-shadow:0 3px 8px #0f294514}.timetable-view-group .timetable-view-btn.is-active{box-shadow:0 4px 10px #1a3a5c33}.timetable-manage-group{justify-content:flex-end}.timetable-chip-btn,.timetable-menu-trigger{border-radius:10px;font-size:12px;min-height:40px}.timetable-toolbar-search{flex:1;min-width:220px;width:auto;min-height:42px}.timetable-toolbar-select{min-width:220px;min-height:42px;border-radius:10px}.modal-overlay.timetable-manage-modal{align-items:flex-start;justify-content:center;padding:8px 16px 16px;overflow-y:auto;z-index:1200}.timetable-manage-modal .timetable-manage-modal-content{width:min(450px,calc(100vw - 32px));max-width:min(450px,calc(100vw - 32px));max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px);margin:0 auto;overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.timetable-manage-modal .timetable-manage-modal-body{padding:20px;display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px;min-height:0;overflow:hidden}.timetable-manage-modal .timetable-manage-modal-add-row{display:flex;gap:10px}.timetable-manage-modal .timetable-manage-modal-add-row .input{flex:1}.timetable-manage-modal .timetable-manager-list{border:1px solid #e5e7eb;border-radius:10px;overflow-y:auto;min-height:0;max-height:none}.timetable-manage-modal .timetable-manage-modal-content .modal-actions{margin-top:0;flex-shrink:0}@media(max-width:768px){.modal-overlay.timetable-manage-modal{align-items:flex-start;justify-content:center;min-height:100vh;min-height:100dvh;padding:max(8px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom))}.timetable-manage-modal .timetable-manage-modal-content{width:min(450px,calc(100vw - 20px));max-width:min(450px,calc(100vw - 20px));max-height:calc(100vh - 16px);max-height:calc(100dvh - 16px);border-radius:18px}.timetable-manage-modal .timetable-manage-modal-body{padding:14px;gap:12px}.timetable-manage-modal .timetable-manage-modal-content h3{border-radius:18px 18px 0 0}.timetable-manage-modal .timetable-manage-modal-content .modal-actions{border-radius:0 0 18px 18px}}@media(max-width:420px){.timetable-manage-modal .timetable-manage-modal-add-row{flex-direction:column}.timetable-manage-modal .timetable-manage-modal-add-row .btn{width:100%}}.master-timetable-table{width:max-content;min-width:100%;border-collapse:collapse;table-layout:fixed}.master-timetable-table th,.master-timetable-table td{border:1px solid #d8e2ee;text-align:center;vertical-align:middle;padding:6px 5px;font-size:12px}.master-timetable-table thead th{position:sticky;top:0;z-index:3}.master-timetable-wrap.master-export-open{overflow:visible}.master-timetable-wrap.master-export-open .master-timetable-table thead th,.master-timetable-wrap.master-export-open .master-teacher-head,.master-timetable-wrap.master-export-open .master-teacher-head-sub,.master-timetable-wrap.master-export-open .master-teacher-cell{position:static}.master-teacher-head,.master-teacher-head-sub{position:sticky;right:0;z-index:5!important;background:#0f2945;color:#fff;width:240px;min-width:240px}html[dir=ltr] .master-teacher-head,html[dir=ltr] .master-teacher-head-sub,html[dir=ltr] .master-teacher-cell{left:0;right:auto}.master-day-group{background:#113558;color:#fff;font-weight:800}.master-period-head{background:#1f4b76;color:#fff;font-weight:700;min-width:92px}.master-teacher-cell{position:sticky;right:0;z-index:2;background:#f8fafc;min-width:240px;width:240px;text-align:right}html[dir=ltr] .master-teacher-cell{text-align:left}.master-teacher-main{display:flex;align-items:center;justify-content:space-between;gap:8px}.master-teacher-main strong{display:block;color:#0f2945;font-size:12px}.master-teacher-main small{display:block;color:#64748b;font-size:10px}.master-slot{min-width:92px;min-height:58px;height:58px;line-height:1.2}.master-slot-free{background:#f8fafc;color:#64748b;font-weight:700}.master-slot-busy{background:#eef6ff}.master-slot-busy .class-label{display:block;font-weight:800;color:#0f2945;font-size:12px}.master-slot-busy .subject-label{display:block;color:#334155;font-size:10px;margin-top:2px}.master-empty{padding:20px;color:#64748b;font-weight:700;background:#f8fafc}.duty-settings-panel{max-width:1400px;margin:12px auto 0;padding:0 var(--space-8);display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap}.duty-settings-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:10px;flex:1}.duty-settings-grid label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;color:#334155}.duty-table{width:100%;border-collapse:collapse;table-layout:fixed}.duty-table th,.duty-table td{border:1px solid #d6e0eb;padding:10px;vertical-align:top}.duty-table thead th{background:#0f2945;color:#fff;font-weight:800;font-size:13px}.duty-day-cell{width:120px;background:#f8fafc;color:#0f2945;font-weight:800}.duty-slot-cell{display:flex;flex-direction:column;gap:8px}.duty-slot-cell strong{color:#0f2945;font-size:12px}.duty-pill-wrap{display:flex;flex-wrap:wrap;gap:6px}.duty-teacher-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#eef6ff;border:1px solid #cfe0f4;border-radius:999px;color:#0f2945;font-size:12px;font-weight:700}.duty-teacher-pill small{color:#9a3412;font-size:10px;font-weight:800}.duty-empty{color:#94a3b8;font-size:12px;font-weight:700}.class-timetable .class-schedule-cell{text-align:center}.class-timetable .class-subject-name{display:block;font-weight:800;color:#0f2945;font-size:12px;line-height:1.25}.class-timetable .class-teacher-name{display:block;color:#475569;font-size:10px;line-height:1.25;margin-top:2px}.schedule-cell.schedule-cell-editable{cursor:pointer;transition:transform .14s ease,box-shadow .18s ease,filter .18s ease}.schedule-cell.schedule-cell-editable:hover{filter:brightness(.99);transform:translateY(-1px);box-shadow:0 6px 14px #0f29451f}.schedule-cell.schedule-cell-editable:active{transform:translateY(0)}.modal-overlay.timetable-slot-modal{align-items:flex-start;justify-content:center;padding:8px 16px 16px;overflow-y:auto;z-index:1200}.timetable-slot-modal .timetable-slot-modal-content{width:min(500px,calc(100vw - 32px));max-width:min(500px,calc(100vw - 32px));max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px);margin:0 auto;overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.timetable-slot-modal .timetable-slot-modal-body{padding:20px;display:grid;gap:12px;min-height:0;overflow-y:auto;background:#f8fbff}.timetable-slot-modal .timetable-slot-readonly-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.timetable-slot-modal .timetable-slot-field{display:grid;gap:6px;font-size:12px;font-weight:700;color:#334155}.timetable-slot-modal .timetable-slot-field .input[readonly]{background:#eef2f8;color:#334155;border-color:#d6e1ef}.timetable-slot-modal .timetable-slot-hint{margin:4px 0 0;color:#64748b;font-size:11px;line-height:1.45}.timetable-slot-modal .timetable-slot-modal-content .modal-actions{margin-top:0;flex-shrink:0}@media(max-width:1024px){.master-timetable-outer{padding:0 var(--space-4) var(--space-5)}.timetable-toolbar{max-width:100%}.duty-settings-panel{padding:0 var(--space-4)}.duty-settings-grid{grid-template-columns:repeat(2,minmax(140px,1fr))}}@media(max-width:768px){.master-timetable-outer{padding:0 var(--space-3) var(--space-3)}.timetable-toolbar-main,.timetable-chip-group,.timetable-view-group{width:100%}.timetable-view-group .timetable-view-btn{flex:1 1 calc(50% - 4px);justify-content:center}.timetable-chip-btn,.timetable-menu-trigger,.timetable-toolbar-search,.timetable-toolbar-select{width:100%;min-width:0}.download-menu{width:100%}.download-menu>summary{width:100%}.download-menu-list{position:static;margin-top:6px;min-width:0}.duty-settings-panel{padding:0 var(--space-3)}.duty-settings-grid{grid-template-columns:1fr;width:100%}.modal-overlay.timetable-slot-modal{align-items:flex-start;justify-content:center;min-height:100vh;min-height:100dvh;padding:max(8px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom))}.timetable-slot-modal .timetable-slot-modal-content{width:min(500px,calc(100vw - 20px));max-width:min(500px,calc(100vw - 20px));max-height:calc(100vh - 16px);max-height:calc(100dvh - 16px);border-radius:18px}.timetable-slot-modal .timetable-slot-modal-content h3{border-radius:18px 18px 0 0}.timetable-slot-modal .timetable-slot-modal-body{padding:14px}.timetable-slot-modal .timetable-slot-readonly-grid{grid-template-columns:1fr}.timetable-slot-modal .timetable-slot-modal-content .modal-actions{border-radius:0 0 18px 18px}}.mobile-menu-btn{display:none;width:40px;height:40px;border:none;background:none;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:8px}.mobile-menu-btn span{display:block;width:22px;height:2px;background:var(--brand-navy);border-radius:2px;transition:all .3s}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr;padding:0 var(--space-4) var(--space-4)}.stats-row{padding:var(--space-4)}.top-nav{padding:0 var(--space-4)}.action-bar{padding:var(--space-4) var(--space-4) 0}.portal-welcome,.portal-stats,.portal-section{padding-left:var(--space-4);padding-right:var(--space-4)}.portal-welcome{margin-left:var(--space-4);margin-right:var(--space-4)}.portal-nav{padding:0 var(--space-4)}.teachers-header{padding:var(--space-4)}.teachers-grid{padding:0 var(--space-4) var(--space-4)}.absence-table,.schedule-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.dashboard-content{gap:var(--space-4)}.stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){html{font-size:14px}body{overflow-x:hidden}.top-nav{height:56px;padding:0 var(--space-3)}.dashboard-page,.teacher-portal-page{padding-top:56px}.nav-brand{font-size:var(--font-size-sm);gap:var(--space-2)}.nav-brand svg{width:24px;height:24px}.nav-brand span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-btn{display:flex}.nav-links{position:fixed;top:56px;right:-100%;width:240px;height:calc(100vh - 56px);background:#fff;flex-direction:column;align-items:stretch;padding:var(--space-4);box-shadow:-4px 0 20px #0000001a;transition:right .3s ease;z-index:200;gap:var(--space-2)}.nav-links.open{right:0}.nav-link{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);border-radius:var(--radius-md);text-align:right}.nav-user{display:flex;gap:var(--space-2)}.nav-user-name,.bot-status-tag,.notification-bell{display:none}.user-avatar{width:34px;height:34px;font-size:13px}.user-menu-dropdown{max-width:min(200px,calc(100vw - 16px))}.btn,.input,select{min-height:48px;font-size:1rem!important}.card,.panel,.teacher-card,.stat-card{border-radius:16px}.stats-row{grid-template-columns:1fr;gap:var(--space-3);padding:var(--space-3)}.stat-card{padding:var(--space-4);display:flex;align-items:center;gap:var(--space-4);text-align:right}.stat-card .stat-bar{position:absolute;top:0;left:0;right:0;height:3px}.stat-value{font-size:2rem;margin:0}.stat-icon{display:none}.dashboard-content{grid-template-columns:1fr;padding:0 var(--space-3) var(--space-3);gap:var(--space-3)}.teacher-list{max-height:400px}.teacher-row{padding:var(--space-2) var(--space-3)}.teacher-avatar{width:32px;height:32px;font-size:10px}.teacher-info strong{font-size:var(--font-size-xs)}.status-select{font-size:10px;padding:3px 8px 3px 18px}.action-bar{padding:var(--space-3) var(--space-3) 0}.auto-assign-global-btn{padding:10px 20px;font-size:var(--font-size-sm);width:100%;justify-content:center}.panel{overflow:hidden}.absence-table thead,.absence-table tbody,.absence-table tr,.absence-table th,.absence-table td{font-size:var(--font-size-xs)}.absence-table td,.absence-table th{padding:var(--space-2) var(--space-3);white-space:nowrap}.hero-section{flex-direction:column!important;text-align:center;padding:var(--space-4);gap:var(--space-6)}.hero-brand-name{font-size:2.2rem}.hero-tagline{font-size:var(--font-size-base)}.hero-description{font-size:var(--font-size-sm)}.hero-ctas{flex-direction:column;align-items:center}.cta-primary,.cta-secondary{width:100%;text-align:center;justify-content:center}.hero-preview{max-width:100%;width:100%}.features-grid{grid-template-columns:1fr;gap:var(--space-4)}.features-section{padding:0 var(--space-4) var(--space-6)}.stats-bar-inner{flex-direction:column;gap:var(--space-4);padding:var(--space-6)}.lang-switcher-bar{justify-content:center;padding:var(--space-3)}.login-page{padding:var(--space-4);min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{width:100%;max-width:100%;padding:var(--space-5);border-radius:var(--radius-lg)}.login-card h2{font-size:var(--font-size-xl)}.login-card .input{padding:var(--space-3);font-size:1rem!important;min-height:48px}.portal-nav{height:56px;padding:0 var(--space-3)}.portal-brand{font-size:var(--font-size-sm);gap:var(--space-2)}.portal-user-name{display:none}.portal-brand svg{width:24px;height:24px}.portal-welcome{margin:var(--space-3);padding:var(--space-5);border-radius:var(--radius-lg)}.portal-welcome h1{font-size:var(--font-size-lg)}.portal-welcome p{font-size:var(--font-size-sm)}.portal-stats{grid-template-columns:1fr;gap:var(--space-3);padding:0 var(--space-3) var(--space-3)}.portal-stat{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);text-align:right}.portal-stat-value{font-size:1.8rem;margin:0}.portal-stat-icon{display:none}.portal-section{padding:0 var(--space-3) var(--space-3)}.portal-section h2{font-size:var(--font-size-base)}.assignments-grid{grid-template-columns:1fr}.assignment-card{border-radius:var(--radius-lg)}.schedule-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg)}.schedule-table th,.schedule-table td{font-size:10px;padding:var(--space-2);min-width:55px}.teachers-header{flex-direction:column;gap:var(--space-3);align-items:stretch;padding:var(--space-3)}.teachers-header h2{font-size:var(--font-size-lg);text-align:center}.teachers-actions{flex-direction:column;gap:var(--space-2)}.search-input{width:100%}.teachers-grid{grid-template-columns:1fr;gap:var(--space-3);padding:0 var(--space-3) var(--space-3)}.teacher-card-header{padding:var(--space-3)}.teacher-card-avatar{width:40px;height:40px;font-size:var(--font-size-sm)}.teacher-card-stats{margin:0 var(--space-3)}.mini-stat{padding:var(--space-2)}.mini-stat-value{font-size:var(--font-size-base)}.teacher-card-actions{padding:var(--space-3)}.teacher-card-actions .btn{font-size:var(--font-size-xs);padding:var(--space-2) var(--space-3)}.modal-overlay{align-items:flex-end;padding:0}.modal{width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-5);max-height:85vh}.modal-content{width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:0;max-height:85vh}.teacher-edit-modal-overlay{align-items:flex-start;justify-content:center;min-height:100vh;min-height:100dvh;padding:max(8px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom))}.teacher-edit-modal-content{width:min(640px,calc(100vw - 20px));max-width:min(640px,calc(100vw - 20px));max-height:calc(100vh - 16px);max-height:calc(100dvh - 16px);border-radius:20px}.teacher-edit-modal-content h3{border-radius:20px 20px 0 0}.teacher-edit-modal-content .modal-actions{border-radius:0 0 20px 20px}.modal-content form{padding:20px 20px 0}.teacher-edit-modal-content form{padding:14px 14px 0;gap:10px}.modal-lg{max-height:90vh}#toast-container{left:var(--space-3);right:var(--space-3);transform:none}.toast{min-width:unset;width:100%;font-size:var(--font-size-sm);padding:var(--space-3) var(--space-4)}.notification-dropdown{position:fixed;top:56px;left:0;right:0;width:100%;border-radius:0 0 var(--radius-lg) var(--radius-lg)}}@media(max-width:480px){.hero-brand-name{font-size:1.8rem}.stat-value,.portal-stat-value{font-size:1.5rem}.teacher-card-name strong{font-size:var(--font-size-sm)}.schedule-table th,.schedule-table td{min-width:48px;font-size:9px;padding:4px}.absence-table td,.absence-table th{font-size:10px;padding:var(--space-1) var(--space-2)}}@media(pointer:coarse){.btn,.btn-sm,.cta-primary,.cta-secondary{min-height:44px}.status-select{min-height:36px}.nav-link{min-height:44px;display:flex;align-items:center}.teacher-row{min-height:52px}}
