@import"https://fonts.googleapis.com/css2?family=Lexend:wght@400;600;700;800&display=swap";:root{--gi-bg: #ffffff;--gi-surface: #f8fafc;--gi-surface-2: #f1f5f9;--gi-text: #0f172a;--gi-muted: #475569;--gi-line: #e2e8f0;--gi-primary: #2563eb;--gi-primary-dark: #1d4ed8;--gi-shadow-sm: 0 10px 30px rgba(15, 23, 42, .06);--gi-shadow-md: 0 18px 40px rgba(15, 23, 42, .08);--gi-radius-lg: 24px;--gi-radius-md: 18px;--gi-radius-sm: 14px;--gi-nav-h: 88px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{overflow:hidden}:root{--gi-bg: #ffffff;--gi-surface: #f8fafc;--gi-surface-2: #f1f5f9;--gi-text: #0f172a;--gi-muted: #475569;--gi-line: #e2e8f0;--gi-primary: #2563eb;--gi-primary-dark: #1d4ed8;--gi-shadow-sm: 0 10px 30px rgba(15, 23, 42, .06);--gi-shadow-md: 0 18px 40px rgba(15, 23, 42, .08);--gi-radius-lg: 24px;--gi-radius-md: 18px;--gi-radius-sm: 14px;--gi-section-pad: clamp(72px, 8vw, 112px)}html,body,#root{min-height:100%;margin:0;padding:0}html{scroll-behavior:smooth}body{overflow-x:hidden;overflow-y:auto}.gi-landing-page{min-height:100vh;background:var(--gi-bg);color:var(--gi-text);font-family:Inter,sans-serif;overflow-x:hidden}.gi-landing__main{margin-top:var(--gi-nav-h);width:100%}.gi-landing__container{width:min(1200px,calc(100% - 32px));margin:0 auto}.gi-landing__hero,.gi-landing__overview,.gi-landing__features,.gi-landing__download{width:100%;box-sizing:border-box;scroll-margin-top:calc(var(--gi-nav-h) + 12px)}.gi-landing__section-head{max-width:760px;margin:0 auto 2.5rem;text-align:center;position:relative;z-index:2}.gi-landing__eyebrow{margin:0 0 .9rem;font-size:.9rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gi-primary)}.gi-landing__section-title{margin:0 0 1rem;font-size:clamp(2rem,4vw,3.3rem);line-height:1.08;font-weight:800;color:var(--gi-text)}.gi-landing__section-text{margin:0;font-size:1.02rem;line-height:1.8;color:var(--gi-muted)}.gi-landing__section-text--center{max-width:720px;margin-inline:auto}.gi-landing__hero{min-height:calc(100vh - var(--gi-nav-h));display:flex;align-items:center;padding:32px 0;background:radial-gradient(circle at top center,rgba(37,99,235,.06),transparent 28%),#fff}.gi-landing__hero-shell{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--gi-nav-h) - 64px)}.gi-landing__hero-content{width:min(900px,100%);margin:0 auto;text-align:center}.gi-landing__badge{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .95rem;margin-bottom:1.25rem;border-radius:999px;background:#2563eb14;border:1px solid rgba(37,99,235,.12);color:var(--gi-primary);font-size:.85rem;font-weight:700;letter-spacing:.04em}.gi-landing__hero-title{margin:0 0 1.35rem;font-size:clamp(2.5rem,6vw,4.9rem);line-height:1.02;font-weight:900;letter-spacing:-.03em;color:var(--gi-text);max-width:920px;margin-inline:auto}.gi-landing__hero-subtitle{max-width:760px;margin:0 auto 2rem;font-size:1.08rem;line-height:1.85;color:var(--gi-muted)}.gi-landing__hero-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.35rem}.gi-landing__highlight-main{color:#2563eb;font-weight:800}.gi-landing__highlight-light{color:#59b3fc;font-weight:800}.gi-landing__highlight-orange{color:#2563eb;font-weight:800}.gi-landing__highlight-main,.gi-landing__highlight-light,.gi-landing__highlight-orange{display:inline-block;opacity:0;transform:translateY(10px);animation:giWordFadeUp .6s ease forwards}.gi-landing__highlight-main{animation-delay:.1s}.gi-landing__highlight-light{animation-delay:.25s}.gi-landing__highlight-orange:nth-of-type(1){animation-delay:.4s}.gi-landing__highlight-orange:nth-of-type(2){animation-delay:.55s}@keyframes giWordFadeUp{to{opacity:1;transform:translateY(0)}}.gi-landing__btn{display:inline-flex;align-items:center;justify-content:center;gap:.7rem;min-width:180px;padding:.95rem 1.4rem;border-radius:16px;font-size:.98rem;font-weight:700;text-decoration:none;box-sizing:border-box;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease}.gi-landing__btn:hover{transform:translateY(-2px)}.gi-landing__btn--primary{background:var(--gi-primary);color:#fff;box-shadow:0 8px 20px #2563eb38}.gi-landing__btn--primary:hover{background:var(--gi-primary-dark);box-shadow:0 14px 26px #2563eb42}.gi-landing__btn--secondary{background:#fff;color:var(--gi-text);border:1px solid var(--gi-line);box-shadow:var(--gi-shadow-sm)}.gi-landing__btn--secondary:hover{box-shadow:var(--gi-shadow-md)}.gi-landing__hero-note{margin:0;font-size:.96rem;color:#64748b}.gi-landing__scroll-cue{margin-top:2rem;border:none;background:transparent;color:var(--gi-primary);font:inherit;font-weight:700;display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;transition:transform .25s ease,opacity .25s ease}.gi-landing__scroll-cue:hover{transform:translateY(2px);opacity:.85}.gi-landing__scroll-cue i{animation:giBounceDown 1.4s infinite}@keyframes giBounceDown{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.gi-landing__overview{padding:var(--gi-section-pad) 0;background:#fff;position:relative;z-index:1;scroll-margin-top:calc(var(--gi-nav-h) + 16px)}.gi-landing__overview-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,500px);gap:clamp(24px,4vw,56px);align-items:center}.gi-landing__overview-copy{min-width:0}.gi-landing__overview-card-list{display:grid;gap:1rem;margin-top:1.6rem;max-width:620px}.gi-landing__overview-mini-card{display:grid;grid-template-columns:56px 1fr;gap:1rem;align-items:start;padding:1rem 1.1rem;background:#fff;border:1px solid var(--gi-line);border-radius:18px;box-shadow:var(--gi-shadow-sm);transition:transform .25s ease,box-shadow .25s ease}.gi-landing__overview-mini-card:hover{transform:translateY(-3px);box-shadow:var(--gi-shadow-md)}.gi-landing__overview-mini-icon{width:56px;height:56px;display:grid;place-items:center;border-radius:16px;background:#2563eb1a;color:var(--gi-primary);font-size:1.15rem}.gi-landing__overview-mini-card h3{margin:0 0 .45rem;font-size:1.05rem;font-weight:800;color:var(--gi-text)}.gi-landing__overview-mini-card p{margin:0;font-size:.95rem;line-height:1.7;color:var(--gi-muted)}.gi-landing__phone-wrap{position:relative;display:flex;align-items:center;justify-content:center;min-height:620px;isolation:isolate}.gi-landing__phone-glow{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.22),transparent 70%);filter:blur(18px);animation:giPulseGlow 4s ease-in-out infinite;z-index:0}@keyframes giPulseGlow{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.12);opacity:1}}.gi-landing__phone{position:relative;width:min(320px,100%);aspect-ratio:9 / 19;background:linear-gradient(180deg,#111827,#020617);border-radius:38px;padding:12px;box-shadow:0 30px 60px #0f172a38,0 10px 25px #0f172a24;z-index:2;animation:giPhoneFloat 5s ease-in-out infinite,giTilt 6s ease-in-out infinite}@keyframes giPhoneFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes giTilt{0%,to{transform:rotate(0)}50%{transform:rotate(1.2deg)}}.gi-landing__phone-notch{position:absolute;top:10px;left:50%;transform:translate(-50%);width:34%;height:22px;border-radius:999px;background:#0f172a;z-index:3}.gi-landing__phone-screen{width:100%;height:100%;object-fit:cover;border-radius:30px;display:block;background:#fff}.gi-landing__venn{position:absolute;pointer-events:none;z-index:1;opacity:0;transform-origin:center center;animation:giVennReveal .95s cubic-bezier(.2,.8,.2,1) forwards;filter:drop-shadow(0 24px 50px rgba(37,99,235,.18))}.gi-landing__venn--right{width:clamp(250px,30vw,410px);height:clamp(280px,36vw,460px);right:0;top:50%;transform:translateY(-50%) scale(.88)}.gi-landing__venn-float{position:relative;width:100%;height:100%;animation:giVennFloat 7s ease-in-out 1s infinite}.gi-landing__venn--right:before{content:"";position:absolute;inset:10% 6% 6%;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.22) 0%,rgba(37,99,235,.12) 38%,rgba(37,99,235,.04) 60%,transparent 78%);filter:blur(30px);z-index:-2}.gi-landing__venn--right:after{content:"";position:absolute;width:72%;height:72%;left:18%;top:18%;border-radius:50%;background:radial-gradient(circle at center,rgba(96,165,250,.16) 0%,rgba(59,130,246,.08) 45%,transparent 75%);filter:blur(22px);z-index:-1}.gi-landing__venn-circle{position:absolute;border-radius:50%;overflow:hidden;opacity:0;transform:scale(.72);border:1px solid rgba(255,255,255,.22);box-shadow:inset 0 1px #ffffff47,inset 0 -16px 32px #0a183e2e,0 18px 40px #2563eb2e,0 0 0 1px #2563eb0f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.gi-landing__venn-circle:before{content:"";position:absolute;inset:7%;border-radius:50%;background:radial-gradient(circle at 30% 28%,rgba(255,255,255,.46) 0%,rgba(255,255,255,.18) 22%,rgba(255,255,255,.06) 40%,transparent 68%);mix-blend-mode:screen}.gi-landing__venn-circle:after{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 70% 72%,rgba(255,255,255,.12),transparent 34%),radial-gradient(circle at center,transparent 54%,rgba(8,18,48,.12) 100%)}.gi-landing__venn-circle--1{width:clamp(150px,18vw,210px);height:clamp(150px,18vw,210px);top:0;left:105px;background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.38) 0%,rgba(255,255,255,.1) 18%,transparent 42%),linear-gradient(145deg,#7dadfff5,#3b82f6f0 52%,#1d4ed8fa);animation:giCirclePop .72s cubic-bezier(.18,.9,.2,1) .15s forwards}.gi-landing__venn-circle--2{width:clamp(210px,25vw,295px);height:clamp(210px,25vw,295px);top:94px;left:92px;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.34) 0%,rgba(255,255,255,.09) 18%,transparent 42%),linear-gradient(145deg,#6fa7fffa,#2563ebf2,#1e40affa);animation:giCirclePop .78s cubic-bezier(.18,.9,.2,1) .3s forwards}.gi-landing__venn-circle--3{width:clamp(170px,20vw,235px);height:clamp(170px,20vw,235px);top:260px;left:46px;background:radial-gradient(circle at 35% 32%,rgba(255,255,255,.34) 0%,rgba(255,255,255,.08) 20%,transparent 42%),linear-gradient(145deg,#61b3fff5,#2563ebed 54%,#0891b2f2);animation:giCirclePop .76s cubic-bezier(.18,.9,.2,1) .45s forwards}@keyframes giVennReveal{0%{opacity:0;transform:translateY(-50%) scale(.82)}60%{opacity:1;transform:translateY(-50%) scale(1.04)}to{opacity:1;transform:translateY(-50%) scale(1)}}@keyframes giCirclePop{0%{opacity:0;transform:scale(.72)}65%{opacity:1;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes giVennFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.gi-landing__features{padding:var(--gi-section-pad) 0;background:var(--gi-surface);position:relative;z-index:2;scroll-margin-top:calc(var(--gi-nav-h) + 16px)}.gi-landing__feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem}.gi-landing__feature-card{padding:1.6rem;border-radius:var(--gi-radius-lg);background:#fff;border:1px solid var(--gi-line);box-shadow:var(--gi-shadow-sm);transition:transform .25s ease,box-shadow .25s ease;min-height:220px}.gi-landing__feature-card:hover{transform:translateY(-4px);box-shadow:var(--gi-shadow-md)}.gi-landing__feature-icon{width:54px;height:54px;display:grid;place-items:center;border-radius:16px;margin-bottom:1rem;background:linear-gradient(135deg,#2563eb1f,#2563eb0f);color:var(--gi-primary);font-size:1.2rem}.gi-landing__feature-card h3{margin:0 0 .7rem;font-size:1.15rem;font-weight:800;color:var(--gi-text)}.gi-landing__feature-card p{margin:0;font-size:.96rem;line-height:1.75;color:var(--gi-muted)}.gi-landing__download{padding:var(--gi-section-pad) 0;background:#fff;scroll-margin-top:calc(var(--gi-nav-h) + 16px)}.gi-landing__download-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:1.5rem;margin-top:2.25rem}.gi-landing__download-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem;border-radius:26px;background:#fff;border:1px solid var(--gi-line);box-shadow:var(--gi-shadow-sm)}.gi-landing__download-icon{width:62px;height:62px;display:grid;place-items:center;border-radius:18px;margin-bottom:1rem;background:#2563eb1a;color:var(--gi-primary);font-size:1.5rem}.gi-landing__download-card h3{margin:0 0 1rem;font-size:1.25rem;font-weight:800;color:var(--gi-text)}.gi-landing__qr-image{width:170px;height:170px;object-fit:contain;margin-bottom:1rem}.gi-landing__download-link{margin:0;font-size:.97rem;color:var(--gi-muted)}.gi-landing__footer{background:#111;opacity:.9;color:#fff;border-top:1px solid rgba(255,255,255,.08);padding-top:3rem}.gi-landing__footer-main{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:2rem;padding-bottom:2rem}.gi-landing__footer-col{min-width:0}.gi-landing__footer-title{margin:0 0 .5rem;font-size:1.55rem;font-weight:800;color:#fff}.gi-landing__footer-subtitle{margin:0;font-size:.98rem;line-height:1.7;color:#cbd5e1}.gi-landing__footer-heading{margin:0 0 1rem;font-size:1rem;font-weight:800;color:#fff}.gi-landing__footer-links{display:grid;gap:.75rem}.gi-landing__footer-links button{border:none;background:transparent;color:#cbd5e1;padding:0;text-align:left;font:inherit;font-weight:600;cursor:pointer;transition:color .2s ease,transform .2s ease}.gi-landing__footer-links button:hover{color:#fff;transform:translate(4px)}.gi-landing__footer-socials{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.gi-landing__footer-socials a{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;text-decoration:none;color:#f8fafc;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);transition:transform .25s ease,background .25s ease,border-color .25s ease}.gi-landing__footer-socials a:hover{transform:translateY(-2px);background:#ffffff1a}.gi-landing__footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 0 1.5rem;border-top:1px solid rgba(255,255,255,.08)}.gi-landing__footer-copy{margin:0;font-size:.92rem;color:#94a3b8}.gi-landing__footer-bottom-right{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.gi-landing__footer-legal{color:#cbd5e1;text-decoration:none;font-size:.93rem;font-weight:600;transition:color .2s ease}.gi-landing__footer-legal:hover{color:#fff}.gi-landing__footer-top{display:inline-flex;align-items:center;gap:.55rem;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#f8fafc;padding:.8rem 1rem;border-radius:14px;cursor:pointer;font:inherit;font-weight:700;transition:transform .25s ease,background .25s ease,border-color .25s ease}.gi-landing__footer-top:hover{transform:translateY(-3px)}@media(max-width:1200px){.gi-landing__hero-title{font-size:clamp(2.5rem,5vw,4.2rem);max-width:780px}.gi-landing__overview-grid{grid-template-columns:minmax(0,1fr) minmax(280px,420px)}.gi-landing__phone-wrap{min-height:560px}.gi-landing__phone{width:min(290px,100%)}}@media(max-width:991px){.gi-landing__overview-grid{grid-template-columns:1fr;gap:32px}.gi-landing__overview-copy{text-align:center}.gi-landing__overview-card-list{margin:24px auto 0}.gi-landing__phone-wrap{min-height:500px}.gi-landing__feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gi-landing__download-grid{grid-template-columns:1fr}.gi-landing__footer-main{grid-template-columns:1fr;gap:2rem}.gi-landing__venn--right{width:290px;height:335px;right:50%;top:50%;transform:translate(50%,-50%) scale(.88)}@keyframes giVennReveal{0%{opacity:0;transform:translate(50%,-50%) scale(.82)}60%{opacity:1;transform:translate(50%,-50%) scale(1.04)}to{opacity:1;transform:translate(50%,-50%) scale(1)}}.gi-landing__venn-circle--1{width:142px;height:142px;left:85px;top:0}.gi-landing__venn-circle--2{width:195px;height:195px;left:74px;top:72px}.gi-landing__venn-circle--3{width:152px;height:152px;left:34px;top:190px}}@media(max-width:768px){.gi-landing__hero,.gi-landing__overview,.gi-landing__features,.gi-landing__download{padding:72px 0}.gi-landing__hero-shell{min-height:auto}.gi-landing__section-head{margin-bottom:2rem}.gi-landing__footer-main{text-align:center}.gi-landing__footer-col{display:flex;flex-direction:column;align-items:center}.gi-landing__footer-links{align-items:center}.gi-landing__footer-links button{text-align:center}.gi-landing__footer-bottom{flex-direction:column;align-items:center;gap:1rem}.gi-landing__footer-bottom-right{width:100%;justify-content:center}.gi-landing__venn--right{width:230px;height:260px;right:50%;top:52%;transform:translate(50%,-50%) scale(.9);opacity:.8}.gi-landing__venn-circle--1{width:108px;height:108px;left:70px;top:0}.gi-landing__venn-circle--2{width:150px;height:150px;left:60px;top:56px}.gi-landing__venn-circle--3{width:118px;height:118px;left:24px;top:142px}}@media(max-width:640px){.gi-landing__hero,.gi-landing__overview,.gi-landing__features,.gi-landing__download{padding:64px 0}.gi-landing__hero-title{font-size:clamp(2.1rem,10vw,3rem);line-height:1.06}.gi-landing__hero-subtitle{font-size:1rem;line-height:1.7}.gi-landing__hero-actions{flex-direction:column;align-items:stretch;width:100%;max-width:320px;margin:0 auto 1.35rem}.gi-landing__btn{width:100%;max-width:100%;min-width:0}.gi-landing__feature-grid{grid-template-columns:1fr}.gi-landing__download-card{padding:1.5rem}.gi-landing__qr-image{width:150px;height:150px}.gi-landing__overview-mini-card{grid-template-columns:48px 1fr;gap:.85rem;padding:.95rem 1rem}.gi-landing__overview-mini-icon{width:48px;height:48px;border-radius:14px;font-size:1rem}.gi-landing__overview-mini-card h3{font-size:1rem}.gi-landing__overview-mini-card p{font-size:.92rem}.gi-landing__phone-wrap{min-height:420px}.gi-landing__phone{width:min(260px,84vw);border-radius:30px;padding:10px}.gi-landing__phone-screen{border-radius:22px}.gi-landing__phone-notch{height:18px}.gi-landing__footer{padding-top:2.5rem}.gi-landing__footer-title{font-size:1.35rem}.gi-landing__footer-subtitle{font-size:.94rem}.gi-landing__footer-bottom-right{flex-direction:column;align-items:center;width:100%}}@media(max-width:576px){.gi-landing__venn--right{width:185px;height:210px;right:50%;top:54%;transform:translate(50%,-50%) scale(.92);opacity:.68}.gi-landing__venn-circle--1{width:86px;height:86px;left:55px;top:0}.gi-landing__venn-circle--2{width:118px;height:118px;left:48px;top:48px}.gi-landing__venn-circle--3{width:96px;height:96px;left:18px;top:110px}}@media(prefers-reduced-motion:reduce){.gi-landing__highlight-main,.gi-landing__highlight-light,.gi-landing__highlight-orange,.gi-landing__scroll-cue i,.gi-landing__phone,.gi-landing__phone-glow,.gi-landing__venn,.gi-landing__venn-float,.gi-landing__venn-circle{animation:none!important;transform:none!important;opacity:1!important}}.loading-screen{min-height:100vh;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;font-family:Inter,sans-serif}.loading-logo{width:100px;height:100px;object-fit:contain}.pulse{animation:pulseAnim 1.5s ease-in-out infinite}@keyframes pulseAnim{0%{transform:scale(1);opacity:.9}50%{transform:scale(1.06);opacity:1}to{transform:scale(1);opacity:.9}}.loading-text{font-size:1.2rem;font-weight:700;color:#1f2937;margin:0}.loading-bar{width:min(320px,80vw);height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden}.loading-bar__fill{height:100%;background:linear-gradient(90deg,#2563eb,#60a5fa);border-radius:999px;transition:width .25s ease}.loading-percent{font-size:1.1rem;font-weight:700;color:#000}:root{--gi-nav-h: 88px}.gi-header{position:fixed;top:0;left:0;right:0;height:var(--gi-nav-h);padding:0 clamp(14px,2vw,24px);box-sizing:border-box;background:#fffffff0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.92);color:#000;font-family:Inter,sans-serif;display:flex;justify-content:space-between;align-items:center;z-index:100000}.gi-header--login{background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:1px solid #e5e7eb}.gi-header__brand{display:flex;align-items:center;gap:12px;min-width:0;flex:1 1 auto}.gi-header__logo{width:54px;height:54px;object-fit:contain;flex-shrink:0}.gi-header__brand-text{display:flex;flex-direction:column;justify-content:center;min-width:0}.gi-header__title{margin:0;font-size:clamp(1.1rem,1.5vw,1.65rem);font-weight:800;letter-spacing:.01em;line-height:1;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gi-header__subtitle{margin:.22rem 0 0;font-size:.78rem;font-weight:600;line-height:1.2;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gi-header__login{display:inline-flex;align-items:center;justify-content:center;gap:.7rem;padding:.8rem 1.15rem;border-radius:14px;background:#0f172a;color:#fff;text-decoration:none;font-weight:700;font-size:.96rem;letter-spacing:.01em;line-height:1;box-shadow:0 10px 24px #0f172a29;transition:transform .25s ease,background .25s ease,box-shadow .25s ease;flex-shrink:0;white-space:nowrap}.gi-header__login:hover{transform:translateY(-2px);background:#1e293b;box-shadow:0 14px 28px #0f172a33}.gi-header__login-text{display:inline-block}.gi-header__qr{width:18px;height:18px;display:grid;grid-template-columns:repeat(2,1fr);gap:2px;flex-shrink:0}.gi-header__qr span{background:#60a5fa;border-radius:3px}@media(max-width:1100px){:root{--gi-nav-h: 82px}.gi-header__logo{width:48px;height:48px}.gi-header__login{padding:.76rem 1rem}}@media(max-width:768px){:root{--gi-nav-h: 76px}.gi-header{padding:0 16px}.gi-header__brand{gap:10px}.gi-header__logo{width:44px;height:44px}.gi-header__title{font-size:1.15rem}.gi-header__subtitle{font-size:.7rem}.gi-header__login{padding:.7rem .95rem;font-size:.9rem;border-radius:12px}.gi-header__qr{width:16px;height:16px}}@media(max-width:560px){:root{--gi-nav-h: 72px}.gi-header{padding:0 14px}.gi-header__brand{gap:8px}.gi-header__logo{width:40px;height:40px}.gi-header__title{font-size:1rem}.gi-header__subtitle{display:none}.gi-header__login{padding:.66rem .85rem;font-size:.84rem;gap:.5rem}.gi-header__qr{width:14px;height:14px}}@media(max-width:420px){.gi-header__login-text{display:none}.gi-header__login{padding:.7rem;min-width:44px;justify-content:center}}:root{--hair: rgba(255, 255, 255, .14);--muted: #64748b;--ink: #0f172a;--brand1: #0b1f7a;--brand2: #1e3cc8}.login{position:relative;min-height:100dvh;padding-top:var(--gi-nav-h, 88px);padding-left:16px;padding-right:16px;padding-bottom:16px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-family:Lexend,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background-color:#fff;overflow:hidden;isolation:isolate}.login__overlay{position:absolute;inset:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:0;pointer-events:none}.login__card{position:relative;z-index:1;width:min(980px,100%);display:grid;grid-template-columns:1.06fr 1fr;background:transparent;border-radius:22px;box-shadow:0 24px 60px #00000052;overflow:hidden}.login__left{position:relative;background:#fff;padding:18px 24px 24px;color:var(--ink);display:flex;flex-direction:column;justify-content:flex-start;min-height:0}.login_position{width:100%;max-width:420px;margin:0 auto;display:flex;flex-direction:column;justify-content:flex-start}.login__title{text-align:center;font-weight:800;letter-spacing:.08em;font-size:30px;line-height:1.1;margin:0 0 18px;color:#0f172a}.login__error{margin:0 0 14px;padding:12px 14px;border-radius:14px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:13px;font-weight:600}.login__label{display:block;font-weight:700;font-size:14px;margin:10px 0 8px;color:#111827}.input-wrap{background:#f8fafc;border:1px solid #dbe3ee;border-radius:999px;padding:9px 14px;display:flex;align-items:center;min-height:50px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.input-wrap:focus-within{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61f}.input-wrap input{width:100%;border:none;background:transparent;outline:none;font-size:14px;color:#111827;padding:6px 4px;font-family:inherit}.input-wrap input::placeholder{color:#94a3b8}.input-wrap--pwd{position:relative;padding-right:44px}.peek{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;background:transparent;border-radius:50%;cursor:pointer;color:#6b7280;font-size:17px;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.peek:hover{background:#94a3b824;color:#334155}.login__forgot{display:inline-block;align-self:flex-end;margin-top:10px;font-size:12px;font-weight:600;color:#2563eb;text-decoration:none}.login__forgot:hover{text-decoration:underline}.btn{width:100%;height:48px;border:0;border-radius:999px;padding:0 18px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,opacity .15s ease;font-family:inherit}.btn:disabled{cursor:not-allowed;opacity:.7}.btn--primary{margin-top:18px;color:#fff;background:linear-gradient(135deg,#1940ee,#1e3cc8);box-shadow:0 12px 26px #1940ee47}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 28px #1940ee52}.login__or{text-align:center;color:#64748b;font-weight:700;margin:14px 0}.btn--secondary{color:#fff;background:#010165;display:flex;align-items:center;justify-content:center;gap:8px}.btn--secondary:hover{transform:translateY(-2px);background:#1e3cc8}.btn__seal{width:20px;height:20px;object-fit:cover;border-radius:50%}.login__right{background:#0b0d12;display:flex;align-items:center;justify-content:center;min-height:100%}.login__right img{width:100%;height:100%;object-fit:cover}.back-btn{position:static;display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-bottom:12px;background:transparent;border:none;color:#0b1f7a;font-weight:700;font-size:14px;cursor:pointer;padding:0;transition:color .2s ease,transform .2s ease;font-family:inherit}.back-btn i{font-size:14px;transition:transform .2s ease}.back-btn:hover{color:#1f48ff;transform:translate(-2px)}.back-btn:hover i{transform:translate(-3px)}@media(max-width:900px){.login__card{grid-template-columns:1fr;width:min(560px,100%);max-height:100%}.login__right{display:none}}@media(max-width:768px){.login__left{padding:14px 18px 18px}.back-btn{margin-bottom:10px;font-size:13px}.login__title{font-size:26px;margin-bottom:16px}}@media(max-width:560px){.login__left{padding:12px 14px 16px}.back-btn{font-size:12px;margin-bottom:8px}.login__title{font-size:24px;margin-bottom:14px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInCenter{0%{opacity:0;transform:translate(-50%,calc(-50% + 15px))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes spin{to{transform:rotate(360deg)}}.state-center{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 36px;text-align:center;max-width:100%}.loading-state{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;pointer-events:none;animation:fadeInUp .5s ease forwards}.spinner{border:4px solid rgba(0,0,0,.1);border-top:4px solid #1f48ff;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite;margin:0 auto 12px;flex:0 0 auto}.loading-state p{margin-top:16px;color:#334155;font-weight:600}.reset-success,.reset-error{animation:fadeInUp .6s ease forwards,fadeHold 3s ease-in-out;text-align:center}@keyframes fadeHold{0%,90%{opacity:1}to{opacity:.6}}.success-icon,.error-icon{font-size:44px;line-height:1;display:inline-block;margin-bottom:16px}.success-icon{color:#22c55e}.error-icon{color:#dc2626}.reset-success h2,.reset-error h2{font-size:20px;font-weight:700;margin-bottom:10px}.reset-success p,.reset-error p{color:#64748b;font-size:14px;line-height:1.6}.auto-return{font-size:12px;color:#94a3b8;font-style:italic;margin-top:-6px}@media(max-width:768px){.state-center{position:static;inset:auto;transform:none;display:block;padding:0;text-align:z}.back-btn{position:static;margin-top:16px}}.code-form{margin-top:6px}.code-boxes{display:flex;gap:12px;margin:14px 0 18px;justify-content:center;flex-wrap:wrap}.code-input{width:46px;height:46px;border-radius:10px;border:1px solid #e5e7eb;background:#f3f5f9;text-align:center;font-weight:800;font-size:18px;transition:box-shadow .2s ease,border-color .2s ease}.code-input:focus{border-color:#1f48ff;box-shadow:0 0 0 3px #1f48ff26}.resend{margin-top:10px;font-size:13px;color:#64748b;text-align:center}.resend a{color:#1f48ff;font-weight:700;text-decoration:none}.resend a:hover{text-decoration:underline}.code-error{margin-top:10px;color:#dc2626;font-weight:700;font-size:13px;text-align:center}.btn[disabled]{cursor:not-allowed}@media(max-width:768px){.code-boxes{gap:10px}.code-input{width:40px;height:40px;font-size:16px}}@media(max-width:480px){.code-boxes{gap:8px}.code-input{width:36px;height:36px;font-size:15px}.resend,.code-error{font-size:12px}}.rp-align-left{text-align:left;width:100%}.rp-title{margin-bottom:4px}.rp-subtitle{margin-bottom:24px}.rp-success{text-align:center}.input-wrap--with-icon{position:relative}.input-trailing{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:none;background:transparent;display:grid;place-items:center;cursor:pointer;color:#64748b}.input-trailing:hover{color:#0f172a}.pw-rules{list-style:none;padding:8px 0 16px;margin:0 0 8px;color:#64748b;font-size:13px}.pw-rules li{margin:4px 0}.pw-rules li.ok{color:#16a34a;font-weight:600}.reset-form{width:100%;max-width:none;margin:0}.reset-form .input-wrap{width:100%}.reset-success-full{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;animation:fadeIn .5s ease forwards}.success-circle{width:100px;height:100px;border-radius:50%;background:#1f48ff1a;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;flex:0 0 auto}.success-circle i{font-size:50px;color:#1f48ff}.reset-success-full h2{font-size:22px;font-weight:700;color:#111827}.reset-success-full p{font-size:14px;color:#64748b;max-width:300px;line-height:1.6}@media(max-width:768px){.success-circle{width:60px;height:60px}.reset-success-full h2{font-size:20px}.reset-success-full p{font-size:13px}}.act-form{text-align:left;width:100%;max-width:500px}.activate-form{width:100%}.act-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;animation:fadeIn .5s ease forwards}.success-circle{width:90px;height:90px;border-radius:50%;background:#1f48ff1a;display:flex;align-items:center;justify-content:center}.success-circle i{font-size:45px;color:#1f48ff}@media(max-width:768px){.act-form{max-width:100%}.success-circle{width:70px;height:70px}}.head-shell.head--light{position:relative;min-height:100vh;background:var(--bg);color:var(--ink);font-family:Lexend,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.head-main{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.head-content{flex:1;min-height:0;overflow-y:auto}.head-sidebar-backdrop{position:fixed;inset:0;background:#0f172a6b;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease;z-index:1090}.head-sidebar-backdrop.is-visible{opacity:1;visibility:visible;pointer-events:auto}.head-sidebar{position:fixed;top:0;left:0;width:min(var(--sidebar-w),calc(100vw - 28px));height:100vh;background:radial-gradient(circle at top right,rgba(255,255,255,.14),transparent 28%),linear-gradient(180deg,#1e3a8a,#2563eb);color:#fff;display:flex;flex-direction:column;padding:18px 16px 16px;gap:18px;box-shadow:0 20px 50px #02061740;transform:translate(-100%);transition:transform .3s ease;z-index:1100;overflow-y:auto}.head-sidebar.is-open{transform:translate(0)}.head-sidebar__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.head-sidebar__brand{display:flex;align-items:center;gap:12px;flex:1;min-width:0;padding:12px;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;box-shadow:inset 0 0 0 1px #ffffff0a}.head-sidebar__brand-copy{min-width:0}.head-sidebar__logo{width:46px;height:46px;object-fit:contain;flex-shrink:0}.head-sidebar__title{margin:0;font-size:18px;font-weight:800;color:#fff;letter-spacing:.2px}.head-sidebar__subtitle{margin:3px 0 0;font-size:12px;color:#ffffffc7}.head-sidebar__close{width:42px;height:42px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:#ffffff1a;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease;flex-shrink:0}.head-sidebar__close:hover{background:#ffffff2e;transform:translateY(-1px)}.head-sidebar__menu{display:flex;flex-direction:column;gap:8px;margin-top:4px}.head-menu-item{display:flex;align-items:center;gap:12px;min-height:48px;padding:12px 14px;border-radius:14px;color:#ffffffe6;text-decoration:none;font-weight:600;transition:background .2s ease,transform .2s ease,color .2s ease}.head-menu-item i{width:18px;text-align:center;color:#dbeafe;font-size:15px;flex-shrink:0}.head-menu-item:hover{background:#ffffff1f;color:#fff;transform:translate(2px)}.head-menu-item.active{background:#ffffff2e;color:#fff;box-shadow:inset 0 0 0 1px #ffffff14}.head-menu-group{display:flex;flex-direction:column;gap:6px}.head-menu-item--group{width:100%;justify-content:space-between;background:transparent;border:none;cursor:pointer;text-align:left}.head-menu-item__main{display:inline-flex;align-items:center;gap:12px}.head-menu-item__chevron{font-size:12px;opacity:.75;transition:transform .2s ease,opacity .2s ease}.head-menu-group.is-active .head-menu-item__chevron{transform:rotate(180deg);opacity:1}.head-submenu{display:grid;gap:6px;padding-left:14px;max-height:0;overflow:hidden;opacity:0;transition:max-height .28s ease,opacity .2s ease}.head-submenu.is-open{max-height:220px;opacity:1}.head-submenu-item{display:flex;align-items:center;gap:10px;min-height:42px;padding:10px 14px;border-radius:12px;color:#ffffffd9;text-decoration:none;font-size:.94rem;font-weight:600;transition:background .2s ease,color .2s ease,transform .2s ease}.head-submenu-item i{width:16px;text-align:center;font-size:14px;color:#bfdbfe}.head-submenu-item:hover{background:#ffffff1a;color:#fff;transform:translate(3px)}.head-submenu-item.active{background:#ffffff29;color:#fff;font-weight:600;box-shadow:inset 0 0 0 1px #ffffff0f}.head-menu-group.is-active>.head-menu-item--group{background:#ffffff24;color:#fff}.head-sidebar__footer{margin-top:auto}.head-sidebar__hint{padding:12px 14px;border-radius:14px;background:#ffffff1a;color:#ffffffd1;font-size:12px;line-height:1.5}.head-topbar{position:sticky;top:0;z-index:100;height:var(--topbar-h);display:flex;justify-content:space-between;align-items:center;gap:18px;background:#ffffffeb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:14px 20px;border-bottom:1px solid rgba(229,231,235,.9);box-shadow:0 8px 22px #0f172a0a}.head-topbar__left{display:flex;align-items:center;gap:14px;min-width:0}.head-topbar__title-wrap{min-width:0}.head-topbar__title{margin:0;font-size:20px;font-weight:800;color:var(--brand);line-height:1.1}.head-topbar__subtitle{margin:3px 0 0;font-size:12px;color:var(--ink-muted)}.head-menu-toggle{border:none;background:#fff;color:var(--brand);font-size:19px;cursor:pointer;width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #2563eb14;border:1px solid rgba(219,234,254,.9);transition:color .2s ease,background .2s ease,transform .2s ease,box-shadow .2s ease;flex-shrink:0}.head-menu-toggle:hover{color:var(--brand-2);background:var(--hover);transform:translateY(-1px);box-shadow:0 10px 24px #2563eb24}.head-topbar__user{position:relative;display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.head-dep-select{min-width:80px;max-width:100px;height:42px;padding:0 14px;border-radius:12px;border:1px solid var(--hair);background:#fff;color:var(--ink);font-weight:600;outline:none}.head-dep-select:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1f}.head-role-chip,.head-chip,.prof-chip{padding:8px 12px;border-radius:999px;font-size:.84rem;font-weight:700;display:inline-flex;align-items:center;gap:8px;color:#fff;background:#2563eb;box-shadow:0 8px 16px #2563eb33}.head-role-switch-btn{width:38px;height:38px;background:#fff;border:1.5px solid #dbe3f0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .12s ease;position:relative}.head-role-switch-btn i{font-size:14px;color:#2f54eb;transition:transform .22s ease,color .2s ease}.head-role-switch-btn:hover{background:#eef3ff;border-color:#2f54eb}.head-role-switch-btn:hover i{transform:rotate(180deg) scale(1.06);color:#1e4ed8}.head-role-switch-btn:active{transform:scale(.96)}.head-role-switch-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2f54eb38}.head-role-switch-btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;top:50%;right:calc(100% + 10px);transform:translateY(-50%);background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;line-height:1;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.head-role-switch-btn[data-tooltip]:before{content:"";position:absolute;top:50%;right:calc(100% + 4px);transform:translateY(-50%);border-width:6px;border-style:solid;border-color:transparent transparent transparent #111827;opacity:0;pointer-events:none;transition:opacity .15s ease}.head-role-switch-btn:hover:after,.head-role-switch-btn:hover:before{opacity:1;transform:translateY(-50%) translate(-2px)}.head-user-chip{display:flex;align-items:center;gap:10px;min-height:44px;background:#fff;border:1px solid var(--hair);border-radius:999px;padding:6px 10px;cursor:pointer;box-shadow:0 8px 24px #0f172a0f;color:var(--ink);transition:background .2s ease,transform .2s ease}.head-user-chip:hover{background:var(--hover);transform:translateY(-1px)}.head-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:#2563eb;color:#fff;flex-shrink:0}.head-user-meta{display:grid;line-height:1.1;text-align:left}.head-user-name{font-weight:700;color:var(--ink)}.head-user-role{font-size:12px;color:var(--ink-muted)}.head-user-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:#fff;border:1px solid var(--hair);border-radius:14px;box-shadow:0 16px 36px #0000001a;padding:8px;animation:headFadeIn .16s ease-out;z-index:30}.head-user-menu__item{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;padding:11px 12px;text-align:left;border-radius:10px;color:var(--ink);cursor:pointer;transition:background .2s ease;font-weight:500}.head-user-menu__item:hover{background:var(--hover)}.head-user-menu__item i{color:var(--brand)}@keyframes headFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1200px){.head-topbar__user{gap:10px}.head-dep-select{min-width:160px;max-width:200px}}@media(max-width:960px){.head-topbar{padding:12px 14px;gap:12px}.head-topbar__title{font-size:18px}.head-topbar__subtitle,.head-user-meta{display:none}.head-dep-select{min-width:135px;max-width:160px;font-size:13px}.head-role-chip,.head-chip,.prof-chip{display:none}}@media(max-width:680px){.head-topbar__left{gap:10px}.head-topbar__user{gap:8px}.head-dep-select{display:none}.head-user-chip{padding:6px 8px}.head-sidebar{width:min(88vw,320px);padding:16px 14px 14px}}@media(prefers-reduced-motion:reduce){.head-sidebar,.head-sidebar-backdrop,.head-menu-item,.head-menu-toggle,.head-user-chip,.head-sidebar__close,.head-role-switch-btn{transition:none}}.admin-dashboard{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background:#fff}.admin-dashboard__title{margin-top:0;font-size:1.5rem;font-weight:700;margin-bottom:16px}.admin-dashboard__main{display:grid;grid-template-columns:3fr 1.15fr;gap:20px;align-items:stretch}.admin-left-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-areas:"students professors classes" "stuSum   yearTrend  yearTrend" "stuList  stuList    deanList";gap:16px}.admin-card--students{grid-area:students}.admin-card--professors{grid-area:professors}.admin-card--classes{grid-area:classes}.admin-card--studentSummary{grid-area:stuSum}.admin-card--yearTrend{grid-area:yearTrend}.admin-card--studentList{grid-area:stuList}.admin-card--deanList{grid-area:deanList}.admin-right-column{display:flex;flex-direction:column;gap:16px}.card.admin-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;padding:16px;display:flex;align-items:center;gap:12px;transition:transform .2s ease,box-shadow .2s ease}.card.admin-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #0000001a}.cardd-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.cardd-icon i{font-size:22px;line-height:1;display:block}.cardd-icon.students{background:#2563eb}.cardd-icon.professor{background:#10b981;color:#fff}.cardd-icon.classes{background:#f59e0b;color:#fff}.card-content p{margin:4px 0 0;color:#6b7280}.admin-card--calendar{flex-direction:column;align-items:stretch}.admin-card--studentSummary{display:flex;flex-direction:column;align-items:stretch}.list{width:100%;list-style:none;margin:0;padding:0;display:grid;gap:8px}.list li{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px}.list li span{color:#475569}.list li strong{color:#0f172a;font-size:24px}.admin-card--yearTrend{display:flex;flex-direction:column;min-height:260px}.yearTrend-chart{width:100%;height:220px;margin-top:8px}.admin-card--quickActions{flex-direction:column;align-items:stretch}.enroll-btn,.action-btn{background:#2563eb;color:#fff;padding:10px 18px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.enroll-btn,.action-btn:hover{background:#1e40af}.admin-card--studentList,.admin-card--deanList{flex-direction:column;align-items:stretch}.admin-card--studentList .card-header,.admin-card--deanList .card-header{margin-bottom:10px}.admin-card--studentList{display:flex;flex-direction:column;align-items:stretch}.recent-list{width:100%;max-height:420px;overflow-y:auto;margin-top:8px;padding:0 16px 8px;display:flex;flex-direction:column;gap:8px}.recent-item{width:100%;display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:#f8fafc;border:1px solid #e5e7eb}.recent-avatar{width:32px;height:32px;border-radius:999px;background:#2563eb15;border:1px solid #bfdbfe;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#1d4ed8}.recent-main{display:flex;flex-direction:column;gap:2px;min-width:0}.recent-name{font-size:.9rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-meta{font-size:.78rem;color:#64748b}.recent-time{font-size:.75rem;color:#94a3b8;white-space:nowrap}.rank-list{width:80%;list-style:none;margin:0;padding:0;display:grid;gap:10px}.rank-list li{display:grid;grid-template-columns:28px 1fr 60px;align-items:center;gap:10px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px}.rank-list li span{color:#475569}.rank-list li strong{color:#0f172a}.rank-list li em{justify-self:end;font-style:normal;font-weight:700;color:#2563eb}.rank-footer{margin-top:12px;display:flex;justify-content:flex-end}.see-all-btn{background:#f1f5f9;border:1px solid #d4d7dd;color:#475569;font-size:.85rem;padding:6px 14px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease,color .2s ease,border-color .2s ease}.see-all-btn:hover{background:#e2e8f0;border-color:#cbd5e1}.admin-card--enrollment{flex-direction:column;align-items:stretch}.enrollment-type{display:grid;gap:10px}.enroll-btn{height:40px;border-radius:10px;border:1px solid #dbeafe;background:#eef2ff;color:#1e3a8a;font-weight:700;cursor:pointer}.enroll-btn:hover{background:#e0e7ff}@media(max-width:1100px){.admin-dashboard__main{grid-template-columns:1fr}.admin-left-grid{grid-template-columns:repeat(2,1fr);grid-template-areas:"students professors" "classes  classes" "stuSum   yearTrend" "stuList  stuList" "deanList deanList"}.admin-right-column{flex-direction:row;flex-wrap:wrap}.admin-card--calendar,.admin-card--quickActions,.admin-card--enrollment{flex:1 1 340px}}@media(max-width:700px){.admin-left-grid{grid-template-columns:1fr;grid-template-areas:"students" "professors" "classes" "stuSum" "yearTrend" "stuList" "deanList"}}.class{padding:20px;font-family:Lexend,system-ui,sans-serif;color:#0f172a;background:#fff}.class-course_name{margin-top:0;margin-bottom:0;font-size:1.5rem;font-weight:700}.class-subtitle{margin:4px 0 0;color:#6b7280}.active-sem-banner{margin-top:6px;font-size:13px;color:#475569}.active-sem-banner strong{color:#0f172a;font-weight:600}.class-header{margin-top:0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.bttn{height:46px;border:0;border-radius:16px;padding:0 18px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.bttn--one{color:#fff;background:#1940ee}.bttn--one:hover{transform:translateY(-2px);background:#1e3cc8}.card{background:#fff;border-radius:16px;padding:14px;border:1px solid #e5e7eb;position:relative}.card:hover{border-color:#2563eb1f}.toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:12px}.subjects-filters-right{display:flex;align-items:flex-end;gap:12px}.toolbar .search{flex:1;max-width:480px}.toolbar .search input{width:100%}.search{position:relative;flex:1}.search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.search input{width:100%;height:40px;border-radius:10px;border:1px solid #e5e7eb;padding:0 12px 0 36px;outline:none}.search input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.table-scroll{width:100%;max-height:420px;overflow:auto;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.subjects-table{width:100%;border-collapse:collapse;font-size:.95rem}.subjects-table thead th{position:sticky;top:0;background:#eef2ff;color:#1e3a8a;text-align:left;padding:10px 12px;border-bottom:1px solid #e5e7eb}.subjects-table tbody td{padding:10px 12px;border-bottom:1px solid #eef2f4;color:#334155}.subjects-table tbody tr:hover{background:#f3f4f6}.subjects-table .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.actionss{display:flex;gap:6px}.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:grid;place-items:center}.icon-btn.edit{color:#0669d9;border-color:#8acbfd}.icon-btn.edit:hover{background:#c7f1fe}.icon-btn.danger{color:#ef4444;border-color:#fecaca}.icon-btn.danger:hover{background:#fee2e2}.empty{text-align:center;color:#6b7280;padding:16px}.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:2001}.backdrop{position:fixed;inset:0;background:#02061780}.modal-card{position:relative;z-index:51;width:min(720px,92vw);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;border:1px solid rgba(37,99,235,.12)}.modal-header{position:sticky;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.1rem;font-weight:800;display:flex;gap:8px;align-items:center}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:14px 16px 16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-weight:700;color:#0f172a}.field input,.field select{height:40px;border-radius:10px;border:1px solid #e5e7eb;padding:0 10px;outline:none;background:#fff}.field input:focus,.field select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.field .error{color:#ef4444;margin:-2px 0 0;font-size:.85rem}.span-2{grid-column:span 2}.actions-row{display:flex;justify-content:flex-end;gap:10px;margin-top:25px}.actions-row .bttn.one{min-width:150px;text-align:center}@media(max-width:700px){.form-grid{grid-template-columns:1fr}.span-2{grid-column:auto}}.segmented{display:inline-flex;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px;margin:10px 0 14px}.seg-btn{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease}.seg-btn:hover{background:#2563eb1a}.seg-btn.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.seg-btn:active{transform:scale(.96)}.table-top{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;justify-content:space-between}.table-top .search{flex:1;max-width:480px}.table-top .search input{width:100%}.sched-filters{display:flex;align-items:flex-end;gap:16px}.sched-filter{display:flex;flex-direction:column;gap:4px}.sem-tabs{margin-top:4px}.ay-select-row{display:flex;align-items:center;gap:8px;padding-bottom:12px}.ay-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:10px}.ay-card{background:#fff;border-radius:14px;border:1px solid #e5e7eb;padding:10px 10px 8px;box-shadow:0 4px 12px #0f172a0f;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background-color .16s ease}.ay-card:hover{transform:translateY(-2px);border-color:#2563eb38;box-shadow:0 8px 18px #0f172a1a;background-color:#f9fafb}.ay-card.is-active{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb14,0 8px 20px #2563eb1a;background-color:#eff6ff}.ay-card-header{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:4px}.ay-card-header h4{margin:0;font-size:.98rem;font-weight:700;color:#111827;letter-spacing:.01em}.ay-card .icon-btn.danger{width:26px;height:26px;min-width:26px;border-radius:8px;padding:0;opacity:0;transform:scale(.9);transition:all .16s ease}.ay-card:hover .icon-btn.danger{opacity:1;transform:scale(1)}.ay-card-body{font-size:.8rem;color:#6b7280;margin-bottom:4px}.ay-card-meta{margin:2px 0 0;font-size:.78rem;color:#2563eb;font-weight:600}.ay-card-foot{margin-top:2px}.ay-card-foot .pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:.7rem;font-weight:500;color:#2563eb;background:#eff6ff;border:1px solid rgba(37,99,235,.25)}.ay-card-foot .pill:before{content:"";width:6px;height:6px;border-radius:999px;background:#2563eb}.delete-ay{position:absolute;top:10px;right:12px}.ay-label{color:#334155;font-weight:600}.ay-select{height:36px;border:1px solid #e5e7eb;border-radius:8px;padding:0 10px;min-width:180px;background:#fff}.ay-list{display:grid;gap:12px}.ay-item{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.ay-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ay-actions{display:flex;gap:8px}.semesters{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}.semester-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:10px}.semester-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.section-code-row{display:flex;align-items:center;gap:6px}.section-code-row .mini{height:36px;border-radius:10px;border:1px solid #e5e7eb;padding:0 10px;font-size:.9rem}.readonly-total{background-color:#f1f5f9;color:#64748b;border:1px solid #cbd5e1;cursor:not-allowed;pointer-events:none;opacity:.8}.plus-sign{color:#9ca3af;font-weight:600}.hint{margin-top:4px;font-size:.78rem;color:#6b7280}.section-add{display:flex;gap:8px;align-items:center;margin:8px 0 10px}.section-add .mini{margin-top:16px;height:36px;border-radius:10px;border:1px solid #e5e7eb;padding:0 10px}.modal-card.small{width:min(480px,92vw)}.tiny-link{margin-top:6px;background:none;border:none;color:#2563eb;cursor:pointer;padding:0}.sub-tabs{margin-top:10px}.wt-wrapper{padding:10px 8px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.wt-title{margin:6px 8px 12px;font-size:1.1rem;font-weight:700;color:#0f172a}.wt-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}@media(max-width:1200px){.wt-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:720px){.wt-grid{grid-template-columns:1fr}}.wt-col{display:flex;flex-direction:column;gap:10px}.wt-daychip{align-self:center;justify-self:center;text-align:center;background:#eef2ff;color:#1e293b;padding:6px 12px;border-radius:10px;font-weight:700;font-size:.95rem;border:1px solid #e5e7eb;min-width:90px}.wt-empty{color:#94a3b8;font-size:.85rem;padding:6px 2px 2px;text-align:center}.wt-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;box-shadow:0 1px 4px #0206170d;display:grid;grid-template-rows:auto auto auto;gap:6px}.wt-head{display:grid;gap:2px}.wt-code{font-weight:700;color:#111827;font-size:.95rem}.wt-subtitle{color:#475569;font-weight:600;font-size:.9rem}.wt-small{color:#64748b;font-size:.8rem}.wt-meta{display:grid;gap:4px;margin-top:2px}.wt-row{display:flex;align-items:center;gap:6px;color:#334155;font-size:.83rem}.wt-row i{font-size:13px;color:#64748b}.wt-foot{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:4px}.badge{text-transform:lowercase;font-weight:600;font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid transparent}.badge--lec{background:#3b82f624;color:#1e40af;border-color:#3b82f640}.badge--lab{background:#a855f729;color:#6b21a8;border-color:#a855f740}.wt-cap{font-weight:600;font-size:12px}.wt-cap.is-good{color:#16a34a}.wt-cap.is-bad{color:#ef4444}.curriculum-container{display:flex;gap:24px;justify-content:center;align-items:flex-start;padding:20px}.curriculum-column{width:48%}.curriculum-term{text-align:center;font-size:1.6rem;font-weight:800;margin-bottom:16px}.year-block{margin-bottom:26px}.year-block h3{font-weight:700;margin:6px 0}.cur-table{width:100%;border-collapse:collapse;font-size:.9rem}.cur-table th,.cur-table td{border:1px solid #000;padding:4px 6px;text-align:left}.cur-table thead th{background:#f9f9f9;font-weight:700}.cur-table tfoot td{font-weight:700;background:#f7f7f7}.add-section-error{color:#ef4444;margin-top:2px;font-size:.8em}.ay-ongoing{border:1px solid;border-radius:6px;padding:2px;font-size:.8em;background-color:#334155;color:#fff;width:10px;height:10px}.on{background-color:#9bec9b}.off{background-color:#c86a6a}.ay-semester{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.checklist-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.checklist-controls{margin-top:12px}.checklist-preview{margin-top:14px}.checklist-page{background:#fff;color:#000;padding:14px;border:1px solid rgba(0,0,0,.2);border-radius:10px}.checklist-header{text-align:center;margin-bottom:10px}.checklist-school{font-weight:800;letter-spacing:.4px}.checklist-campus{font-size:12px;margin-top:2px}.checklist-program{font-weight:700;margin-top:6px}.checklist-meta{display:flex;justify-content:space-between;gap:16px;font-size:12px;margin:10px 0 14px}.checklist-block{margin-bottom:18px}.checklist-block-title{font-weight:800;margin-bottom:6px}.checklist-table th,.checklist-table td{font-size:12px}.cc-code{width:110px}.cc-units{width:80px;text-align:center}.cc-prereq{width:160px}.cc-sem{width:60px;text-align:center}.cc-sy{width:70px;text-align:center}.cc-grade{width:80px;text-align:center}.cc-center{text-align:center}.cc-total{font-weight:800}.student-search{margin-top:12px;position:relative}.student-search-box{position:relative;max-width:420px}.student-search-box input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #d1d5db;font-size:14px}.student-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 24px #0000001f;max-height:260px;overflow-y:auto;z-index:50}.student-result{padding:10px 12px;font-size:12px;font-weight:500;cursor:pointer}.student-result:hover{background:#f3f4f6}.student-name{font-weight:600}.student-meta{font-size:12px;color:#6b7280}.student-empty{padding:12px;font-size:13px;color:#6b7280}.checklist-blank{padding:18px;border:1px dashed rgba(148,163,184,.6);border-radius:12px;background:#0f172a05}.checklist-blank-title{font-weight:800;font-size:14px}.checklist-blank-sub{margin-top:6px;font-size:13px;color:#64748b}.bttn[disabled]{opacity:.55;cursor:not-allowed}@media print{@page{size:A4 portrait;margin:10mm}html,body{width:100%;height:auto;margin:0!important;padding:0!important;background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}body *{visibility:hidden!important}#checklist-print-area,#checklist-print-area *{visibility:visible!important}#checklist-print-area{position:fixed;left:0;top:0;width:100%!important;max-width:none!important;margin:0!important;padding:0!important;transform:none!important;zoom:1!important}.checklist-preview,.checklist-page{width:100%!important;max-width:none!important;margin:0!important;padding:0!important;box-shadow:none!important;border:none!important;background:#fff!important}.table-scroll{overflow:visible!important;max-height:none!important}.checklist-header{text-align:center!important;margin-bottom:6mm!important}.checklist-school{font-size:12pt!important;font-weight:700!important}.checklist-campus{font-size:10.5pt!important;font-weight:600!important}.checklist-program{font-size:10pt!important;font-weight:600!important}.checklist-meta{font-size:10pt!important;margin:2mm 0 6mm!important;display:flex!important;justify-content:space-between!important;gap:12mm!important}table.checklist-table,.checklist-table{width:100%!important;border-collapse:collapse!important;font-size:9.5pt!important}.checklist-table th,.checklist-table td{border:1px solid #000!important;padding:4px 6px!important;vertical-align:top!important}.checklist-table th{background:#f2f2f2!important;text-align:center!important;font-weight:700!important}.cc-center{text-align:center!important}.cc-total{font-weight:700!important}.checklist-block{page-break-inside:avoid!important;break-inside:avoid!important;margin-bottom:6mm!important}.class-header,.segmented,.checklist-controls,.checklist-top,.bttn,button{display:none!important}}.grading-summary{display:flex;height:38px;border-radius:10px;overflow:hidden;background:#e5e7eb;margin:12px 0 18px}.grading-summary .bar{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.bar.prelim{background:#2563eb}.bar.midterm{background:#7c3aed}.bar.finals{background:#16a34a}.total-box{padding:10px 14px;border-radius:8px;font-weight:700;margin-top:10px}.total-box.is-valid{background:#ecfdf5;color:#065f46}.total-box.is-invalid{background:#fef2f2;color:#991b1b}.grading-total{cursor:not-allowed;background-color:#f8f9fb;color:#6b7280;border-color:#e5e7eb}.grading-total:focus{outline:none;box-shadow:none}.class-tableLoader{display:flex;align-items:center;justify-content:center;gap:12px;padding:18px;color:#475569}.class-spinner{width:18px;height:18px;border:2px solid #dbeafe;border-top-color:#2563eb;border-radius:999px;animation:class-spin .7s linear infinite}@keyframes class-spin{to{transform:rotate(360deg)}}.class-row-clickable{transition:background-color .18s ease}.class-row-clickable:hover{background:#f8fbff}:root{--hg-bg: #ffffff;--hg-surface: #ffffff;--hg-surface-soft: #f8fbff;--hg-border: #e5e7eb;--hg-border-strong: #d7e2ee;--hg-text: #0f172a;--hg-text-soft: #64748b;--hg-text-muted: #94a3b8;--hg-brand: #1e3a8a;--hg-brand-2: #2563eb;--hg-brand-soft: #eff6ff;--hg-shadow-sm: 0 8px 20px rgba(15, 23, 42, .04);--hg-shadow-md: 0 16px 36px rgba(15, 23, 42, .06);--hg-shadow-lg: 0 28px 70px rgba(15, 23, 42, .14);--hg-radius-xl: 24px;--hg-radius-lg: 18px;--hg-radius-md: 14px}.hg-page{display:grid;gap:20px;padding:22px;color:var(--hg-text);background:var(--hg-bg);font-family:Lexend,system-ui,sans-serif;min-height:100%}.hg-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}.hg-page__title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--hg-text)}.hg-page__subtitle{margin:8px 0 0;max-width:760px;color:var(--hg-text-soft);line-height:1.65;font-size:.96rem}.hg-page__meta{display:flex;gap:10px;flex-wrap:wrap}.hg-chip{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;background:#fffffff0;border:1px solid var(--hg-border);color:#334155;font-weight:700;font-size:.88rem;box-shadow:var(--hg-shadow-sm);white-space:nowrap}.hg-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:stretch}.hg-search{flex:1 1 360px;display:flex;align-items:center;gap:12px;min-height:50px;padding:0 16px;background:#fffffff5;border:1px solid var(--hg-border);border-radius:16px;box-shadow:var(--hg-shadow-sm);transition:border-color .2s ease,box-shadow .2s ease,transform .16s ease}.hg-search:focus-within{border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1f}.hg-search i{color:var(--hg-text-soft);font-size:.95rem}.hg-search input{flex:1;border:none;outline:none;background:transparent;color:var(--hg-text);font-size:.95rem;font-family:inherit}.hg-search input::placeholder,.hg-input::placeholder,.hg-textarea::placeholder{color:var(--hg-text-muted)}.hg-select,.hg-input,.hg-textarea{width:100%;border:1px solid var(--hg-border-strong);border-radius:16px;background:#fffffff5;color:var(--hg-text);outline:none;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.hg-select,.hg-input{min-height:50px;padding:0 14px}.hg-select{min-width:190px}.hg-textarea{padding:12px 14px;resize:vertical;line-height:1.55}.hg-select:focus,.hg-input:focus,.hg-textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1f;background:#fff}.hg-summary{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px}.hg-stat{min-width:0;padding:18px;border-radius:20px;background:linear-gradient(180deg,#fffffffa,#f8fafcfa);border:1px solid var(--hg-border);box-shadow:var(--hg-shadow-md)}.hg-stat__label{display:block;color:var(--hg-text-soft);font-size:.84rem;margin-bottom:9px;font-weight:600}.hg-stat__value{font-size:1.55rem;color:var(--hg-brand);font-weight:800;letter-spacing:-.02em}.hg-stack{display:grid;gap:18px}.hg-card,.hg-panel{background:#fffffffa;border:1px solid var(--hg-border);border-radius:var(--hg-radius-xl);box-shadow:var(--hg-shadow-md);overflow:hidden}.hg-card__head{width:100%;border:none;background:linear-gradient(180deg,#f8fafccc,#fffffffa);padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;text-align:left;transition:background .2s ease}.hg-card__head:hover{background:linear-gradient(180deg,#eff6ffe6,#fffffffa)}.hg-card__head-main{display:flex;align-items:center;gap:14px;min-width:0}.hg-card__head-side{display:flex;align-items:center;gap:12px;color:var(--hg-text-soft);flex-shrink:0;font-weight:700}.hg-iconbox{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(180deg,#eff6ff,#dbeafe);color:var(--hg-brand-2);box-shadow:inset 0 0 0 1px #2563eb14;flex-shrink:0}.hg-card__title{margin:0;font-size:1.06rem;font-weight:800;color:var(--hg-text);letter-spacing:-.01em}.hg-card__desc{margin:5px 0 0;color:var(--hg-text-soft);font-size:.92rem;line-height:1.45}.hg-table-wrap{overflow-x:auto;border-top:1px solid #edf2f7}.hg-table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}.hg-table th,.hg-table td{padding:15px 16px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:middle;font-size:.93rem}.hg-table thead th{position:sticky;top:0;background:#f8fafc;color:#475569;font-weight:800;z-index:1}.hg-table tbody tr{transition:background .18s ease}.hg-table tbody tr:hover{background:#fbfdff}.hg-cell-remarks{max-width:280px;color:#475569;line-height:1.55}.hg-actions{display:flex;gap:8px;flex-wrap:wrap}.hg-btn{min-height:38px;padding:0 14px;border-radius:12px;border:none;cursor:pointer;font-weight:700;font-family:inherit;transition:transform .16s ease,background .2s ease,box-shadow .2s ease,border-color .2s ease}.hg-btn:hover{transform:translateY(-1px)}.hg-btn:focus-visible,.hg-icon-btn:focus-visible,.hg-student-card:focus-visible{outline:none;box-shadow:0 0 0 4px #2563eb24}.hg-btn--ghost{background:#fff;color:var(--hg-brand);border:1px solid #dbe3f0}.hg-btn--ghost:hover{background:#f8fbff;border-color:#bfd7ff}.hg-btn--primary{background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 22px #2563eb38}.hg-btn--primary:hover{box-shadow:0 14px 28px #2563eb47}.hg-btn--danger{background:linear-gradient(180deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 10px 22px #dc26262e}.hg-btn--danger-soft{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.hg-btn--danger-soft:hover{background:#fee2e2;border-color:#fca5a5}.hg-badge{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;font-size:.79rem;font-weight:800;letter-spacing:.01em;border:1px solid transparent}.hg-badge--draft{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.hg-badge--submitted{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.hg-badge--reviewed{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.hg-badge--recalled{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.hg-badge--neutral{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.hg-empty{min-height:260px;display:grid;place-items:center;text-align:center;padding:28px;color:var(--hg-text-soft)}.hg-empty i{font-size:1.4rem;color:#94a3b8}.hg-empty h3{margin:12px 0 6px;color:#334155;font-size:1.02rem}.hg-empty p{margin:0;max-width:420px;line-height:1.55}.hg-empty--compact{min-height:140px}.hg-modal-backdrop{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172a6b;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.hg-modal{width:min(100%,720px);max-height:min(88vh,840px);overflow-y:auto;background:#fff;border-radius:24px;border:1px solid var(--hg-border);box-shadow:var(--hg-shadow-lg);padding:22px}.hg-modal--sm{width:min(100%,560px)}.hg-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.hg-modal__header h3{margin:0;color:var(--hg-text);font-size:1.08rem}.hg-modal__header p{margin:6px 0 0;color:var(--hg-text-soft);line-height:1.5}.hg-icon-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--hg-border);background:#fff;color:var(--hg-text-soft);cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .16s ease}.hg-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.hg-detail-grid,.hg-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.hg-detail-item,.hg-form-block{display:grid;gap:8px}.hg-detail-item span,.hg-label{font-size:.84rem;font-weight:700;color:var(--hg-text-soft)}.hg-detail-item strong{display:block;min-height:50px;padding:14px;border-radius:14px;background:#f8fafc;border:1px solid var(--hg-border);color:var(--hg-text);line-height:1.45}.hg-detail-item--full,.hg-form-block--full{grid-column:1 / -1}.hg-modal__actions{margin-top:20px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.hg-audit-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:18px;align-items:start}.hg-panel{padding:18px}.hg-panel--main{min-height:520px}.hg-panel__head{margin-bottom:16px}.hg-panel__head h3{margin:0;color:var(--hg-text);font-size:1.05rem;font-weight:800}.hg-panel__head p{margin:6px 0 0;color:var(--hg-text-soft);line-height:1.55}.hg-student-list{margin-top:16px;display:grid;gap:10px;max-height:540px;overflow-y:auto;padding-right:2px}.hg-student-card{width:100%;text-align:left;border:1px solid var(--hg-border);background:linear-gradient(180deg,#fff,#fbfdff);border-radius:16px;padding:14px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .16s ease,background .2s ease}.hg-student-card:hover{transform:translateY(-1px);border-color:#bfdbfe;box-shadow:0 12px 24px #2563eb14}.hg-student-card.is-active{border-color:#93c5fd;background:linear-gradient(180deg,#f8fbff,#eff6ff);box-shadow:0 14px 26px #2563eb1a}.hg-student-card__top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.hg-student-card__top strong{font-size:.96rem;color:var(--hg-text)}.hg-student-card__meta{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap;color:var(--hg-text-soft);font-size:.88rem;line-height:1.45}.hg-student-card__meta span{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#f8fafc;border:1px solid #edf2f7}@media(max-width:1080px){.hg-audit-layout,.hg-summary{grid-template-columns:1fr}.hg-student-list{max-height:none}}@media(max-width:720px){.hg-page{padding:14px;gap:16px}.hg-detail-grid,.hg-form-grid{grid-template-columns:1fr}.hg-modal{padding:18px;border-radius:20px}.hg-page__header,.hg-toolbar{flex-direction:column}.hg-card__head{align-items:flex-start}.hg-card__head-side{align-self:center}.hg-table th,.hg-table td{padding:13px 14px}}@media(prefers-reduced-motion:reduce){.hg-search,.hg-select,.hg-input,.hg-textarea,.hg-card__head,.hg-btn,.hg-icon-btn,.hg-student-card{transition:none}}.hg-meta-row{margin-bottom:14px}.hg-inline-alert{margin-bottom:14px;padding:12px 14px;border-radius:14px;font-size:.92rem;font-weight:600}.hg-inline-alert--error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.hg-subtext{margin-top:4px;font-size:.84rem;color:#64748b;font-weight:500}.hg-form-grid--mt{margin-top:16px}.hg-btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}.professor{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background:#fff}.professor-title{margin-top:0;font-size:1.5rem;font-weight:700;margin-bottom:0}.tag{display:inline-block;margin:2px 6px 2px 0;padding:2px 8px;font-size:.8rem;border:1px solid #e5e7eb;border-radius:999px;background:#f8fafc;color:#334155}.hint{color:#475569;font-size:.9rem;margin-top:4px}.hint.bad{color:#b91c1c}.avatar{width:34px;height:34px;border-radius:999px;background:#e5e7eb;color:#111827;display:grid;place-items:center;font-weight:800}.chip{display:inline-block;border:1px solid #cbd5e1;border-radius:999px;padding:3px 8px;font-size:.82rem;font-weight:600;color:#334155;background:#f8fafc}.chip.ge{border-color:#60a5fa;color:#1e40af;background:#3b82f61f}.chip.it{border-color:#34d399;color:#065f46;background:#10b9811f}.chip.light{opacity:.85}td.bad{color:#b91c1c;font-weight:700}.info-row{display:flex;flex-wrap:wrap;gap:6px}.icon-btn.assign{color:#06d929;border-color:#8afdaa}.icon-btn.assign:hover{background:#c7fee1}.assign-header{padding-bottom:12px;display:flex;align-items:center;justify-content:flex-start}.assign-header h3{font-weight:700}.assign-headerr{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.assign-subheader{display:flex;justify-content:space-between;align-items:center}.ay-display,.semester-filter{display:flex;align-items:center;gap:8px}.ay-label{font-size:.85rem;font-weight:500;color:#475569}.ay-label-static{padding:6px 10px;border-radius:6px;background:#f1f5f9;border:1px solid #cbd5e1;font-size:.85rem;color:#334155}.ay-select{border:1px solid #cbd5e1;border-radius:6px;padding:6px 10px;font-size:.85rem;background:#fff;color:#334155}.assign-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.assign-col{border:1px solid #e5e7eb;border-radius:12px;background:#fff;display:flex;flex-direction:column;min-height:360px}.assign-head{display:flex;align-items:center;gap:12px;padding:10px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.assign-head h4{margin:0;font-weight:600}.assign-list{padding:30px 20px 20px;display:grid;gap:8px;overflow:auto}.assign-item{text-align:left;border:1px solid #e5e7eb;background:#fff;border-radius:16px;padding:20px;cursor:pointer;transition:all .15s ease}.assign-item:hover{background:#f1f3f7}.assign-item-title{display:flex;gap:10px;align-items:baseline;margin-bottom:6px}.assign-item-title .muted{color:#64748b;font-size:.9rem}.assign-item-meta{display:flex;flex-wrap:wrap;gap:6px}.load-inline{margin-top:10px}.load-inline-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px}.load-inline-head{display:flex;gap:8px;align-items:center;justify-content:space-between;flex-wrap:wrap}.progress{height:8px;background:#f1f5f9;border-radius:8px;overflow:hidden;margin-top:8px}.progress-bar{height:100%;background:#0ea5e9}.assign-row{width:100%;padding:6px 10px;border:1px solid #2f3a4a;border-radius:6px;background:transparent;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:pointer;text-align:left}.assign-row.is-selected{border-color:#38bdf8;background:#38bdf80f}.assign-row-main{font-size:.9rem;display:flex;flex-direction:column}.assign-row-sub{font-size:.75rem;opacity:.75}.loads-list{display:grid;gap:16px}.load-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;box-shadow:0 3px 12px #0f172a0f}.load-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.load-title .name{font-weight:600;color:#0f172a;margin-bottom:4px;font-size:1.05rem}.load-title .course{color:#64748b;font-size:.95rem}.load-units{text-align:right;min-width:120px}.load-units .units{font-weight:600;color:#0f172a}.load-units .percent{color:#64748b;font-size:.9rem}.progress{margin:10px 0 8px;height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:#22c55e;border-radius:999px}.load-meta{color:#475569;font-size:.95rem}@media(max-width:640px){.load-header{flex-direction:column;align-items:flex-start}.load-units{text-align:left}}.load-subject-chip{position:relative;display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #dbeafe;background:#f8fbff;border-radius:999px;color:#1e3a8a;font-size:13px;line-height:1;cursor:default}.load-subject-code{font-weight:700}.load-subject-count{color:#475569;font-size:12px}.assign-item__button:disabled{opacity:.55;cursor:not-allowed}.assign-item.is-disabled{background:#f9fafb}.student,.professor{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background:#fff}.class-title{margin:0;font-size:1.5rem;font-weight:700}.class-subtitle{margin:6px 0 0;color:#64748b;font-size:.95rem;line-height:1.5}.headstudent-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.headstudent-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:14px}.headstudent-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px 16px;box-shadow:0 8px 24px #0f172a0d;display:flex;flex-direction:column;gap:6px}.headstudent-stat-label{font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.headstudent-stat-value{font-size:1.5rem;font-weight:700;color:#0f172a;line-height:1}.headstudent-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.headstudent-section-copy{margin:6px 0 0;color:#64748b;font-size:.92rem;line-height:1.55;max-width:760px}.enr-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:12px}.enr-left{display:flex;flex-direction:column;gap:4px}.enr-right{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.enr-sem-label{font-size:.85rem;font-weight:600;color:#334155}.enr-search{min-width:220px}.subjects-table.tight th,.subjects-table.tight td{padding-top:8px;padding-bottom:8px;vertical-align:middle}.subjects-table th,.subjects-table td{vertical-align:middle}.subjects-table td:nth-child(2),.subjects-table td:nth-child(3),.subjects-table th:nth-child(2),.subjects-table th:nth-child(3){text-align:center}.headstudent-name-cell{display:flex;flex-direction:column;gap:4px}.headstudent-row-actions{display:flex;align-items:center;gap:8px}.mini-btn{height:34px;min-width:34px;border-radius:10px;border:1px solid #dbe2ea;background:#fff;color:#334155;display:inline-flex;align-items:center;justify-content:center;transition:.18s ease;cursor:pointer}.mini-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.mini-btn:disabled{opacity:.45;cursor:not-allowed}.modal-card.wide{max-width:980px}.headstudent-modal-note{margin-bottom:14px;padding:12px 14px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:.92rem;line-height:1.55}.headstudent-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.headstudent-type-card{text-align:left;border:1px solid #dbe2ea;background:#fff;border-radius:14px;padding:14px;cursor:pointer;transition:.18s ease}.headstudent-type-card:hover{background:#f8fafc;border-color:#93c5fd}.headstudent-type-card.is-active{border-color:#2563eb;background:#eff6ff}.headstudent-type-title{font-weight:700;color:#0f172a;margin-bottom:6px}.headstudent-type-copy{font-size:.87rem;line-height:1.5;color:#64748b}.headstudent-picked-card{background:#fff;border:1px solid #dbe2ea;border-radius:14px;padding:14px}.headstudent-picked-title{font-weight:700;color:#0f172a;margin-bottom:8px}.headstudent-picked-meta{display:flex;gap:8px;flex-wrap:wrap}.assign-list{display:flex;flex-direction:column;gap:10px}.assign-item{width:100%;text-align:left;border:1px solid #dbe2ea;background:#fff;border-radius:12px;padding:12px 14px;transition:.18s ease;cursor:pointer}.assign-item:hover{background:#f8fafc;border-color:#cbd5e1}.assign-item.is-selected{border-color:#2563eb;background:#eff6ff}.assign-item.assign-static{cursor:default}.assign-item.assign-static:hover{background:#fff;border-color:#dbe2ea}.assign-item-title{color:#0f172a;margin-bottom:6px}.assign-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.w-full{width:100%}.ctrl.input-like{width:100%;border:1px solid #e5e7eb;background:#f8fafc;border-radius:10px;padding:10px 12px;font-size:.95rem}.search i{padding-left:4px}.chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:9999px;font-size:.82rem;font-weight:600;line-height:1;text-transform:capitalize;border:1px solid transparent;white-space:nowrap}.chip.ok{background:#dcfce7;color:#166534}.chip.warn{background:#fee2e2;color:#991b1b}.chip.soft{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.chip.outline{background:#fff;color:#475569;border-color:#dbe2ea}.chip:hover{filter:brightness(.98);cursor:default}@media(max-width:1100px){.headstudent-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.student,.professor{padding:14px}.headstudent-stats{grid-template-columns:1fr}.headstudent-header-actions{justify-content:flex-start}.headstudent-section-head{flex-direction:column}.headstudent-type-grid{grid-template-columns:1fr}.enr-right{width:100%;align-items:stretch}.enr-search{min-width:100%}}.admin-shell.admin--light{position:relative;min-height:100vh;background:var(--bg);color:var(--ink);font-family:Lexend,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.admin-main{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.admin-content{flex:1;min-height:0;overflow-y:auto}.admin-sidebar-backdrop{position:fixed;inset:0;background:#0f172a6b;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease;z-index:1090}.admin-sidebar-backdrop.is-visible{opacity:1;visibility:visible;pointer-events:auto}.admin-sidebar{position:fixed;top:0;left:0;width:min(var(--sidebar-w),calc(100vw - 28px));height:100vh;background:radial-gradient(circle at top right,rgba(255,255,255,.14),transparent 28%),linear-gradient(180deg,#1e3a8a,#2563eb);color:#fff;display:flex;flex-direction:column;padding:18px 16px 16px;gap:18px;box-shadow:0 20px 50px #02061740;transform:translate(-100%);transition:transform .3s ease;z-index:1100;overflow-y:auto}.admin-sidebar.is-open{transform:translate(0)}.admin-sidebar__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.admin-sidebar__brand{display:flex;align-items:center;gap:12px;flex:1;min-width:0;padding:12px;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;box-shadow:inset 0 0 0 1px #ffffff0a}.admin-sidebar__brand-copy{min-width:0}.admin-sidebar__logo{width:46px;height:46px;object-fit:contain;flex-shrink:0}.admin-sidebar__title{margin:0;font-size:18px;font-weight:800;color:#fff;letter-spacing:.2px}.admin-sidebar__subtitle{margin:3px 0 0;font-size:12px;color:#ffffffc7}.admin-sidebar__close{width:42px;height:42px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:#ffffff1a;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease;flex-shrink:0}.admin-sidebar__close:hover{background:#ffffff2e;transform:translateY(-1px)}.admin-sidebar__menu{display:flex;flex-direction:column;gap:8px;margin-top:4px}.admin-menu-item{display:flex;align-items:center;gap:12px;min-height:48px;padding:12px 14px;border-radius:14px;color:#ffffffe6;text-decoration:none;font-weight:600;transition:background .2s ease,transform .2s ease,color .2s ease}.admin-menu-item i{width:18px;text-align:center;color:#dbeafe;font-size:15px;flex-shrink:0}.admin-menu-item:hover{background:#ffffff1f;color:#fff;transform:translate(2px)}.admin-menu-item.active{background:#ffffff2e;color:#fff;box-shadow:inset 0 0 0 1px #ffffff14}.admin-sidebar__footer{margin-top:auto}.admin-sidebar__hint{padding:12px 14px;border-radius:14px;background:#ffffff1a;color:#ffffffd1;font-size:12px;line-height:1.5}.admin-topbar{position:sticky;top:0;z-index:100;height:var(--topbar-h);display:flex;justify-content:space-between;align-items:center;gap:18px;background:#ffffffeb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:14px 20px;border-bottom:1px solid rgba(229,231,235,.9);box-shadow:0 8px 22px #0f172a0a}.admin-topbar__left{display:flex;align-items:center;gap:14px;min-width:0}.admin-topbar__page{min-width:0}.admin-topbar__title{margin:0;font-size:20px;font-weight:800;color:var(--brand);line-height:1.1}.admin-topbar__subtitle{margin:3px 0 0;font-size:12px;color:var(--ink-muted)}.admin-menu-toggle{border:none;background:#fff;color:var(--brand);font-size:19px;cursor:pointer;width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #2563eb14;border:1px solid rgba(219,234,254,.9);transition:color .2s ease,background .2s ease,transform .2s ease,box-shadow .2s ease;flex-shrink:0}.admin-menu-toggle:hover{color:var(--brand-2);background:var(--hover);transform:translateY(-1px);box-shadow:0 10px 24px #2563eb24}.admin-topbar__user{position:relative;display:flex;align-items:center;gap:12px;justify-content:flex-end}.admin-role-chip,.admin-chip{padding:8px 12px;border-radius:999px;font-size:.84rem;font-weight:700;display:inline-flex;align-items:center;gap:8px;color:#fff;background:#f59e0b;box-shadow:0 8px 16px #ea580c2e}.admin-user-chip{display:flex;align-items:center;gap:10px;min-height:44px;background:#fff;border:1px solid var(--hair);border-radius:999px;padding:6px 10px;cursor:pointer;box-shadow:0 8px 24px #0f172a0f;color:var(--ink);transition:background .2s ease,transform .2s ease}.admin-user-chip:hover{background:var(--hover);transform:translateY(-1px)}.admin-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:#f59e0b;color:#fff;flex-shrink:0}.admin-user-meta{display:grid;line-height:1.1;text-align:left}.admin-user-name{font-weight:700;color:var(--ink)}.admin-user-role{font-size:12px;color:var(--ink-muted)}.admin-user-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:#fff;border:1px solid var(--hair);border-radius:14px;box-shadow:0 16px 36px #0000001a;padding:8px;animation:adminFadeIn .16s ease-out;z-index:30}.admin-user-menu__item{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;padding:11px 12px;text-align:left;border-radius:10px;color:var(--ink);cursor:pointer;transition:background .2s ease;font-weight:500}.admin-user-menu__item:hover{background:var(--hover)}.admin-user-menu__item i{color:#ea580c}@keyframes adminFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.admin-topbar{padding:12px 14px;gap:12px}.admin-topbar__title{font-size:18px}.admin-topbar__subtitle,.admin-user-meta,.admin-role-chip,.admin-chip{display:none}}@media(max-width:680px){.admin-topbar__left{gap:10px}.admin-topbar__user{gap:8px}.admin-user-chip{padding:6px 8px}.admin-sidebar{width:min(88vw,320px);padding:16px 14px 14px}}@media(prefers-reduced-motion:reduce){.admin-sidebar,.admin-sidebar-backdrop,.admin-menu-item,.admin-menu-toggle,.admin-user-chip,.admin-sidebar__close{transition:none}}.acctmng-wrap{padding:20px;display:flex;flex-direction:column;gap:14px;background-color:#fff}.acctmng-header{display:flex;flex-direction:column;gap:12px}.acctmng-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.acctmng-title{margin-top:0;font-size:1.5rem;font-weight:700;margin-bottom:16px}.acctmng-tabs{display:flex;gap:8px;flex-wrap:wrap}.acctmng-tab{border:1px solid #e5e7eb;background:#fff;padding:8px 10px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;color:#111827}.acctmng-tab.acctmng-tab--active{background:#1940ee;color:#fff;font-weight:600;border-color:#1940ee}.acctmng-filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.acctmng-input-icon{position:relative;min-width:260px;flex:1;font-size:14px;font-weight:500}.acctmng-input-icon i{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:.6}.acctmng-input{width:100%;padding:10px 10px 10px 32px;border:1px solid #e5e7eb;border-radius:12px;outline:none}.acctmng-select{padding:10px;border:1px solid #e5e7eb;border-radius:12px;outline:none;background:#fff;font-size:14px;font-weight:500}.acctmng-card{border:1px solid #e5e7eb;border-radius:14px;background:#fff}.acctmng-table-wrap{overflow:auto}.acctmng-table{width:100%;border-collapse:collapse}.acctmng-table th,.acctmng-table td{padding:12px;border-bottom:1px solid #f1f5f9;text-align:left;font-size:16px;font-weight:700}.acctmng-th-actions{width:140px}.acctmng-empty{text-align:center;padding:22px;opacity:.7}.acctmng-name-cell{display:flex;flex-direction:column;gap:3px}.acctmng-name{font-weight:700}.acctmng-sub{font-size:12px;opacity:.65}.acctmng-actions{display:flex;gap:8px}.acctmng-btn{border:1px solid #e5e7eb;background:#fff;padding:10px 12px;border-radius:12px;cursor:pointer;font-size:12px;display:inline-flex;align-items:center;gap:8px}.acctmng-btn:disabled{opacity:.5;cursor:not-allowed}.acctmng-btn-small{padding:8px 10px;border-radius:10px}.acctmng-btn-primary{border-color:#111827;background:#111827;color:#fff}.acctmng-btn-ghost{background:#fff;font-size:14px;font-weight:500}.acctmng-btn-danger{border-color:#ef4444;color:#ef4444}.acctmng-badge{display:inline-flex;padding:5px 10px;border-radius:999px;font-size:12px;border:1px solid #e5e7eb}.acctmng-badge--ok{border-color:#16a34a;color:#16a34a}.acctmng-badge--off{border-color:#ef4444;color:#ef4444}.acctmng-badge--role{border-color:#1118271a}.acctmng-alert{border-radius:12px;font-size:13px}.acctmng-alert--error{color:#b91c1c}.acctmng-alert--success{border-color:#16a34a;color:#166534;background:#f0fdf4}.acctmng-pager{display:flex;justify-content:space-between;align-items:center;padding:12px;gap:10px}.acctmng-pager-left{font-size:12px;opacity:.8}.acctmng-pager-right{display:flex;gap:8px}.acctmng-modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:16px;z-index:2000}.acctmng-modal{width:min(720px,100%);background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #00000026;position:relative;z-index:2001}.acctmng-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 0}.acctmng-modal-title{margin:0;font-size:16px;font-weight:800}.acctmng-form{padding:14px;display:flex;flex-direction:column;gap:12px}.acctmng-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.acctmng-span-2{grid-column:span 2}.acctmng-field{display:flex;flex-direction:column;gap:6px}.acctmng-field label{font-size:16px;font-weight:700}.acctmng-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:6px}.acctmng-tableLoader{display:flex;align-items:center;justify-content:center;gap:12px;padding:18px;color:#475569}.acctmng-spinner{width:18px;height:18px;border:2px solid #dbeafe;border-top-color:#2563eb;border-radius:999px;animation:acctmng-spin .7s linear infinite}@keyframes acctmng-spin{to{transform:rotate(360deg)}}:root{--acad-border: #e5e7eb;--acad-border-soft: #f1f5f9;--acad-text: #111827;--acad-text-muted: #64748b;--acad-blue: #1940ee;--acad-blue-ring: rgba(25, 64, 238, .08);--acad-success: #16a34a;--acad-success-bg: #f0fdf4;--acad-danger: #ef4444;--acad-danger-bg: #fef2f2;--acad-panel: #ffffff;--acad-shadow: 0 20px 60px rgba(0, 0, 0, .15)}.acadsetup-wrap{display:flex;flex-direction:column;gap:14px;padding:20px;background:#fff;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif}.acadsetup-header{display:flex;flex-direction:column;gap:12px}.acadsetup-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.acadsetup-title{margin:0;font-size:1.5rem;font-weight:700}.acadsetup-tabs{display:flex;gap:8px;flex-wrap:wrap}.acadsetup-tab,.acadsetup-step-tab{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--acad-border);background:#fff;color:var(--acad-text);border-radius:10px;padding:8px 12px;font-size:14px;font-weight:600;cursor:pointer;transition:.18s ease}.acadsetup-tab:hover,.acadsetup-step-tab:hover{border-color:#cbd5e1;background:#f8fafc}.acadsetup-tab--active,.acadsetup-step-tab--active,.acadsetup-tab.acadsetup-tab--active{background:var(--acad-blue);color:#fff;border-color:var(--acad-blue)}.acadsetup-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.acadsetup-input-icon{position:relative;min-width:260px;flex:1;font-size:14px;font-weight:500}.acadsetup-input-icon i{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:.6}.acadsetup-input,.acadsetup-select,.field input,.field select,.field textarea{width:100%;box-sizing:border-box;border:1px solid var(--acad-border);border-radius:12px;background:#fff;color:var(--acad-text);padding:10px 12px;font-size:14px;font-weight:500;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.acadsetup-input:focus,.acadsetup-select:focus,.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--acad-blue);box-shadow:0 0 0 3px var(--acad-blue-ring)}.acadsetup-input-icon .acadsetup-input{padding-left:32px}.acadsetup-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--acad-border);background:#fff;color:var(--acad-text);border-radius:12px;padding:10px 12px;font-size:12px;cursor:pointer;transition:.18s ease}.acadsetup-btn:hover{border-color:#cbd5e1;background:#f8fafc}.acadsetup-btn:disabled{opacity:.5;cursor:not-allowed}.acadsetup-btn-small{padding:8px 10px;border-radius:10px;font-size:12px}.acadsetup-btn-ghost{background:#fff;font-size:14px;font-weight:500}.acadsetup-btn-primary{background:#111827;color:#fff;border-color:#111827}.acadsetup-btn-danger{border-color:var(--acad-danger);color:var(--acad-danger)}.acadsetup-badge{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border:1px solid var(--acad-border);border-radius:999px;background:#fff;color:#334155;font-size:12px;font-weight:600}.acadsetup-badge--ok{border-color:var(--acad-success);background:var(--acad-success-bg);color:var(--acad-success)}.acadsetup-badge--off{border-color:var(--acad-danger);background:var(--acad-danger-bg);color:var(--acad-danger)}.acadsetup-alert{padding:10px 12px;border-radius:12px;border:1px solid transparent;font-size:13px;margin-top:4px}.acadsetup-alert--error{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.acadsetup-alert--success{color:#166534;background:#f0fdf4;border-color:#16a34a}.acadsetup-card,.card{border:1px solid var(--acad-border);border-radius:14px;background:var(--acad-panel)}.card{padding:16px}.acadsetup-tableWrap{overflow:auto}.acadsetup-table{width:100%;border-collapse:collapse}.acadsetup-table th,.acadsetup-table td{padding:12px;border-bottom:1px solid var(--acad-border-soft);text-align:left;vertical-align:middle;font-size:14px}.acadsetup-table th{background:#fcfcfd;color:var(--acad-text);font-weight:700}.acadsetup-table td{color:#1f2937;font-weight:500}.acadsetup-th-actions{width:140px}.acadsetup-empty,.empty{text-align:center;opacity:.75}.acadsetup-empty{padding:22px}.acadsetup-actions,.as-actions,.actions-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.acadsetup-actions,.as-actions{justify-content:center;white-space:nowrap}.actions-row{justify-content:flex-end}.acadsetup-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;padding:12px}.acadsetup-pager-left{font-size:12px;opacity:.8}.acadsetup-pager-right{display:flex;gap:8px}.acadsetup-modal-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;background:#0f172a61}.acadsetup-modal{position:relative;z-index:2001;width:min(720px,100%);max-height:90vh;overflow-y:auto;background:#fff;border:1px solid var(--acad-border);border-radius:16px;box-shadow:var(--acad-shadow)}.acadsetup-modal--wide{width:min(1180px,100%);max-height:calc(100vh - 40px);overflow:hidden;border-radius:20px;display:flex;flex-direction:column}.acadsetup-modal-header{position:sticky;top:0;z-index:10;padding:16px 20px 12px;background:#fffffff5;border-bottom:1px solid #eef2f7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.acadsetup-modal-headcopy{display:grid;gap:4px;margin-bottom:4px}.acadsetup-modal-title{margin:0;font-size:16px;font-weight:800;color:var(--acad-text)}.acadsetup-modal-subtitle{margin:0;font-size:13px;color:var(--acad-text-muted);font-weight:500}.acadsetup-step-tabs{display:inline-flex;gap:8px;flex-wrap:wrap}.acadsetup-form{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding:18px 20px}.acadsetup-modal-footer{position:sticky;bottom:0;z-index:10;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;padding:14px 20px;background:#fffffff5;border-top:1px solid #eef2f7}.acadsetup-grid,.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.acadsetup-span-2,.field.span-2{grid-column:span 2}.acadsetup-field,.field{display:flex;flex-direction:column;gap:6px}.acadsetup-field label,.field label{font-size:14px;font-weight:700;color:var(--acad-text)}.muted{opacity:.75}.as-section{border:1px solid var(--acad-border);border-radius:14px;padding:16px;background:#fff}.as-section h4{margin:0 0 12px;font-size:15px;font-weight:800;color:var(--acad-text)}.as-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:14px}.as-section-subtitle{margin:6px 0 0;font-size:13px;color:var(--acad-text-muted)}.as-checkboxRow{display:flex;align-items:center;gap:10px;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:600;opacity:.95}.as-checkboxRow input{transform:translateY(1px)}.as-mapping-grid{display:grid;gap:12px}.as-mapping-row{display:grid;grid-template-columns:140px repeat(4,minmax(0,1fr));gap:12px;align-items:center}.as-mapping-header{color:var(--acad-text-muted);font-size:.78rem;font-weight:700;letter-spacing:.02em}.as-program-map-card{display:grid;gap:12px;border:1px solid var(--acad-border);border-radius:16px;background:#fff;padding:14px}.as-program-map-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.as-program-map-title{display:grid;gap:4px}.as-program-cell,.as-program-code{font-weight:800;color:#0f172a}.as-program-code{font-size:1.05rem;line-height:1}.as-program-name{font-size:13px;color:var(--acad-text-muted);line-height:1.35}.as-mapping-actions{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}.as-review-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.as-review-card,.as-review-block{border:1px solid var(--acad-border);border-radius:14px;padding:14px;background:#fff}.as-review-block{margin-top:14px}.as-review-title{margin-bottom:10px;font-weight:800;color:var(--acad-text)}.as-review-list,.as-review-stack,.as-preview-stack{display:grid;gap:8px}.as-preview-stack{gap:12px}.as-review-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--acad-border-soft);border-radius:12px}.as-review-code{font-weight:700;color:var(--acad-text)}.as-review-meta{font-size:12px;color:var(--acad-text-muted)}.as-preview-card{border:1px solid var(--acad-border-soft);border-radius:12px;padding:12px}.as-preview-head{margin-bottom:8px;color:var(--acad-text)}.as-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;font-size:13px}.as-preview-item{border:1px solid var(--acad-border-soft);border-radius:10px;padding:10px}.as-preview-item-title{margin-bottom:6px;font-weight:700;color:var(--acad-text)}.as-preview-item-value{color:#475569}.ay-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.ay-card{border:1px solid var(--acad-border);border-radius:14px;background:#fff;padding:14px}.ay-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.ay-card-header h4{margin:0;font-size:16px;font-weight:800;color:var(--acad-text)}.ay-card-body{display:grid;gap:10px}.ay-semester{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px;border:1px solid var(--acad-border-soft);border-radius:12px}.ay-semester strong,.ay-semester b{color:var(--acad-text)}.ay-ongoing{width:10px;height:10px;border-radius:999px}.ay-ongoing.on{background:var(--acad-success)}.ay-ongoing.off{background:#cbd5e1}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--acad-border);border-radius:10px;background:#fff;color:var(--acad-text);cursor:pointer;transition:.18s ease}.icon-btn:hover{border-color:#cbd5e1;background:#f8fafc}.icon-btn.edit:hover{color:var(--acad-blue);border-color:#1940ee40;background:#1940ee0a}.icon-btn.danger:hover{color:#dc2626;border-color:#dc262640;background:#dc26260a}.as-scrollable-area::-webkit-scrollbar,.acadsetup-tableWrap::-webkit-scrollbar,.acadsetup-modal::-webkit-scrollbar{width:6px;height:6px}.as-scrollable-area::-webkit-scrollbar-track,.acadsetup-tableWrap::-webkit-scrollbar-track,.acadsetup-modal::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.as-scrollable-area::-webkit-scrollbar-thumb,.acadsetup-tableWrap::-webkit-scrollbar-thumb,.acadsetup-modal::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.as-scrollable-area::-webkit-scrollbar-thumb:hover,.acadsetup-tableWrap::-webkit-scrollbar-thumb:hover,.acadsetup-modal::-webkit-scrollbar-thumb:hover{background:#94a3b8}.rs__control{min-height:40px!important;border-radius:10px!important;border-color:var(--acad-border)!important;box-shadow:none!important}.rs__control--is-focused{border-color:var(--acad-blue)!important;box-shadow:0 0 0 3px var(--acad-blue-ring)!important}.rs__value-container{padding:0 10px!important}.rs__menu{z-index:60!important}@media(max-width:980px){.acadsetup-grid,.form-grid,.as-review-grid{grid-template-columns:1fr}.acadsetup-span-2,.field.span-2{grid-column:span 1}.as-mapping-row{grid-template-columns:1fr}.as-preview-grid,.ay-card-grid{grid-template-columns:1fr 1fr}}@media(max-width:680px){.acadsetup-wrap{padding:14px}.acadsetup-title-row{align-items:stretch}.acadsetup-title{font-size:1.3rem}.acadsetup-modal-overlay{padding:10px}.acadsetup-modal,.acadsetup-modal--wide{width:100%;max-height:92vh;border-radius:14px}.acadsetup-step-tabs{width:100%}.acadsetup-step-tab{flex:1 1 calc(33.333% - 6px);text-align:center}.acadsetup-modal-footer{flex-direction:column-reverse;align-items:stretch}.acadsetup-btn,.bttn{width:100%;justify-content:center}.acadsetup-pager{flex-direction:column;align-items:stretch}.acadsetup-pager-right{width:100%;display:grid;grid-template-columns:1fr 1fr}.as-preview-grid,.ay-card-grid{grid-template-columns:1fr}}@media print{.no-print,.acadsetup-header,.acadsetup-tabs,.acadsetup-filters,.acadsetup-modal-footer,.icon-btn,.acadsetup-btn,.bttn{display:none!important}.acadsetup-wrap,.acadsetup-card,.ay-card,.as-section{box-shadow:none!important;border-color:#d1d5db!important}.acadsetup-modal-overlay{position:static!important;background:#fff!important;padding:0!important}.acadsetup-modal,.acadsetup-modal--wide{width:100%!important;max-width:none!important;max-height:none!important;overflow:visible!important;box-shadow:none!important}body{background:#fff!important}}.acadsetup-tableLoader,.acadsetup-sectionLoader{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;color:#475569}.acadsetup-spinner{width:18px;height:18px;border:2px solid #dbeafe;border-top-color:#2563eb;border-radius:999px;animation:acadsetup-spin .7s linear infinite}@keyframes acadsetup-spin{to{transform:rotate(360deg)}}.ay-semester--active{border-color:#bbf7d0!important;background:#f0fdf4}.ay-card-meta{margin-top:6px;font-size:12px;color:#64748b}.settings{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background:#fff}.settings-title{font-size:1.5rem;font-weight:700;margin-bottom:16px}.settings{display:grid;gap:16px}.settings-title{margin:0}.card-head{margin-bottom:16px}.muted{color:#64748b;font-size:.95rem}.alert{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;font-size:.95rem;margin-bottom:10px}.alert.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.alert.danger{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.pw-wrap{position:relative;display:flex;align-items:center}.pw-wrap input{width:100%;padding-right:44px}.pw-wrap .icon-btn.ghost{position:absolute;right:6px;top:50%;transform:translateY(-50%)}.pw-strength{display:flex;align-items:center;gap:10px;margin-top:8px}.pw-bar{flex:1;height:8px;background:#eef2f7;border-radius:999px;overflow:hidden}.pw-fill{height:100%;width:0%;transition:width .25s ease;background:#fca5a5}.pw-fill.s2{background:#fde68a}.pw-fill.s3{background:#86efac}.pw-fill.s4{background:#34d399}.pw-rules{list-style:none;padding:8px 0 0;margin:0;display:grid;gap:4px;color:#64748b;font-size:.92rem}.pw-rules li.ok{color:#065f46}:root{--bg: #f5f7fb;--panel: #ffffff;--ink: #0f172a;--ink-muted: #64748b;--hair: #e5e7eb;--brand: #1e3a8a;--brand-2: #2563eb;--hover: #eef2ff;--active: #dbeafe;--shadow: 0 10px 30px rgba(2, 6, 23, .08);--sidebar-w: 290px;--topbar-h: 76px}.prof-shell.prof--light{position:relative;min-height:100vh;background:var(--bg);color:var(--ink);font-family:Lexend,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.prof-main{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.prof-content{flex:1;min-height:0;overflow-y:auto}.prof-sidebar-backdrop{position:fixed;inset:0;background:#0f172a6b;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease;z-index:1090}.prof-sidebar-backdrop.is-visible{opacity:1;visibility:visible;pointer-events:auto}.prof-sidebar{position:fixed;top:0;left:0;width:min(var(--sidebar-w),calc(100vw - 28px));height:100vh;background:radial-gradient(circle at top right,rgba(255,255,255,.14),transparent 28%),linear-gradient(180deg,#1e3a8a,#2563eb);color:#fff;display:flex;flex-direction:column;padding:18px 16px 16px;gap:18px;box-shadow:0 20px 50px #02061740;transform:translate(-100%);transition:transform .3s ease;z-index:1100;overflow-y:auto}.prof-sidebar.is-open{transform:translate(0)}.prof-sidebar__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.prof-sidebar__brand{display:flex;align-items:center;gap:12px;flex:1;min-width:0;padding:12px;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;box-shadow:inset 0 0 0 1px #ffffff0a}.prof-sidebar__brand-copy{min-width:0}.prof-sidebar__logo{width:46px;height:46px;object-fit:contain;flex-shrink:0}.prof-sidebar__title{margin:0;font-size:18px;font-weight:800;color:#fff;letter-spacing:.2px}.prof-sidebar__subtitle{margin:3px 0 0;font-size:12px;color:#ffffffc7}.prof-sidebar__close{width:42px;height:42px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:#ffffff1a;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease;flex-shrink:0}.prof-sidebar__close:hover{background:#ffffff2e;transform:translateY(-1px)}.prof-sidebar__menu{display:flex;flex-direction:column;gap:8px;margin-top:4px}.prof-menu-item,.prof-menu-item-static{display:flex;align-items:center;gap:12px;min-height:48px;padding:12px 14px;border-radius:14px;color:#ffffffe6;text-decoration:none;font-weight:600;transition:background .2s ease,transform .2s ease,color .2s ease}.prof-menu-item i,.prof-menu-item-static i{width:18px;text-align:center;color:#dbeafe;font-size:15px;flex-shrink:0}.prof-menu-item:hover{background:#ffffff1f;color:#fff;transform:translate(2px)}.prof-menu-item.active{background:#ffffff2e;color:#fff;box-shadow:inset 0 0 0 1px #ffffff14}.prof-menu-item-static{opacity:.95}.prof-menu-item--subject{min-height:42px;padding:10px 14px 10px 44px;font-size:13px;font-weight:600;border-radius:12px;color:#ffffffdb;opacity:.96}.prof-menu-item--subject i{width:14px;font-size:11px;color:#dbeafe}.prof-menu-item--subject span{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prof-sidebar__empty{display:block;padding:10px 14px;font-size:13px;color:#ffffffc7}.prof-topbar{position:sticky;top:0;z-index:100;height:var(--topbar-h);display:flex;justify-content:space-between;align-items:center;gap:18px;background:#ffffffeb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:14px 20px;border-bottom:1px solid rgba(229,231,235,.9);box-shadow:0 8px 22px #0f172a0a}.prof-topbar__left{display:flex;align-items:center;gap:14px;min-width:0}.prof-topbar__title-wrap{min-width:0}.prof-topbar__title{margin:0;font-size:20px;font-weight:800;color:var(--brand);line-height:1.1}.prof-topbar__subtitle{margin:3px 0 0;font-size:12px;color:var(--ink-muted)}.prof-menu-toggle{border:none;background:#fff;color:var(--brand);font-size:19px;cursor:pointer;width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #2563eb14;border:1px solid rgba(219,234,254,.9);transition:color .2s ease,background .2s ease,transform .2s ease,box-shadow .2s ease;flex-shrink:0}.prof-menu-toggle:hover{color:var(--brand-2);background:var(--hover);transform:translateY(-1px);box-shadow:0 10px 24px #2563eb24}.prof-topbar__user{position:relative;display:flex;align-items:center;gap:12px;justify-content:flex-end;flex-wrap:wrap}.prof-role-chip,.prof-chip,.head-chip{padding:8px 12px;border-radius:999px;font-size:.84rem;font-weight:700;display:inline-flex;align-items:center;gap:8px;color:#fff}.prof-chip{background:#16a34a;box-shadow:0 8px 16px #16a34a2e}.head-chip{background:#2563eb;box-shadow:0 8px 16px #2563eb2e}.prof-role-switch-btn{width:38px;height:38px;background:#fff;border:1.5px solid #dbe3f0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .12s ease;position:relative}.prof-role-switch-btn i{font-size:14px;color:#2f54eb;transition:transform .22s ease,color .2s ease}.prof-role-switch-btn:hover{background:#eef3ff;border-color:#2f54eb}.prof-role-switch-btn:hover i{transform:rotate(180deg) scale(1.06);color:#1e4ed8}.prof-role-switch-btn:active{transform:scale(.96)}.prof-role-switch-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2f54eb38}.prof-role-switch-btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;top:50%;right:calc(100% + 10px);transform:translateY(-50%);background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;line-height:1;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.prof-role-switch-btn[data-tooltip]:before{content:"";position:absolute;top:50%;right:calc(100% + 4px);transform:translateY(-50%);border-width:6px;border-style:solid;border-color:transparent transparent transparent #111827;opacity:0;pointer-events:none;transition:opacity .15s ease}.prof-role-switch-btn:hover:after,.prof-role-switch-btn:hover:before{opacity:1;transform:translateY(-50%) translate(-2px)}.prof-user-chip{display:flex;align-items:center;gap:10px;min-height:44px;background:#fff;border:1px solid var(--hair);border-radius:999px;padding:6px 10px;cursor:pointer;box-shadow:0 8px 24px #0f172a0f;color:var(--ink);transition:background .2s ease,transform .2s ease}.prof-user-chip:hover{background:var(--hover);transform:translateY(-1px)}.prof-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:#16a34a;color:#fff;flex-shrink:0}.prof-user-meta{display:grid;line-height:1.1;text-align:left}.prof-user-name{font-weight:700;color:var(--ink)}.prof-user-role{font-size:12px;color:var(--ink-muted)}.prof-user-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:#fff;border:1px solid var(--hair);border-radius:14px;box-shadow:0 16px 36px #0000001a;padding:8px;animation:profFadeIn .16s ease-out;z-index:30}.prof-user-menu__item{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;padding:11px 12px;text-align:left;border-radius:10px;color:var(--ink);cursor:pointer;transition:background .2s ease;font-weight:500}.prof-user-menu__item:hover{background:var(--hover)}.prof-user-menu__item i{color:#16a34a}@keyframes profFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.prof-topbar{padding:12px 14px;gap:12px}.prof-topbar__title{font-size:18px}.prof-topbar__subtitle,.prof-user-meta,.prof-role-chip,.prof-chip,.head-chip{display:none}}@media(max-width:680px){.prof-topbar__left{gap:10px}.prof-topbar__user{gap:8px}.prof-user-chip{padding:6px 8px}.prof-sidebar{width:min(88vw,320px);padding:16px 14px 14px}}@media(prefers-reduced-motion:reduce){.prof-sidebar,.prof-sidebar-backdrop,.prof-menu-item,.prof-menu-toggle,.prof-user-chip,.prof-sidebar__close,.prof-role-switch-btn{transition:none}}.prof-notification-wrap{position:relative}.prof-notification-btn{width:42px;height:42px;border:1px solid #e5e7eb;background:#fff;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;color:#374151;cursor:pointer;position:relative;transition:.18s ease}.prof-notification-btn:hover{background:#f9fafb;border-color:#d1d5db}.prof-notification-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:2px solid #ffffff}.prof-notification-popover{position:absolute;top:calc(100% + 12px);right:0;width:380px;max-width:calc(100vw - 28px);background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 20px 45px #0f172a24;z-index:80;overflow:hidden}.prof-notification-head{padding:16px 18px;border-bottom:1px solid #f1f5f9;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.prof-notification-head h4{margin:0;font-size:15px;font-weight:800;color:#111827}.prof-notification-head p{margin:3px 0 0;font-size:12px;color:#6b7280}.prof-notification-close{border:0;background:#f3f4f6;color:#374151;width:28px;height:28px;border-radius:9px;cursor:pointer}.prof-notification-list{max-height:420px;overflow-y:auto;padding:8px}.prof-notification-empty{padding:28px 14px;text-align:center;color:#6b7280;font-size:13px}.prof-notification-item{width:100%;text-align:left;cursor:pointer}.prof-notification-item.is-unread{background:#eff6ff;border-color:#bfdbfe}.prof-notification-item-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.prof-notification-item-top strong{font-size:13px;color:#111827;line-height:1.3}.prof-notification-date{font-size:11px;color:#6b7280;white-space:nowrap}.prof-notification-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:7px}.prof-notification-row span{font-size:11px;color:#6b7280;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.notif-status{font-size:12px;padding:4px 9px;border-radius:999px;background:#f3f4f6;color:#374151}.notif-status.approved,.notif-status.reviewed{background:#dcfce7;color:#166534}.notif-status.rejected{background:#fee2e2;color:#991b1b}.notif-status.pending,.notif-status.submitted{background:#fef3c7;color:#92400e}.prof-notification-row.remarks{align-items:flex-start;flex-direction:column;gap:4px}.prof-notification-row.remarks p{margin:0;font-size:12.5px;color:#374151;line-height:1.45}.prof-dashboard{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background-color:#fff;min-height:100vh;display:flex;flex-direction:column}.prof-dashboard__title{font-size:1.5rem;font-weight:700;margin-bottom:16px}.prof-dashboard__main{flex:1;display:grid;grid-template-columns:minmax(0,3fr) minmax(0,1.2fr);gap:20px;align-items:stretch}.prof-left-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-areas:"students    pass      atrisk" "keyPerf    keyPerf  quickActions " "atRisklist  atRisklist    atRisklist";gap:16px}.prof-card--students{grid-area:students}.prof-card--pass{grid-area:pass}.prof-card--atrisk{grid-area:atrisk}.prof-card--quickActions{grid-area:quickActions}.prof-card--keyPerf{grid-area:keyPerf}.prof-card--gwa{grid-area:atRisklist}.prof-card--ranking{grid-area:ranking}.prof-right-column{display:flex;flex-direction:column;gap:16px;align-self:stretch}.card.prof-card{background:#fff;border-radius:16px;border:1px solid #E5E7EB;padding:16px;display:flex;align-items:center;gap:12px;transition:transform .2s ease,box-shadow .2s ease}.card.prof-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #0000001a}.card-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;color:#fff;font-size:20px;flex-shrink:0}.card-icon.students{background:#2563eb}.card-icon.pass{background:#10b981}.card-icon.atrisk{background:#f52a0b}.card-content h3{margin:0;font-size:1.7rem;font-weight:800}.card-content p{margin:4px 0 0;font-size:.95rem;color:#6b7280}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.card-header h3{margin:0;font-size:1.1rem;font-weight:800}.card-header i{color:#2563eb}.card-content--kpi{display:flex;justify-content:space-between;align-items:center;width:100%}.kpi-left{display:flex;flex-direction:column}.mini-breakdown{display:flex;flex-direction:column;align-items:flex-end;gap:2px;text-align:right;padding-right:10px}.mini-breakdown span{font-size:.7rem;font-weight:700;opacity:.7}.mini-breakdown .count{font-size:.8rem;color:#0554ff;font-weight:900;opacity:1}@media(max-width:900px){.mini-breakdown{gap:4px 10px;font-size:.72rem}}@media(max-width:600px){.mini-breakdown{justify-content:center;text-align:center;gap:4px 8px}}.prof-card--quickActions,.prof-card--keyPerf{flex-direction:column;align-items:stretch}.chart-placeholder{background:#f3f4f6;border-radius:10px;width:100%;height:220px;display:grid;place-items:center;color:#6b7280}.prof-card--quickActions{flex-direction:column;align-items:stretch}.qa-selectors{display:grid;gap:10px;margin-bottom:12px}.actions{display:grid;gap:10px}.action-btn{height:40px;border-radius:10px;border:1px solid #dbeafe;background:#eef2ff;color:#1e3a8a;font-weight:700;cursor:pointer}.action-btn:hover{background:#e0e7ff}.prof-card--atRisklist,.prof-card--keyPerf,.prof-card--ranking{flex-direction:column;align-items:stretch}.prof-card--atRisklist .card-header,.prof-card--keyPerf .card-header,.prof-card--ranking .card-header{margin-bottom:10px}.kpi-toggle{display:flex;gap:8px;margin-top:8px}.kpi-chip{border:1px solid #e5e7eb;background:#f9fafb;color:#6b7280;padding:4px 10px;border-radius:999px;font-size:.78rem;cursor:pointer;transition:.15s ease}.kpi-chip:hover{background:#f1f5f9}.kpi-chip.is-active{border-color:#3b82f6;background:#dbeafe;color:#1d4ed8}.mini-bar-chart{margin-top:10px;height:220px;display:flex;align-items:flex-end;gap:16px;padding:8px 4px 0;justify-content:space-evenly}.bar-tooltip-wrapper{position:relative;display:flex;justify-content:center}.bar-tooltip{position:absolute;bottom:100%;margin-bottom:8px;background:#0f172a;color:#f9fafb;padding:6px 8px;border-radius:8px;font-size:.7rem;text-align:center;white-space:nowrap;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:10}.bar-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:#0f172a transparent transparent transparent}.bar-tooltip-wrapper:hover .bar-tooltip{opacity:1;transform:translateY(0)}.bar-tooltip-total{margin-top:2px;font-size:.65rem;color:#cbd5f5}.stacked-bar{width:48px;height:200px;border-radius:18px;background:#e5e7eb;display:flex;flex-direction:column-reverse;overflow:hidden;transition:.2s ease}.stacked-bar:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}.stacked-segment{width:100%}.stacked-pass{background:#25eb7e}.stacked-risk{background:#ef4444}.bar-group{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.stacked-label{font-size:.8rem;font-weight:600;color:#475569;margin-top:6px}.stacked-values{font-size:.76rem;color:#334155}.sv-pass{color:#2563eb;font-weight:600}.sv-risk{color:#dc2626;font-weight:600}.risk-total{margin:4px 0 10px;padding:8px 10px;border-radius:10px;border:1px solid#E5E7EB;text-align:center}.risk-total-label{font-size:.94rem;color:#5a687c;letter-spacing:.04em;margin-bottom:2px}.risk-total-value{font-size:3.1rem;font-weight:800;color:#1d4ed8;line-height:1.1}.risk-total-sub{font-size:.8rem;color:#475569;margin-top:2px}.risk-breakdown{display:flex;flex-direction:column;gap:12px}.risk-item{display:grid;grid-template-columns:1fr auto 40px;align-items:center;gap:10px}.risk-label{font-size:.85rem;color:#334155;font-weight:600}.risk-bar{height:8px;border-radius:6px;background:#e2e8f0;position:relative;overflow:hidden}.risk-bar--grade{background:#fecaca}.risk-bar--attendance{background:#fde68a}.risk-bar--both{background:#c7d2fe}.risk-count{font-size:.9rem;font-weight:700;color:#0f172a}.filters{display:flex;align-items:center;gap:10px}.small-select{background:#fff;color:#334155;border:1px solid #cbd5e1;padding:6px 32px 6px 12px;border-radius:8px;font-size:.85rem;cursor:pointer;outline:none;transition:.15s ease;height:34px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg fill='none' stroke='%236b7280' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}.small-select:hover{border-color:#94a3b8}.small-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f640}.small-select:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.small-select option{background:#fff;color:#334155}.tiny-note{margin-top:6px;font-size:.78rem;color:#475569;padding:6px 8px;border-radius:6px;background:#f8fafc;border:1px dashed #e2e8f0}@media(max-width:1100px){.prof-dashboard__main{grid-template-columns:1fr}.prof-left-grid{grid-template-columns:repeat(2,1fr);grid-template-areas:"students    pass" "atrisk      atrisk" "keyPerf     keyPerf" "quickActions quickActions" "atRisklist  atRisklist"}.prof-right-column{flex-direction:row;flex-wrap:wrap;gap:16px}.prof-card--calendar,.prof-card--ranking{flex:1 1 360px}}@media(max-width:700px){.prof-left-grid{grid-template-columns:1fr;grid-template-areas:"students" "pass" "atrisk" "keyPerf" "quickActions" "atRisklist"}.prof-right-column{flex-direction:column}}.prof-card--calendar{display:flex;flex-direction:column;align-items:stretch;min-height:580px}.prof-card--ranking{flex-shrink:0}.mini-cal{width:100%;background:#fff;border-radius:12px;padding:8px;border:1px solid #e5e7eb;display:flex;flex-direction:column;flex:1}.mini-cal-header{font-size:.9rem;font-weight:700;margin-bottom:6px;color:#0f172a;text-align:center}.mini-cal-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px;margin-bottom:4px}.mini-cal-dow{text-align:center;font-size:.7rem;font-weight:600;color:#6b7280;background:#e5edff;border-radius:6px;padding:2px 0}.mini-cal-grid{flex:1;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.mini-cal-cell{height:100%;min-height:40px;border-radius:8px;background:#fff;border:1px solid #e5e7eb;padding:4px;display:flex;flex-direction:column;justify-content:space-between}.mini-cal-cell.is-outside-month{background:#f3f4f6;color:#9ca3af}.mini-cal-date{font-size:.7rem;font-weight:600;color:#0f172a}.mini-cal-dots{display:flex;gap:2px;margin-top:2px}.mini-dot{width:6px;height:6px;border-radius:999px}.mini-dot--exam{background:#2563eb}.mini-dot--event{background:#f97316}.mini-dot--holiday{background:#16a34a}.mini-dot--noclass{background:#ef4444}.mini-cal-legend{display:flex;gap:12px;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;font-size:.75rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot--exam{background:#2563eb}.legend-dot--event{background:#f97316}.legend-dot--holiday{background:#16a34a}.legend-dot--noclass{background:#ef4444}.calendar-mini-list{list-style:none;margin:8px 0 6px;padding:0;display:flex;flex-direction:column;gap:8px}.mini-event{display:grid;grid-template-columns:64px 1fr;gap:10px;padding:8px 10px;border-radius:10px;background:#f8fafc;border:1px solid #e5e7eb}.mini-event-date{font-size:.8rem;font-weight:700;color:#1d4ed8;background:#e0ecff;border-radius:10px;display:flex;align-items:center;justify-content:center}.mini-event-main{display:flex;flex-direction:column;gap:2px}.mini-event-title{font-size:.9rem;font-weight:600;color:#0f172a}.mini-event-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:.75rem;color:#64748b}.mini-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-weight:600;font-size:.7rem}.mini-event--exam .mini-pill--exam{background:#dbeafe;color:#1d4ed8}.mini-event--event .mini-pill--event{background:#ffedd5;color:#ea580c}.mini-event--holiday .mini-pill--holiday{background:#dcfce7;color:#166534}.mini-event--no_class .mini-pill--no_class{background:#fee2e2;color:#b91c1c}.mini-event-date-full{color:#9ca3af}.mini-link{font-size:.78rem;color:#2563eb;text-decoration:none;font-weight:600}.mini-link:hover{text-decoration:underline}.prof-card--gwa{flex-direction:column;align-items:stretch;height:100%}.prof-card--gwa .gwa-chart-wrapper{flex:1;width:100%;min-height:260px}.gwa-rechart{width:100%;height:220px;border:1px solid #E5E7EB;border-radius:12px;background:#fff;padding:10px}.grad-att{display:flex;flex-direction:column;gap:10px}.grad-att .att-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.grad-att .prof-attendance__title{margin:0;font-size:1.2rem;font-weight:700}.grad-att .prof-attendance__subtitle{margin:2px 0 0;font-size:.9rem;color:#64748b}.grad-att .att-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.grad-att .prof-card{background:#fff;border-radius:14px;border:1px solid #e5e7eb;padding:10px 12px;display:flex;align-items:center;gap:8px}.grad-att .card-icon{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:16px}.grad-att .card-icon.records{background:#334155}.grad-att .card-icon.present{background:#16a34a}.grad-att .card-icon.late{background:#f59e0b}.grad-att .card-icon.absent{background:#dc2626}.grad-att .card-content h3{margin:0;font-size:1.8rem;font-weight:700}.grad-att .card-content p{margin:0;font-size:.94rem;color:#6b7280}.grad-att .att-card{background:#fff;border-radius:14px;border:1px solid #e5e7eb;padding:10px;display:flex;flex-direction:column;gap:6px}.grad-att .att-toolbar{display:flex;gap:12px;justify-content:space-between;align-items:center;margin:10px 0 14px}.grad-att .search{display:flex;align-items:center;gap:8px;border:1px solid #e2e8f0;border-radius:10px;min-width:200px}.grad-att .search input{width:100%;height:40px;border:1px solid #e5e7eb;padding:0 12px 0 36px;outline:none}.grad-att .toolbar-right{display:flex;align-items:center;gap:10px}.grad-att .filter{display:grid;gap:2px;font-size:14px;color:#475569}.grad-att .ay-select,.grad-att .ctrl{height:30px;border-radius:8px;border:1px solid #e2e8f0;padding:0 8px;font-size:16px}.grad-att .table-scroll{width:100%;max-height:260px;overflow:auto;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc}.grad-att .att-table{width:100%;border-collapse:collapse;font-size:.94rem}.grad-att .att-table thead th{position:sticky;top:0;background:#eef2ff;color:#1e3a8a;text-align:left;padding:8px 10px;border-bottom:1px solid #e5e7eb;font-size:16px}.grad-att .att-table tbody td{padding:8px 10px;border-bottom:1px solid #eef2f4;color:#334155}.grad-att .att-table tbody tr:hover{background:#f3f4f6}.grad-att .chip{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;border-radius:999px;font-size:.7rem;border:1px solid transparent}.grad-att .chip.ok{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.grad-att .chip.warn{background:#fffbeb;color:#854d0e;border-color:#fde68a}.grad-att .chip.danger{background:#fef2f2;color:#7f1d1d;border-color:#fecaca}.att-history-card{background:#fff;border:1px solid #e6eaf2;border-radius:14px;padding:14px;margin-bottom:14px}.att-history-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.att-history-title{margin:0;font-size:16px;font-weight:700;color:#111827}.att-history-sub{margin:4px 0 0;font-size:12px;color:#6b7280}.att-history-list{display:grid;gap:10px}.att-history-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:12px;border:1px solid #eef2f7;background:#f8fafc;cursor:pointer;transition:background .15s ease,transform .08s ease;text-align:left}.att-history-row:hover{background:#eef2ff}.att-history-row:active{transform:scale(.99)}.att-history-left{min-width:0}.att-history-date{font-weight:700;color:#111827}.att-history-meta{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px}.att-pill{font-size:12px;color:#374151;padding:4px 8px;border-radius:999px;border:1px solid #e5e7eb;background:#fff}.att-history-right{display:flex;align-items:center;gap:8px}.att-row-chevron{color:#6b7280;margin-left:4px}.att-history-empty{padding:12px;color:#6b7280;font-size:13px;border:1px dashed #e5e7eb;border-radius:12px;background:#fafafa}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:grid;place-items:center;z-index:9999;padding:18px}.modal-card{background:#fff;width:760px;max-width:100%;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px #0003}.modal-card--wide{width:900px}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px;border-bottom:1px solid #eef2f7}.modal-title{margin:0;font-weight:900;color:#111827}.modal-subtitle{margin:4px 0 0;font-size:12px;color:#6b7280}.modal-close{border:1px solid #e5e7eb;background:#fff;width:34px;height:34px;border-radius:10px;cursor:pointer}.modal-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.modal-kpi{border:1px solid #eef2f7;border-radius:12px;padding:10px 12px;background:#f8fafc}.modal-kpi-label{font-size:12px;color:#6b7280}.modal-kpi-value{font-size:22px;font-weight:900;color:#111827;margin-top:2px}.modal-kpi-sub{font-size:12px;color:#6b7280;margin-top:2px}.modal-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.modal-tabs{display:flex;gap:8px;padding:4px;border:1px solid #e6eaf2;background:#f8fafc;border-radius:12px}.modal-tab{border:none;background:transparent;padding:8px 10px;border-radius:10px;font-weight:800;font-size:13px;cursor:pointer;color:#374151}.modal-search{width:260px;max-width:100%;padding:9px 10px;border-radius:10px;border:1px solid #e6eaf2;outline:none}.modal-panel{border:1px solid #eef2f7;border-radius:12px;overflow:hidden}.modal-panel-title{margin:0;padding:10px 12px;font-size:13px;font-weight:900;border-bottom:1px solid #eef2f7;background:#f8fafc}.modal-scroll{max-height:320px;overflow:auto;padding:10px 12px}.modal-list{display:grid;gap:10px}.modal-list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border:1px solid #eef2f7;border-radius:12px;background:#fff}.modal-list-title{font-weight:900;color:#111827}.modal-list-sub{font-size:12px}.modal-footer{display:flex;justify-content:flex-end;padding-top:12px}.modal-primary{padding:10px 14px;border-radius:12px;border:none;background:#111827;color:#fff;font-weight:900;cursor:pointer}.att-tabs{display:flex;gap:10px}.att-tab{border:1px solid #e6eaf2;background:#f8fafc;color:#374151;padding:10px;border-radius:999px;font-weight:800;font-size:12px;cursor:pointer;transition:background .15s ease,transform .08s ease}.att-tab:hover{background:#eef2ff}.att-tab:active{transform:scale(.99)}.att-tab.is-active{background:#2563eb;color:#fff}.attendance-student-picker{position:relative}.attendance-student-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 30px #0f172a14;z-index:20;max-height:220px;overflow-y:auto}.attendance-student-option{width:100%;border:none;background:transparent;text-align:left;padding:10px 12px;display:flex;flex-direction:column;gap:2px;cursor:pointer}.attendance-student-option:hover{background:#f8fafc}.attendance-student-option__name{font-size:14px;font-weight:600;color:#0f172a}.attendance-student-option__id{font-size:12px;color:#64748b}.attendance-student-option--empty{padding:12px;color:#64748b;font-size:13px}.classes{color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;padding:20px;background-color:#fff}.classes__header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:6px}.classes__subject-block{display:flex;flex-direction:column;gap:4px}.classes__label{font-size:14px;color:#64748b}.classes__subject-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.classes__subject{font-size:20px;font-weight:700;color:#0f172a;margin:0}.classes__subject-switch{padding:6px 10px;border-radius:8px;border:1px solid #dbe1e8;background:#fff;font-size:14px;color:#475569;cursor:pointer;outline:none;transition:all .18s ease}.classes__subject-switch:hover{border-color:#2563eb;box-shadow:0 2px 6px #2563eb26}.classes__subtitle{color:#64748b}.classes__section-block{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:130px}.classes__section-label{font-size:16px;font-weight:700;color:#0f172a;border-radius:12px}.classes__section-chip{padding:4px 10px;border-radius:8px;border:1px solid #dbeafe;background:#eff6ff;font-size:14px;font-weight:600;color:#1d4ed8;cursor:pointer;outline:none;transition:all .16s ease}.classes__section-chip:hover{background:#dbeafe;border-color:#2563eb}.classes__tabs{display:inline-flex;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px;margin:10px 0 14px}.classes__tab{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease}.classes__tab:hover{background:#2563eb1a}.classes__tab.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.classes__tab:active{transform:scale(.96)}.gradbook-tab{display:flex;flex-direction:column;gap:10px}.grad-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.grad-title{margin:0;font-size:1.2rem;font-weight:700;color:#0f172a}.grad-subtitle{margin:2px 0 0;font-size:.9rem;color:#64748b}.gradbook-card{background:#fff;border-radius:16px;border:1px solid #E5E7EB;padding:14px;margin-top:6px;display:flex;flex-direction:column;gap:8px}.gradbook-table-scroll{width:100%;overflow:visible;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc}.gradbook-table{width:100%;border-collapse:collapse;font-size:.94rem}.gradbook-table thead th{position:sticky;top:0;background:#eef2ff;color:#1e3a8a;text-align:center;padding:10px 12px;border-bottom:1px solid #e5e7eb;z-index:1;font-size:14px}.gradbook-table thead th:last-child{border-right:none}.gradbook-table tbody td{padding:10px 12px;border-bottom:1px solid #eef2f4;color:#334155}.gradbook-table tbody td:last-child{border-right:none}.grade-cell{position:relative;width:100%}.grade-input{width:100%;border:none;outline:none;background:transparent;font-size:.85rem;color:#0f172a;padding:6px 22px 6px 4px;border-radius:8px;text-align:center;transition:background .15s ease}.grade-input::placeholder{color:#cbd5e1}.grade-cell:hover .grade-input{background:#eff6ff;cursor:pointer}.grade-input:focus{background:#eff6ff}.grade-input::-webkit-outer-spin-button,.grade-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grade-input[type=number]{-moz-appearance:textfield}.grade-edit-icon{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:.75rem;color:#2563eb;opacity:0;pointer-events:none;transition:opacity .15s ease}.grade-cell:hover .grade-edit-icon{opacity:1}.gradbook__legend{margin-top:2px;font-size:9px;color:#9ca3af;text-align:right}.term-switch{display:inline-flex;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px}.term-tab{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease;display:flex;align-items:center}.term-tab:hover{background:#2563eb1a}.term-tab.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.term-tab:active{transform:scale(.96)}.term-badge{font-size:.75rem;opacity:.85;margin-left:6px}.col-sub{display:block;font-size:.75rem;opacity:.65}.gradbook-tools{display:flex;align-items:center;gap:14px}.search{flex:1;display:flex;align-items:center;gap:10px;border:1px solid #e6eaf2;background:#fff;border-radius:10px}.search i{color:#6b7280;font-size:14px}.search input{border:none;outline:none;width:100%;font-size:14px;background:transparent}.activity-type-switch{width:240px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid #e6eaf2;background:#fff;border-radius:12px}.type-arrow{width:34px;height:34px;border-radius:10px;border:1px solid #e6eaf2;background:#f8fafc;display:grid;place-items:center;cursor:pointer;transition:transform .08s ease,background .15s ease}.type-arrow:hover{background:#eef2ff}.type-arrow:active{transform:scale(.98)}.type-arrow:disabled{opacity:.5;cursor:not-allowed}.type-arrow i{font-size:14px;color:#111827}.type-label{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.1;align-items:center}.type-label__title{font-size:14px;color:#6b7280}.type-label__value{font-size:16px;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:900px){.gradbook-tools{flex-direction:column;align-items:stretch}.activity-type-switch{width:100%}}.gradbook-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:14px;margin-top:6px;border-top:1px solid #eef2f7;padding-bottom:12px}.page-btn{padding:6px 12px;font-size:13px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:background .15s ease,transform .08s ease}.page-btn:hover:not(:disabled){background:#eef2ff}.page-btn:active:not(:disabled){transform:scale(.98)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:13px;color:#374151}.gb-chip{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;background:#f9fafb}.gb-chip--pass{background:#dcfce7;color:#166534}.gb-chip--risk{background:#fee2e2;color:#991b1b}.gradbookterms-table-scroll{width:100%;overflow:visible;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc}.gradbookterms-table{width:100%;border-collapse:collapse;font-size:.94rem}.gradbookterms-table thead th{position:sticky;top:0;background:#eef2ff;color:#1e3a8a;text-align:left;padding:10px 12px;border-bottom:1px solid #e5e7eb;z-index:1;font-size:14px}.gradbookterms-table thead th:last-child{border-right:none}.gradbookterms-table tbody td{padding:10px 12px;border-bottom:1px solid #eef2f4;color:#334155}.gradbookterms-table tbody td:last-child{border-right:none}.gradbook-table thead th:not(:first-child){text-align:center}.gradbook-table tbody td:not(:first-child){text-align:center;vertical-align:middle}.grade-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:56px}.grade-cell .bttn{display:inline-flex;align-items:center;justify-content:center}.gradeit-custom-select{border:1px solid #edf2f7;border-radius:6px;padding:8px 12px;background-color:#fff;font-size:14px;color:#2d3748;cursor:pointer;outline:none}.gradeit-custom-select:focus{border-color:#4fd1c5}.grade-rubric-btn{border:1px solid #c7d2fe;background:#eef2ff;color:#1d4ed8;padding:6px 12px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease,border-color .15s ease}.grade-rubric-btn:hover{background:#dbeafe;border-color:#93c5fd}.rubric-modal{width:min(860px,100%);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;background:#fff;border-radius:18px;box-shadow:0 20px 50px #0f172a2e;border:1px solid #e5e7eb}.rubric-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px 14px;border-bottom:1px solid #e5e7eb}.rubric-modal__close{border:none;background:#f8fafc;color:#334155;width:36px;height:36px;border-radius:10px;font-size:20px;cursor:pointer}.rubric-modal__close:hover{background:#eef2ff}.rubric-summary__item{min-width:180px;padding:12px 14px;border-radius:12px;background:#f8fafc;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:14px;color:#334155}.rubric-summary__item strong{color:#0f172a;font-size:15px}.rubric-table tbody td{padding:12px 14px;border-bottom:1px solid #eef2f4;color:#334155;font-size:14px;vertical-align:top}.rubric-table tbody tr:last-child td{border-bottom:none}.rubric-points-input{width:100px;border:1px solid #dbe1e8;border-radius:10px;padding:8px 10px;outline:none;font-size:14px;background:#fff}.rubric-points-input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f61f}.rubric-empty{text-align:center;color:#64748b;padding:18px!important}@media(max-width:640px){.rubric-modal{width:100%;max-height:92vh}.rubric-summary__item,.rubric-points-input{width:100%}}.grade-rubric-btn{border:1px solid #c7d2fe;background:#eef2ff;color:#1d4ed8;padding:6px 12px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease}.grade-rubric-btn:hover{background:#dbeafe}.grade-rubric-btn:active{transform:scale(.98)}.grade-rubric-score{font-size:12px;color:#475569;font-weight:600}.rubric-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.rubric-modal{width:min(900px,100%);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 50px #0f172a2e}.rubric-modal__header{display:flex;justify-content:space-between;gap:16px;padding:18px 20px 14px;border-bottom:1px solid #e5e7eb}.rubric-modal__title{margin:0;font-size:18px;font-weight:700;color:#0f172a}.rubric-modal__subtitle{margin:4px 0 0;font-size:13px;color:#64748b}.rubric-modal__close{border:none;background:#f8fafc;width:36px;height:36px;border-radius:10px;font-size:20px;cursor:pointer}.rubric-modal__body{padding:18px 20px;overflow:auto;display:flex;flex-direction:column;gap:14px}.rubric-summary{display:flex;gap:12px;flex-wrap:wrap}.rubric-summary__item{min-width:180px;padding:12px 14px;border-radius:12px;background:#f8fafc;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.rubric-summary__item strong.is-danger{color:#dc2626}.rubric-alert{border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;border-radius:12px;padding:10px 12px;font-size:13px;font-weight:600}.rubric-table-wrap{border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;background:#fff}.rubric-table{width:100%;border-collapse:collapse}.rubric-table thead th{background:#eef2ff;color:#1e3a8a;text-align:left;font-size:13px;font-weight:700;padding:12px 14px;border-bottom:1px solid #e5e7eb}.rubric-table tbody td{padding:12px 14px;border-bottom:1px solid #eef2f4;vertical-align:top}.rubric-text-input,.rubric-points-input{width:100%;border:1px solid #dbe1e8;border-radius:10px;padding:8px 10px;outline:none;font-size:14px;background:#fff}.rubric-text-input:focus,.rubric-points-input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f61f}.rubric-remove-btn,.rubric-add-btn{border:1px solid #dbe1e8;background:#fff;color:#334155;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer}.rubric-add-btn{align-self:flex-start}.rubric-modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px 18px;border-top:1px solid #e5e7eb;background:#fff}.grad-unsaved{margin-top:4px;font-size:12px;color:#dc2626;font-weight:600}.bttn.is-dirty{box-shadow:0 0 0 3px #dc262626;border-color:#dc2626}.grade-action-btn{border:1px solid #c7d2fe;background:#eef2ff;color:#1d4ed8;padding:6px 12px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease}.grade-action-btn:hover{background:#dbeafe;border-color:#93c5fd}.grade-action-btn:active{transform:scale(.97)}.gradbook-empty-state{min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 20px;gap:10px}.gradbook-empty-state__icon{font-size:28px;color:#dc2626}.gradbook-empty-state__title{margin:0;font-size:18px;font-weight:700;color:#0f172a}.gradbook-empty-state__text{margin:0;max-width:520px;font-size:14px;color:#64748b;line-height:1.6}.fgm-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1200}.fgm-modal{width:min(1200px,100%);max-height:92vh;overflow:hidden;background:#fff;border-radius:22px;box-shadow:0 30px 80px #0f172a2e;display:flex;flex-direction:column}.fgm-header{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 24px 16px;border-bottom:1px solid #e5e7eb}.fgm-title{margin:0;font-size:1.4rem;font-weight:700;color:#0f172a}.fgm-subtitle{margin:6px 0 0;color:#64748b;font-size:.95rem}.fgm-close{border:none;background:transparent;font-size:1.75rem;line-height:1;cursor:pointer;color:#475569}.fgm-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:18px 24px;border-bottom:1px solid #eef2f7}.fgm-summary-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:8px}.fgm-summary-card span{font-size:.84rem;color:#64748b}.fgm-summary-card strong{font-size:1.2rem;color:#0f172a}.fgm-term-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 18px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.fgm-term-title{margin:0;font-size:1.1rem;font-weight:700;color:#0f172a}.fgm-term-subtitle{margin:6px 0 0;color:#64748b;font-size:.9rem}.fgm-term-grade{min-width:120px;text-align:right;display:flex;flex-direction:column;gap:6px}.fgm-term-grade span{font-size:.8rem;color:#64748b}.fgm-term-grade strong{font-size:1.15rem;color:#0f172a}.fgm-table{width:100%;border-collapse:collapse;min-width:760px}.fgm-table thead th{text-align:left;padding:12px 14px;background:#fff;color:#334155;font-size:.9rem;font-weight:700;border-bottom:1px solid #e5e7eb}.fgm-table tbody td{padding:12px 14px;border-bottom:1px solid #eef2f7;color:#0f172a;font-size:.92rem}.fgm-status{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:600}.fgm-status.is-excellent{background:#dbeafe;color:#1d4ed8}.fgm-status.is-passed{background:#dcfce7;color:#166534}.fgm-status.is-review{background:#fef3c7;color:#92400e}.fgm-footer{display:flex;justify-content:flex-end;gap:10px;padding:18px 24px 22px;border-top:1px solid #e5e7eb;background:#fff}@media(max-width:900px){.fgm-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.fgm-term-header{flex-direction:column}.fgm-term-grade{text-align:left}}.fgm-structure{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:0 24px 18px;border-bottom:1px solid #eef2f7}.fgm-structure-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.fgm-structure-item span{font-size:.84rem;color:#64748b}.fgm-structure-item strong{font-size:1rem;color:#0f172a}.fgm-term-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:14px 18px 0}.fgm-term-summary-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.fgm-term-summary-item span{font-size:.8rem;color:#64748b}.fgm-term-summary-item strong{font-size:1rem;color:#0f172a}@media(max-width:900px){.fgm-structure{grid-template-columns:repeat(2,minmax(0,1fr))}.fgm-term-summary{grid-template-columns:1fr}}.fgm-modal--wide{width:min(1280px,96vw)}.fgm-loading,.fgm-error{margin:16px 24px 0;padding:12px 14px;border-radius:12px;font-size:.92rem}.fgm-loading{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.fgm-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.fgm-table--grouped{min-width:900px}.fgm-group-head{text-align:center;background:#f8fafc;font-weight:700}.fgm-sub-head{min-width:110px;text-align:center;vertical-align:top}.fgm-sub-head__index{font-weight:700;font-size:.95rem;color:#0f172a}.fgm-sub-head__meta{display:flex;flex-direction:column;gap:2px;margin-top:4px}.fgm-sub-head__meta span{font-size:.78rem;color:#334155;line-height:1.2}.fgm-sub-head__meta small{font-size:.72rem;color:#64748b}.fgm-sticky-col{position:sticky;left:0;background:#fff;z-index:2;min-width:220px;box-shadow:1px 0 #e5e7eb}.fgm-table thead .fgm-sticky-col{z-index:4;background:#f8fafc}.fgm-student-cell{display:flex;flex-direction:column;gap:4px}.fgm-student-cell strong{color:#0f172a;font-size:.92rem}.fgm-student-cell span{color:#64748b;font-size:.8rem}.fgm-score-cell{text-align:center;font-weight:700}.fgm-score-cell.is-excellent{background:#dbeafe;color:#1d4ed8}.fgm-score-cell.is-passed{background:#dcfce7;color:#166534}.fgm-score-cell.is-review{background:#fef3c7;color:#92400e}.fgm-gwa-footer{margin-top:4px;display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border:1px solid #dbeafe;background:#eff6ff;border-radius:16px}.fgm-gwa-footer span{font-size:.92rem;font-weight:600;color:#1e3a8a}.fgm-gwa-footer strong{font-size:1.2rem;font-weight:800;color:#0f172a}.fgm-body{overflow:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px;background:#fcfdff}.fgm-term-card+.fgm-term-card{margin-top:2px}.fgm-table-wrap{overflow:auto;background:#fff}.fgm-empty{text-align:center;color:#64748b;padding:24px 18px}.fgm-group-head__title{font-size:.92rem;font-weight:700;color:#0f172a;margin-bottom:6px}.fgm-group-head__stats{display:flex;flex-direction:column;gap:2px;align-items:center}.fgm-group-head__stats span{font-size:.72rem;font-weight:600;color:#475569;line-height:1.2}@media(max-width:900px){.fgm-group-head__stats span{font-size:.68rem}}.submitmodal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1200}.submitmodal-card{width:min(1180px,100%);max-height:92vh;overflow:hidden;background:#fff;border-radius:22px;box-shadow:0 30px 80px #0f172a2e;display:flex;flex-direction:column}.submitmodal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px 18px;border-bottom:1px solid #e5e7eb}.submitmodal-header-copy{min-width:0}.submitmodal-title{margin:0;font-size:1.4rem;font-weight:700;color:#0f172a}.submitmodal-subtitle{margin:6px 0 0;color:#64748b;font-size:.95rem;max-width:760px;line-height:1.5}.submitmodal-close{border:none;background:transparent;font-size:1.75rem;line-height:1;cursor:pointer;color:#475569;flex-shrink:0}.submitmodal-top{display:flex;flex-direction:column;gap:16px;padding:18px 24px 20px;background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:1px solid #eef2f7}.submitmodal-meta{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px}.submitmodal-meta-item{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;min-width:0}.submitmodal-meta-item strong{color:#0f172a;font-size:1rem;line-height:1.4;word-break:break-word}.submitmodal-meta-item--wide{min-width:0}.submitmodal-meta-label{font-size:.8rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.submitmodal-status-text{color:#1d4ed8}.submitmodal-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.submitmodal-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px 18px;display:flex;flex-direction:column;gap:8px;min-height:92px;justify-content:center}.submitmodal-summary-card span{font-size:.84rem;color:#64748b}.submitmodal-summary-card strong{font-size:1.25rem;color:#0f172a;line-height:1.1}.submitmodal-loading,.submitmodal-error{margin:16px 24px 0;padding:12px 14px;border-radius:12px;font-size:.92rem}.submitmodal-loading{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.submitmodal-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.submitmodal-content{display:flex;flex-direction:column;gap:0;min-height:0;overflow:hidden}.submitmodal-table-wrap{padding:0 24px 20px;overflow:auto;min-height:0}.submitmodal-table{width:100%;border-collapse:separate;border-spacing:0;min-width:860px;background:#fff;border:1px solid #e5e7eb;border-radius:18px;overflow:hidden}.submitmodal-table thead th{position:sticky;top:0;background:#f8fafc;color:#334155;font-weight:700;font-size:.9rem;text-align:left;padding:13px 14px;border-bottom:1px solid #e2e8f0;white-space:nowrap;z-index:1}.submitmodal-table tbody td{padding:13px 14px;border-bottom:1px solid #eef2f7;color:#0f172a;font-size:.92rem;vertical-align:middle}.submitmodal-table tbody tr:last-child td{border-bottom:none}.submitmodal-table tbody tr:hover td{background:#fafcff}.submitmodal-student-name{font-weight:600;min-width:220px}.submitmodal-status{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:600;white-space:nowrap}.submitmodal-status.is-ready{background:#dcfce7;color:#166534}.submitmodal-status.is-review{background:#fef3c7;color:#92400e}.submitmodal-empty{text-align:center;color:#64748b;padding:20px}.submitmodal-remarks{padding:18px 24px 20px;border-top:1px solid #eef2f7;background:#fff;display:flex;flex-direction:column;gap:10px}.submitmodal-remarks-input{width:100%;min-height:96px;padding:12px 16px;border-radius:14px;border:1.5px solid #e2e8f0;background:#fff;font-family:inherit;font-size:.95rem;color:#1e293b;resize:vertical;transition:all .2s ease;outline:none;line-height:1.45}.submitmodal-remarks-input::placeholder{color:#94a3b8}.submitmodal-remarks-input:hover{border-color:#cbd5e1}.submitmodal-remarks-input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a;background:#fff}.submitmodal-footer{display:flex;justify-content:flex-end;gap:10px;padding:18px 24px 22px;border-top:1px solid #e5e7eb;background:#fff}@media(max-width:1024px){.submitmodal-meta{grid-template-columns:1fr 1fr}.submitmodal-meta-item--wide{grid-column:1 / -1}.submitmodal-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.submitmodal-backdrop{padding:14px}.submitmodal-card{width:100%;max-height:94vh;border-radius:18px}.submitmodal-header{padding:18px 18px 16px}.submitmodal-top{padding:14px 18px 16px}.submitmodal-meta,.submitmodal-summary{grid-template-columns:1fr}.submitmodal-table-wrap{padding:0 18px 18px}.submitmodal-remarks{padding:16px 18px 18px}.submitmodal-footer{padding:16px 18px 18px;flex-wrap:wrap}.submitmodal-footer .bttn{flex:1 1 160px}}.settings-wrap{display:flex;flex-direction:column;gap:1rem}.settings-term-tabs{display:inline-flex;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px;margin:10px 0 14px}.settings-term-tab{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease}.settings-term-tab:hover{background:#2563eb1a}.settings-term-tab.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.settings-term-tab.active{transform:scale(.96)}.settings-term-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:12px}.settings-sub-tabs{display:flex;gap:8px;margin-top:16px;margin-bottom:4px}.settings-sub-tab{display:flex;padding:6px 14px;border-radius:999px;border:1px solid #dbe1e8;background:#f8fafc;font-size:.85rem;font-weight:600;cursor:pointer}.settings-sub-tab.is-active{background:#2563eb;color:#fff;border-color:#2563eb}.syllabus-card{margin-top:8px}.syllabus-actions-row{display:flex;justify-content:flex-end;margin-bottom:12px}.course-activities-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.course-activities-header h3{font-size:1.2rem;font-weight:700;margin:0;color:#111827}.course-activities-header p{margin:2px 0 0;font-size:.9rem;color:#6b7280}.term-weight-card{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-radius:12px;background:#f9fafb;border:1px solid #e5e7eb;margin-bottom:20px}.term-weight-left{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.term-weight-label{font-size:.9rem;font-weight:500;color:#111827}.term-weight-value{font-size:1.1rem;font-weight:700;color:#16a34a}.term-activities-card{border-radius:14px;border:1px solid #e5e7eb;background:#fff;padding:18px 18px 4px}.term-activities-header h4{margin:0 0 12px;font-size:.98rem;font-weight:600;color:#111827}.activities-table-wrapper{width:100%;overflow-x:auto}.activities-table{width:100%;border-collapse:collapse;font-size:.9rem}.activities-table thead tr{border-bottom:1px solid #e5e7eb}.activities-table th,.activities-table td{padding:10px 8px;text-align:left;white-space:nowrap}.activities-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:#6b7280;font-weight:600}.activities-table tbody tr:hover{background:#f9fafb}.type-pill{display:inline-flex;padding:2px 10px;border-radius:999px;background:#e5edff;color:#1d4ed8;font-size:.75rem;font-weight:500}.rubric-criteria-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.rubric-criteria-row{display:grid;grid-template-columns:36px 1fr 120px 44px;gap:10px;align-items:center}.rubric-criteria-index{font-size:.85rem;color:#9ca3af;text-align:center}.term-percentage-card{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;margin:1rem 0;width:100%}.term-percentage-left{display:flex;flex-direction:column;justify-content:center}.term-percentage-label{font-size:14px;font-weight:500;color:#4b5563;margin-bottom:4px}.term-percentage-value{font-size:24px;font-weight:700;color:#10b981;margin-bottom:0}.activity-type-weights-card{border-radius:14px;border:1px solid #e5e7eb;background:#fff;padding:18px 18px 4px}.activity-type-weights-header{margin:0 0 12px;font-size:.98rem;font-weight:600;color:#111827}.activity-type-weights-table th,.activity-type-weights-table td{padding:10px 8px;text-align:left;white-space:nowrap}.activity-type-weights-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:#6b7280;font-weight:600}.empty-row{padding:16px 8px;text-align:center;color:#9ca3af}.x-btn{cursor:pointer;padding:16px;border-radius:16px;border:1px solid #e5e7eb;background:#fff}.modal{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px}.backdrop{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:0}.modal-card{position:relative;z-index:1;width:min(760px,100%);max-height:90vh;overflow:auto;border-radius:20px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 28px 70px #0f172a38;padding:20px 20px 18px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.1rem;font-weight:700;color:#0f172a}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 18px}.field{display:flex;flex-direction:column;gap:8px;min-width:0}.field label{font-size:.86rem;font-weight:600;color:#334155}.ctrl,.ay-select,.field textarea{width:100%;min-height:44px;padding:10px 12px;border:1px solid #dbe1e8;border-radius:12px;background:#fff;color:#0f172a;font-size:.92rem;outline:none;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.ctrl:focus,.ay-select:focus,.field textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.ctrl:disabled,.ay-select:disabled,.field textarea:disabled{background:#f8fafc;color:#64748b;cursor:not-allowed}.actions-row{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:6px}.rubric-preview-card{border:1px solid #e5e7eb;border-radius:16px;background:#f8fafc;overflow:hidden}.rubric-preview-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #e5e7eb;background:#fff}.rubric-preview-head strong{font-size:.95rem;color:#0f172a}.rubric-preview-head span{font-size:.84rem;font-weight:700;color:#2563eb;white-space:nowrap}.rubric-preview-table-wrapper{width:100%;overflow-x:auto}.rubric-preview-table{width:100%;border-collapse:collapse;font-size:.9rem}.rubric-preview-table thead tr{border-bottom:1px solid #e5e7eb}.rubric-preview-table th,.rubric-preview-table td{padding:10px 12px;text-align:left;vertical-align:top}.rubric-preview-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;color:#64748b;font-weight:700;background:#f8fafc}.rubric-preview-table tbody tr:not(:last-child) td{border-bottom:1px solid #eef2f7}.rubric-preview-table tbody tr:hover{background:#fff}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#475569;cursor:pointer;transition:all .16s ease}.icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.icon-btn.edit:hover{color:#2563eb}.icon-btn.danger:hover,.icon-btn.delete-row:hover{color:#dc2626}.x-btn{cursor:pointer;min-height:42px;padding:0 16px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#334155;font-weight:600;transition:all .16s ease}.x-btn:hover{background:#f8fafc;border-color:#cbd5e1}@media(max-width:768px){.modal{padding:14px;align-items:flex-end}.modal-card{width:100%;max-height:92vh;border-radius:18px 18px 0 0;padding:18px 16px 16px}.form-grid{grid-template-columns:1fr;gap:14px}.rubric-preview-head{flex-direction:column;align-items:flex-start}.actions-row{flex-wrap:wrap;justify-content:stretch}.actions-row .x-btn,.actions-row .bttn{flex:1 1 160px}}.rubric-meta-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.rubric-meta-chip{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:14px;border:1px solid #e5e7eb;background:#fff}.rubric-meta-chip span{font-size:.8rem;color:#64748b;font-weight:600}.rubric-meta-chip strong{font-size:1rem;color:#0f172a;font-weight:700}.rubric-criteria-card{border:1px solid #e5e7eb;border-radius:16px;background:#fff;padding:14px;display:flex;flex-direction:column;gap:12px}.rubric-criteria-card__head{display:flex;align-items:center;justify-content:space-between;gap:10px}.rubric-criteria-index-badge{width:34px;height:34px;border-radius:10px;background:#eaf2ff;color:#2563eb;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.rubric-criteria-card__body{display:grid;grid-template-columns:minmax(0,1fr) 140px;gap:14px 16px;align-items:start}@media(max-width:768px){.rubric-meta-row,.rubric-criteria-card__body{grid-template-columns:1fr}}.modal-shell,.modal-body{display:flex;flex-direction:column;gap:16px}.modal-section{display:flex;flex-direction:column;gap:14px;padding:16px;border:1px solid #e5e7eb;border-radius:16px;background:#fbfdff}.modal-section-title{font-size:.92rem;font-weight:700;color:#0f172a;margin:0}@media(max-width:768px){.modal-section{padding:14px;border-radius:14px}}.rubric-criteria-wrapper{max-height:320px;overflow-y:auto;padding-right:6px}.rubric-criteria-wrapper::-webkit-scrollbar{width:6px}.rubric-criteria-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.rubric-criteria-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.rubric-criteria-list{display:flex;flex-direction:column;gap:12px}.activity-type-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:10px}.add-activity-type-btn{display:flex;justify-content:flex-end}.activity-type-weights-card{border-radius:16px;border:1px solid #e5e7eb;background:#fff;padding:18px;box-shadow:0 10px 28px #0f172a0a}.activity-type-weights-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.activity-type-weights-header h4{margin:0;font-size:1rem;font-weight:700;color:#111827}.activity-type-weights-table-wrapper{width:100%;overflow-x:auto}.activity-type-weights-table{width:100%;border-collapse:collapse;font-size:.9rem}.activity-type-weights-table thead tr{border-bottom:1px solid #e5e7eb}.activity-type-weights-table th,.activity-type-weights-table td{padding:12px 10px;text-align:left;white-space:nowrap}.activity-type-weights-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b;font-weight:700;background:#f8fafc}.activity-type-weights-table tbody tr{border-bottom:1px solid #f1f5f9}.activity-type-weights-table tbody tr:hover{background:#f9fafb}.activity-type-weights-table tbody tr:last-child{border-bottom:0}.activity-type-total{display:flex;justify-content:flex-end;align-items:center;gap:4px;margin-top:14px;padding-top:12px;border-top:1px solid #e5e7eb;color:#0f172a;font-size:.95rem}.th-actions,.td-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.empty-row{padding:18px 10px;text-align:center;color:#94a3b8}.activity-type-modal-card{position:relative;z-index:1;width:min(640px,100%);max-height:90vh;overflow:auto;border-radius:20px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 28px 70px #0f172a38;padding:20px}.activity-type-form{display:flex;flex-direction:column;gap:16px}.activity-rows-container{display:flex;flex-direction:column;gap:12px}.activity-type-row{display:grid;grid-template-columns:minmax(0,1fr) 130px 42px;gap:12px;align-items:end;padding:14px;border:1px solid #e5e7eb;border-radius:16px;background:#fff}.activity-type-row.is-required{background:#f8fafc;border-color:#dbeafe}.activity-type-row .field{min-width:0}.activity-type-lock{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;margin-bottom:3px;border-radius:10px;color:#64748b;background:#eef2f7;border:1px solid #e2e8f0}.activity-type-divider{border:none;border-top:1px solid #e5e7eb;margin:2px 0}.activity-type-modal-footer{display:flex;justify-content:space-between;align-items:center;gap:12px}.activity-type-form-total{font-weight:700;white-space:nowrap}.activity-type-form-total.is-valid{color:#16a34a}.activity-type-form-total.is-invalid{color:#dc2626}.icon-btn.delete-row{margin-bottom:3px;color:#dc2626}.icon-btn.delete-row:hover{color:#b91c1c;background:#fef2f2;border-color:#fecaca}@media(max-width:768px){.activity-type-toolbar{justify-content:stretch}.add-activity-type-btn,.add-activity-type-btn .bttn{width:100%}.activity-type-modal-card{width:100%;max-height:92vh;border-radius:18px 18px 0 0;padding:18px 16px 16px}.activity-type-row{grid-template-columns:1fr}.activity-type-lock,.icon-btn.delete-row{width:100%;margin-bottom:0}.activity-type-modal-footer{align-items:stretch;flex-direction:column}.activity-type-modal-footer .actions-row{width:100%;justify-content:stretch}.activity-type-modal-footer .x-btn,.activity-type-modal-footer .bttn{flex:1}}.dash{display:flex;flex-direction:column;gap:1rem}.dash-header{display:flex;justify-content:space-between;align-items:center}.dash-title{margin:0;font-size:1.2rem;font-weight:700;color:#0f172a}.dash-subtitle{margin:2px 0 0;font-size:.9rem;color:#64748b}.dash-modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center}.dash-modal-backdrop{position:absolute;inset:0;background:#00000040}.dash-modal-card{position:relative;z-index:51;width:min(900px,96vw);max-height:80vh;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 20px 35px #0f172a33;display:flex;flex-direction:column}.dash-modal-header{padding:.8rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.dash-modal-header h3{font-size:1rem;font-weight:600}.dash-modal-close{border:none;background:none;font-size:1.1rem;cursor:pointer}.dash-modal-body{padding:.8rem 1rem;overflow:auto}.dash-modal-footer{padding:.7rem 1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.dash-quick-btn{padding:6px;border-radius:999px;border:none;background:#dae9fd;color:#2656db;font-size:.72rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.dash-quick-btn:hover{background:#d1defd}.dash-quick-btn.is-active{background:#b9d6ff}.dash-insight{display:flex;flex-direction:column;gap:.6rem}.dash-analytics-tabs{display:inline-flex;width:fit-content;max-width:max-content;align-self:flex-start;justify-self:start;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px}.dash-analytics-tab{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease}.dash-analytics-tab:hover{background:#2563eb1a}.dash-analytics-tab.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.dash-analytics-tab:active{transform:scale(.96)}.overall-dash-wrap{display:flex;flex-direction:column;gap:20px}.dash-kpi-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.dash-grid-2x2,.dash-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}@media(max-width:1024px){.dash-kpi-row,.dash-grid-2x2,.dash-grid-2{grid-template-columns:minmax(0,1fr)}}.dash-kpi-card{border-radius:14px;border:1px solid #e5e7eb;background:#fff;padding:12px}.dash-kpi-label{font-size:.8rem;font-weight:600;letter-spacing:.05em;color:#6b7280}.dash-kpi-value{margin-top:4px;font-size:1.8rem;font-weight:700;color:#111827}.dash-kpi-subtitle{margin-top:3px;font-size:.78rem;color:#9ca3af}.dash-analytics-card{background:#fff;border-radius:12px;padding:16px 18px;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:12px}.dash-analytics-card-header h4{font-size:1rem;font-weight:600;color:#111827}.dash-analytics-card-header p{font-size:.78rem;color:#6b7280}.dash-analytics-card-body{margin-top:4px}.chart-placeholder{border-radius:10px;background:#f9fafb;border:1px solid #e5e7eb;padding:12px;min-height:160px;display:flex;flex-direction:column;justify-content:space-between}.chart-placeholder-text{color:#6b7280;font-size:.8rem}.chart-mini-legend{list-style:none;padding:0;color:#374151;font-size:.78rem}.chart-mini-legend li{display:flex;align-items:center;gap:6px;margin-bottom:2px}.chart-mini-legend .dot{width:6px;height:6px;border-radius:50%;background:#3b82f6}.students-table-wrapper{max-height:260px;overflow-y:auto}.students-table{width:100%;border-collapse:collapse;font-size:.82rem;color:#111827}.students-table th{background:#f3f4f6;color:#374151;font-weight:600;padding:8px;border-bottom:1px solid #e5e7eb}.students-table td{padding:8px}.risk-pill{padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600}.risk-high{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.risk-medium{background:#fef9c3;color:#ca8a04;border:1px solid #fde047}.status-pill{padding:3px 8px;border-radius:999px;font-size:.72rem;font-weight:600;background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.dash-analytics-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.dash-analytics-card-header>div:first-child{min-width:0}.dash-analytics-card-right{display:flex;align-items:center}.chart-view-tabs{display:inline-flex;background:#f3f4f6;border-radius:999px;padding:2px;gap:2px}.chart-view-tab{border:none;background:transparent;font-size:.75rem;padding:4px 10px;border-radius:999px;color:#6b7280;cursor:pointer}.chart-view-tab.is-active{background:#fff;color:#111827;box-shadow:0 1px 2px #00000014}.linechart-container{width:100%;height:260px;background:#fff;border-radius:10px;padding:8px;border:1px solid #e5e7eb}.horizontal-barchart-container{width:100%;height:260px;background:#fff;border-radius:10px;border:1px solid #e5e7eb}.activity-insight{padding:8px 2px;font-size:.85rem;color:#374151}.dash-bullets{list-style:disc;padding-left:1.25rem;margin:0}.dash-bullets li+li{margin-top:4px}.dash-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.mode-switches{display:inline-flex;background:#f1f5f9;border:1px solid #dbe1e8;padding:4px;border-radius:12px;gap:4px}.dash-subheader{display:flex;justify-content:space-between;align-items:center;gap:16px}.term-switch{display:flex;gap:8px;align-items:center}.topic-right-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.topic-filter-select{height:34px;padding:0 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.9rem;color:#111827}.topic-selected-summary{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:10px;background:#fff}.topic-selected-sub{color:#6b7280;font-size:.9rem}.topic-activities-list{margin-top:12px;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.topic-activities-head,.topic-activities-row{display:grid;grid-template-columns:1.6fr .7fr .5fr;gap:10px;padding:10px 12px;align-items:center}.topic-activities-head{background:#f9fafb;font-weight:600;color:#111827;font-size:.9rem}.topic-activities-row{border-top:1px solid #f3f4f6;color:#111827;font-size:.9rem}.topic-act-date{color:#6b7280;font-size:.85rem}.topic-act-type{color:#6b7280}.topic-act-score{text-align:right;font-weight:600}.students-search{height:34px;padding:0 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.9rem;color:#111827;min-width:200px}.students-sort{height:34px;padding:0 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.9rem;color:#111827}.weakest-chip{display:inline-block;padding:4px 8px;border-radius:8px;font-size:.8rem;background:#fee2e2;color:#991b1b;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weakest-chip.subtle{background:#fef3c7;color:#92400e}.is-clickable-row{cursor:pointer}.students-table-wrapper{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;width:100%;padding-right:14px;background:#fff}.students-table-wrapper.is-scrollable{max-height:260px;overflow-y:auto}.students-table{width:100%;border-collapse:separate;border-spacing:0}.students-table thead th{text-align:left;font-size:.85rem;font-weight:700;color:#111827;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:12px;position:sticky;top:0;z-index:1}.students-table tbody td{padding:12px;border-bottom:1px solid #f3f4f6;color:#111827;font-size:.92rem;vertical-align:middle}.is-clickable-row{cursor:pointer;transition:background .14s ease}.is-clickable-row:hover{background:#f9fafb}.student-cell{display:flex;flex-direction:column;gap:2px;min-width:220px}.student-name{font-weight:700;color:#111827;line-height:1.2}.student-sub{font-size:.82rem;color:#6b7280}.students-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.students-search,.students-sort{height:34px;padding:0 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.9rem;color:#111827}.students-search{min-width:220px}.students-toggle{height:34px;padding:0 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:.9rem;cursor:pointer}.students-toggle:hover{background:#f9fafb}.weakest-topic-text{font-size:.9rem;color:#991b1b;font-weight:600;max-width:340px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:26px;padding:0 10px;border-radius:999px;background:#fff;font-size:.82rem;font-weight:700;color:#111827;white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis}.chip-grade{background:#eff6ff;color:#1d4ed8}.chip-grade.is-low{background:#fef2f2;color:#b91c1c}.chip-weak{background:#fef2f2;color:#991b1b}.chip-warn{background:#fffbeb;color:#92400e}.chip-risk.is-high{background:#fef2f2;color:#b91c1c}.chip-risk.is-medium{background:#fffbeb;color:#92400e}.chip-status.is-excellent{background:#eff6ff;color:#1d4ed8}.chip-status.is-track{background:#f3f4f6;color:#374151}.chip-status.is-pass{background:#ecfdf5;color:#047857}.modal-backdrop{position:fixed;inset:0;background:#1118278c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.modal-card{width:min(980px,100%);background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #00000040;overflow:hidden}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 16px;border-bottom:1px solid #e5e7eb;position:sticky}.modal-title{margin:0;font-size:1.05rem;color:#111827}.modal-subtitle{margin:4px 0 0;font-size:.9rem;color:#6b7280}.modal-close{height:34px;width:34px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.modal-body{padding:14px 16px 16px}.modal-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px}.modal-kpi{border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;background:#fff}.modal-kpi-label{color:#6b7280;font-size:.85rem}.modal-kpi-value{color:#111827;font-size:1.05rem;font-weight:700;margin-top:2px}.modal-kpi-sub{color:#6b7280;font-size:.8rem;margin-top:2px}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-panel{border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;background:#fff}.modal-panel-title{margin:0 0 10px;font-size:.95rem;color:#111827}.modal-list{display:flex;flex-direction:column;gap:10px}.modal-list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border:1px solid #f3f4f6;border-radius:12px;background:#fff}.modal-list-title{font-weight:600;color:#111827;font-size:.9rem}.modal-list-sub{font-size:.82rem}.modal-list-score{font-weight:700;color:#111827;white-space:nowrap}.muted{color:#6b7280}.modal-footer{display:flex;justify-content:flex-end;margin-top:12px}.modal-primary{height:36px;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#111827;color:#fff;cursor:pointer}@media(max-width:900px){.modal-kpis,.modal-grid{grid-template-columns:1fr}}.modal-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.modal-tabs{display:inline-flex;gap:6px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:4px}.modal-tab{height:30px;padding:0 14px;border-radius:999px;border:none;background:transparent;font-size:.85rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s ease}.modal-tab:hover{background:#fff;color:#111827}.modal-tab.is-active{background:#111827;color:#fff}.modal-search{height:32px;min-width:200px;padding:0 10px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;font-size:.85rem;color:#111827}.modal-search::placeholder{color:#9ca3af}.modal-search:focus{outline:none;border-color:#3b82f6}.modal-scroll{max-height:320px;overflow-y:auto;padding-right:4px}.modal-scroll::-webkit-scrollbar{width:6px}.modal-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:999px}.modal-scroll::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media(max-width:640px){.modal-controls{flex-direction:column;align-items:stretch}.modal-tabs{width:100%;justify-content:space-between}.modal-tab{flex:1;text-align:center}.modal-search{width:100%}}.dash-empty{margin:0;font-size:.85rem;color:#6b7280;line-height:1.5}.chip-rank.is-top1{background:#ecfeff;color:#0369a1;border:1px solid #bae6fd}.chip-rank.is-top2{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.chip-rank.is-top3{background:#fefce8;color:#854d0e;border:1px solid #fde68a}.classranking-table-wrapper{border:1px solid #e5e7eb;border-radius:12px;width:100%;background:#fff;min-width:0;overflow-x:auto;overflow-y:hidden}.classranking-table-wrapper.is-scrollable{max-height:400px;overflow:auto}.classranking-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.classranking-table thead th{text-align:left;font-size:.85rem;font-weight:700;color:#111827;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:12px;position:sticky;top:0;z-index:1}.classranking-table tbody td{padding:12px;border-bottom:1px solid #f3f4f6;color:#111827;font-size:.92rem;vertical-align:middle}.classranking-table th,.classranking-table td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;align-items:stretch}.grid-span-2{grid-column:span 2}.dash-grid-3>*{min-width:0}@media(max-width:1200px){.dash-grid-3{grid-template-columns:1fr}.grid-span-2{grid-column:span 1}}.att-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:8px}@media(max-width:1200px){.att-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.att-kpi-grid{grid-template-columns:1fr}}.report-nav{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.report-tab{padding:8px 16px;border-radius:10px;border:none;background:transparent;font-size:.88rem;font-weight:600;color:#475569;cursor:pointer;transition:all .18s ease}.report-tab:hover{background:#2563eb1a}.report-tab.is-active{background:#2563eb;color:#fff;box-shadow:0 2px 5px #2563eb40}.report-color-key{display:flex;gap:16px;flex-wrap:wrap;font-size:.75rem;color:#6b7280;margin-bottom:18px}.report-color-key span{display:flex;align-items:center;gap:6px}.key-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.key-blue{background:#3b82f6}.key-green{background:#22c55e}.key-yellow{background:#facc15}.key-red{background:#ef4444}.key-gray{background:#9ca3af}.pa{display:flex;flex-direction:column;gap:14px}.pa-card{background:#fff;border:1px solid #e7e7ef;border-radius:12px;padding:14px}.pa-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.pa-card-head-row{align-items:center}.pa-title{margin:0;font-size:18px;font-weight:700}.pa-sub{margin:4px 0 0;color:#5f6470;font-size:13px}.pa-card-title{margin:0;font-size:14px;font-weight:700}.pa-empty{color:#6b7280;font-size:13px;padding:10px 0}.pa-filters{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:10px}.pa-field label{display:block;font-size:12px;color:#6b7280;margin-bottom:6px}.pa-field select{width:100%;height:38px;border-radius:10px;border:1px solid #e7e7ef;padding:0 10px;outline:none}.pa-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.pa-activity-meta{display:flex;flex-direction:column;gap:8px}.pa-meta-row{display:flex;justify-content:space-between;gap:10px;border-bottom:1px dashed #eef0f6;padding-bottom:8px}.pa-meta-k{color:#6b7280;font-size:12px}.pa-meta-v{font-size:12px;font-weight:600;text-align:right}.pa-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.pa-kpi{border:1px solid #eef0f6;border-radius:12px;padding:10px}.pa-kpi-label{font-size:12px;color:#6b7280;margin-bottom:6px}.pa-kpi-value{font-size:18px;font-weight:800;line-height:1}.pa-kpi-sub{margin-top:6px;font-size:11px;color:#6b7280}.pa-chart{width:100%;height:260px}.pa-table-controls{display:flex;align-items:center;gap:8px}.pa-table-controls label{font-size:12px;color:#6b7280}.pa-table-controls select{height:34px;border-radius:10px;border:1px solid #e7e7ef;padding:0 10px;outline:none}.pa-table-wrap{width:100%;overflow:auto}.pa-table{width:100%;border-collapse:collapse}.pa-table th,.pa-table td{text-align:left;padding:10px 8px;border-bottom:1px solid #eef0f6;font-size:13px}.pa-student-name{font-weight:700}.pa-student-sub{font-size:12px;color:#6b7280;margin-top:2px}.pa-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}.pa-chip.ok{background:#dcfce7;color:#166534}.pa-chip.bad{background:#fee2e2;color:#991b1b}.pa-chip.muted{background:#f3f4f6;border-color:#e5e7eb}@media(max-width:980px){.pa-filters,.pa-grid{grid-template-columns:1fr}.pa-kpis{grid-template-columns:1fr 1fr}}.pa-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:2000}.pa-modal{background:#fff;width:min(900px,95%);max-height:85vh;border-radius:14px;padding:16px;display:flex;flex-direction:column}.pa-modal-header{display:flex;align-items:center;justify-content:space-between}.pa-modal-header h4{margin:0;font-size:16px;font-weight:800}.pa-modal-close{background:transparent;border:none;font-size:18px;cursor:pointer}.pa-modal-subtitle{font-size:13px;color:#6b7280;margin:6px 0 12px}.pa-modal-body{overflow:auto}.pa-search{height:34px;border-radius:10px;border:1px solid #e7e7ef;padding:0 10px;outline:none;font-size:13px}.pa-sort-btn{height:34px;min-width:36px;border-radius:10px;border:1px solid #e7e7ef;background:#fff;cursor:pointer;font-size:14px}.pa-table-wrap{max-height:320px;overflow-y:auto;border-radius:12px}.pa-table-wrap{scrollbar-width:thin;scrollbar-color:#c7c9d3 transparent}.pa-table-wrap::-webkit-scrollbar{width:8px}.pa-table-wrap::-webkit-scrollbar-track{background:transparent}.pa-table-wrap::-webkit-scrollbar-thumb{background-color:#c7c9d3;border-radius:10px}.ps-wrap{display:flex;flex-direction:column;gap:14px}.ps-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.ps-title{margin:0;font-size:18px;font-weight:700}.ps-subtitle{margin:6px 0 0;font-size:13px;opacity:.75}.ps-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.at-kpi-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.at-wrap{display:flex;flex-direction:column;gap:1rem}.at-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.at-title{margin:0;font-size:20px;font-weight:700}.at-filters{display:flex;gap:10px;flex-wrap:wrap}.at-filter{border:1px solid #e5e7eb;border-radius:12px;padding:8px 10px;font-size:12px}.at-card{border:1px solid #e5e7eb;border-radius:14px;padding:14px}.at-card-header{margin-bottom:10px}.at-card-title{font-weight:700;font-size:14px}.at-card-subtitle{margin-top:4px;font-size:12px;opacity:.8}.at-kpi{border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;background:#0000001f;min-height:76px}.at-kpi-label{font-size:12px;opacity:.8}.at-kpi-value{margin-top:6px;font-size:18px;font-weight:800}.at-kpi-sub{margin-top:4px;font-size:11px;opacity:.7}.at-grid-2x2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media(max-width:900px){.at-grid-2x2{grid-template-columns:1fr}}.at-chart-placeholder{border:1px #e5e7eb;border-radius:12px;min-height:220px;display:flex;flex-direction:column;justify-content:center;padding:14px}.at-placeholder-title{font-weight:700;margin-bottom:6px}.at-placeholder-desc{font-size:12px;opacity:.8}.at-list{display:flex;flex-direction:column;gap:10px}.at-rowstat{display:flex;justify-content:space-between;gap:10px;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px}.at-rowstat-label{font-size:14px;opacity:.85}.at-rowstat-value{font-size:16px;font-weight:700}.at-table-wrap{overflow:auto;border-radius:12px;border:1px solid#e5e7eb}.at-table{width:100%;border-collapse:collapse}.at-table th,.at-table td{text-align:left;padding:10px 12px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.08)}.at-table th{font-size:14px;opacity:.8;font-weight:700}.at-note{margin-top:10px;font-size:12px;opacity:.75}.at-bullets{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;font-size:12px;opacity:.9}@media(max-width:1200px){.at-kpi-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.at-two-col{grid-template-columns:1fr}.at-table{min-width:0}}@media(max-width:520px){.at-kpi-grid{grid-template-columns:repeat(2,1fr)}}.at-kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.at-kpi{border:1px solid#e5e7eb;border-radius:12px;padding:14px;background-color:#fff}.at-kpi-label{font-size:12px;opacity:.8;letter-spacing:.2px}.at-kpi-value{margin-top:8px;font-size:22px;font-weight:800;line-height:1.1}.at-kpi-sub{margin-top:6px;font-size:11px;opacity:.7}.at-chart{width:100%;min-height:260px;border-radius:14px;padding:6px;border:1px solid #e5e7eb}.at-card{border:1px solid #e5e7eb;border-radius:12px;padding:14px}@media(max-width:520px){.at-kpi-grid{grid-template-columns:1fr}}.at-rank-row{cursor:pointer;transition:background .15s ease}.at-rank-row:hover{background:#f9fafb}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;font-weight:700;font-size:12px;background:#e5e7eb}.rank-1{background:#facc15;color:#78350f}.rank-2{background:#e5e7eb}.rank-3{background:#d97706;color:#fff}.status-chip{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600}.status-chip.pass{background:#dcfce7;color:#166534}.status-chip.risk{background:#fee2e2;color:#991b1b}.at-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2001}.at-modal{z-index:2001;background:#fff;border-radius:14px;padding:20px}.at-modal-sub{font-size:12px;opacity:.7;margin-bottom:12px}.at-modal-summary{margin-top:14px;font-size:14px}.at-modal-actions{display:flex;justify-content:flex-end;margin-top:16px}.at-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;position:sticky;top:0}.at-modal-title{margin:0}.at-modal-sub{font-size:.85rem;opacity:.85;margin-top:4px}.at-modal-kpis{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.at-mini-kpi{border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;background:#fff}.at-mini-kpi-label{font-size:.75rem;opacity:.7}.at-mini-kpi-value{font-size:1.05rem;font-weight:700;margin-top:4px}.at-modal-section{margin-top:14px}.at-modal-section-title{font-weight:700;margin-bottom:8px}.at-alert-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.at-alert-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.at-alert-title{display:flex;align-items:center;justify-content:space-between;font-weight:700;margin-bottom:8px}.at-alert-count{font-size:.85rem;opacity:.8}.at-alert-list{margin:0;padding-left:18px}.at-alert-list li{margin:6px 0;font-size:.9rem}.at-alert-meta{margin-left:8px;font-size:.8rem;opacity:.75}@media(max-width:820px){.at-alert-grid{grid-template-columns:1fr}}.at-modal-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.at-modal-section-sub{font-size:.82rem;opacity:.75;margin-top:2px}.at-muted{opacity:.75}.at-modal--lg{width:min(920px,calc(100vw - 28px));max-height:min(86vh,760px);display:flex;flex-direction:column;border-radius:16px;overflow:hidden}.at-modal-top{position:sticky;top:0;z-index:2;background:#fff;border-bottom:1px solid #eef2f7;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.at-modal-x{border:1px solid #e5e7eb;background:#fff;border-radius:10px;padding:6px 10px;cursor:pointer}.at-modal-body{padding:12px 14px;overflow:auto;flex:1}.at-modal-bottom{position:sticky;bottom:0;z-index:2;background:#fff;border-top:1px solid #eef2f7;padding:12px 16px;display:flex;justify-content:flex-end}.at-modal-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:12px}.at-panel{border:1px solid #e5e7eb;background:#fff;border-radius:14px;overflow:hidden}.at-panel--full{grid-column:1 / -1}.at-panel-head{padding:10px 12px;border-bottom:1px solid #eef2f7;display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.at-panel-title{font-weight:700}.at-panel-sub{font-size:.82rem;opacity:.75;margin-top:2px;padding-bottom:4px}.at-panel-content{padding:10px 12px 12px}.at-snap-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.at-att-stats--compact{grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:900px){.at-modal-grid{grid-template-columns:1fr}.at-panel--full{grid-column:auto}.at-snap-row{grid-template-columns:1fr}}.at-table-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}.at-pager{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.at-pager-size{display:flex;align-items:center;gap:6px;font-size:.85rem}.at-pager-size select{padding:6px 8px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.at-pager-btn{padding:6px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer}.at-pager-btn:disabled{opacity:.5;cursor:not-allowed}.at-pager-info{font-size:.85rem;padding:0 6px}.at-att-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}@media(max-width:820px){.at-att-grid{grid-template-columns:1fr}}.at-compact-chart{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}.at-compact-chart-scroll{max-height:240px;overflow:auto;padding:10px 10px 0}.at-compact-chart-inner{min-height:180px}.at-compact-chart-foot{display:flex;justify-content:flex-end;gap:6px;padding:8px 12px 10px;border-top:1px solid #eef2f7;font-size:.85rem}.at-att-compact{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:12px}.at-att-top{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.at-att-rate-label{font-size:.78rem;opacity:.75}.at-att-rate-value{font-size:1.35rem;font-weight:800;margin-top:2px}.at-att-bar{margin-top:10px;height:10px;border-radius:999px;background:#eef2f7;overflow:hidden}.at-att-bar-fill{height:100%;border-radius:999px;width:0%;background:#3b82f6}.at-att-stats{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.at-att-stat{border:1px solid #eef2f7;border-radius:10px;padding:8px 10px}.at-att-stat-label{font-size:.75rem;opacity:.75}.at-att-stat-value{font-size:1.05rem;font-weight:800;margin-top:2px}.status-chip.warn{background:#fef3c7;color:#92400e}@media(max-width:820px){.at-att-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.calendar{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background-color:#fff}.calendar__title{font-size:1.5rem;font-weight:700;margin-bottom:16px}.card-calendar{border:1px solid#E5E7EB;border-radius:16px;padding:12px}.calendar-top{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}.cal-left{display:flex;align-items:center;gap:8px}.cal-title{margin:0 6px;font-weight:800}.cal-legend{display:flex;flex-wrap:wrap;gap:8px}.legend-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:6px 10px;font-weight:600}.legend-chip.is-off{opacity:.4;filter:grayscale(30%)}.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.cal-dow{text-align:center;font-weight:700;color:#475569;padding:6px 0;border-radius:8px;background:#f1f5f9}.cal-cell{min-height:110px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;padding:6px;display:flex;flex-direction:column}.cal-cell.is-dim{background:#fafafa;color:#9ca3af}.cal-date{display:flex;justify-content:flex-end}.cal-badge{font-size:.85rem;font-weight:700;color:#334155;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 6px;border-radius:8px}.cal-badge.is-today{background:#2563eb;color:#fff;border-color:#2563eb}.cal-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.cal-tag{font-size:.68rem;padding:1px 4px;border-radius:6px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;border:1px solid}.cal-more-tag{font-size:.7rem;color:#475569}.icon-btn{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:6px 8px;cursor:pointer}.icon-btn:hover{background:#f8fafc}.act-type-chip{border:1px solid;border-radius:999px;padding:2px 8px;font-weight:600;font-size:.8rem}.prof-settings{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background-color:#fff}.profsettings__title{font-size:1.5rem;font-weight:700;margin-bottom:16px}.card-profsettings{background-color:#fff;border-radius:16px;border:1px solid #e5e7eb;padding:12px;margin-top:12px}.pass-peek{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;font-size:18px}.grad-history{padding:20px;color:var(--ink, #0f172a);font-family:Lexend,system-ui,sans-serif;background-color:#fff}.gradhistory__title{font-size:1.5rem;font-weight:700}.gradhistory__subtitle{margin:4px 0 0;color:#6b7280}.grad-history__filters{display:flex;align-items:flex-end;gap:15px;padding:12px 0;flex-wrap:wrap}.gh-filter{display:flex;flex-direction:column;gap:6px;min-width:200px;gap:.25rem}.gh-filter:hover{border-color:#94a3b8}.gh-filter:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f640}.gh-filter label{font-size:.85rem;font-weight:600;color:#475569;letter-spacing:.02em}.gh-filter .ay-select{padding:10px 12px;border:1px solid #dbe1e8;background:#fff;border-radius:8px;font-size:.9rem;color:#1e293b;cursor:pointer;transition:.15s ease}.gh-filter .ay-select:hover{border-color:#2563eb}.gh-filter .ay-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40}@media(max-width:768px){.grad-history__filters{flex-direction:column;align-items:stretch;gap:18px}.gh-filter{width:100%}}
