:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#eef2ff,#f8fafc 60% 100%)}#root{min-height:100vh}.sidebar{width:280px;height:100vh;background:linear-gradient(180deg,#1e40af,#1e3a8a,#1e293b);border-right:2px solid rgba(251,191,36,.2);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;overflow-y:auto;box-shadow:4px 0 20px #0003}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#fbbf244d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#fbbf2480}.sidebar__header{padding:24px 20px;border-bottom:2px solid rgba(251,191,36,.2);display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#1e40af4d,#1e3a8a33);position:relative}.sidebar__header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#fbbf24,transparent)}.sidebar__logo{width:56px;height:56px;border-radius:14px;object-fit:cover;border:3px solid rgba(251,191,36,.4);box-shadow:0 4px 12px #fbbf244d;transition:all .3s}.sidebar__logo:hover{transform:scale(1.05);box-shadow:0 6px 16px #fbbf2466}.sidebar__school-name{font-size:18px;font-weight:800;color:#fff;margin:0;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.3);letter-spacing:.5px}.sidebar__school-subtitle{font-size:12px;color:#fbbf24e6;margin:4px 0 0;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sidebar__nav{flex:1;padding:20px 12px;display:flex;flex-direction:column;gap:6px}.sidebar__item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:12px;color:#fffc;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px;font-weight:600;position:relative;border:1px solid transparent}.sidebar__item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:0;background:linear-gradient(180deg,#fbbf24,#f59e0b);border-radius:0 4px 4px 0;transition:height .3s}.sidebar__item:hover{background:linear-gradient(135deg,#3b82f633,#1e40af33);color:#fff;border-color:#fbbf244d;transform:translate(4px)}.sidebar__item:hover:before{height:60%}.sidebar__item--active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 6px 20px #3b82f666;border-color:#fbbf2480;transform:translate(4px)}.sidebar__item--active:before{height:80%;background:linear-gradient(180deg,#fbbf24,#f59e0b)}.sidebar__icon{font-size:22px;width:28px;height:28px;text-align:center;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));flex-shrink:0}.sidebar__icon svg{width:20px;height:20px;stroke:currentColor;stroke-width:2}.sidebar__label{flex:1;letter-spacing:.3px}.sidebar__footer{padding:20px;border-top:2px solid rgba(251,191,36,.2);background:linear-gradient(135deg,#1e40af33,#1e3a8a1a)}.sidebar__version{font-size:11px;color:#fbbf24b3;margin:0;text-align:center;font-weight:600;text-transform:uppercase;letter-spacing:1px}.sidebar__dropdown{margin-top:6px}.sidebar__dropdown-toggle{width:100%;cursor:pointer;border:none;background:none;text-align:left}.sidebar__dropdown-arrow{font-size:10px;transition:transform .3s cubic-bezier(.4,0,.2,1);margin-left:auto;color:#fbbf24cc;font-weight:700}.sidebar__dropdown-arrow--open{transform:rotate(180deg)}.sidebar__dropdown-menu{margin-top:6px;margin-left:16px;padding-left:16px;border-left:3px solid rgba(251,191,36,.3);display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.sidebar__dropdown-menu::-webkit-scrollbar{width:4px}.sidebar__dropdown-menu::-webkit-scrollbar-track{background:#ffffff0d}.sidebar__dropdown-menu::-webkit-scrollbar-thumb{background:#fbbf244d;border-radius:2px}.sidebar__dropdown-item{display:flex;align-items:center;gap:12px;border-radius:10px;color:#ffffffb3;text-decoration:none;transition:all .3s;font-size:13px;font-weight:600;padding:12px 18px 12px 40px;position:relative;border:1px solid transparent}.sidebar__dropdown-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:linear-gradient(180deg,#fbbf24,#f59e0b);border-radius:0 3px 3px 0;transition:height .3s}.sidebar__dropdown-item:hover{background:linear-gradient(135deg,#3b82f626,#1e40af26);color:#fff;border-color:#fbbf2433;transform:translate(4px)}.sidebar__dropdown-item:hover:before{height:50%}.sidebar__dropdown-item--active{background:linear-gradient(135deg,#3b82f64d,#1e40af4d);color:#fbbf24;border-color:#fbbf2466;border-left:3px solid #fbbf24;font-weight:700;box-shadow:0 4px 12px #fbbf2433}.sidebar__dropdown-item--active:before{height:70%}.sidebar__dropdown-item .sidebar__icon{font-size:18px;width:22px;height:22px}.sidebar__dropdown-item .sidebar__icon svg{width:18px;height:18px}.sidebar__icon--sun svg{color:#fbbf24;filter:drop-shadow(0 0 2px rgba(251,191,36,.5))}.sidebar__icon--moon svg{color:#818cf8;filter:drop-shadow(0 0 2px rgba(129,140,248,.5))}.sidebar__dropdown-item:hover .sidebar__icon--sun svg{color:#fcd34d;filter:drop-shadow(0 0 4px rgba(252,211,77,.7))}.sidebar__dropdown-item:hover .sidebar__icon--moon svg{color:#a5b4fc;filter:drop-shadow(0 0 4px rgba(165,180,252,.7))}.sidebar__dropdown-item--active .sidebar__icon--sun svg{color:#fde047;filter:drop-shadow(0 0 6px rgba(253,224,71,.9))}.sidebar__dropdown-item--active .sidebar__icon--moon svg{color:#c7d2fe;filter:drop-shadow(0 0 6px rgba(199,210,254,.9))}.sidebar__dropdown-loading,.sidebar__dropdown-empty{padding:12px 18px 12px 40px;color:#ffffff80;font-size:12px;font-style:italic}.sidebar__dropdown-subject{margin-bottom:8px}.sidebar__dropdown-subject-header{display:flex;align-items:center;gap:12px;padding:10px 18px 10px 40px;color:#fffc;font-weight:600;font-size:13px;border-radius:8px;transition:all .2s}.sidebar__dropdown-subject-header:hover{background:#3b82f61a;color:#fff}.sidebar__dropdown-subject-header .sidebar__icon{font-size:16px;width:18px;height:18px}.sidebar__dropdown-subject-header .sidebar__icon svg{width:16px;height:16px}.sidebar__label--subject{font-weight:600;color:#ffffffe6}.sidebar__dropdown-classes{margin-left:50px;margin-top:4px;padding-left:8px;border-left:2px solid rgba(251,191,36,.2);display:flex;flex-direction:column;gap:2px}.sidebar__dropdown-class-item{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 24px;color:#fff9;font-size:12px;border-radius:6px;transition:all .2s}.sidebar__dropdown-class-item:hover{background:#3b82f614;color:#fffc}.sidebar__icon--class-small{font-size:14px;width:14px;height:14px}.sidebar__icon--class-small svg{width:14px;height:14px}.sidebar__label--class{font-size:12px;color:#fff9}@media(max-width:1024px){.sidebar{width:70px}.sidebar__header{flex-direction:column;text-align:center;padding:clamp(.75rem,2vw,1rem) clamp(.5rem,1vw,.75rem)}.sidebar__school-name,.sidebar__school-subtitle{display:none}.sidebar__logo{width:clamp(40px,8vw,44px);height:clamp(40px,8vw,44px)}.sidebar__label{display:none}.sidebar__item{justify-content:center;padding:clamp(.75rem,2vw,.875rem)}.sidebar__dropdown-menu{margin-left:0;border-left:none;position:absolute;left:70px;background:linear-gradient(180deg,#1e40af,#1e3a8a,#1e293b);border:2px solid rgba(251,191,36,.3);border-radius:12px;padding:8px;min-width:200px;box-shadow:4px 4px 20px #0000004d;z-index:101}.sidebar__dropdown-item{padding-left:18px}}@media(max-width:640px){.sidebar{transform:translate(-100%);transition:transform .3s ease;width:280px}.sidebar.sidebar--open{transform:translate(0)}.sidebar__header{flex-direction:row;text-align:left;padding:1rem}.sidebar__school-name,.sidebar__school-subtitle,.sidebar__label{display:block}.sidebar__item{justify-content:flex-start;padding:14px 18px}.sidebar__dropdown-menu{position:static;margin-left:0;padding-left:0;border-left:2px solid rgba(251,191,36,.2);background:transparent;border-radius:0;box-shadow:none;min-width:auto}.sidebar__dropdown-item{padding-left:18px}}.layout{display:flex;min-height:100vh;background:linear-gradient(145deg,#f0f4ff,#e8f0fe);position:relative}.layout:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at top right,rgba(15,104,215,.1),transparent 50%),radial-gradient(circle at bottom left,rgba(76,110,245,.1),transparent 50%);pointer-events:none;z-index:0}.layout__main{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1;width:calc(100% - 280px);transition:margin-left .3s ease,width .3s ease;overflow-x:hidden}@media(max-width:1024px){.layout__main{margin-left:70px;width:calc(100% - 70px)}}@media(max-width:640px){.layout__main{margin-left:0;width:100%}.mobile-menu-button{display:flex}.sidebar-overlay{display:block}}.layout__header{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(226,232,240,.5);padding:clamp(1rem,2vw,1.25rem) clamp(1rem,3vw,2rem);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;box-shadow:0 4px 20px #0f172a14;gap:1rem}.layout__page-title{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700;color:#1e293b;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout__header-content{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.mobile-menu-button{display:none;background:#3b82f61a;border:none;border-radius:8px;padding:.5rem;cursor:pointer;color:#3b82f6;transition:all .2s;min-width:44px;min-height:44px;align-items:center;justify-content:center}.mobile-menu-button:hover{background:#3b82f633}.mobile-menu-button:active{transform:scale(.95)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.layout__header-actions{display:flex;align-items:center;gap:12px}.header-icon-wrapper{position:relative}.header-icon-button{position:relative;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border:none;border-radius:10px;cursor:pointer;transition:all .2s;color:#3b82f6}.header-icon-button:hover{background:#3b82f633;transform:translateY(-1px)}.header-icon-button:active{transform:translateY(0)}.notification-badge{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:9px;padding:0 5px;border:2px solid white;box-shadow:0 2px 6px #ef444466}.profile-button{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:#fff;border:1px solid rgba(226,232,240,.8);border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0f172a0d}.profile-button:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-1px)}.profile-avatar{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#1e40af);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;overflow:hidden;flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-info{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.profile-name{font-size:14px;font-weight:600;color:#1e293b;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.profile-role{font-size:11px;color:#64748b;margin:2px 0 0;line-height:1.2;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.chevron{color:#64748b;transition:transform .2s;flex-shrink:0}.chevron.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0f172a26,0 2px 8px #0f172a1a;border:1px solid rgba(226,232,240,.8);min-width:320px;max-height:500px;overflow:hidden;z-index:1000;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notifications-dropdown{max-width:400px}.dropdown-header{padding:16px 20px;border-bottom:1px solid rgba(226,232,240,.8);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#3b82f60d,#1e40af0d)}.dropdown-header h3{margin:0;font-size:16px;font-weight:700;color:#1e293b}.mark-all-read{background:none;border:none;color:#3b82f6;font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}.mark-all-read:hover{background:#3b82f61a}.notifications-list{max-height:400px;overflow-y:auto}.notification-item{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(226,232,240,.5);cursor:pointer;transition:all .2s;position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:#3b82f60d}.notification-item.unread{background:#3b82f608}.notification-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:#3b82f61a}.notification-icon.assignment{background:#8b5cf61a}.notification-icon.exam{background:#ec48991a}.notification-icon.system{background:#3b82f61a}.notification-content{flex:1;min-width:0}.notification-content h4{margin:0 0 4px;font-size:14px;font-weight:600;color:#1e293b}.notification-content p{margin:0 0 4px;font-size:13px;color:#64748b;line-height:1.4}.notification-time{font-size:11px;color:#94a3b8}.unread-dot{position:absolute;top:50%;right:16px;transform:translateY(-50%);width:8px;height:8px;background:#3b82f6;border-radius:50%}.empty-notifications{padding:60px 20px;text-align:center;color:#94a3b8}.empty-notifications span{font-size:48px;display:block;margin-bottom:12px;opacity:.5}.empty-notifications p{margin:0;font-size:14px;font-weight:500}.profile-dropdown{min-width:280px}.dropdown-profile-header{padding:20px;background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;display:flex;gap:14px;align-items:center}.dropdown-profile-avatar{width:56px;height:56px;border-radius:12px;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0;overflow:hidden;border:2px solid rgba(255,255,255,.3)}.dropdown-profile-avatar img{width:100%;height:100%;object-fit:cover}.dropdown-profile-info{flex:1;min-width:0}.dropdown-profile-info h4{margin:0 0 4px;font-size:16px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-profile-info p{margin:0 0 8px;font-size:13px;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{display:inline-block;padding:4px 10px;background:#fff3;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.dropdown-divider{height:1px;background:#e2e8f080;margin:0}.dropdown-menu-items{padding:8px}.dropdown-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;background:none;border:none;border-radius:8px;cursor:pointer;transition:all .2s;color:#1e293b;font-size:14px;font-weight:500;text-align:left}.dropdown-menu-item:hover{background:#3b82f61a;color:#3b82f6}.dropdown-menu-item.logout{color:#ef4444}.dropdown-menu-item.logout:hover{background:#ef44441a;color:#dc2626}.dropdown-menu-item svg{flex-shrink:0}.modal-content--password{max-width:480px;width:90%}.password-form{padding:24px}.password-success{padding:60px 40px;text-align:center}.success-icon{font-size:64px;margin-bottom:20px;animation:successPop .5s ease-out}@keyframes successPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.password-success h4{margin:0 0 12px;font-size:20px;font-weight:700;color:#10b981}.password-success p{margin:0;font-size:14px;color:#64748b}.form-error-message{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:20px}.form-error-message span:first-child{font-size:20px}.layout__content{flex:1;padding:clamp(1rem,3vw,2rem);overflow-y:auto;overflow-x:hidden;position:relative;z-index:1;width:100%;max-width:100%}.layout-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1024px){.layout__header{padding:clamp(.75rem,2vw,1rem) clamp(1rem,2vw,1.25rem)}.layout__content{padding:clamp(1rem,3vw,1.5rem)}.profile-info{display:none}.profile-button{padding:clamp(.375rem,1vw,.5rem)}.dropdown-menu{min-width:min(280px,90vw);right:-10px}.notifications-dropdown{max-width:min(400px,calc(100vw - 2rem))}.profile-dropdown{min-width:min(260px,90vw)}}@media(max-width:640px){.layout__header{padding:clamp(.75rem,2vw,1rem);flex-wrap:wrap}.layout__header-content{flex:1 1 100%;order:1}.layout__header-actions{order:2;flex:1 1 auto;justify-content:flex-end}.layout__content{padding:clamp(.75rem,2vw,1rem)}.dropdown-menu{right:0;left:auto;min-width:min(280px,calc(100vw - 2rem))}.notifications-dropdown,.profile-dropdown{max-width:calc(100vw - 1rem)}}.login{min-height:100vh;background:linear-gradient(145deg,#0f68d7,#4c6ef5);display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,3rem);color:#0f172a}.login--canvas{background:radial-gradient(circle at top,rgba(255,255,255,.25),transparent 45%),linear-gradient(145deg,#0f68d7,#4c6ef5)}.login__panel-glass{width:min(1100px,100%);background:#f8f9fff2;border-radius:30px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 50px 120px #05113c66;padding:clamp(1.5rem,4vw,3rem);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1.5rem,4vw,3rem)}.panel__hero{background:linear-gradient(180deg,#fff,#eef2ff);border-radius:24px;padding:clamp(1.25rem,3vw,2rem);display:flex;flex-direction:column;gap:1.25rem;border:1px solid #e0e7ff}.panel__hero-content{text-align:left}.hero-logo{width:140px;height:140px;object-fit:contain;margin-bottom:.75rem}.panel__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.panel__stats article{border-radius:18px;background:#fff;border:1px solid #e2e8f0;padding:.9rem;text-align:center}.panel__stats span{display:block;color:#94a3b8;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.panel__stats strong{font-size:1.6rem;color:#0f172a}.panel__form{background:#fff;border-radius:24px;padding:clamp(1.25rem,3vw,2.5rem);border:1px solid #f1f5f9;box-shadow:0 25px 60px #0f172a12;display:flex;flex-direction:column;gap:1.25rem}.text-left{text-align:left}.login__status--spread{display:flex;align-items:center;justify-content:space-between;gap:1rem}@media(max-width:720px){.login__panel-glass,.panel__hero,.panel__form{border-radius:20px}.login__status--spread{flex-direction:column;align-items:flex-start}}.app{max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem 4rem;color:#0f172a}.app__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.health-message{margin:.5rem 0 2rem;color:#475569}.layout{display:flex;flex-direction:column;gap:1.5rem}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.75rem;box-shadow:0 20px 45px #0f172a14}.panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.panel__description{margin-top:0;color:#475569}.form{display:flex;flex-direction:column;gap:1rem;max-width:420px}.form label{display:flex;flex-direction:column;gap:.35rem;font-size:.95rem;color:#334155}.form input{padding:.75rem .9rem;border-radius:10px;border:1px solid #cbd5f5;font-size:1rem;transition:border-color .2s}.form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb33}button{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.25rem;border-radius:999px;border:none;font-weight:600;font-size:1rem;cursor:pointer;background:#2563eb;color:#fff;transition:transform .15s,box-shadow .15s}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #2563eb40}button:disabled{opacity:.7;cursor:not-allowed}.secondary{background:#f1f5f9;color:#0f172a;box-shadow:inset 0 0 0 1px #cbd5f5}.profile-card{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.badge{padding:.35rem .9rem;border-radius:999px;background:#e0e7ff;color:#312e81;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.stat-card{border:1px solid #e2e8f0;border-radius:12px;padding:1rem;background:#f8fafc}.stat-card__label{text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;color:#64748b;margin-bottom:.5rem}.stat-card__value{font-size:2rem;font-weight:700;color:#0f172a}.status-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border-radius:999px;font-weight:600;text-transform:uppercase;font-size:.85rem}.status-pill .dot{width:10px;height:10px;border-radius:50%;background:currentColor}.status-pill--success{background:#ecfdf5;color:#0f8a4b}.status-pill--error{background:#fef2f2;color:#b91c1c}.status-pill--checking{background:#fefce8;color:#b45309}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#94a3b8;margin:0}.muted{margin:0;color:#94a3b8;font-size:.9rem}.error{color:#b91c1c;margin:.5rem 0 0}@media(max-width:720px){.panel{padding:1.25rem}.profile-card{flex-direction:column;align-items:flex-start;gap:.75rem}}.dashboard-modern{max-width:1400px;margin:0 auto;padding:0}.dashboard-modern__hero{background:linear-gradient(135deg,#fffffff2,#f8f9fff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:clamp(2rem,5vw,3rem);margin-bottom:2rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 25px 60px #0f172a1a;display:flex;align-items:center;justify-content:space-between;gap:2rem}.dashboard-modern__hero-content h1{font-size:clamp(2rem,5vw,3rem);font-weight:700;background:linear-gradient(135deg,#0f68d7,#4c6ef5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.dashboard-modern__hero-content p{font-size:1.1rem;color:#64748b;margin:0}.dashboard-modern__hero-stats{display:flex;gap:2rem}.hero-stat{text-align:center;padding:1rem 1.5rem;background:#fff9;border-radius:16px;border:1px solid rgba(255,255,255,.3)}.hero-stat__label{display:block;font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.hero-stat__value{display:block;font-size:2rem;font-weight:700;color:#0f172a}.dashboard-modern__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card-modern{background:linear-gradient(135deg,#fffffffa,#f8fafff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.15);box-shadow:0 8px 32px #1e40af1f,0 2px 8px #fbbf2414,inset 0 1px #ffffffe6;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:1.5rem}.stat-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--card-gradient, linear-gradient(90deg, #1e40af, #fbbf24));opacity:.8}.stat-card-modern:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 48px #1e40af33,0 4px 16px #fbbf2426,inset 0 1px #fffffff2;border-color:#1e40af4d}.stat-card-modern:hover:before{opacity:1;height:5px}.stat-card-modern__glow{position:absolute;top:-50%;right:-50%;width:200%;height:200%;opacity:.15;border-radius:50%;filter:blur(80px);pointer-events:none;background:var(--card-gradient, linear-gradient(135deg, #1e40af, #fbbf24));transition:opacity .4s}.stat-card-modern:hover .stat-card-modern__glow{opacity:.25}.stat-card-modern__border-glow{position:absolute;inset:-2px;border-radius:24px;padding:2px;background:var(--card-gradient, linear-gradient(135deg, #1e40af, #fbbf24));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s;pointer-events:none}.stat-card-modern:hover .stat-card-modern__border-glow{opacity:.3}.stat-card-modern__icon-wrapper{width:72px;height:72px;border-radius:20px;background:var(--card-gradient, linear-gradient(135deg, #1e40af, #fbbf24));opacity:.12;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:0 4px 16px #1e40af33,inset 0 1px #ffffff4d;transition:all .4s}.stat-card-modern:hover .stat-card-modern__icon-wrapper{opacity:.2;transform:scale(1.1) rotate(5deg);box-shadow:0 6px 24px #1e40af4d,inset 0 1px #fff6}.stat-card-modern__icon{font-size:2rem;display:flex;align-items:center;justify-content:center;color:var(--card-color);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:all .4s}.stat-card-modern__icon svg{width:36px;height:36px;stroke:currentColor;stroke-width:2.5}.stat-card-modern:hover .stat-card-modern__icon{transform:scale(1.1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.stat-card-modern__content{flex:1;min-width:0}.stat-card-modern__label{font-size:.875rem;color:#64748b;margin:0 0 .5rem;font-weight:500}.stat-card-modern__value{font-size:2rem;font-weight:800;background:var(--card-gradient, linear-gradient(135deg, #1e40af, #fbbf24));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;line-height:1.2;letter-spacing:-.02em}.stat-card-modern__meta{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.stat-card-modern__trend{font-size:.8rem;font-weight:700;color:var(--card-color);padding:.25rem .75rem;background:#1e40af14;border-radius:12px;display:inline-block;border:1px solid rgba(30,64,175,.15)}.stat-card-modern__subtitle{font-size:.7rem;color:#94a3b8;font-weight:500}.dashboard-modern__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.dashboard-modern__card--wide{grid-column:span 2}@media(max-width:1024px){.dashboard-modern__card--wide{grid-column:span 1}}.dashboard-modern__card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:1.75rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 25px 60px #0f172a1a}.dashboard-modern__card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(226,232,240,.5)}.dashboard-modern__card-header h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.dashboard-modern__card-header p{font-size:.875rem;color:#94a3b8;margin:0}.dashboard-modern__card-link{font-size:.875rem;color:#3b82f6;text-decoration:none;font-weight:600;transition:all .2s;white-space:nowrap}.dashboard-modern__card-link:hover{color:#2563eb;transform:translate(2px)}.dashboard-modern__table-wrapper{overflow-x:auto}.dashboard-modern__table{width:100%;border-collapse:collapse}.dashboard-modern__table thead{background:#f8fafccc}.dashboard-modern__table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(226,232,240,.5)}.dashboard-modern__table td{padding:1rem;font-size:.875rem;color:#1e293b;border-bottom:1px solid rgba(226,232,240,.3)}.dashboard-modern__table tbody tr{transition:background .2s}.dashboard-modern__table tbody tr:hover{background:#f8fafc80}.dashboard-modern__table tbody tr:last-child td{border-bottom:none}.table-user{display:flex;align-items:center;gap:.75rem}.table-user__avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.table-class{display:flex;align-items:center;gap:.75rem}.table-class__icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;color:#1e40af}.table-class__icon svg{width:20px;height:20px;stroke:currentColor;stroke-width:2}.table-section{padding:.25rem .75rem;background:#3b82f61a;color:#2563eb;border-radius:8px;font-size:.75rem;font-weight:600}.badge-modern{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge-modern--teacher{background:#10b98126;color:#059669}.badge-modern--student{background:#3b82f626;color:#2563eb}.badge-modern--parent{background:#f59e0b26;color:#d97706}.dashboard-modern__empty{text-align:center;padding:3rem 1.5rem;color:#94a3b8;display:flex;flex-direction:column;align-items:center;gap:.75rem}.dashboard-modern__empty svg{width:48px;height:48px;stroke:currentColor;stroke-width:1.5;opacity:.5}.dashboard-modern__empty p{font-size:.875rem;margin:0}.dashboard-modern__analytics{padding:.5rem 0}.analytics-list{display:flex;flex-direction:column;gap:.75rem}.analytics-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background:#f8fafc99;border-radius:12px;transition:all .2s}.analytics-item:hover{background:#f8fafce6;transform:translate(4px)}.analytics-item__label{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:600;color:#1e293b}.analytics-item__label svg{width:18px;height:18px;color:#3b82f6;stroke:currentColor;stroke-width:2}.analytics-item__value{font-size:.875rem;font-weight:700;color:#3b82f6;padding:.25rem .75rem;background:#3b82f61a;border-radius:8px}.table-exam{display:flex;align-items:center;gap:.75rem}.table-exam__icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;color:#06b6d4}.table-exam__icon svg{width:20px;height:20px;stroke:currentColor;stroke-width:2}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.dashboard-loading .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.dashboard-error{padding:1.5rem;background:#ef44441a;color:#dc2626;border-radius:16px;text-align:center;border:1px solid rgba(239,68,68,.2)}@media(max-width:768px){.dashboard-modern__hero{flex-direction:column;align-items:flex-start}.dashboard-modern__hero-stats{width:100%;justify-content:space-between}.dashboard-modern__stats,.dashboard-modern__grid{grid-template-columns:1fr}.dashboard-modern__card-header{flex-direction:column;gap:.75rem}}.dashboard-modern__section{background:linear-gradient(135deg,#fffffffa,#f8fafff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.15);box-shadow:0 8px 32px #1e40af1f}.dashboard-modern__section-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-modern__list{display:flex;flex-direction:column;gap:.75rem}.dashboard-modern__list-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fffc;border-radius:16px;border:1px solid rgba(30,64,175,.1);transition:all .3s;text-decoration:none;color:inherit}.dashboard-modern__list-item:hover{background:#fff;border-color:#1e40af33;transform:translate(4px);box-shadow:0 4px 12px #1e40af1a}.dashboard-modern__list-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);display:flex;align-items:center;justify-content:center;color:#1e40af;flex-shrink:0}.dashboard-modern__list-icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:2}.dashboard-modern__list-content{flex:1;min-width:0}.dashboard-modern__list-title{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 .25rem}.dashboard-modern__list-subtitle{font-size:.875rem;color:#64748b;margin:0}.dashboard-modern__view-all{display:block;text-align:center;padding:1rem;margin-top:1rem;color:#1e40af;font-weight:600;text-decoration:none;border-radius:12px;background:#1e40af0d;transition:all .3s}.dashboard-modern__view-all:hover{background:#1e40af1a;transform:translateY(-2px)}.dashboard-modern__action-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:linear-gradient(135deg,#fffffffa,#f8fafff2);border-radius:20px;border:2px solid rgba(30,64,175,.15);text-decoration:none;color:#1e293b;transition:all .3s;box-shadow:0 4px 12px #1e40af14}.dashboard-modern__action-btn:hover{transform:translateY(-4px);box-shadow:0 8px 24px #1e40af26;border-color:#1e40af4d}.dashboard-modern__action-btn svg{width:32px;height:32px;stroke:currentColor;stroke-width:2;color:#1e40af}.dashboard-modern__action-btn span{font-size:.875rem;font-weight:600;text-align:center}.dashboard-modern__empty{text-align:center;padding:2rem 1rem;color:#94a3b8;font-size:.875rem}.attendance-timeline{display:flex;flex-direction:column;gap:1rem}.attendance-timeline__item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8fafc;border-radius:.5rem;transition:all .2s}.attendance-timeline__item:hover{background:#f1f5f9;transform:translate(4px)}.attendance-timeline__icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.25rem;flex-shrink:0}.attendance-timeline__content{flex:1}.attendance-timeline__date{font-weight:600;color:#334155;font-size:.875rem}.attendance-timeline__status{font-size:.75rem;font-weight:600;text-transform:uppercase;margin-top:.25rem}.marks-list{display:flex;flex-direction:column;gap:.75rem}.marks-list__item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:.5rem;border-left:4px solid #3b82f6;transition:all .2s}.marks-list__item:hover{background:#f1f5f9;transform:translate(4px)}.marks-list__info{flex:1}.marks-list__subject{font-weight:600;color:#1e293b;font-size:.9375rem}.marks-list__exam{font-size:.8125rem;color:#64748b;margin-top:.25rem}.marks-list__score{display:flex;align-items:center;gap:.75rem}.marks-list__marks{font-weight:600;color:#475569;font-size:.875rem}.marks-list__grade{padding:.375rem .75rem;border-radius:.375rem;font-weight:700;font-size:.875rem;min-width:40px;text-align:center}.exams-list{display:flex;flex-direction:column;gap:.75rem}.exams-list__item{display:flex;gap:1rem;padding:1rem;background:#fef3c7;border-radius:.5rem;border-left:4px solid #f59e0b;transition:all .2s}.exams-list__item:hover{background:#fde68a;transform:translate(4px)}.exams-list__icon{width:40px;height:40px;background:#fbbf24;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.exams-list__info{flex:1}.exams-list__subject{font-weight:700;color:#92400e;font-size:.9375rem}.exams-list__name{font-size:.8125rem;color:#78350f;margin-top:.25rem}.exams-list__date{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:#92400e}.exams-list__date svg{width:16px;height:16px}.notices-list{display:flex;flex-direction:column;gap:.75rem}.notices-list__item{display:flex;gap:1rem;padding:1rem;background:#f8fafc;border-radius:.5rem;border-left:4px solid #8b5cf6;transition:all .2s}.notices-list__item:hover{background:#f1f5f9;transform:translate(4px)}.notices-list__icon{width:40px;height:40px;background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.notices-list__content{flex:1}.notices-list__title{font-weight:600;color:#1e293b;font-size:.9375rem}.notices-list__text{font-size:.8125rem;color:#64748b;margin-top:.25rem;line-height:1.5}.notices-list__date{font-size:.75rem;color:#94a3b8;margin-top:.5rem}.fees-list{display:flex;flex-direction:column;gap:.75rem}.fees-list__item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fef2f2;border-radius:.5rem;border-left:4px solid #ef4444;transition:all .2s}.fees-list__item:hover{background:#fee2e2;transform:translate(4px)}.fees-list__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fees-list__info{flex:1;margin-left:1rem}.fees-list__title{font-weight:600;color:#1e293b;font-size:.9375rem}.fees-list__date{font-size:.8125rem;color:#64748b;margin-top:.25rem}.fees-list__description{font-size:.75rem;color:#94a3b8;margin-top:.25rem}.fees-list__amount{text-align:right}.fees-list__price{font-weight:700;color:#1e293b;font-size:1.125rem}.fees-list__status{display:inline-block;margin-top:.5rem;text-transform:uppercase;font-size:.75rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.quick-actions__btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:.75rem;text-decoration:none;color:#334155;transition:all .3s;cursor:pointer}.quick-actions__btn:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;color:#fff;transform:translateY(-4px);box-shadow:0 8px 20px #3b82f64d}.quick-actions__btn svg{width:32px;height:32px;stroke:currentColor;stroke-width:2}.quick-actions__btn span{font-size:.875rem;font-weight:600;text-align:center}.dashboard-modern__card--full,.dashboard-modern__card--actions{grid-column:1 / -1}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.class-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:.75rem;transition:all .3s;text-decoration:none;color:inherit}.class-item:hover{border-color:#3b82f6;background:#eff6ff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.class-item__icon{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.class-item__content{flex:1}.class-item__name{font-weight:700;color:#1e293b;font-size:.9375rem;margin-bottom:.25rem}.class-item__details{font-size:.8125rem;color:#64748b}.class-item__arrow{font-size:1.25rem;color:#3b82f6;font-weight:700}.subjects-list{display:flex;flex-wrap:wrap;gap:.75rem}.subject-badge{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border-radius:.5rem;font-weight:600;font-size:.875rem;transition:all .2s}.subject-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.subject-badge svg{width:16px;height:16px}.schedule-list{display:flex;flex-direction:column;gap:.75rem}.schedule-item{padding:1rem;background:#f8fafc;border-radius:.75rem;border:2px solid #e2e8f0;transition:all .2s}.schedule-item:hover{background:#f1f5f9;border-color:#f59e0b}.schedule-item__time{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:#64748b;margin-bottom:.5rem}.schedule-item__time svg{width:16px;height:16px;color:#f59e0b}.schedule-item__details{display:flex;flex-direction:column;gap:.25rem}.schedule-item__subject{font-weight:700;color:#1e293b;font-size:.9375rem}.schedule-item__class{font-size:.8125rem;color:#64748b}.exam-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fef3c7;border-radius:.75rem;border-left:4px solid #f59e0b;transition:all .2s}.exam-item:hover{background:#fde68a;transform:translate(4px)}.exam-item__icon{width:40px;height:40px;background:#fbbf24;border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.exam-item__content{flex:1}.exam-item__name{font-weight:700;color:#92400e;font-size:.9375rem;margin-bottom:.25rem}.exam-item__details{font-size:.8125rem;color:#78350f}.dashboard-modern__stats--six{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.dashboard-modern__grid--admin{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.admin-list{display:flex;flex-direction:column;gap:.75rem}.admin-list-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;background:#f8fafc;border-radius:.75rem;border:2px solid #e2e8f0;transition:all .2s;text-decoration:none;color:inherit}.admin-list-item:hover{background:#f1f5f9;border-color:#3b82f6;transform:translate(4px)}.admin-list-item__icon{width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.admin-list-item__icon--user{background:linear-gradient(135deg,#10b981,#34d399)}.admin-list-item__icon--exam{background:linear-gradient(135deg,#ef4444,#f87171)}.admin-list-item__icon--notice{background:linear-gradient(135deg,#06b6d4,#22d3ee)}.admin-list-item__content{flex:1;min-width:0}.admin-list-item__title{font-weight:700;color:#1e293b;font-size:.9375rem;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list-item__subtitle{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#64748b;flex-wrap:wrap}.admin-list-item__date{font-size:.75rem;color:#94a3b8}.admin-list-item__arrow{font-size:1.25rem;color:#3b82f6;font-weight:700;opacity:0;transition:opacity .2s}.admin-list-item:hover .admin-list-item__arrow{opacity:1}.admin-list-item--exam{background:#fef3c7;border-color:#fde68a}.admin-list-item--exam:hover{background:#fde68a;border-color:#fbbf24}.admin-list-item--notice{background:#e0f2fe;border-color:#bae6fd}.admin-list-item--notice:hover{background:#bae6fd;border-color:#0ea5e9}.role-badge{display:inline-block;padding:.125rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.role-badge--student{background:#dbeafe;color:#1e40af}.role-badge--teacher{background:#d1fae5;color:#065f46}.role-badge--admin{background:#e9d5ff;color:#6b21a8}.role-badge--super{background:#fecaca;color:#991b1b}.priority-badge{display:inline-block;padding:.125rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.priority-badge--high{background:#fecaca;color:#991b1b}.priority-badge--medium{background:#fed7aa;color:#92400e}.priority-badge--low{background:#d1fae5;color:#065f46}.quick-actions--admin{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.quick-actions__btn--blue{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.quick-actions__btn--green{background:linear-gradient(135deg,#10b981,#34d399)}.quick-actions__btn--purple{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.quick-actions__btn--orange{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.quick-actions__btn--cyan{background:linear-gradient(135deg,#06b6d4,#22d3ee)}.quick-actions__btn--red{background:linear-gradient(135deg,#ef4444,#f87171)}.quick-actions__btn--indigo{background:linear-gradient(135deg,#6366f1,#818cf8)}.quick-actions__btn--teal{background:linear-gradient(135deg,#14b8a6,#2dd4bf)}.teacher-header-info{display:flex;align-items:center;gap:1.5rem;padding:1rem 0}.teacher-header-info__avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid #3b82f6;box-shadow:0 4px 12px #3b82f64d;flex-shrink:0}.teacher-header-info__avatar img{width:100%;height:100%;object-fit:cover}.teacher-header-info__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:2rem;font-weight:700}.teacher-header-info__details{flex:1}.teacher-header-info__details h2{margin:0 0 .5rem;font-size:1.75rem;color:#1e293b}.teacher-header-info__details .dashboard-modern__subtitle{margin:0 0 .75rem;color:#64748b;font-size:.95rem}.teacher-header-info__meta{display:flex;gap:1.5rem;flex-wrap:wrap}.teacher-header-info__meta .meta-item{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#3b82f61a;border-radius:8px;font-size:.875rem;color:#475569;border:1px solid rgba(59,130,246,.2)}.weekly-timetable{padding:0}.weekly-timetable__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.weekly-timetable__day{background:#f8fafccc;border-radius:12px;padding:1rem;border:1px solid rgba(226,232,240,.8);transition:all .3s ease}.weekly-timetable__day:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:#3b82f64d}.weekly-timetable__day--today{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border:2px solid #3b82f6;box-shadow:0 4px 12px #3b82f633}.weekly-timetable__day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid rgba(226,232,240,.8)}.weekly-timetable__day--today .weekly-timetable__day-header{border-bottom-color:#3b82f64d}.weekly-timetable__day-header h4{margin:0;font-size:.95rem;font-weight:700;color:#1e293b}.today-badge{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.weekly-timetable__periods{display:flex;flex-direction:column;gap:.75rem}.timetable-period{background:#fff;border-radius:8px;padding:.75rem;border:1px solid rgba(226,232,240,.8);transition:all .2s ease}.timetable-period:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f626}.timetable-period--empty{background:#f8fafc80;border-style:dashed;text-align:center;color:#94a3b8;font-size:.85rem;padding:1.5rem .75rem}.timetable-period__time{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#64748b;margin-bottom:.5rem}.timetable-period__time svg{width:14px;height:14px;stroke:currentColor}.timetable-period__subject{font-weight:600;color:#1e293b;font-size:.875rem;margin-bottom:.25rem}.timetable-period__class{font-size:.75rem;color:#64748b}.weekly-timetable__note{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#3b82f60d;border-radius:8px;border:1px solid rgba(59,130,246,.1)}.weekly-timetable__note svg{width:20px;height:20px;stroke:#3b82f6;flex-shrink:0}.weekly-timetable__note span{font-size:.875rem;color:#475569}@media(max-width:1024px){.weekly-timetable__grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media(max-width:768px){.teacher-header-info{flex-direction:column;align-items:flex-start;text-align:left}.teacher-header-info__avatar{width:60px;height:60px}.teacher-header-info__meta{gap:.75rem}.weekly-timetable__grid{grid-template-columns:1fr}.weekly-timetable__day{padding:.875rem}}.users-page-modern{max-width:min(1400px,100%);margin:0 auto;width:100%;padding:0}.users-page-modern__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.users-page-modern__header h2{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;background:linear-gradient(135deg,#0f68d7,#4c6ef5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.users-page-modern__header p{font-size:1rem;color:#64748b;margin:0}.btn-modern{padding:.75rem 1.5rem;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-modern--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.btn-modern--primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.btn-modern--secondary{background:#f1f5f9;color:#475569}.users-page-modern__tabs{display:flex;gap:.75rem;margin-bottom:2rem;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:.5rem;border-radius:16px;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 20px #0f172a14}.tab-btn{flex:1;padding:.875rem 1.25rem;border:none;background:transparent;border-radius:12px;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.tab-btn:hover{background:#f8fafccc;color:#1e293b}.tab-btn--active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.management-section{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:1.75rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 25px 60px #0f172a1a}.management-section__header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(226,232,240,.5)}.management-section__header h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0}.management-section__table{overflow-x:auto}.management-section__table table{width:100%;border-collapse:collapse}.management-section__table thead{background:#f8fafccc}.management-section__table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(226,232,240,.5)}.management-section__table td{padding:1rem;font-size:.875rem;color:#1e293b;border-bottom:1px solid rgba(226,232,240,.3)}.management-section__table tbody tr{transition:background .2s}.management-section__table tbody tr:hover{background:#f8fafc80}.management-section__table tbody tr:last-child td{border-bottom:none}.table-user-info__avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.table-user-photo{width:50px;height:50px;border-radius:12px;overflow:hidden;border:2px solid rgba(30,64,175,.2);flex-shrink:0}.table-user-photo img{width:100%;height:100%;object-fit:cover}.table-user-photo__placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem}.student-id-badge{display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);color:#1e40af;border-radius:8px;font-weight:700;font-size:.8125rem;border:1px solid rgba(30,64,175,.2)}.status-badge{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-badge--active{background:#10b98126;color:#059669}.status-badge--inactive{background:#ef444426;color:#dc2626}.table-actions{display:flex;gap:.5rem}.action-btn{background:none;border:none;font-size:1.125rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:36px;height:36px;position:relative;z-index:1}.action-btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;pointer-events:none}.action-btn--edit{color:#3b82f6;background:#3b82f61a}.action-btn--edit:hover{background:#3b82f633;color:#2563eb;transform:scale(1.05);box-shadow:0 2px 8px #3b82f64d}.action-btn--edit:active{transform:scale(.95)}.action-btn--view{color:#3b82f6;background:#3b82f61a}.action-btn--view:hover{background:#3b82f633;color:#2563eb;transform:scale(1.05);box-shadow:0 2px 8px #3b82f64d}.action-btn--export{color:#10b981;background:#10b9811a}.action-btn--export:hover{background:#10b98133;color:#059669;transform:scale(1.05);box-shadow:0 2px 8px #10b9814d}.action-btn--delete{color:#ef4444;background:#ef44441a}.action-btn--delete:hover{background:#ef444433;color:#dc2626;transform:scale(1.05);box-shadow:0 2px 8px #ef44444d}.action-btn--delete:active{transform:scale(.95)}.action-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.action-btn:disabled:hover{transform:none;box-shadow:none}.table-empty{text-align:center;padding:3rem 1.5rem}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#94a3b8}.empty-state span{font-size:3rem;opacity:.5}.empty-state p{font-size:.875rem;margin:0}.users-page-modern__error{padding:1rem;background:#ef44441a;color:#dc2626;border-radius:12px;margin-bottom:1.5rem;border:1px solid rgba(239,68,68,.2)}.users-page-modern__loading{text-align:center;padding:3rem;color:#64748b;font-size:1rem}.modal-content{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;width:100%;max-width:210mm;max-height:90vh;overflow-y:auto;box-shadow:0 50px 120px #05113c66;border:1px solid rgba(255,255,255,.3)}.modal-content--large{max-width:210mm}.modal-content--a4{max-width:210mm;width:210mm;min-height:297mm;max-height:95vh;overflow-y:auto;padding:0;display:flex;flex-direction:column;box-shadow:0 50px 120px #05113c80}@media print{.modal-content--a4{width:210mm;height:297mm;max-width:none;max-height:none;box-shadow:none;border:none;border-radius:0}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.75rem;border-bottom:1px solid rgba(226,232,240,.5)}.modal-header h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.modal-close{background:none;border:none;font-size:2rem;color:#94a3b8;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-content--a4 .modal-form{padding:2.5rem;font-size:.95rem}.modal-content--a4 .form-group{margin-bottom:1.5rem}.modal-content--a4 .form-group label{font-size:.9375rem;margin-bottom:.625rem}.modal-content--a4 .form-group input,.modal-content--a4 .form-group select,.modal-content--a4 .form-group textarea{padding:.875rem 1.125rem;font-size:.9375rem}.modal-content--a4 .form-section{margin-bottom:2.5rem;padding-bottom:2rem}.modal-content--a4 .form-section__title{font-size:1.25rem;margin-bottom:1.5rem}@media print{.modal-content--a4 .modal-form{padding:1.5rem}}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#1e293b;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:12px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group small{display:block;margin-top:.25rem;font-size:.75rem;color:#94a3b8}.form-help-text{font-size:.875rem;color:#64748b;margin-bottom:1rem;padding:.75rem;background:#1e40af0d;border-radius:8px;border-left:3px solid #1e40af;line-height:1.5}.form-help-text strong{color:#1e40af}.form-error{display:block;margin-top:.5rem;font-size:.75rem;color:#dc2626;font-weight:600}.enrollment-summary{background:linear-gradient(135deg,#10b9811a,#0596691a);border:2px solid rgba(16,185,129,.3);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem}.enrollment-summary strong{display:block;color:#059669;font-size:.875rem;margin-bottom:.5rem}.enrollment-summary ul{margin:.5rem 0 0;padding-left:1.5rem;color:#1e293b;font-size:.875rem}.enrollment-summary li{margin:.25rem 0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(226,232,240,.5)}.form-section:last-child{border-bottom:none}.form-section__title{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:2px solid rgba(59,130,246,.2)}.form-help-text{font-size:.75rem;color:#64748b;margin:.5rem 0 1rem}.subjects-by-class{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem;max-height:400px;overflow-y:auto;padding:1rem;background:#f8fafc80;border-radius:12px;border:1px solid rgba(226,232,240,.5)}.class-subjects-group{background:#fff;padding:1rem;border-radius:12px;border:1px solid rgba(226,232,240,.5)}.class-subjects-group__title{font-size:.875rem;font-weight:700;color:#1e293b;margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(226,232,240,.5);display:flex;align-items:center;justify-content:space-between;gap:1rem}.class-name{color:#1e40af}.selected-badge{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.subjects-checkbox-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.subject-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:8px;cursor:pointer;transition:background .2s;font-size:.875rem}.subject-checkbox:hover{background:#f8fafccc}.subject-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.form-error{display:block;margin-top:.5rem;font-size:.75rem;color:#dc2626}.photo-preview{margin-top:.5rem}.photo-preview img{border:2px solid rgba(226,232,240,.5);box-shadow:0 2px 8px #0000001a}.view-student-body{padding:2rem}.view-student__photo-section{display:flex;align-items:center;gap:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:20px;margin-bottom:2rem;border:2px solid rgba(30,64,175,.1)}.view-student__photo{width:120px;height:120px;border-radius:20px;overflow:hidden;border:4px solid rgba(30,64,175,.2);box-shadow:0 8px 24px #1e40af33;flex-shrink:0}.view-student__photo img{width:100%;height:100%;object-fit:cover}.view-student__photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800}.view-student__header-info{flex:1}.view-student__header-info h2{font-size:2rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.view-student__id{font-size:.875rem;color:#64748b;font-weight:600;margin:0 0 .25rem;padding:.375rem .75rem;background:#1e40af1a;border-radius:8px;display:inline-block}.view-student__email{font-size:.875rem;color:#64748b;margin:.5rem 0 0}.view-student__sections{display:flex;flex-direction:column;gap:2rem}.view-student__section{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1)}.view-student__section-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:2px solid rgba(30,64,175,.2)}.view-student__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.view-student__info-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#f8fafc80,#f1f5f980);border-radius:12px;border:1px solid rgba(30,64,175,.1)}.view-student__info-item--full{grid-column:1 / -1}.view-student__label{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.view-student__value{font-size:.9375rem;color:#1e293b;font-weight:500}.view-student__value:empty:before{content:"Not provided";color:#94a3b8;font-style:italic}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(226,232,240,.5)}@media(max-width:1024px){.users-page-modern__header{flex-direction:column;align-items:flex-start;gap:1rem}.users-page-modern__tabs{flex-wrap:wrap;gap:.5rem}.tab-btn{flex:1 1 auto;min-width:calc(50% - .25rem);font-size:clamp(.75rem,2vw,.875rem);padding:clamp(.625rem,2vw,.875rem) clamp(.75rem,2vw,1.25rem)}.management-section{padding:clamp(1rem,3vw,1.75rem)}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-modern{min-width:800px}}@media(max-width:768px){.users-page-modern__header{flex-direction:column;align-items:flex-start;gap:1rem}.users-page-modern__tabs{flex-direction:column;gap:.5rem}.tab-btn{width:100%}.form-row{grid-template-columns:1fr;gap:1rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -1rem;padding:0 1rem}.table-modern{min-width:700px;font-size:clamp(.75rem,2vw,.875rem)}.modal-content{max-height:95vh;max-width:95vw;width:95vw;margin:2.5vh auto;padding:clamp(1rem,3vw,1.5rem);overflow-y:auto}.modal-content--a4{width:100%;max-width:100%;min-height:auto}.subjects-by-class{max-height:300px}.photo-upload-section{flex-direction:column;align-items:center;gap:1rem}.photo-preview{width:clamp(120px,25vw,150px);height:clamp(120px,25vw,150px)}.subjects-grid{grid-template-columns:1fr}.management-section{padding:clamp(.75rem,2vw,1rem)}}@media(max-width:640px){.users-page-modern__header h2{font-size:clamp(1.25rem,5vw,1.5rem)}.users-page-modern__header p{font-size:clamp(.875rem,2vw,1rem)}.btn-modern{padding:clamp(.625rem,2vw,.75rem) clamp(1rem,3vw,1.5rem);font-size:clamp(.75rem,2vw,.875rem);width:100%}.table-modern{min-width:600px}.action-btn{padding:clamp(.375rem,1vw,.5rem);font-size:clamp(1rem,2.5vw,1.125rem)}.modal-content{max-width:98vw;width:98vw;margin:1vh auto;padding:clamp(.75rem,2vw,1rem);border-radius:12px}}.photo-upload-section{display:flex;gap:2rem;align-items:flex-start;padding:1.5rem;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0}.photo-preview{width:150px;height:150px;flex-shrink:0}.photo-preview img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:3px solid #e2e8f0}.photo-placeholder{width:100%;height:100%;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.875rem;border:3px dashed #cbd5e1}.photo-upload-controls{flex:1;display:flex;flex-direction:column;gap:.75rem}.photo-upload-controls .btn{width:fit-content}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;padding:1rem;background:#f8fafc;border-radius:8px;max-height:300px;overflow-y:auto}.subject-checkbox{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s}.subject-checkbox:hover{background:#f1f5f9;border-color:#3b82f6}.subject-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.subject-checkbox label{margin:0;cursor:pointer;font-size:.9375rem;color:#1e293b;flex:1}.selected-subjects{margin-top:1rem;padding:1rem;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:4px;font-size:.9375rem;color:#1e40af}.user-card__phone{font-size:.875rem;color:#64748b;margin:.25rem 0}.user-card__university{font-size:.875rem;color:#059669;margin:.25rem 0;font-weight:500}.user-card__subjects{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.user-card__subjects strong{display:block;margin-bottom:.5rem;color:#475569;font-size:.8125rem}.subject-badges{display:flex;flex-wrap:wrap;gap:.375rem}.subject-badge-sm{display:inline-block;padding:.25rem .625rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.user-card__actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.625rem;border:2px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.action-btn--edit{border-color:#3b82f6;color:#3b82f6}.action-btn--edit:hover{background:#3b82f6;color:#fff}.action-btn--print{border-color:#10b981;color:#10b981}.action-btn--print:hover{background:#10b981;color:#fff}.action-btn--download{border-color:#8b5cf6;color:#8b5cf6}.action-btn--download:hover{background:#8b5cf6;color:#fff}.action-btn--delete{border-color:#ef4444;color:#ef4444}.action-btn--delete:hover{background:#ef4444;color:#fff}.action-btn:disabled{opacity:.5;cursor:not-allowed}.search-filter-bar{display:flex;gap:1rem;align-items:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.search-input{flex:1;padding:.875rem 1.25rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9375rem;transition:all .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-results-count{font-size:.875rem;color:#64748b;white-space:nowrap}.checkbox-group{display:flex;align-items:center;gap:.5rem}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-group label{margin:0;cursor:pointer;color:#475569}.classes-page-modern{max-width:1600px;margin:0 auto;padding:0}.classes-page-modern__header{background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);border-radius:24px;padding:2.5rem 3rem;margin-bottom:2.5rem;box-shadow:0 20px 60px #1e40af4d;position:relative;overflow:hidden}.classes-page-modern__header:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.classes-page-modern__header>div{position:relative;z-index:1}.classes-page-modern__header h2{font-size:2.5rem;font-weight:800;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.classes-page-modern__header p{font-size:1.125rem;color:#ffffffe6;margin:0}.classes-page-modern__header .btn-modern--primary{position:relative;z-index:1;background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 8px 24px #fbbf2466;border:2px solid rgba(255,255,255,.3)}.classes-page-modern__header .btn-modern--primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #fbbf2480}.classes-page-modern__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}.stat-card-modern{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 10px 40px #1e40af1a;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;text-align:center}.stat-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--card-color, #3b82f6),var(--card-color-light, #60a5fa));border-radius:24px 24px 0 0}.stat-card-modern:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 60px #1e40af33;border-color:#1e40af4d}.stat-card-modern__icon-wrapper{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--card-color, #3b82f6),var(--card-color-light, #60a5fa));display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:0 10px 30px #1e40af4d;position:relative}.stat-card-modern__icon-wrapper:after{content:"";position:absolute;inset:-4px;border-radius:50%;background:linear-gradient(135deg,var(--card-color, #3b82f6),var(--card-color-light, #60a5fa));opacity:.2;z-index:-1;filter:blur(12px)}.stat-card-modern__icon{font-size:3rem;filter:brightness(0) invert(1);display:flex;align-items:center;justify-content:center}.stat-card-modern__icon svg{width:48px;height:48px;stroke:currentColor;stroke-width:2;filter:brightness(0) invert(1)}.stat-card-modern__content{width:100%}.stat-card-modern__label{font-size:.875rem;color:#64748b;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 .75rem}.stat-card-modern__value{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;line-height:1}.stat-card-modern__glow{display:none}.classes-page-modern__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:2rem}.class-card-modern{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:28px;padding:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 10px 40px #1e40af1a;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.class-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:8px;background:linear-gradient(90deg,#1e40af,#3b82f6,#60a5fa);border-radius:28px 28px 0 0}.class-card-modern:hover{transform:translateY(-8px);box-shadow:0 20px 60px #1e40af40;border-color:#1e40af4d}.class-card-modern__header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(30,64,175,.1)}.class-card-modern__icon{width:70px;height:70px;border-radius:20px;background:linear-gradient(135deg,#1e40af,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff}.class-card-modern__icon svg{width:36px;height:36px;stroke:currentColor;stroke-width:2}.class-card-modern__icon:after{content:"";position:absolute;inset:-3px;border-radius:20px;background:linear-gradient(135deg,#1e40af,#3b82f6);opacity:.2;z-index:-1;filter:blur(8px)}.class-card-modern__title-group{flex:1}.class-card-modern__name{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.class-card-modern__section{font-size:.875rem;color:#fff;background:linear-gradient(135deg,#fbbf24,#f59e0b);padding:.375rem 1rem;border-radius:12px;display:inline-block;font-weight:600;box-shadow:0 4px 12px #fbbf244d}.class-card-modern__content{flex:1}.class-card-modern__info{margin-bottom:1rem}.class-card-modern__student-count{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-radius:12px;font-size:.875rem;font-weight:600;color:#1e40af;margin-bottom:1rem}.class-card-modern__student-count svg{width:20px;height:20px;stroke:currentColor;stroke-width:2}.class-card-modern__stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:16px;border:1px solid rgba(30,64,175,.1)}.class-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #1e40af14}.class-stat__icon{font-size:2rem;margin-bottom:.5rem;opacity:.8;display:flex;align-items:center;justify-content:center;color:#1e40af}.class-stat__icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:2}.class-stat__content{display:flex;flex-direction:column;align-items:center}.class-stat__value{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.25rem}.class-stat__label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.class-card-modern__actions{display:flex;flex-direction:column;gap:.75rem;padding-top:1.5rem;border-top:2px solid rgba(30,64,175,.1)}.class-card-modern__actions-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.class-card-modern__actions .btn-modern{justify-content:center;white-space:nowrap;font-size:.8125rem;padding:.75rem 1rem;border-radius:12px;font-weight:600;transition:all .3s}.btn-modern--danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border:1px solid rgba(220,38,38,.2)}.btn-modern--danger:hover{background:linear-gradient(135deg,#fecaca,#fca5a5);transform:translateY(-1px)}.btn-modern--small{padding:.625rem 1rem;font-size:.8125rem}.classes-page-modern__error{padding:1.25rem 1.75rem;background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-radius:16px;margin-bottom:1.5rem;border:2px solid rgba(220,38,38,.2);display:flex;align-items:center;gap:.75rem;font-weight:600;box-shadow:0 4px 12px #dc26261a}.classes-page-modern__loading{text-align:center;padding:6rem 2rem;color:#64748b}.classes-page-modern__empty{grid-column:1 / -1;padding:6rem 2rem}.empty-state{text-align:center;max-width:500px;margin:0 auto}.empty-state__icon{font-size:5rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;opacity:.6;filter:grayscale(.3)}.empty-state__icon svg{width:64px;height:64px;stroke:currentColor;stroke-width:1.5}.empty-state h3{font-size:2rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .75rem}.empty-state p{font-size:1.125rem;color:#64748b;margin:0 0 2rem}.modal-form{padding:2rem}.modal-body{padding:2rem;max-height:calc(90vh - 120px);overflow-y:auto}.form-group label{display:block;font-size:.875rem;font-weight:700;color:#1e293b;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:1rem 1.25rem;border:2px solid rgba(30,64,175,.1);border-radius:16px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .3s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 4px #1e40af1a;background:#fff}.form-group small{display:block;margin-top:.5rem;font-size:.75rem;color:#64748b}.section-selection{display:flex;flex-direction:column;gap:.75rem}.section-quick-buttons{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.section-quick-label{font-size:.75rem;color:#64748b;font-weight:600;margin-right:.25rem}.section-quick-btn{padding:.5rem 1rem;border:2px solid rgba(30,64,175,.2);background:#fff;color:#1e40af;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:40px}.section-quick-btn:hover{background:#1e40af1a;border-color:#1e40af66;transform:translateY(-1px)}.section-quick-btn.active{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;border-color:#1e40af;box-shadow:0 2px 8px #1e40af4d}.modal-loading,.modal-empty{text-align:center;padding:4rem 1rem;color:#64748b;font-size:1.125rem}.modal-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #1e40af14}.modal-table thead{background:linear-gradient(135deg,#1e40af,#3b82f6)}.modal-table th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;border-bottom:2px solid rgba(255,255,255,.2)}.modal-table td{padding:1rem 1.25rem;font-size:.875rem;color:#1e293b;border-bottom:1px solid rgba(30,64,175,.1);background:#fff}.modal-table tbody tr:hover{background:linear-gradient(135deg,#1e40af0d,#3b82f60d)}.modal-table tbody tr:last-child td{border-bottom:none}.students-list,.subjects-list,.timetable-view{margin-top:1rem}.export-info{text-align:center;padding:3rem 2rem}.export-info p{font-size:1.125rem;color:#64748b;margin-bottom:2rem;font-weight:600}.table-user-info{display:flex;align-items:center;gap:.75rem}.table-user-info__avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0;box-shadow:0 4px 12px #1e40af4d}@media(max-width:768px){.classes-page-modern__header{padding:2rem 1.5rem}.classes-page-modern__header h2{font-size:2rem}.classes-page-modern__grid,.classes-page-modern__stats,.class-card-modern__actions-row{grid-template-columns:1fr}.class-card-modern__actions .btn-modern{width:100%}}.class-detail{max-width:1600px;margin:0 auto;padding:0}.class-detail__header{background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);border-radius:24px;padding:2.5rem 3rem;margin-bottom:2rem;box-shadow:0 20px 60px #1e40af4d;position:relative;overflow:hidden}.class-detail__header:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.class-detail__header-content{position:relative;z-index:1;margin-bottom:1.5rem}.class-detail__back{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s;margin-bottom:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.class-detail__back:hover{background:#ffffff4d;transform:translate(-4px)}.class-detail__header h1{font-size:2.5rem;font-weight:800;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.class-detail__section{font-size:1.125rem;color:#fbbf24;font-weight:600;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.2)}.class-detail__actions{position:relative;z-index:1;display:flex;gap:1rem;flex-wrap:wrap}.class-detail__search{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:1.5rem 2rem;margin-bottom:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 10px 40px #1e40af1a;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.search-box{flex:1;position:relative;display:flex;align-items:center;gap:1rem;background:#fff;border:2px solid rgba(30,64,175,.1);border-radius:16px;padding:.875rem 1.25rem;transition:all .3s}.search-box:focus-within{border-color:#1e40af;box-shadow:0 0 0 4px #1e40af1a}.search-icon{font-size:1.25rem;color:#64748b}.search-input{flex:1;border:none;outline:none;font-size:1rem;color:#1e293b;background:transparent}.search-input::placeholder{color:#94a3b8}.search-clear{background:#ef44441a;border:none;color:#dc2626;width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.search-clear:hover{background:#ef444433}.search-results{font-size:.875rem;color:#64748b;font-weight:600;white-space:nowrap}.class-detail__students{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 10px 40px #1e40af1a}.students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.student-card{background:#fff;border-radius:20px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 8px 24px #1e40af14;transition:all .3s;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;overflow:hidden}.student-card:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#1e40af,#3b82f6,#60a5fa);border-radius:20px 20px 0 0}.student-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #1e40af26;border-color:#1e40af4d}.student-card__photo{width:100px;height:100px;border-radius:50%;margin-bottom:1rem;border:4px solid rgba(30,64,175,.1);overflow:hidden;position:relative;box-shadow:0 8px 20px #1e40af33}.student-card__photo img{width:100%;height:100%;object-fit:cover}.student-card__photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800}.student-card__info{width:100%}.student-card__id{font-size:.75rem;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;padding:.375rem .75rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-radius:8px;display:inline-block}.student-card__name{font-size:1.125rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.student-card__email{font-size:.875rem;color:#64748b;word-break:break-word}.class-detail__empty{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;opacity:.5}.empty-icon svg{width:48px;height:48px;stroke:currentColor;stroke-width:1.5}.class-detail__empty h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.class-detail__empty p{font-size:1rem;color:#64748b;margin:0}.class-detail__loading,.class-detail__error{text-align:center;padding:4rem 2rem}.class-detail__error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-radius:16px;border:2px solid rgba(220,38,38,.2);display:flex;align-items:center;justify-content:center;gap:.75rem;font-weight:600}.loading-spinner{width:64px;height:64px;border:5px solid rgba(30,64,175,.1);border-top-color:#1e40af;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1.5rem}.btn-modern{padding:.75rem 1.5rem;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem}.btn-modern--primary{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;box-shadow:0 4px 12px #fbbf244d}.btn-modern--primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2466}.btn-modern--action{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;box-shadow:0 4px 12px #1e40af4d;border:1px solid rgba(255,255,255,.2)}.btn-modern--action:hover{background:linear-gradient(135deg,#1e3a8a,#2563eb);transform:translateY(-2px);box-shadow:0 6px 16px #1e40af66}.btn-modern--secondary{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border:1px solid rgba(30,64,175,.1)}.btn-modern--secondary:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);transform:translateY(-1px)}.modal-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.modal-content{background:linear-gradient(135deg,#fff,#f8fafc);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:28px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 50px 120px #1e40af66;border:2px solid rgba(30,64,175,.1)}.modal-content--large{max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:2rem;border-bottom:2px solid rgba(30,64,175,.1);background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:28px 28px 0 0}.modal-header h3{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.modal-close{background:linear-gradient(135deg,#fee2e2,#fecaca);border:none;font-size:1.5rem;color:#dc2626;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all .3s;font-weight:700}.modal-close:hover{background:linear-gradient(135deg,#fecaca,#fca5a5);transform:scale(1.1)}.modal-form,.modal-body{padding:2rem}.form-group label{display:block;font-size:.75rem;font-weight:700;color:#1e293b;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select{width:100%;padding:1rem 1.25rem;border:2px solid rgba(30,64,175,.1);border-radius:16px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .3s;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 4px #1e40af1a}.form-select{width:100%;padding:1rem 1.25rem;border:2px solid rgba(30,64,175,.1);border-radius:16px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .3s;font-family:inherit}.form-select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 4px #1e40af1a}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px solid rgba(30,64,175,.1)}.modal-loading{text-align:center;padding:4rem 1rem;color:#64748b;font-size:1.125rem}.subjects-checkbox-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem;max-height:400px;overflow-y:auto;padding:1.5rem;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:16px;border:2px solid rgba(30,64,175,.1)}.subject-checkbox{display:flex;align-items:center;gap:.75rem;padding:.875rem;border-radius:12px;cursor:pointer;transition:all .3s;font-size:.875rem;background:#fff;border:2px solid rgba(30,64,175,.1)}.subject-checkbox:hover{background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-color:#1e40af;transform:translate(4px)}.subject-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#1e40af}@media(max-width:768px){.class-detail__header{padding:2rem 1.5rem}.class-detail__header h1{font-size:2rem}.class-detail__actions{flex-direction:column}.class-detail__actions .btn-modern{width:100%}.class-detail__search{flex-direction:column;align-items:stretch}.students-grid{grid-template-columns:1fr}}.subjects-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.subjects-page-modern__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.subjects-page-modern__search{margin-bottom:2rem}.search-box-modern{display:flex;align-items:center;gap:.75rem;background:#fff;border-radius:12px;padding:.75rem 1rem;box-shadow:0 4px 12px #1e40af14;border:2px solid rgba(30,64,175,.1);transition:all .2s}.search-box-modern:focus-within{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.search-box-modern svg{color:#64748b;flex-shrink:0}.search-input-modern{flex:1;border:none;outline:none;font-size:.9375rem;color:#1e293b}.search-input-modern::placeholder{color:#94a3b8}.search-clear{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .2s;border-radius:4px}.search-clear:hover{background:#ef44441a;color:#dc2626}.subjects-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.subjects-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.subjects-page-modern__error{padding:1rem;background:#ef44441a;color:#dc2626;border-radius:12px;margin-bottom:1.5rem;border:1px solid rgba(239,68,68,.2)}.subjects-page-modern__loading{text-align:center;padding:3rem;color:#64748b;font-size:1rem}.subjects-page-modern__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.subject-card-modern{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14;transition:all .3s ease;position:relative;overflow:hidden}.subject-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#1e40af,#3b82f6)}.subject-card-modern:hover{transform:translateY(-4px);box-shadow:0 8px 24px #1e40af26;border-color:#1e40af4d}.subject-card-modern__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.75rem}.subject-card-modern__checkbox{display:flex;align-items:center;justify-content:center;flex-shrink:0}.subject-card-modern__checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#1e40af;border-radius:4px}.subject-card-modern--selected{border-color:#1e40af;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);box-shadow:0 4px 16px #1e40af33}.subject-card-modern__icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);display:flex;align-items:center;justify-content:center;color:#1e40af}.subject-card-modern__actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.action-btn-modern{width:36px;height:36px;border-radius:8px;border:none;background:#1e40af1a;color:#1e40af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;position:relative;z-index:10;pointer-events:auto;-webkit-tap-highlight-color:transparent}.action-btn-modern svg{width:18px;height:18px;flex-shrink:0}.action-btn-modern--view{background:linear-gradient(135deg,#3b82f633,#2563eb33)!important;color:#2563eb!important;border:1.5px solid rgba(59,130,246,.4)!important}.action-btn-modern--view:hover{background:linear-gradient(135deg,#3b82f64d,#2563eb4d)!important;color:#1d4ed8!important;border-color:#3b82f699!important;box-shadow:0 4px 8px #3b82f666!important}.action-btn-modern--edit{background:linear-gradient(135deg,#10b98133,#05966933)!important;color:#059669!important;border:1.5px solid rgba(16,185,129,.4)!important}.action-btn-modern--edit:hover{background:linear-gradient(135deg,#10b9814d,#0596694d)!important;color:#047857!important;border-color:#10b98199!important;box-shadow:0 4px 8px #10b98166!important}.action-btn-modern--delete{background:linear-gradient(135deg,#ef444433,#dc262633)!important;color:#dc2626!important;border:1.5px solid rgba(239,68,68,.4)!important}.action-btn-modern--delete:hover{background:linear-gradient(135deg,#ef44444d,#dc26264d)!important;color:#b91c1c!important;border-color:#ef444499!important;box-shadow:0 4px 8px #ef444466!important}.subject-card-modern__content{display:flex;flex-direction:column;gap:.75rem}.subject-card-modern__id{font-size:.75rem;color:#64748b;font-weight:600;margin-bottom:.25rem}.subject-card-modern__name{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.subject-card-modern__code{font-size:.875rem;color:#64748b;margin:0}.class-badge-modern{display:inline-block;padding:.375rem .875rem;background:#1e40af1a;color:#1e40af;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid rgba(30,64,175,.2)}.class-badge-modern--all{background:linear-gradient(135deg,#fbbf2426,#f59e0b26);color:#d97706;border-color:#fbbf244d}.class-badge-modern--count{background:linear-gradient(135deg,#1e40af26,#3b82f626);color:#1e40af;border-color:#1e40af4d;font-weight:700}.subjects-page-modern__empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#64748b}.subjects-page-modern__empty svg{margin-bottom:1rem;opacity:.5}.subjects-page-modern__empty p{font-size:1.125rem;margin:0 0 1.5rem}.btn-modern{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;font-size:.9375rem;border:none;cursor:pointer;transition:all .2s}.btn-modern--primary{background:#fff;color:#1e40af}.btn-modern--primary:hover{background:#ffffffe6;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-modern--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.modal-content{background:#fff;border-radius:24px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 50px 120px #05113c66}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem;border-bottom:1px solid rgba(226,232,240,.5)}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:#e2e8f080;color:#64748b;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-form{padding:1.75rem}.form-group label{display:block;font-weight:600;color:#475569;margin-bottom:.5rem;font-size:.875rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:2px solid rgba(226,232,240,.8);border-radius:12px;font-size:.9375rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group select:disabled{background:#f1f5f9;cursor:not-allowed;opacity:.7}.form-hint{display:block;font-size:.75rem;color:#64748b;margin-top:.25rem}.modal-body{padding:1.75rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding:1.75rem;border-top:1px solid rgba(226,232,240,.5)}.subject-view-info{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(226,232,240,.5)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(226,232,240,.3)}.info-row:last-child{border-bottom:none}.info-row strong{color:#475569;font-weight:600;font-size:.9375rem}.info-row span{color:#1e293b;font-weight:500}.assigned-classes-section,.assigned-teachers-section{margin-top:2rem}.assigned-classes-section h4,.assigned-teachers-section h4{margin:0 0 1rem;font-size:1.125rem;font-weight:700;color:#1e293b}.assigned-classes-list,.assigned-teachers-list{display:flex;flex-direction:column;gap:.75rem}.class-item-view,.teacher-item-view{padding:1rem;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:12px;border:2px solid rgba(30,64,175,.1);transition:all .2s}.class-item-view:hover,.teacher-item-view:hover{background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-color:#1e40af33;transform:translateY(-2px);box-shadow:0 4px 12px #1e40af26}.class-item-view__info,.teacher-item-view__info{display:flex;flex-direction:column;gap:.5rem}.class-item-view__name,.teacher-item-view__name{font-size:1rem;font-weight:700;color:#1e40af}.class-item-view__id,.teacher-item-view__email{font-size:.875rem;color:#64748b}.no-classes-assigned{text-align:center;padding:3rem 2rem;color:#94a3b8}.no-classes-assigned svg{margin-bottom:1rem}.no-classes-assigned p{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:#64748b}.no-classes-assigned small{font-size:.875rem;color:#94a3b8}.subjects-bulk-actions{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:#fff;border-radius:16px;margin-top:2rem;box-shadow:0 4px 12px #1e40af14;border:2px solid rgba(30,64,175,.1)}.subjects-bulk-actions__left{display:flex;align-items:center}.bulk-select-all{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600;color:#1e293b;font-size:.9375rem}.bulk-select-all input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#1e40af;border-radius:4px}.bulk-select-all span{-webkit-user-select:none;user-select:none}.subjects-bulk-actions__right{display:flex;gap:.75rem}.btn-modern--danger{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border:none;box-shadow:0 4px 12px #dc26264d}.btn-modern--danger:hover{background:linear-gradient(135deg,#b91c1c,#dc2626);transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.btn-modern--delete-all{background:linear-gradient(135deg,#991b1b,#dc2626);font-weight:700;border:2px solid rgba(255,255,255,.3);position:relative;overflow:hidden}.btn-modern--delete-all:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-modern--delete-all:hover:before{left:100%}.btn-modern--delete-all:hover{background:linear-gradient(135deg,#7f1d1d,#b91c1c);box-shadow:0 8px 20px #dc262680;transform:translateY(-2px) scale(1.02)}.modal-content--delete-all{max-width:500px}.modal-header--danger{background:linear-gradient(135deg,#dc26261a,#ef44441a);border-bottom:2px solid rgba(220,38,38,.2)}.modal-header--danger h3{color:#dc2626}.delete-all-warning{text-align:center;padding:1rem 0}.warning-icon{margin:0 auto 1.5rem;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#dc26261a,#ef44441a);display:flex;align-items:center;justify-content:center;color:#dc2626}.delete-all-warning h4{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.delete-all-warning p{font-size:1rem;color:#64748b;margin:.5rem 0;line-height:1.6}.warning-bold{font-weight:700;color:#dc2626!important;font-size:1.125rem!important}.delete-all-confirm-input{margin-top:2rem;padding-top:2rem;border-top:2px solid rgba(226,232,240,.8)}.delete-all-confirm-input label{display:block;font-weight:600;color:#1e293b;margin-bottom:.75rem;font-size:.9375rem}.delete-all-confirm-input input{width:100%;padding:1rem 1.25rem;border:2px solid rgba(220,38,38,.3);border-radius:12px;font-size:1rem;font-weight:600;text-align:center;letter-spacing:.1em;text-transform:uppercase;transition:all .3s}.delete-all-confirm-input input:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 4px #dc26261a}.delete-all-confirm-input input.confirm-match{border-color:#059669;background:#0596690d;color:#059669}.delete-all-confirm-input small{display:block;margin-top:.5rem;font-size:.875rem;font-weight:600}.confirm-error{color:#dc2626}.confirm-success{color:#059669}.modal-actions button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.modal-actions button:disabled:hover{background:linear-gradient(135deg,#dc2626,#ef4444);transform:none;box-shadow:0 4px 12px #dc26264d}.exams-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.exams-page-modern__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.exams-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.exams-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.exams-page-modern__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.exam-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ef4444,#f59e0b)}.exam-card-modern__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.exam-card-modern__icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#ef44441a,#f59e0b1a);display:flex;align-items:center;justify-content:center;color:#ef4444}.exam-card-modern__actions{display:flex;gap:.5rem}.action-btn-modern{width:32px;height:32px;border-radius:8px;border:none;background:#1e40af1a;color:#1e40af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.action-btn-modern:hover{background:#1e40af33;transform:scale(1.1)}.action-btn-modern--delete:hover{background:#ef44441a;color:#dc2626}.exam-card-modern__content{display:flex;flex-direction:column;gap:.75rem}.exam-card-modern__name{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.exam-card-modern__date{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem}.exam-card-modern__badge{display:flex;gap:.5rem;flex-wrap:wrap}.badge-modern{display:inline-block;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:600}.badge-modern--subject{background:linear-gradient(135deg,#3b82f61a,#1e40af1a);color:#1e40af}.badge-modern--class{background:linear-gradient(135deg,#10b9811a,#0596691a);color:#10b981}.exams-page-modern__empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#64748b}.exams-page-modern__empty svg{margin-bottom:1rem;opacity:.5}.exams-page-modern__empty p{font-size:1.125rem;margin:0 0 1.5rem}.attendance-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.attendance-page-modern__header{margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.attendance-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.attendance-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.attendance-form-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #1e40af14;border:2px solid rgba(30,64,175,.1)}.attendance-form-card h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.attendance-students-list{margin-top:2rem}.attendance-students-list h4{font-size:1.125rem;font-weight:600;color:#475569;margin:0 0 1rem}.attendance-table-wrapper{margin-bottom:1.5rem;border-radius:12px;overflow:hidden;border:1px solid rgba(226,232,240,.8)}.attendance-table{width:100%;border-collapse:collapse}.attendance-table thead{background:linear-gradient(135deg,#1e40af0d,#3b82f60d)}.attendance-table th{padding:1rem;text-align:left;font-weight:700;color:#1e293b;font-size:.875rem;text-transform:uppercase}.attendance-table td{padding:1rem;border-bottom:1px solid rgba(226,232,240,.8)}.student-avatar-attendance{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.status-select{padding:.5rem .75rem;border:2px solid rgba(226,232,240,.8);border-radius:8px;font-size:.875rem;cursor:pointer;transition:all .2s}.status-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-modern--full{width:100%;justify-content:center}.take-attendance-page{max-width:1400px;margin:0 auto;padding:2rem}.take-attendance-page__header{margin-bottom:2rem}.take-attendance-page__header h2{font-size:2rem;font-weight:700;color:#0f172a;margin:0 0 .5rem;background:linear-gradient(135deg,#1e40af,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.take-attendance-page__header p{font-size:1rem;color:#64748b;margin:0}.take-attendance-form-card{background:linear-gradient(135deg,#fffffffa,#f8fafff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.15);box-shadow:0 8px 32px #1e40af1f,0 2px 8px #fbbf2414}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.class-info-card{display:flex;gap:2rem;padding:1.5rem;background:linear-gradient(135deg,#1e40af0d,#fbbf240d);border-radius:16px;margin-bottom:2rem;border:1px solid rgba(30,64,175,.1)}.class-info-item{display:flex;align-items:center;gap:.75rem}.class-info-label{font-size:.875rem;color:#64748b;font-weight:500}.class-info-value{font-size:1rem;color:#1e293b;font-weight:600}.shift-badge{padding:.375rem .875rem;border-radius:12px;font-size:.875rem;font-weight:600}.shift-badge--morning{background:linear-gradient(135deg,#3b82f626,#2563eb26);color:#2563eb;border:1px solid rgba(59,130,246,.3)}.shift-badge--afternoon{background:linear-gradient(135deg,#fbbf2426,#f59e0b26);color:#d97706;border:1px solid rgba(251,191,36,.3)}.periods-section{margin-bottom:2rem}.periods-section label{display:block;font-size:.875rem;font-weight:600;color:#1e293b;margin-bottom:1rem}.periods-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.period-card{padding:1.25rem 1rem;background:#fff;border:2px solid rgba(30,64,175,.2);border-radius:16px;cursor:pointer;transition:all .3s;text-align:center}.period-card:hover{border-color:#1e40af;transform:translateY(-2px);box-shadow:0 4px 12px #1e40af26}.period-card--active{background:linear-gradient(135deg,#1e40af,#3b82f6);border-color:#1e40af;color:#fff;box-shadow:0 4px 16px #1e40af4d}.period-card--active .period-card__number,.period-card--active .period-card__time{color:#fff}.period-card__number{font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.period-card__time{font-size:.875rem;color:#64748b;font-weight:500}.students-attendance-section{margin-top:2rem}.students-attendance-section h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.attendance-table-wrapper{overflow-x:auto;margin-bottom:1.5rem;border-radius:12px;border:1px solid rgba(30,64,175,.1)}.attendance-table{width:100%;border-collapse:collapse;background:#fff}.attendance-table thead{background:linear-gradient(135deg,#1e40af1a,#3b82f61a)}.attendance-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#1e293b;text-transform:uppercase;letter-spacing:.05em}.attendance-table td{padding:1rem;border-top:1px solid rgba(226,232,240,.5)}.attendance-table tbody tr:hover{background:#f8fafc80}.student-info-attendance{display:flex;align-items:center;gap:.75rem}.student-avatar-attendance{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.student-avatar-attendance img{width:100%;height:100%;object-fit:cover;border-radius:10px}.status-select{padding:.5rem .75rem;border:2px solid rgba(30,64,175,.2);border-radius:8px;font-size:.875rem;background:#fff;cursor:pointer;transition:all .2s}.status-select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.btn-modern{padding:.875rem 1.75rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-modern--full{width:100%}@media(max-width:768px){.take-attendance-page{padding:1rem}.form-row{grid-template-columns:1fr}.class-info-card{flex-direction:column;gap:1rem}.periods-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.attendance-reports-page{max-width:1400px;margin:0 auto;padding:2rem}.attendance-reports-page__header{margin-bottom:2rem}.attendance-reports-page__header h2{font-size:2rem;font-weight:700;color:#0f172a;margin:0 0 .5rem;background:linear-gradient(135deg,#1e40af,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.attendance-reports-page__header p{font-size:1rem;color:#64748b;margin:0}.reports-search-card,.reports-results-card{background:linear-gradient(135deg,#fffffffa,#f8fafff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:2rem;border:2px solid rgba(30,64,175,.15);box-shadow:0 8px 32px #1e40af1f,0 2px 8px #fbbf2414;margin-bottom:2rem}.reports-search-card h3,.reports-results-card h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 1.5rem}.search-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#1e293b}.form-group select,.form-group input[type=date]{padding:.875rem 1rem;border:2px solid rgba(30,64,175,.2);border-radius:12px;font-size:1rem;background:#fff;transition:all .3s}.form-group select:focus,.form-group input[type=date]:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.btn-modern{padding:.875rem 1.75rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;align-self:flex-start}.btn-modern--primary{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;box-shadow:0 4px 12px #1e40af4d}.btn-modern--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #1e40af66}.btn-modern--primary:disabled{opacity:.6;cursor:not-allowed}.attendance-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:#fff;padding:1.5rem;border-radius:16px;border:2px solid rgba(30,64,175,.1);text-align:center;transition:all .3s}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #1e40af26;border-color:#1e40af4d}.summary-card--rate{background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-color:#1e40af4d}.summary-label{font-size:.875rem;color:#64748b;font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:2rem;font-weight:800;color:#0f172a}.summary-value--present{color:#10b981}.summary-value--late{color:#f59e0b}.summary-value--absent{color:#ef4444}.summary-value--excused{color:#8b5cf6}.summary-value--rate{background:linear-gradient(135deg,#1e40af,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.attendance-table-section{margin-top:2rem}.attendance-table-section h4{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid rgba(30,64,175,.1)}.reports-table{width:100%;border-collapse:collapse;background:#fff}.reports-table thead{background:linear-gradient(135deg,#1e40af1a,#3b82f61a)}.reports-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#1e293b;text-transform:uppercase;letter-spacing:.05em}.reports-table td{padding:1rem;border-top:1px solid rgba(226,232,240,.5);font-size:.875rem;color:#1e293b}.reports-table tbody tr:hover{background:#f8fafc80}.status-badge{display:inline-block;padding:.375rem .875rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.no-results{text-align:center;padding:3rem 1.5rem;color:#94a3b8}.no-results p{font-size:1rem;margin:0}@media(max-width:768px){.attendance-reports-page{padding:1rem}.form-row{grid-template-columns:1fr}.attendance-summary{grid-template-columns:repeat(2,1fr)}}.notices-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.notices-page-modern__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.notices-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.notices-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.notices-page-modern__list{display:flex;flex-direction:column;gap:1.5rem}.notice-card-modern{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14;transition:all .3s ease;position:relative;overflow:hidden}.notice-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--priority-color, #3b82f6)}.notice-card-modern:hover{transform:translate(4px);box-shadow:0 8px 24px #1e40af26}.notice-card-modern__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.notice-card-modern__priority{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:rgba(var(--priority-color-rgb, 59, 130, 246),.1);border-radius:8px;font-size:.8125rem;font-weight:600;color:var(--priority-color, #3b82f6)}.priority-dot{width:8px;height:8px;border-radius:50%;background:var(--priority-color, #3b82f6)}.notice-card-modern__actions{display:flex;gap:.5rem}.notice-card-modern__content h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.notice-card-modern__content p{color:#475569;line-height:1.6;margin:0 0 1rem}.notice-card-modern__meta{display:flex;gap:1rem;font-size:.8125rem;color:#94a3b8;padding-top:1rem;border-top:1px solid rgba(226,232,240,.8)}.notices-page-modern__empty{text-align:center;padding:4rem 2rem;color:#64748b}.notices-page-modern__empty svg{margin-bottom:1rem;opacity:.5}.notices-page-modern__empty p{font-size:1.125rem;margin:0 0 1.5rem}.marks-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.marks-page-modern__header{margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.marks-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.marks-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.marks-page-modern__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.exam-card-modern{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14;transition:all .3s ease;position:relative;overflow:hidden}.exam-card-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#fbbf24,#f59e0b)}.exam-card-modern:hover{transform:translateY(-4px);box-shadow:0 8px 24px #1e40af26}.exam-card-modern__icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);display:flex;align-items:center;justify-content:center;color:#f59e0b;margin-bottom:1rem}.exam-card-modern__content h3{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.exam-card-modern__date{color:#64748b;font-size:.875rem;margin:0 0 1rem}.subject-badge-modern,.class-badge-modern{display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);color:#1e40af;border-radius:8px;font-size:.8125rem;font-weight:600;margin-right:.5rem;margin-bottom:.5rem}.marks-table-wrapper{padding:1.75rem}.marks-table-modern{width:100%;border-collapse:collapse}.marks-table-modern thead{background:linear-gradient(135deg,#1e40af0d,#3b82f60d)}.marks-table-modern th{padding:1rem;text-align:left;font-weight:700;color:#1e293b;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.marks-table-modern td{padding:1rem;border-bottom:1px solid rgba(226,232,240,.8);color:#475569}.marks-value{font-weight:700;color:#1e40af;font-size:1.125rem}.grade-badge{display:inline-block;padding:.375rem .75rem;border-radius:8px;font-weight:700;font-size:.875rem}.grade-badge--a{background:#10b9811a;color:#10b981}.grade-badge--b{background:#3b82f61a;color:#3b82f6}.grade-badge--c{background:#fbbf241a;color:#fbbf24}.grade-badge--d,.grade-badge--f{background:#ef44441a;color:#ef4444}.marks-empty{text-align:center;padding:3rem;color:#64748b}.modal-content--large{max-width:800px}.marks-page-modern__content{display:flex;flex-direction:column;gap:1.5rem}.form-card-modern{background:#fff;border-radius:16px;padding:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14}.exam-info-card{background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:12px;padding:1.5rem;margin:1.5rem 0;border:1px solid rgba(30,64,175,.1)}.exam-info-card h3{margin:0 0 1rem;color:#1e40af;font-size:1.25rem}.exam-info-details{display:flex;flex-wrap:wrap;gap:1rem}.exam-info-details span{font-size:.9rem;color:#475569}.marks-input{width:100%;padding:.5rem;border:2px solid rgba(226,232,240,.8);border-radius:8px;font-size:.9375rem;transition:all .2s}.marks-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{margin-top:1.5rem;display:flex;justify-content:flex-end}.exam-marks-list{display:flex;flex-direction:column;gap:1.5rem}.exam-marks-card{background:#fff;border-radius:16px;padding:2rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14}.exam-marks-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(226,232,240,.8)}.exam-marks-card__header h3{margin:0 0 .5rem;color:#1e40af;font-size:1.5rem}.exam-marks-card__meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.9rem;color:#64748b}.empty-subtitle{font-size:.9rem;color:#94a3b8;margin-top:.5rem}.marks-page-modern__loading{text-align:center;padding:3rem;color:#64748b;font-size:1.1rem}.student-attendance{padding:2rem;max-width:1400px;margin:0 auto}.student-attendance__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.student-attendance__title{display:flex;align-items:center;gap:1rem}.student-attendance__title svg{color:#3b82f6}.student-attendance__title h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0}.student-attendance__filters{display:flex;gap:.75rem}.student-attendance__select{padding:.625rem 1rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:.9375rem;font-weight:600;color:#334155;background:#fff;cursor:pointer;transition:all .2s}.student-attendance__select:hover{border-color:#3b82f6}.student-attendance__select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.student-attendance__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.attendance-stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:1rem;border:2px solid #e2e8f0;transition:all .3s}.attendance-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000014}.attendance-stat-card__icon{width:56px;height:56px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0}.attendance-stat-card__content{flex:1}.attendance-stat-card__label{font-size:.875rem;color:#64748b;margin:0 0 .25rem;font-weight:600}.attendance-stat-card__value{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0}.student-attendance__calendar{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:2rem;margin-bottom:2rem}.calendar-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-header{padding:.75rem;text-align:center;font-weight:700;color:#64748b;font-size:.875rem;background:#f8fafc;border-radius:.5rem}.calendar-day{aspect-ratio:1;padding:.5rem;border:2px solid #e2e8f0;border-radius:.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;background:#fff;transition:all .2s;position:relative}.calendar-day--empty{border-color:transparent;background:#f8fafc}.calendar-day--today{border-color:#3b82f6;background:#eff6ff}.calendar-day--has-record:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000001a;z-index:10}.calendar-day__number{font-size:.875rem;font-weight:600;color:#334155}.calendar-day__status{font-size:1.125rem;font-weight:700}.student-attendance__list{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:2rem;margin-bottom:2rem}.list-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.attendance-records{display:flex;flex-direction:column;gap:.75rem}.attendance-record{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:.75rem;border:2px solid #e2e8f0;transition:all .2s}.attendance-record:hover{background:#f1f5f9;transform:translate(4px)}.attendance-record__icon{width:48px;height:48px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.attendance-record__info{flex:1}.attendance-record__date{font-weight:600;color:#1e293b;font-size:.9375rem}.attendance-record__remarks{font-size:.8125rem;color:#64748b;margin-top:.25rem}.attendance-record__status{padding:.5rem 1rem;border-radius:.5rem;font-weight:700;font-size:.875rem;text-transform:uppercase}.attendance-records__empty{text-align:center;padding:3rem;color:#94a3b8}.attendance-records__empty svg{width:64px;height:64px;margin-bottom:1rem;opacity:.5}.attendance-records__empty p{font-size:1rem;margin:0}.student-attendance__legend{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:1.5rem}.student-attendance__legend h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.legend-item span:last-child{font-size:.875rem;color:#64748b;font-weight:600}.student-attendance__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b8}@media(max-width:768px){.student-attendance{padding:1rem}.student-attendance__header{flex-direction:column;align-items:flex-start}.student-attendance__stats{grid-template-columns:1fr}.calendar-grid{gap:.25rem}.calendar-day{padding:.25rem}.calendar-day__number{font-size:.75rem}.calendar-day__status{font-size:.875rem}}.student-marks{padding:2rem;max-width:1600px;margin:0 auto}.student-marks__header{margin-bottom:2rem}.student-marks__title{display:flex;align-items:center;gap:1rem}.student-marks__title svg{color:#8b5cf6}.student-marks__title h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0}.student-marks__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.marks-stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:1rem;border:2px solid #e2e8f0;transition:all .3s}.marks-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000014}.marks-stat-card__icon{width:56px;height:56px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0}.marks-stat-card__content{flex:1}.marks-stat-card__label{font-size:.875rem;color:#64748b;margin:0 0 .25rem;font-weight:600}.marks-stat-card__value{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0}.student-marks__table-container{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:2rem;margin-bottom:2rem;overflow:hidden}.table-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 1.5rem}.marks-table-wrapper{overflow-x:auto;border-radius:.75rem;border:2px solid #e2e8f0}.marks-table{width:100%;border-collapse:collapse;background:#fff;font-size:.875rem}.marks-table__header{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;padding:1rem .75rem;text-align:center;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.1);white-space:nowrap}.marks-table__header:first-child{text-align:left;position:sticky;left:0;z-index:10;min-width:150px}.marks-table__header--exam{background:linear-gradient(135deg,#8b5cf6,#a78bfa);min-width:120px}.marks-table__header--total{background:linear-gradient(135deg,#f59e0b,#fbbf24);min-width:100px}.marks-table__header--percentage{background:linear-gradient(135deg,#10b981,#34d399);min-width:120px}.marks-table__header--status{background:linear-gradient(135deg,#ef4444,#f87171);min-width:140px}.marks-table__row{transition:all .2s}.marks-table__row:nth-child(2n){background:#f8fafc}.marks-table__row:hover{background:#eff6ff;transform:scale(1.01)}.marks-table__cell{padding:1rem .75rem;text-align:center;border:1px solid #e2e8f0}.marks-table__cell--subject{text-align:left;font-weight:600;color:#1e293b;position:sticky;left:0;background:inherit;z-index:5;min-width:150px}.marks-table__row:nth-child(2n) .marks-table__cell--subject{background:#f8fafc}.marks-table__row:hover .marks-table__cell--subject{background:#eff6ff}.subject-name{font-size:.9375rem;line-height:1.4}.marks-table__cell--exam{font-weight:600}.exam-mark{font-size:1.125rem;font-weight:700;color:#1e293b}.exam-mark--empty{color:#cbd5e1}.exam-max{font-size:.75rem;color:#94a3b8;margin-left:2px}.marks-table__cell--total{font-weight:700}.total-marks{font-size:1.25rem;font-weight:700;color:#f59e0b}.total-max{font-size:.8125rem;color:#94a3b8;margin-left:2px}.marks-table__cell--percentage{padding:.5rem}.percentage-badge{display:inline-block;padding:.5rem 1rem;border-radius:.5rem;color:#fff;font-weight:700;font-size:.9375rem;min-width:70px}.percentage-badge--large{padding:.625rem 1.25rem;font-size:1.125rem;min-width:80px}.marks-table__cell--status{padding:.5rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;color:#fff;font-weight:700;font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.status-badge svg{width:16px;height:16px}.status-badge--large{padding:.625rem 1.25rem;font-size:.875rem}.status-badge--large svg{width:18px;height:18px}.marks-table__footer{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;font-weight:700}.marks-table__footer td{padding:1.25rem .75rem;border:1px solid rgba(255,255,255,.1)}.marks-table__footer-label{text-align:left;font-size:1rem;text-transform:uppercase;letter-spacing:.5px}.marks-table__footer-total{text-align:center;font-size:1.125rem;color:#fbbf24}.marks-table__footer-percentage,.marks-table__footer-status{text-align:center}.marks-table__empty{text-align:center;padding:4rem 2rem;color:#94a3b8}.marks-table__empty svg{width:80px;height:80px;margin-bottom:1.5rem;opacity:.5}.marks-table__empty p{font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.marks-table__empty small{font-size:.875rem;color:#cbd5e1}.student-marks__legend{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:1.5rem}.student-marks__legend h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem}.grade-scale{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem}.grade-item{display:flex;align-items:center;gap:.5rem}.grade-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.grade-label{font-size:.875rem;color:#64748b;font-weight:600}.grade-note{margin:1rem 0 0;padding:.75rem 1rem;background:#f8fafc;border-radius:.5rem;font-size:.875rem;color:#64748b;border-left:4px solid #3b82f6}.student-marks__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b8}@media(max-width:1200px){.marks-table{font-size:.8125rem}.marks-table__header{padding:.75rem .5rem;font-size:.75rem}.marks-table__cell{padding:.75rem .5rem}.exam-mark{font-size:1rem}.total-marks{font-size:1.125rem}.percentage-badge{padding:.375rem .75rem;font-size:.8125rem}.status-badge{padding:.375rem .75rem;font-size:.75rem}}@media(max-width:768px){.student-marks{padding:1rem}.student-marks__stats{grid-template-columns:1fr}.student-marks__table-container{padding:1rem}.marks-table-wrapper{border-radius:.5rem}.marks-table{font-size:.75rem}.marks-table__header{padding:.5rem .25rem;font-size:.6875rem}.marks-table__cell{padding:.5rem .25rem}.marks-table__cell--subject{min-width:100px}.subject-name{font-size:.8125rem}.exam-mark{font-size:.875rem}.total-marks{font-size:1rem}.percentage-badge{padding:.25rem .5rem;font-size:.75rem;min-width:50px}.status-badge{padding:.25rem .5rem;font-size:.6875rem}.status-badge svg{width:12px;height:12px}.grade-scale{flex-direction:column;gap:.75rem}}@media print{.student-marks__header,.student-marks__legend{display:none}.marks-table{page-break-inside:avoid}.marks-table__row:hover{transform:none}}.student-notices{padding:2rem;max-width:1400px;margin:0 auto}.student-notices__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.student-notices__title{display:flex;align-items:center;gap:1rem}.student-notices__title svg{color:#8b5cf6}.student-notices__title h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0}.btn-send-notice{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border:none;border-radius:.75rem;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #8b5cf64d}.btn-send-notice:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.btn-send-notice:active{transform:translateY(0)}.notices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.notice-card{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:1.5rem;transition:all .3s;display:flex;flex-direction:column;gap:1rem}.notice-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000014;border-color:#8b5cf6}.notice-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.notice-card__title{font-size:1.125rem;font-weight:700;color:#1e293b;line-height:1.4;flex:1}.notice-card__priority{padding:.25rem .75rem;border-radius:.375rem;color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.notice-card__content{color:#64748b;line-height:1.6;font-size:.9375rem}.notice-card__footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #e2e8f0;flex-wrap:wrap;gap:.75rem}.notice-card__meta{display:flex;flex-direction:column;gap:.25rem}.notice-card__date{font-size:.8125rem;color:#94a3b8;font-weight:600}.notice-card__author{font-size:.75rem;color:#cbd5e1}.notice-card__audience{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#f1f5f9;border-radius:.375rem;font-size:.75rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px}.notice-card__audience svg{width:14px;height:14px}.notices-empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#94a3b8}.notices-empty svg{width:80px;height:80px;margin-bottom:1.5rem;opacity:.5}.notices-empty p{font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.notices-empty small{font-size:.875rem;color:#cbd5e1}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:1rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e2e8f0}.modal-header h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.modal-close{width:36px;height:36px;border:none;background:#f1f5f9;border-radius:.5rem;font-size:1.5rem;color:#64748b;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-form{padding:1.5rem}.form-group label{display:block;font-weight:600;color:#334155;margin-bottom:.5rem;font-size:.9375rem}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:.9375rem;color:#1e293b;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.form-group input:disabled,.form-group textarea:disabled{background:#f8fafc;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:120px}.recipient-options{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s}.radio-option:hover{border-color:#8b5cf6;background:#faf5ff}.radio-option input[type=radio]{width:20px;height:20px;margin-top:2px;cursor:pointer;flex-shrink:0}.radio-option input[type=radio]:checked{accent-color:#8b5cf6}.radio-label{display:flex;flex-direction:column;gap:.25rem;flex:1}.radio-label strong{color:#1e293b;font-size:.9375rem}.radio-label small{color:#64748b;font-size:.8125rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:2px solid #e2e8f0}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:.5rem}.btn-secondary{background:#f1f5f9;color:#64748b}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.btn-secondary:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.student-notices__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b8}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media(max-width:768px){.student-notices{padding:1rem}.student-notices__header{flex-direction:column;align-items:stretch}.notices-grid{grid-template-columns:1fr}.modal-content{max-width:100%;border-radius:.5rem}.recipient-options{gap:.5rem}.radio-option{padding:.75rem}}.student-timetable{padding:2rem;max-width:1600px;margin:0 auto}.student-timetable__header{margin-bottom:2rem}.student-timetable__title{display:flex;align-items:center;gap:1rem}.student-timetable__title svg{color:#3b82f6;flex-shrink:0}.student-timetable__title h2{font-size:1.875rem;font-weight:700;color:#1e293b;margin:0}.class-name{font-size:.9375rem;color:#64748b;font-weight:600;margin:.25rem 0 0}.timetable-container{background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:2rem}.timetable-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.timetable-day{background:#f8fafc;border-radius:.75rem;overflow:hidden;border:2px solid #e2e8f0}.timetable-day__header{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;font-weight:700;font-size:.9375rem;text-transform:uppercase;letter-spacing:.5px}.timetable-day__header svg{width:18px;height:18px}.timetable-day__periods{padding:1rem;display:flex;flex-direction:column;gap:1rem}.timetable-day__empty{text-align:center;padding:2rem 1rem;color:#94a3b8;font-size:.875rem;font-style:italic}.period-card{padding:1rem;border-radius:.75rem;background:#fff;border:2px solid #e2e8f0;transition:all .3s}.period-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.period-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.period-number{font-weight:700;color:#1e293b;font-size:.875rem;background:#f1f5f9;padding:.25rem .75rem;border-radius:.375rem}.period-time{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#64748b;font-weight:600}.period-time svg{width:14px;height:14px}.period-card__subject{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.period-card__subject svg{width:18px;height:18px;color:#3b82f6}.period-card__teacher,.period-card__room{font-size:.8125rem;color:#64748b;margin-top:.375rem;padding-left:1.5rem}.timetable-empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#94a3b8}.timetable-empty svg{width:80px;height:80px;margin-bottom:1.5rem;opacity:.5}.timetable-empty p{font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.timetable-empty small{font-size:.875rem;color:#cbd5e1}.timetable-legend{margin-top:2rem;background:#fff;border-radius:1rem;border:2px solid #e2e8f0;padding:1.5rem}.timetable-legend h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.timetable-legend p{font-size:.875rem;color:#64748b;margin:0 0 1rem;line-height:1.5}.legend-items{display:flex;flex-wrap:wrap;gap:1.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b;font-weight:600}.legend-item svg{width:18px;height:18px;color:#3b82f6}.student-timetable__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b8}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.timetable-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media(max-width:768px){.student-timetable,.timetable-container{padding:1rem}.timetable-grid{grid-template-columns:1fr}.period-card__header{flex-direction:column;align-items:flex-start}.legend-items{flex-direction:column;gap:.75rem}}@media print{.timetable-legend{display:none}.period-card:hover{transform:none;box-shadow:none}}.timetable-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.timetable-page-modern__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.timetable-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.timetable-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.class-select-modern{padding:.75rem 1.5rem;border-radius:12px;border:2px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.class-select-modern:hover{background:#fff3}.class-select-modern:focus{outline:none;border-color:#fff;background:#fff3}.class-select-modern option{background:#1e40af;color:#fff}.timetable-card-modern{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 12px #1e40af14;border:2px solid rgba(30,64,175,.1)}.timetable-card-modern__header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(30,64,175,.1)}.timetable-card-modern__header{display:flex;justify-content:space-between;align-items:flex-start}.timetable-card-modern__header>div:first-child{flex:1}.timetable-card-modern__header h3{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.timetable-shift-badge{margin-top:.5rem}.shift-badge{display:inline-block;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.shift-badge--morning{background:linear-gradient(135deg,#fbbf2433,#f59e0b33);color:#d97706;border:1px solid rgba(251,191,36,.3)}.shift-badge--afternoon{background:linear-gradient(135deg,#8b5cf633,#7c3aed33);color:#7c3aed;border:1px solid rgba(139,92,246,.3)}.timetable-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid rgba(226,232,240,.8)}.timetable-table{width:100%;border-collapse:collapse;min-width:600px}.timetable-table thead{background:linear-gradient(135deg,#1e40af0d,#3b82f60d)}.timetable-table th{padding:1rem;text-align:center;font-weight:700;color:#1e293b;font-size:.875rem;text-transform:uppercase;border-right:1px solid rgba(226,232,240,.8)}.timetable-table th:last-child{border-right:none}.timetable-table td{padding:.75rem;border:1px solid rgba(226,232,240,.8);text-align:center;vertical-align:middle}.period-cell{font-weight:700;color:#1e40af;background:linear-gradient(135deg,#1e40af0d,#3b82f60d)}.timetable-cell{min-width:120px;height:80px}.timetable-entry{padding:.5rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-radius:8px;border:2px solid rgba(30,64,175,.2)}.timetable-entry__subject{font-weight:700;color:#1e40af;font-size:.875rem;margin-bottom:.25rem}.timetable-entry__teacher{font-size:.75rem;color:#64748b}.timetable-empty{color:#cbd5e1;font-size:.875rem}.timetable-page-modern__empty{text-align:center;padding:4rem 2rem;color:#64748b}.timetable-page-modern__empty svg{margin-bottom:1rem;opacity:.5}.timetable-page-modern__loading{text-align:center;padding:3rem;color:#64748b;font-size:1.1rem}.timetable-page-modern__content{display:flex;flex-direction:column;gap:1.5rem}.timetable-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.timetable-day{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14}.timetable-day__header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid rgba(226,232,240,.8)}.timetable-day__header h3{margin:0;color:#1e40af;font-size:1.25rem;font-weight:700}.timetable-day__entries{display:flex;flex-direction:column;gap:.75rem}.timetable-entry{padding:1rem;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);border-radius:12px;border:1px solid rgba(30,64,175,.1);transition:all .2s}.timetable-entry:hover{transform:translate(4px);box-shadow:0 4px 12px #1e40af26}.timetable-entry__time{font-size:.875rem;color:#64748b;margin-bottom:.5rem;font-weight:600}.timetable-entry__subject{font-weight:700;color:#1e40af;font-size:1rem;margin-bottom:.25rem}.timetable-entry__class{font-size:.875rem;color:#64748b}.timetable-day__empty{text-align:center;padding:2rem;color:#94a3b8;font-style:italic}.timetable-hint{font-size:.875rem;color:#64748b;margin-top:.5rem;font-style:italic}.period-cell{font-weight:700;color:#1e40af;background:linear-gradient(135deg,#1e40af0d,#3b82f60d);min-width:100px}.period-number{font-size:1rem;font-weight:800;margin-bottom:.25rem}.period-time{font-size:.75rem;color:#64748b;font-weight:500}.timetable-cell--clickable{cursor:pointer;transition:all .2s}.timetable-cell--clickable:hover{background:#1e40af0d}.timetable-entry{padding:.5rem;background:linear-gradient(135deg,#1e40af1a,#3b82f61a);border-radius:8px;border:2px solid rgba(30,64,175,.2);position:relative}.timetable-entry__delete{position:absolute;top:.25rem;right:.25rem;width:20px;height:20px;border-radius:50%;border:none;background:#ef44441a;color:#dc2626;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;transition:all .2s;padding:0}.timetable-entry__delete:hover{background:#ef444433;transform:scale(1.1)}.timetable-empty{color:#cbd5e1;font-size:.875rem;font-style:italic}.timetable-break-row{background:linear-gradient(135deg,#fbbf240d,#f59e0b0d)}.timetable-break-cell{background:linear-gradient(135deg,#fbbf241a,#f59e0b1a)}.timetable-break-label{color:#d97706;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.timetable-cell--break{background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);cursor:default;text-align:center}.timetable-cell--break:hover{background:linear-gradient(135deg,#fbbf2426,#f59e0b26)}.timetable-break{color:#d97706;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.timetable-modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid rgba(30,64,175,.1)}.modal-header h3{margin:0;font-size:1.5rem;font-weight:700;color:#1e293b}.modal-close{background:none;border:none;font-size:2rem;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:#ef44441a;color:#dc2626}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:2px solid rgba(30,64,175,.1)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#1e293b;font-size:.9375rem}.form-group select{width:100%;padding:.75rem;border:2px solid rgba(30,64,175,.2);border-radius:8px;font-size:1rem;transition:all .2s;background:#fff}.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group select:disabled{background:#f1f5f9;cursor:not-allowed}.error-message{padding:.75rem;background:#ef44441a;color:#dc2626;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.btn-modern{padding:.75rem 1.5rem;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-modern--primary{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff}.btn-modern--primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1e40af4d}.btn-modern--secondary{background:#f1f5f9;color:#64748b}.btn-modern--secondary:hover{background:#e2e8f0}.messages-page-modern{padding:2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.messages-page-modern__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:20px;color:#fff;box-shadow:0 8px 24px #1e40af4d}.messages-page-modern__header h2{font-size:2rem;font-weight:800;margin:0 0 .5rem}.messages-page-modern__header p{margin:0;opacity:.9;font-size:1rem}.messages-page-modern__list{display:flex;flex-direction:column;gap:1rem}.message-card-modern{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid rgba(30,64,175,.1);box-shadow:0 4px 12px #1e40af14;transition:all .3s ease}.message-card-modern:hover{transform:translate(4px);box-shadow:0 8px 24px #1e40af26}.message-card-modern__header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.message-card-modern__avatar{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;flex-shrink:0}.message-card-modern__info{flex:1}.message-card-modern__info h4{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:#1e293b}.message-card-modern__info p{margin:0;font-size:.875rem;color:#64748b}.message-card-modern__role{font-size:.85rem;color:#64748b;text-transform:capitalize}.messages-page-modern__loading{text-align:center;padding:3rem;color:#64748b;font-size:1.1rem}.message-card-modern__date{font-size:.8125rem;color:#94a3b8}.message-card-modern__content{color:#475569;line-height:1.6;padding-top:1rem;border-top:1px solid rgba(226,232,240,.8)}.messages-page-modern__empty{text-align:center;padding:4rem 2rem;color:#64748b}.messages-page-modern__empty svg{margin-bottom:1rem;opacity:.5}.form-group textarea{width:100%;padding:.75rem;border:2px solid rgba(226,232,240,.8);border-radius:12px;font-size:.9375rem;font-family:inherit;resize:vertical;transition:all .2s}.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}
