@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--font:"Inter", system-ui, sans-serif;--bg:#f0f2f7;--bg-card:#fff;--bg-sidebar:#1e1b4b;--bg-sidebar-hover:#ffffff14;--bg-sidebar-active:#ffffff26;--text:#0f172a;--text-muted:#64748b;--text-sidebar:#ffffffd9;--border:#00000012;--shadow:0 1px 3px #00000014, 0 4px 16px #0000000d;--shadow-lg:0 8px 30px #0000001f;--radius:14px;--radius-sm:8px;--sidebar-width:260px;--primary:#6366f1;--primary-dark:#4f46e5;--green:#10b981;--purple:#8b5cf6;--amber:#f59e0b;--red:#ef4444}[data-theme=dark]{--bg:#0d0f1a;--bg-card:#161927;--bg-sidebar:#0a0c18;--bg-sidebar-hover:#ffffff0d;--bg-sidebar-active:#6366f140;--text:#e2e8f0;--text-muted:#94a3b8;--border:#ffffff0f;--shadow:0 1px 3px #0000004d, 0 4px 16px #0003;--shadow-lg:0 8px 30px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:15px}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button,input{font-family:var(--font)}.app-shell{background:var(--bg);height:100vh;color:var(--text);transition:background .3s,color .3s;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;padding:0;display:flex;overflow-y:auto}.app-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);letter-spacing:.01em;margin-top:auto;padding:1rem 2.5rem;font-size:.78rem}.app-footer__name{background:linear-gradient(135deg, var(--primary), var(--purple));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.sidebar{width:var(--sidebar-width);z-index:100;background:linear-gradient(#1a1744 0%,#1e1b4b 60%,#16143a 100%);border-right:1px solid #ffffff0d;flex-direction:column;flex-shrink:0;padding:1.25rem .85rem 1rem;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar__header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:0 .25rem;display:flex}.sidebar__logo{color:#fff;letter-spacing:-.01em;align-items:center;gap:.65rem;font-size:1rem;font-weight:700;display:flex}.sidebar__logo-icon{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex;box-shadow:0 4px 12px #6366f166}.sidebar__user{background:#ffffff0f;border:1px solid #ffffff14;border-radius:12px;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.75rem;display:flex}.sidebar__avatar{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex;box-shadow:0 3px 10px #6366f159}.sidebar__user-info{flex-direction:column;min-width:0;display:flex}.sidebar__user-label{color:#fff;font-size:.82rem;font-weight:600}.sidebar__user-sub{color:#ffffff73;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.sidebar__nav-section{text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;margin-top:.25rem;margin-bottom:.35rem;padding:0 .9rem;font-size:.68rem;font-weight:700}.sidebar__close{display:none}.sidebar__nav{flex-direction:column;flex:1;gap:.2rem;display:flex}.sidebar__nav-item{color:#fff9;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.7rem;width:100%;padding:.65rem .85rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .18s,color .18s,transform .15s;display:flex;position:relative}.sidebar__nav-icon{background:#ffffff0f;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .18s;display:flex}.sidebar__nav-arrow{opacity:0;color:#ffffff80;flex-shrink:0;margin-left:auto;transition:opacity .15s,transform .15s;transform:translate(-4px)}.sidebar__nav-item:hover{color:#fff;background:#ffffff12;transform:translate(2px)}.sidebar__nav-item:hover .sidebar__nav-icon{background:#ffffff1f}.sidebar__nav-item:hover .sidebar__nav-arrow{opacity:1;transform:translate(0)}.sidebar__nav-item--active{border:1px solid #6366f133;font-weight:600;color:#fff!important;background:linear-gradient(135deg,#6366f140,#8b5cf626)!important}.sidebar__nav-item--active .sidebar__nav-icon{color:#c4b5fd;background:#6366f159!important}.sidebar__nav-item--active .sidebar__nav-arrow{opacity:1;transform:translate(0)}.sidebar__footer{border-top:1px solid #ffffff14;flex-direction:column;gap:.2rem;margin-top:.5rem;padding-top:.85rem;display:flex}.sidebar__theme-btn{color:#ffffff8c!important}.sidebar__theme-btn:hover{color:#fff!important}.sidebar__logout{color:#fca5a5cc!important}.sidebar__logout:hover{color:#fca5a5!important;background:#ef44441f!important}.sidebar__logout .sidebar__nav-icon{background:#ef44441a!important}.sidebar__hamburger{z-index:200;background:var(--bg-card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow);display:none;position:fixed;top:1rem;left:1rem}.sidebar__overlay{z-index:99;background:#0000008c;display:none;position:fixed;inset:0}.page{max-width:1200px;margin:0 auto;padding:2rem 2.5rem;animation:.35s both fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-title{letter-spacing:-.03em;color:var(--text);font-size:1.75rem;font-weight:800}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:1.5rem;transition:box-shadow .2s,transform .2s}.card--hoverable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.stat-card__icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-card--primary .stat-card__icon{color:var(--primary);background:#6366f11f}.stat-card--green .stat-card__icon{color:var(--green);background:#10b9811f}.stat-card--purple .stat-card__icon{color:var(--purple);background:#8b5cf61f}.stat-card--amber .stat-card__icon{color:var(--amber);background:#f59e0b1f}.stat-card__body{flex-direction:column;min-width:0;display:flex}.stat-card__value{letter-spacing:-.03em;white-space:nowrap;text-overflow:ellipsis;font-size:1.5rem;font-weight:800;overflow:hidden}.stat-card__label{color:var(--text-muted);margin-top:2px;font-size:.8rem;font-weight:500}.section{margin-top:0}.section-title{color:var(--text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;font-weight:700;display:flex}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem;display:grid}.course-card{align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.course-card__avatar{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:.95rem;font-weight:700;display:flex}.course-card__body{flex:1;min-width:0}.course-card__name{margin-bottom:2px;font-size:.95rem;font-weight:600;line-height:1.35}.course-card__code{color:var(--text-muted);margin-bottom:.5rem;font-size:.78rem}.course-card__meta{flex-wrap:wrap;gap:.3rem;margin-bottom:.4rem;display:flex}.course-card__instructor{color:var(--text-muted);align-items:center;gap:4px;margin-top:.3rem;font-size:.78rem;display:flex}.badge{color:var(--primary);background:#6366f11f;border-radius:20px;align-items:center;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.badge--secondary{color:var(--text-muted);background:#64748b1f}.badge--primary{color:var(--primary);background:#6366f126}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.55rem 1.2rem;font-size:.88rem;font-weight:600;transition:opacity .15s,transform .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f159}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow)}.btn-secondary:hover:not(:disabled){box-shadow:var(--shadow-lg)}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.btn-icon:hover{background:var(--bg-card);color:var(--text)}.btn-reset{cursor:pointer;background:0 0;border:none}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.loading-text{color:var(--text-muted);font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.7s linear infinite spin}.error-container{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;display:flex}.error-icon{color:var(--red)}.error-title{font-size:1.1rem;font-weight:700}.error-message{color:var(--text-muted);max-width:420px;font-size:.9rem}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:1rem;padding:3rem;display:flex}.empty-icon{opacity:.3}.login-page{background:linear-gradient(135deg,#1e1b4b 0%,#312e81 40%,#4c1d95 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.login-bg-pattern{z-index:0;background-image:radial-gradient(circle at 15%,#6366f140 0%,#0000 50%),radial-gradient(circle at 85% 30%,#8b5cf633 0%,#0000 40%);position:absolute;inset:0}.login-card{z-index:1;background:#fffffff7;border-radius:20px;width:100%;max-width:420px;padding:2.5rem;animation:.4s both fadeUp;position:relative;box-shadow:0 25px 50px #0000004d}[data-theme=dark] .login-card{background:#161927;border:1px solid #ffffff12}.login-card__header{text-align:center;margin-bottom:2rem}.login-logo{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1rem;display:flex;box-shadow:0 8px 24px #6366f166}.login-title{letter-spacing:-.03em;color:var(--text);font-size:1.6rem;font-weight:800}.login-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.login-form{flex-direction:column;gap:1.1rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-label{color:var(--text);font-size:.83rem;font-weight:600}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);outline:none;padding:.7rem 1rem;font-size:.92rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-input::placeholder{color:var(--text-muted)}.input-wrapper{position:relative}.input-wrapper .form-input{padding-right:2.8rem}.input-suffix{position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.form-error{color:var(--red);border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef44444d;padding:.6rem .9rem;font-size:.85rem}.login-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.8rem}.profile-layout{grid-template-columns:260px 1fr;align-items:start;gap:1.5rem;display:grid}.profile-avatar-card{text-align:center;padding:2rem 1.5rem}.profile-avatar{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;font-size:1.8rem;font-weight:700;display:flex;box-shadow:0 8px 24px #6366f14d}.profile-name{margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.profile-roll{color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem}.card-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:1rem;font-size:.85rem;font-weight:700}.detail-list{flex-direction:column;gap:.75rem;display:flex}.detail-row{align-items:flex-start;gap:.75rem;display:flex}.detail-row__icon{width:30px;height:30px;color:var(--primary);background:#6366f11a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.detail-row__content{flex-direction:column;display:flex}.detail-row__label{color:var(--text-muted);font-size:.75rem;font-weight:500}.detail-row__value{font-size:.9rem;font-weight:600}.detail-table{flex-direction:column;gap:0;display:flex}.detail-table__row{border-bottom:1px solid var(--border);gap:1rem;padding:.55rem 0;font-size:.88rem;display:flex}.detail-table__row:last-child{border-bottom:none}.detail-table__key{color:var(--text-muted);flex-shrink:0;width:180px}.detail-table__value{font-weight:500}.att-summary{background:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);gap:1px;margin-bottom:1.5rem;display:flex;overflow:hidden}.att-summary__item{background:var(--bg-card);flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:1.1rem;display:flex}.att-summary__value{font-size:1.5rem;font-weight:800}.att-summary__label{color:var(--text-muted);font-size:.75rem;font-weight:500}.att-summary__item--safe .att-summary__value{color:var(--green)}.att-summary__item--warning .att-summary__value{color:var(--amber)}.att-summary__item--danger .att-summary__value{color:var(--red)}.attendance-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.attendance-card{padding:1.25rem}.attendance-card__header{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.85rem;display:flex}.attendance-card__title-group{flex:1;min-width:0}.attendance-card__course{font-size:.93rem;font-weight:600;line-height:1.3}.attendance-card__code{color:var(--text-muted);margin-top:2px;font-size:.75rem}.attendance-card__badge{border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:3px 9px;font-size:.72rem;font-weight:700;display:inline-flex}.attendance-bar{background:var(--border);border-radius:3px;height:6px;margin-bottom:.75rem;overflow:hidden}.attendance-bar__fill{border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.attendance-card__stats{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.attendance-pct{font-size:1.3rem;font-weight:800}.attendance-card__breakdown{flex-wrap:wrap;gap:.3rem;display:flex}.att-chip{background:var(--bg);color:var(--text-muted);border-radius:20px;padding:2px 7px;font-size:.72rem;font-weight:600}.att-chip--present{color:var(--green);background:#10b9811f}.att-chip--absent{color:var(--red);background:#ef44441f}@media (width<=768px){.sidebar{border-right:1px solid var(--border);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar__close,.sidebar__hamburger{display:flex}.sidebar__overlay{display:block}.main-content{overflow-x:hidden}.page{padding:4rem 1rem 1.25rem}.profile-layout{grid-template-columns:1fr}.att-summary{flex-wrap:wrap}.att-summary__item{min-width:50%}.page-title{font-size:1.3rem}}@media (width<=480px){.courses-grid,.attendance-grid,.stat-grid{grid-template-columns:1fr}}.dashboard-page{max-width:1200px;margin:0 auto;padding:2rem 2.5rem}.dashboard-welcome{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);align-items:center;gap:1.25rem;margin-bottom:2rem;padding:1.5rem 2rem;display:flex}.welcome-avatar{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.6rem;font-weight:700;display:flex;box-shadow:0 8px 20px #6366f14d}.welcome-name{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.welcome-sub{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.course-card-inner{align-items:flex-start;gap:1rem;display:flex}.course-color-strip{border-radius:4px;flex-shrink:0;align-self:stretch;width:4px;min-height:40px}.course-card-content{flex:1;min-width:0}.course-code{color:var(--primary);background:#6366f11a;border-radius:4px;margin-bottom:.35rem;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-block}.course-title{font-size:.9rem;font-weight:600;line-height:1.4}.profile-page{max-width:900px;margin:0 auto;padding:2rem 2.5rem}.profile-hero{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:2rem;display:flex}.profile-hero .profile-avatar{background:#fff3;width:80px;height:80px;font-size:2rem;box-shadow:0 4px 20px #0003}.profile-name{color:#fff;font-size:1.6rem;font-weight:800}.profile-roll{color:#ffffffbf;margin-top:.2rem;font-size:.9rem}.profile-programme{color:#fff9;margin-top:.1rem;font-size:.85rem}.profile-highlights{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.profile-highlight-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);flex-direction:column;gap:.3rem;padding:1rem 1.25rem;display:flex}.highlight-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.73rem;font-weight:600}.highlight-value{font-size:.95rem;font-weight:700}.profile-details-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.profile-table{border-collapse:collapse;width:100%}.profile-td-key{color:var(--text-muted);vertical-align:top;border-bottom:1px solid var(--border);width:200px;padding:.5rem .75rem .5rem 0;font-size:.85rem;font-weight:500}.profile-td-val{border-bottom:1px solid var(--border);padding:.5rem 0;font-size:.88rem;font-weight:600}.profile-table tr:last-child .profile-td-key,.profile-table tr:last-child .profile-td-val{border-bottom:none}.no-data-msg{color:var(--text-muted);text-align:center;padding:2rem}.attendance-page{max-width:1200px;margin:0 auto;padding:2rem 2.5rem}.attendance-info-banner{border-radius:var(--radius-sm);color:var(--text-muted);background:#6366f112;border:1px solid #6366f133;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:.85rem 1.1rem;font-size:.87rem;display:flex}.att-card-header{margin-bottom:.6rem}.att-code-badge{border-radius:6px;padding:3px 10px;font-size:.8rem;font-weight:700;display:inline-block}.att-course-title{margin-bottom:.85rem;font-size:.92rem;font-weight:600;line-height:1.35}.att-view-btn{border:1.5px solid;border-radius:6px;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.8rem;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.att-view-btn:hover{opacity:.8;text-decoration:none}@media (width<=768px){.dashboard-page,.profile-page,.attendance-page{padding:4rem 1rem 1.25rem}.profile-hero{text-align:center;flex-direction:column}}.att-modal-overlay{z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.att-modal{background:var(--bg-card);border-radius:var(--radius);flex-direction:column;width:100%;max-width:740px;max-height:85vh;animation:.2s slideUp;display:flex;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.att-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex}.att-modal-title{margin-top:.4rem;font-size:.95rem;font-weight:600}.att-modal-close{color:var(--text-muted)}.att-modal-body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.att-modal-error{color:var(--red);border-radius:var(--radius-sm);background:#ef444414;align-items:center;gap:.5rem;padding:1rem;font-size:.9rem;display:flex}.att-modal-summary{background:var(--border);border-radius:var(--radius-sm);gap:1px;margin-bottom:1.25rem;display:flex;overflow:hidden}.att-stat{background:var(--bg-card);flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.85rem .5rem;display:flex}.att-stat-val{font-size:1.4rem;font-weight:800}.att-stat-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:500}.att-modal-table-wrap{border-radius:var(--radius-sm);border:1px solid var(--border);overflow-x:auto}.att-detail-table{border-collapse:collapse;width:100%;font-size:.85rem}.att-detail-table td{border-bottom:1px solid var(--border);padding:.5rem .75rem}.att-detail-table tr:last-child td{border-bottom:none}.att-row-present td:last-child{color:var(--green);font-weight:600}.att-row-absent td:last-child{color:var(--red);font-weight:600}.att-row-absent{background:#ef44440a}.session-banner{z-index:500;background:linear-gradient(90deg,#7f1d1d,#991b1b);border-bottom:1px solid #ff505059;animation:.3s cubic-bezier(.4,0,.2,1) both slideDown;position:sticky;top:0;box-shadow:0 2px 12px #ef44444d}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.session-banner__inner{flex-wrap:wrap;align-items:center;gap:.75rem;padding:.65rem 1.25rem;display:flex}.session-banner__icon{color:#fca5a5;flex-shrink:0}.session-banner__text{color:#fef2f2;flex:1;min-width:200px;font-size:.87rem;font-weight:500}.session-banner__signout{color:#fff;cursor:pointer;font-size:.82rem;font-weight:600;font-family:var(--font);background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;align-items:center;gap:.4rem;padding:.35rem .85rem;transition:background .15s;display:inline-flex}.session-banner__signout:hover{background:#ffffff40}.session-banner__close{color:#ffffffb3;width:28px;height:28px}.session-banner__close:hover{color:#fff!important;background:#ffffff1a!important}.login-bg-orb{filter:blur(60px);pointer-events:none;z-index:0;border-radius:50%;position:absolute}.login-bg-orb--1{background:radial-gradient(circle,#6366f159 0%,#0000 70%);width:420px;height:420px;animation:8s ease-in-out infinite alternate orbFloat;top:-120px;left:-100px}.login-bg-orb--2{background:radial-gradient(circle,#8b5cf64d 0%,#0000 70%);width:320px;height:320px;animation:10s ease-in-out infinite alternate-reverse orbFloat;bottom:-80px;right:-60px}.login-bg-orb--3{background:radial-gradient(circle,#ec489933 0%,#0000 70%);width:200px;height:200px;animation:12s ease-in-out infinite alternate orbFloat3;top:50%;left:60%}@keyframes orbFloat{0%{transform:translate(0)scale(1)}to{transform:translate(20px,-20px)scale(1.08)}}@keyframes orbFloat3{0%{transform:translate(-50%,-50%)scale(1)}to{transform:translate(calc(20px - 50%),calc(-50% - 20px))scale(1.08)}}.login-bg-grid{z-index:0;pointer-events:none;background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.login-secure-badge{color:#34d399;background:#10b98126;border:1px solid #10b9814d;border-radius:20px;align-items:center;gap:.3rem;margin-top:.6rem;padding:.25rem .65rem;font-size:.72rem;font-weight:600;display:inline-flex}.login-btn{letter-spacing:.02em;margin-top:.25rem;padding:.75rem 1.5rem!important;font-size:.95rem!important;transition:box-shadow .2s,transform .15s!important;box-shadow:0 4px 16px #6366f166!important}.login-btn:hover:not(:disabled){transform:translateY(-1px)!important;box-shadow:0 8px 24px #6366f180!important}.sidebar__nav-item--active:before{content:"";background:linear-gradient(180deg, var(--primary), var(--purple));border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:-.85rem;transform:translateY(-50%);box-shadow:0 0 8px #6366f199}.section-subtitle{color:var(--text-muted);margin-top:-.5rem;margin-bottom:1.25rem;font-size:.84rem}.unified-courses-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.unified-course-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;gap:.55rem;padding:1.25rem 1.25rem 1rem;transition:box-shadow .2s,transform .2s;display:flex;border-left-width:4px!important}.unified-course-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.ucc-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.ucc-loading-dot{border:2px solid var(--primary);border-top-color:#0000;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:.6s linear infinite spin}.ucc-pct-badge{border-radius:20px;margin-left:auto;padding:.2rem .6rem;font-size:.78rem;font-weight:700}.ucc-title{color:var(--text);font-size:.9rem;font-weight:600;line-height:1.4}.ucc-bar-wrap{background:var(--border);border-radius:3px;height:5px;overflow:hidden}.ucc-bar-fill{border-radius:3px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.ucc-mini-stats{color:var(--text-muted);gap:.85rem;font-size:.76rem;font-weight:500;display:flex}.ucc-mini-stats span{align-items:center;gap:3px;display:inline-flex}.ucc-att-err{color:var(--text-muted);font-size:.76rem;font-style:italic}.ucc-detail-btn{cursor:pointer;font-size:.8rem;font-weight:600;font-family:var(--font);background:0 0;border:1.5px solid;border-radius:7px;align-self:flex-start;align-items:center;gap:.4rem;margin-top:.25rem;padding:.4rem .9rem;transition:opacity .15s,transform .15s;display:inline-flex}.ucc-detail-btn:hover{opacity:.75;transform:translateY(-1px)}.att-pct-hero{flex-direction:column;align-items:center;margin:.5rem 0 1rem;display:flex}.att-pct-hero__number{letter-spacing:-.04em;font-size:3rem;font-weight:800;line-height:1}.att-pct-hero__label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:.2rem;font-size:.78rem;font-weight:600}.att-progress-wrap{background:var(--border);border-radius:4px;height:8px;margin-bottom:1.25rem;overflow:hidden}.att-progress-fill{border-radius:4px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.att-absent-heading{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.6rem;font-size:.78rem;font-weight:700}@media (width<=480px){.unified-courses-grid{grid-template-columns:1fr}}.profile-page{flex-direction:column;gap:1.25rem;max-width:780px;margin:0 auto;padding:2rem 2.5rem;animation:.35s both fadeUp;display:flex}.prf-hero{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 60%,#6d28d9 100%);align-items:center;gap:1.5rem;padding:2rem;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #4f46e559}.prf-hero-glow{pointer-events:none;background:radial-gradient(circle,#ffffff1f 0%,#0000 70%);border-radius:50%;width:300px;height:300px;position:absolute;bottom:-100px;right:-60px}.prf-hero-avatar{z-index:1;background:#fff3;border:2px solid #ffffff59;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:1.9rem;font-weight:800;display:flex;box-shadow:0 4px 20px #0003}.prf-hero-info{z-index:1;flex-direction:column;gap:.35rem;display:flex}.prf-hero-name{letter-spacing:-.02em;font-size:1.6rem;font-weight:800}.prf-hero-roll{color:#ffffffb3;font-size:.9rem;font-weight:500}.prf-hero-badges{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.prf-badge{border-radius:20px;align-items:center;padding:.2rem .65rem;font-size:.73rem;font-weight:700;display:inline-flex}.prf-badge--cyan{color:#a5f3fc;background:#06b6d44d;border:1px solid #06b6d480}.prf-badge--red{color:#fca5a5;background:#ef44444d;border:1px solid #ef444480}.prf-badge--amber{color:#fde68a;background:#f59e0b4d;border:1px solid #f59e0b80}.prf-badge--purple{color:#e9d5ff;background:#a855f74d;border:1px solid #a855f780}.prf-stat-tiles{flex-wrap:wrap;gap:.75rem;display:flex}.prf-stat-tile{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;flex-direction:column;flex:1;gap:.2rem;min-width:120px;padding:.85rem 1.1rem;transition:transform .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.prf-stat-tile:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.prf-stat-tile:before{content:"";background:var(--tile-color,var(--primary));border-radius:0 0 12px 12px;height:3px;position:absolute;bottom:0;left:0;right:0}.prf-stat-tile__value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.prf-stat-tile__label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.68rem;font-weight:600}.prf-sections{flex-direction:column;gap:.85rem;display:flex}.prf-section-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.prf-section-header{cursor:pointer;text-align:left;width:100%;font-family:var(--font);background:0 0;border:none;align-items:center;gap:.75rem;padding:1rem 1.25rem;transition:background .15s;display:flex}.prf-section-header:hover{background:#00000008}[data-theme=dark] .prf-section-header:hover{background:#ffffff08}.prf-section-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.prf-section-title{color:var(--text);flex:1;font-size:.9rem;font-weight:700}.prf-section-chevron{color:var(--text-muted);flex-shrink:0}.prf-section-body{border-top:1px solid var(--border);flex-direction:column;gap:0;padding:.25rem 1.25rem 1rem;animation:.2s both fadeUp;display:flex}.prf-info-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:.85rem;padding:.75rem 0;display:flex}.prf-info-row:last-child{border-bottom:none}.prf-info-icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-top:1px;display:flex}.prf-info-body{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.prf-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600}.prf-info-value-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.prf-info-value{color:var(--text);word-break:break-all;font-size:.92rem;font-weight:600}.profile-copy-btn{border:1px solid var(--border);background:var(--bg);width:22px;height:22px;color:var(--text-muted);cursor:pointer;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.profile-copy-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.prf-reveal-btn{border:1px solid var(--border);background:var(--bg);color:var(--primary);cursor:pointer;font-size:.7rem;font-weight:600;font-family:var(--font);border-radius:4px;padding:.1rem .5rem;transition:background .12s}.prf-reveal-btn:hover{background:var(--primary);color:#fff}@media (width<=768px){.profile-page{padding:4rem 1rem 1.25rem}.prf-hero{text-align:center;flex-direction:column;align-items:center}.prf-hero-badges{justify-content:center}}@media (width<=480px){.prf-stat-tiles{flex-direction:column}.prf-stat-tile{min-width:unset}}.safety-chip{letter-spacing:.02em;white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:3px;padding:.18rem .55rem;font-size:.68rem;font-weight:700;display:inline-flex}.safety-chip--safe{color:#10b981;background:#10b9811f;border:1px solid #10b9814d}.safety-chip--danger{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.skip-card{border:1.5px solid;border-radius:10px;align-items:center;gap:.85rem;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.skip-card--safe{background:#10b98114;border-color:#10b9814d}.skip-card--danger{background:#ef444414;border-color:#ef44444d}.skip-card__icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.skip-card--safe .skip-card__icon{color:#10b981;background:#10b98126}.skip-card--danger .skip-card__icon{color:#ef4444;background:#ef444426}.skip-card__body{flex-direction:column;gap:.1rem;display:flex}.skip-card__headline{color:var(--text);font-size:.88rem;font-weight:600}.skip-card--safe .skip-card__headline strong{color:#10b981}.skip-card--danger .skip-card__headline strong{color:#ef4444}.skip-card__sub{color:var(--text-muted);font-size:.76rem}.ucc-threshold-tick{z-index:2;background:#ffffff80;border-radius:2px;width:2px;height:calc(100% + 6px);position:absolute;top:-3px;box-shadow:0 0 4px #0006}.att-threshold-marker{pointer-events:none;z-index:3;flex-direction:column;align-items:center;display:flex;position:absolute;top:-14px;transform:translate(-50%)}.att-threshold-line{background:#64748b80;border-radius:1px;width:2px;height:36px}.att-threshold-label{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:.62rem;font-weight:700}.ucc-skip-hint{border-radius:10px;align-items:center;gap:3px;margin-left:auto;padding:.1rem .45rem;font-size:.7rem;font-weight:600;display:inline-flex}.ucc-skip-hint--safe{color:#10b981;background:#10b9811a}.ucc-skip-hint--danger{color:#ef4444;background:#ef44441a}.att-legend{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px;flex-wrap:wrap;align-items:center;gap:1.1rem;padding:.6rem .85rem;font-size:.76rem;font-weight:500;display:flex}.att-legend__item{align-items:center;gap:.3rem;display:inline-flex}.att-legend__item--safe{color:#10b981}.att-legend__item--danger{color:#ef4444}.att-legend-tick{vertical-align:middle;background:#94a3b8;border-radius:1px;width:2px;height:12px;display:inline-block}.welcome-overview{flex-wrap:wrap;flex-shrink:0;gap:.5rem;margin-left:auto;display:flex}.welcome-overview__item{color:#ffffffd9;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.78rem;font-weight:600;display:inline-flex}.welcome-overview__item--safe{color:#6ee7b7;border-color:#10b98166}.welcome-overview__item--risk{color:#fca5a5;border-color:#ef444466}@media (width<=768px){.welcome-overview{margin-left:0}.dashboard-welcome{flex-wrap:wrap}}
