body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--blue:#4b65f5;--blue-dk:#3550e0;--blue-lt:#eef1fe;--blue-mid:#c3cdfb;--accent:#10b981;--accent-dk:#059669;--accent-lt:#ecfdf5;--surface:#fff;--bg:#f5f6fb;--border:#e8ebf5;--text-1:#0f1733;--text-2:#4b5563;--text-3:#9ca3af;--radius-sm:10px;--radius-md:16px;--radius-lg:22px;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 20px #00000014;--font-head:"Montserrat",sans-serif;--font-body:"Montserrat",sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}a{color:inherit;text-decoration:none}button{background:none;border:none;cursor:pointer}.page-bg,button,input{font-family:Montserrat,sans-serif;font-family:var(--font-body)}.page-bg{background:#f5f6fb;background:var(--bg);color:#0f1733;color:var(--text-1);display:flex;min-height:100vh;overflow-x:hidden}.dashboard-card{display:grid;grid-template-columns:220px 1fr 280px;max-width:100%;min-height:100vh;width:100%}.dashboard-card,.sidebar{background:#fff;background:var(--surface);overflow:hidden}.sidebar{border-right:1px solid #e8ebf5;border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;min-width:0;padding:32px 16px 28px;position:sticky;top:0}.sidebar-logo{gap:10px;padding:0 8px 36px}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{background:#4b65f5;background:var(--blue);border-radius:12px;flex-shrink:0;height:38px;justify-content:center;width:38px}.logo-text{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:-.3px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px}.nav-item{align-items:center;border-radius:10px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-3);display:flex;font-size:13px;font-weight:500;gap:11px;padding:11px 14px;position:relative;transition:background .15s,color .15s}.nav-item--active,.nav-item:hover{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.nav-item--active .nav-icon svg{stroke:#4b65f5;stroke:var(--blue)}.nav-icon{align-items:center;display:flex;flex-shrink:0}.nav-label{flex:1 1}.nav-badge{background:#4b65f5;background:var(--blue);border-radius:999px;color:#fff;font-size:10px;font-weight:700;min-width:20px;padding:2px 7px;text-align:center}.sidebar-app-promo{align-items:center;background:linear-gradient(145deg,#eef1fe,#e0e7ff);background:linear-gradient(145deg,var(--blue-lt),#e0e7ff);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:10px;margin-top:24px;padding:20px 16px;text-align:center}.promo-phone{align-items:center;background:#4b65f5;background:var(--blue);border-radius:8px;display:flex;height:60px;justify-content:center;width:38px}.phone-screen{background:#fff;border-radius:4px;height:40px;width:26px}.promo-text{color:#4b65f5;color:var(--blue);font-size:11.5px;font-weight:600;line-height:1.45}.promo-btn{align-items:center;background:#10b981;background:var(--accent);border-radius:50%;color:#fff;display:flex;height:30px;justify-content:center;width:30px}.main-content{background:#f5f6fb;background:var(--bg);display:flex;flex-direction:column;gap:32px;min-width:0;overflow-x:hidden;overflow-y:auto;padding:32px 32px 36px}.search-box,.topbar{align-items:center;display:flex}.search-box{background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:12px;gap:10px;max-width:380px;padding:10px 16px;transition:border-color .15s;width:100%}.search-box:focus-within{border-color:#c3cdfb;border-color:var(--blue-mid)}.search-input{background:#0000;border:none;color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13.5px;outline:none;width:100%}.search-clear,.search-input::placeholder{color:#9ca3af;color:var(--text-3)}.search-clear{align-items:center;display:flex;flex-shrink:0;transition:color .12s}.search-clear:hover{color:#0f1733;color:var(--text-1)}.welcome-banner{align-items:center;background:linear-gradient(118deg,#3550e0,#4b65f5 50%,#6b7ff8);background:linear-gradient(118deg,#3550e0 0,var(--blue) 50%,#6b7ff8 100%);border-radius:22px;border-radius:var(--radius-lg);display:flex;justify-content:space-between;min-height:140px;overflow:hidden;padding:32px 36px;position:relative}.welcome-banner:before{background-image:radial-gradient(#ffffff1f 1px,#0000 0);background-size:22px 22px;content:"";inset:0;position:absolute}.welcome-text{position:relative;z-index:1}.welcome-greeting{color:#ffffffa6;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:500;margin-bottom:6px}.welcome-name{color:#fff;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:16px}.welcome-link{align-items:center;background:#ffffff26;border:none;border-radius:8px;color:#ffffffd9;cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12.5px;font-weight:600;gap:6px;padding:7px 14px;text-decoration:none;transition:background .15s}.welcome-link:hover{background:#ffffff40;color:#fff}.welcome-link--active{background:#4ade8026;border:1.5px solid #4ade8059;color:#d1fae5;gap:8px}.welcome-link--active:hover{background:#4ade8040;color:#d1fae5}.welcome-illustration{flex-shrink:0;height:120px;position:relative;width:130px;z-index:1}.illus-circle{border-radius:50%;position:absolute}.illus-circle--1{background:#ffffff1a;border:1.5px solid #fff3;height:100px;right:0;top:10px;width:100px}.illus-circle--2{background:#10b9814d;bottom:0;height:60px;left:10px;width:60px}.illus-figure{left:0;position:absolute;top:0}.stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.stat-card{align-items:center;background:#fff;background:var(--surface);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-md);box-shadow:0 1px 4px #0000000f;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;padding:22px 20px 18px}.stat-card--courses{align-items:stretch}.stat-title{align-self:flex-start;color:#4b5563;color:var(--text-2);font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12.5px;font-weight:600;width:100%}.circle-progress{display:inline-flex;position:relative}.circle-inner,.circle-progress{align-items:center;justify-content:center}.circle-inner{display:flex;flex-direction:column;gap:2px;position:absolute}.circle-pct{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:20px;font-weight:700;line-height:1}.circle-sub{font-size:10px}.circle-sub,.stat-legend{color:#9ca3af;color:var(--text-3);font-weight:500}.stat-legend{align-items:center;display:flex;font-size:11px;gap:6px}.legend-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.courses-bars{display:flex;flex:1 1;flex-direction:column;gap:11px}.bar-row{align-items:center;display:flex;gap:10px}.bar-label{color:#4b5563;color:var(--text-2);flex-shrink:0;font-size:12px;font-weight:500;width:52px}.bar-track{background:#eef1fe;background:var(--blue-lt);border-radius:99px;flex:1 1;height:5px;overflow:hidden}.bar-fill{background:linear-gradient(90deg,#4b65f5,#7b8ff8);background:linear-gradient(90deg,var(--blue),#7b8ff8);border-radius:99px;height:100%}.bar-pct{color:#9ca3af;color:var(--text-3);flex-shrink:0;font-size:11px;font-weight:600;text-align:right;width:30px}.media-section{display:flex;flex-direction:column;gap:14px}.media-header{align-items:center;display:flex;justify-content:space-between}.media-title{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700}.media-view-all{color:#4b65f5;color:var(--blue);font-size:12px;font-weight:600;transition:opacity .15s}.media-view-all:hover{opacity:.75}.media-list{display:flex;flex-direction:column;gap:8px}.media-item{align-items:center;background:#fff;background:var(--surface);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);display:flex;gap:14px;padding:14px 16px;transition:box-shadow .15s}.media-item:hover{box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-md)}.media-thumb{align-items:center;background:#eef1fe;background:var(--blue-lt);border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.media-name{color:#0f1733;color:var(--text-1);flex:1 1;font-size:13px;font-weight:600}.media-meta,.media-size{align-items:center;color:#9ca3af;color:var(--text-3);display:flex;font-size:12px;font-weight:500;gap:5px;white-space:nowrap}.media-size{color:#4b65f5;color:var(--blue)}.media-more{border-radius:8px;color:#9ca3af;color:var(--text-3);font-size:18px;letter-spacing:2px;line-height:1;padding:4px 6px}.media-more:hover{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.right-sidebar{background:#fff;background:var(--surface);border-left:1px solid #e8ebf5;border-left:1px solid var(--border);gap:24px;height:100vh;min-width:0;overflow-x:hidden;overflow-y:auto;padding:32px 22px 28px;position:sticky;top:0}.right-sidebar,.user-block{display:flex;flex-direction:column}.user-block{gap:14px}.user-actions{display:flex;gap:6px;justify-content:flex-end}.icon-btn{align-items:center;background:#f5f6fb;background:var(--bg);border-radius:10px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-3);display:flex;height:34px;justify-content:center;transition:background .15s,color .15s;width:34px}.icon-btn:hover{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.icon-btn--logout:hover{background:#fef2f2;color:#ef4444}.user-info{align-items:center;display:flex;gap:10px;justify-content:flex-end}.user-details{text-align:right}.user-name{color:#0f1733;color:var(--text-1);display:block;font-size:13px;font-weight:700}.user-email{color:#9ca3af;color:var(--text-3);display:block;font-size:11px;font-weight:500;margin-top:2px}.user-avatar{align-items:center;background:linear-gradient(135deg,#4b65f5,#6b7ff8);background:linear-gradient(135deg,var(--blue),#6b7ff8);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:14px;font-weight:700;height:38px;justify-content:center;width:38px}.divider{background:#e8ebf5;background:var(--border);height:1px}.calendar{display:flex;flex-direction:column;gap:14px}.cal-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.cal-month-info{display:flex;flex-direction:column;gap:1px;min-width:0}.cal-month{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700;white-space:nowrap}.cal-date-line{color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:500;margin-top:2px}.cal-nav{display:flex;gap:6px}.cal-nav-btn{align-items:center;background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:8px;color:#4b5563;color:var(--text-2);display:flex;font-size:15px;height:28px;justify-content:center;line-height:1;transition:background .12s,border-color .12s;width:28px}.cal-nav-btn:hover{background:#eef1fe;background:var(--blue-lt);border-color:#c3cdfb;border-color:var(--blue-mid);color:#4b65f5;color:var(--blue)}.cal-today-btn{background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:8px;color:#4b5563;color:var(--text-2);cursor:pointer;font-family:Montserrat,sans-serif;font-size:10.5px;font-weight:700;height:28px;padding:0 8px;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.cal-today-btn:hover{background:#eef1fe;background:var(--blue-lt);border-color:#c3cdfb;border-color:var(--blue-mid);color:#4b65f5;color:var(--blue)}.cal-grid{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(7,1fr);text-align:center}.cal-weekday-label{color:#9ca3af;color:var(--text-3);font-size:10.5px;font-weight:700;letter-spacing:.3px;padding:4px 0 6px;text-transform:uppercase}.cal-day{border-radius:8px;color:#4b5563;color:var(--text-2);cursor:pointer;font-size:12px;font-weight:500;line-height:1;padding:6px 2px;transition:background .12s,color .12s}.cal-day:hover:not(.cal-day--empty){background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.cal-day--today{background:#4b65f5!important;background:var(--blue)!important;color:#fff!important;font-weight:700}.cal-day--empty{color:#0000;cursor:default}.today-event{background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:10px;padding:18px}.event-label{color:#10b981;color:var(--accent);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}.event-title{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:12.5px;font-weight:700;line-height:1.45}.event-desc{color:#9ca3af;color:var(--text-3);font-size:12px;font-weight:400;line-height:1.55}.event-participants{align-items:center;display:flex;gap:0}.participant-avatar{align-items:center;background:linear-gradient(135deg,#4b65f5,#7b8ff8);border:2px solid #fff;border:2px solid var(--surface);border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:700;height:26px;justify-content:center;margin-left:-6px;width:26px}.participant-avatar:first-child{margin-left:0}.event-joined{color:#10b981;color:var(--accent);font-size:11px;font-weight:600;margin-left:8px}.event-meta{align-items:center;color:#9ca3af;color:var(--text-3);display:flex;font-size:11px;font-weight:500;gap:6px}.event-actions{display:flex;gap:8px;margin-top:2px}.btn-outline{background:#fff;background:var(--surface);border:1.5px solid #c3cdfb;border:1.5px solid var(--blue-mid);border-radius:10px;color:#4b65f5;color:var(--blue);flex:1 1;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:600;padding:10px 0;transition:background .15s}.btn-outline:hover{background:#eef1fe;background:var(--blue-lt)}.btn-primary{background:#4b65f5;background:var(--blue);border-radius:10px;color:#fff;flex:1 1;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:700;padding:10px 0;transition:background .15s}.btn-primary:hover{background:#3550e0;background:var(--blue-dk)}.mobile-topbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e8ebf5;border-bottom:1px solid var(--border);display:none;grid-column:1/-1;justify-content:space-between;padding:16px 20px;position:sticky;top:0;z-index:100}.mobile-logo{align-items:center;display:flex;gap:9px}.mobile-logo-text{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700}.mobile-user{align-items:center;display:flex;gap:10px}.mobile-bottom-nav{background:#fff;background:var(--surface);border-top:1px solid #e8ebf5;border-top:1px solid var(--border);bottom:0;display:none;left:0;padding:8px 0 env(safe-area-inset-bottom,8px);position:fixed;right:0;z-index:100}.bottom-nav-inner{align-items:center;display:flex;justify-content:space-around}.bottom-nav-item{align-items:center;border-radius:10px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-3);display:flex;flex-direction:column;font-size:10px;font-weight:600;gap:4px;padding:6px 12px;position:relative;text-decoration:none;transition:color .15s}.bottom-nav-item--active{color:#4b65f5;color:var(--blue)}.bottom-nav-item--active svg{stroke:#4b65f5;stroke:var(--blue)}.bottom-nav-badge{background:#10b981;background:var(--accent);border-radius:999px;color:#fff;font-size:9px;font-weight:700;min-width:16px;padding:1px 5px;position:absolute;right:8px;text-align:center;top:4px}@media (max-width:1100px){.dashboard-card{grid-template-columns:68px 1fr}.right-sidebar{display:none}.sidebar{align-items:center;padding:24px 10px 20px}.sidebar-logo{justify-content:center;padding:0 0 28px}.logo-text{display:none}.sidebar-nav{width:100%}.nav-item{justify-content:center;padding:12px}.nav-label{display:none}.nav-badge{font-size:9px;min-width:16px;padding:1px 4px;position:absolute;right:4px;top:6px}.metrics-row{grid-template-columns:repeat(2,1fr)}.col-hide-sm{display:none}.hw-stats-row{grid-template-columns:repeat(2,1fr)}.page-tabs{overflow-x:auto}}@media (max-width:768px){.dashboard-card{grid-template-columns:1fr}.right-sidebar,.sidebar{display:none}.mobile-topbar{display:flex}.mobile-bottom-nav{display:block}.main-content{gap:20px;padding:16px 14px 90px}.search-box{max-width:100%}.welcome-banner{border-radius:16px;border-radius:var(--radius-md);padding:20px 18px}.welcome-illustration{display:none}.welcome-name{font-size:16px;margin-bottom:10px}.welcome-greeting{font-size:12px}.welcome-role{margin-bottom:10px}.metrics-row{gap:10px;grid-template-columns:repeat(2,1fr)}.metric-card{gap:10px;padding:14px 12px}.metric-value{font-size:20px}.metric-icon-wrap{border-radius:10px;height:36px;width:36px}.metric-sub{display:none}.photo-placeholder{border-radius:12px;height:72px;width:72px}.col-hide-sm,.photo-placeholder-text{display:none}.student-meta-sm{display:block}.hw-btn{font-size:11.5px;padding:5px 10px}.hw-stats-row{grid-template-columns:repeat(2,1fr)}.page-tabs{overflow-x:auto;white-space:nowrap}.page-tab{font-size:12px;padding:8px 12px}.filter-bar{flex-wrap:wrap;gap:6px}.filter-pill{font-size:12px;padding:7px 12px}.section-title-wrap{align-items:flex-start;flex-direction:column;gap:4px}.page-header{flex-direction:column;gap:12px}.page-header-actions{width:100%}.btn-page-primary,.btn-page-secondary{flex:1 1;justify-content:center}.page-toolbar{flex-wrap:wrap}.search-box--wide{max-width:100%}.hw-stat-value{font-size:20px}.table-wrap{border-radius:10px;border-radius:var(--radius-sm)}}.welcome-role{color:#ffffff8c;font-size:12px;font-weight:500;margin-bottom:16px;margin-top:-10px}.photo-placeholder-wrap{flex-shrink:0;z-index:1}.photo-placeholder,.photo-placeholder-wrap{align-items:center;display:flex;justify-content:center}.photo-placeholder{background:#ffffff1a;border:2px dashed #ffffff73;border-radius:20px;cursor:pointer;flex-direction:column;gap:8px;height:120px;transition:background .2s,border-color .2s;width:120px}.photo-placeholder:hover{background:#ffffff2e;border-color:#ffffffb3}.photo-placeholder-text{color:#ffffffa6;font-size:11px;font-weight:600;line-height:1.3;text-align:center}.metrics-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}.metric-card{align-items:center;background:#fff;background:var(--surface);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-md);box-shadow:0 1px 4px #0000000f;box-shadow:var(--shadow-sm);display:flex;gap:14px;padding:18px 16px;transition:box-shadow .15s}.metric-card:hover{box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-md)}.metric-icon-wrap{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.metric-card--blue .metric-icon-wrap{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.metric-card--accent .metric-icon-wrap{background:#ecfdf5;background:var(--accent-lt);color:#059669;color:var(--accent-dk)}.metric-card--streak .metric-icon-wrap{background:#fff7ed;color:#c2410c}.metric-body{display:flex;flex-direction:column;gap:1px;min-width:0}.metric-value{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:22px;font-weight:700;line-height:1}.metric-label{color:#4b5563;color:var(--text-2);font-size:11.5px;font-weight:600;margin-top:3px}.metric-sub{color:#9ca3af;color:var(--text-3);font-size:10.5px;font-weight:500;margin-top:1px}.section-block{display:flex;flex-direction:column;gap:12px}.section-header{align-items:center;display:flex;justify-content:space-between}.section-title-wrap{align-items:center;display:flex;gap:10px}.section-title{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700}.section-link{color:#4b65f5;color:var(--blue);font-size:12px;font-weight:600;transition:opacity .15s}.section-link:hover{opacity:.7}.hw-count-badge{background:#eef1fe;background:var(--blue-lt);border-radius:999px;color:#4b65f5;color:var(--blue);font-size:11px;font-weight:700;padding:3px 10px}.table-above-row{align-items:center;display:flex;justify-content:space-between;padding:2px 0 0}.table-count{color:#9ca3af;color:var(--text-3);font-size:12px;font-weight:500}.filter-bar{display:flex;flex-wrap:wrap;gap:6px}.filter-pill{align-items:center;background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;color:#9ca3af;color:var(--text-3);cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s}.filter-pill:hover{background:#eef1fe;background:var(--blue-lt);border-color:#c3cdfb;border-color:var(--blue-mid);color:#4b65f5;color:var(--blue)}.filter-pill--active{background:#4b65f5;background:var(--blue);border-color:#4b65f5;border-color:var(--blue);color:#fff}.filter-pill--active:hover{background:#3550e0;background:var(--blue-dk);border-color:#3550e0;border-color:var(--blue-dk);color:#fff}.filter-count{background:#ffffff40;border-radius:6px;font-size:11px;font-weight:700;padding:1px 6px}.filter-pill:not(.filter-pill--active) .filter-count{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.filter-bar--sub{border-bottom:1px solid #e8ebf5;border-bottom:1px solid var(--border);display:flex;gap:0;margin-top:2px}.filter-chip{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#9ca3af;color:var(--text-3);cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:500;gap:5px;margin-bottom:-1px;padding:7px 14px;transition:color .15s,border-color .15s}.filter-chip--active,.filter-chip:hover{color:#0f1733;color:var(--text-1)}.filter-chip--active{border-bottom-color:#4b65f5;border-bottom-color:var(--blue);font-weight:600}.chip-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.chip-dot--math{background:#8dbf2e}.chip-dot--cs{background:#9b8ef5}.chip-dot--physics{background:#4b65f5;background:var(--blue)}.chip-dot--default{background:#9b8ef5}.chip-count{background:#eef1fe;background:var(--blue-lt);border-radius:6px;color:#4b65f5;color:var(--blue);font-size:11px;font-weight:700;margin-left:2px;padding:1px 6px}.filter-chip--active .chip-count{background:#ffffff40;color:#fff}.table-wrap{border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-md);overflow-x:auto;width:100%}.students-table{border-collapse:collapse;font-size:13px;min-width:600px;width:100%}.students-table,.students-table th{background:#fff;background:var(--surface)}.students-table th{color:#9ca3af;color:var(--text-3);font-size:10.5px;font-weight:700;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}.students-table td,.students-table th{border-bottom:1px solid #e8ebf5;border-bottom:1px solid var(--border)}.students-table td{background:#fff;background:var(--surface);padding:12px 14px;vertical-align:middle}.students-table tbody tr:last-child td{border-bottom:none}.students-table tbody tr{transition:background .1s}.students-table tbody tr:hover td{background:#f5f6fb;background:var(--bg)}.student-cell{align-items:center;display:flex;gap:10px}.student-info{display:flex;flex-direction:column;gap:2px}.student-avatar-sm{align-items:center;background:linear-gradient(135deg,#4b65f5,#7b8ff8);background:linear-gradient(135deg,var(--blue),#7b8ff8);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:30px;justify-content:center;width:30px}.student-name{color:#0f1733;color:var(--text-1);font-size:13px;font-weight:600}.student-meta-sm{color:#9ca3af;color:var(--text-3);display:none;font-size:11px;font-weight:500}.cell-plain{color:#4b5563;color:var(--text-2);font-size:12.5px;font-weight:500}.grade-badge{background:#eef1fe;background:var(--blue-lt);border-radius:7px;color:#4b65f5;color:var(--blue);display:inline-block;font-size:11.5px;font-weight:700;padding:3px 9px}.table-progress{align-items:center;display:flex;gap:8px;min-width:120px}.status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:700;gap:5px;padding:3px 10px;white-space:nowrap}.status-badge:before{border-radius:50%;content:"";display:block;height:6px;width:6px}.subject-label{color:#4b5563;color:var(--text-2);font-size:12px;font-weight:500}.subject-badge{background:#0000;border:1.5px solid;border-radius:8px;display:inline-block;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:11.5px;font-weight:600;padding:3px 10px;white-space:nowrap}.subject-badge--math{border-color:#8dbf2e;color:#6a9b1a}.subject-badge--cs{border-color:#9b8ef5;color:#6b54e0}.subject-badge--physics{border-color:#4b65f5;border-color:var(--blue);color:#4b65f5;color:var(--blue)}.subject-badge--default{border-color:#9b8ef5;color:#6b54e0}.level-badge{align-items:center;background:#0000;border:1.5px solid;border-radius:8px;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:11.5px;font-weight:700;justify-content:center;letter-spacing:.4px;padding:3px 10px;white-space:nowrap}.level-badge--oge{border-color:#f5981f;color:#c2700a}.level-badge--ege{border-color:#9b8ef5;color:#6b54e0}.avg-grade{align-items:center;border-radius:8px;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700;justify-content:center;min-width:44px;padding:4px 10px}.avg-grade--high{background:#ecfdf5;background:var(--accent-lt);color:#059669;color:var(--accent-dk)}.avg-grade--mid{background:#fef9c3;color:#a16207}.avg-grade--low{background:#fef2f2;color:#b91c1c}.status-badge--active{background:#ecfdf5;background:var(--accent-lt);color:#059669;color:var(--accent-dk)}.status-badge--active:before{background:#10b981;background:var(--accent)}.status-badge--warning{background:#fefce8;color:#a16207}.status-badge--warning:before{background:#eab308}.status-badge--danger{background:#fef2f2;color:#b91c1c}.status-badge--danger:before{background:#ef4444}.table-empty{color:#9ca3af;color:var(--text-3);font-size:13px;font-weight:500;padding:28px 16px!important;text-align:center}.hw-student-avatar{align-items:center;background:linear-gradient(135deg,#eef1fe,#c3cdfb);background:linear-gradient(135deg,var(--blue-lt),var(--blue-mid));border-radius:8px;color:#4b65f5;color:var(--blue);display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:30px;justify-content:center;width:30px}.hw-task-cell{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:#4b5563;color:var(--text-2);display:-webkit-box;font-size:12.5px;font-weight:500;max-width:220px;overflow:hidden}.hw-btn{background:#4b65f5;background:var(--blue);border:none;border-radius:10px;color:#fff;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:600;padding:7px 14px;transition:background .15s;white-space:nowrap}.hw-btn:hover{background:#3550e0;background:var(--blue-dk)}.notif-btn{position:relative}.notif-dot{background:#ef4444;border:1.5px solid #fff;border:1.5px solid var(--surface);border-radius:50%;height:7px;position:absolute;right:5px;top:5px;width:7px}.notif-section{display:flex;flex-direction:column;gap:8px}.notif-header{align-items:center;display:flex;justify-content:space-between}.notif-label{color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.notif-nav{align-items:center;display:flex;gap:4px}.notif-counter{font-size:11px;font-weight:600;min-width:26px;text-align:center}.notif-arrow,.notif-counter{color:#9ca3af;color:var(--text-3)}.notif-arrow{align-items:center;border-radius:6px;display:flex;height:20px;justify-content:center;transition:background .12s,color .12s;width:20px}.notif-arrow:hover:not(:disabled){background:#f5f6fb;background:var(--bg);color:#0f1733;color:var(--text-1)}.notif-arrow:disabled{cursor:default;opacity:.3}.notif-slide-wrap{overflow:hidden;position:relative}@keyframes notif-in-next{0%{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}@keyframes notif-in-prev{0%{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}.notif-item{align-items:flex-start;display:flex;gap:9px;padding:10px 0 2px}.notif-item--next{animation:notif-in-next .28s cubic-bezier(.22,.68,0,1.2) both}.notif-item--prev{animation:notif-in-prev .28s cubic-bezier(.22,.68,0,1.2) both}.notif-dot-type{border-radius:50%;flex-shrink:0;height:6px;margin-top:5px;width:6px}.notif-dot-type--hw{background:#10b981;background:var(--accent)}.notif-dot-type--warn{background:#f59e0b}.notif-dot-type--msg{background:#4b65f5;background:var(--blue)}.notif-body{display:flex;flex-direction:column;gap:3px;min-width:0}.notif-text{color:#0f1733;color:var(--text-1);font-size:12px;font-weight:500;line-height:1.4}.notif-time{color:#9ca3af;color:var(--text-3);font-size:10.5px;font-weight:500}.page-content{display:flex;flex-direction:column;gap:20px;width:100%}.page-header{align-items:center;display:flex;gap:16px;justify-content:space-between}.page-header-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.page-title{color:#0f1733;color:var(--text-1);font-size:20px;font-weight:700;margin-bottom:4px}.page-subtitle{color:#9ca3af;color:var(--text-3);font-size:13px;font-weight:500}.btn-page-primary{align-items:center;background:#4b65f5;background:var(--blue);border-radius:10px;color:#fff;display:inline-flex;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:7px;padding:10px 18px;transition:background .15s;white-space:nowrap}.btn-page-primary:hover{background:#3550e0;background:var(--blue-dk)}.btn-page-secondary{align-items:center;background:none;border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;color:#4b5563;color:var(--text-2);cursor:pointer;display:inline-flex;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:7px;padding:10px 18px;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.btn-page-secondary:hover{background:#eef1fe;background:var(--blue-lt);border-color:#c3cdfb;border-color:var(--blue-mid);color:#4b65f5;color:var(--blue)}.page-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.search-box--wide{flex:1 1;max-width:360px;min-width:160px;width:100%}.select-filter{background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;color:#4b5563;color:var(--text-2);cursor:pointer;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:500;outline:none;padding:8px 12px;transition:border-color .15s}.select-filter:focus{border-color:#c3cdfb;border-color:var(--blue-mid)}.page-tabs{border-bottom:1px solid #e8ebf5;border-bottom:1px solid var(--border);display:flex;gap:0}.page-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#9ca3af;color:var(--text-3);cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:500;gap:7px;margin-bottom:-1px;padding:10px 18px;transition:color .15s,border-color .15s}.page-tab:hover{color:#0f1733;color:var(--text-1)}.page-tab--active{border-bottom-color:#4b65f5;border-bottom-color:var(--blue);color:#4b65f5;color:var(--blue);font-weight:600}.tab-count{background:#f5f6fb;background:var(--bg);border-radius:6px;color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:700;padding:1px 6px}.tab-count--active{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.hw-stats-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.hw-stat{background:#fff;background:var(--surface);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;padding:16px 18px}.hw-stat-value{font-size:24px;font-weight:700;line-height:1}.hw-stat-label{color:#9ca3af;color:var(--text-3);font-size:12px;font-weight:500}.hw-stat--blue .hw-stat-value{color:#4b65f5;color:var(--blue)}.hw-stat--red .hw-stat-value{color:#ef4444}.hw-stat--green .hw-stat-value{color:#10b981;color:var(--accent)}.row-actions{align-items:center;display:flex;gap:6px}.row-btn{background:#eef1fe;background:var(--blue-lt);border-radius:8px;color:#4b65f5;color:var(--blue);font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:600;padding:5px 12px;transition:background .15s,color .15s;white-space:nowrap}.row-btn:hover{background:#4b65f5;background:var(--blue);color:#fff}.row-btn--icon{background:#f5f6fb;background:var(--bg);color:#9ca3af;color:var(--text-3);padding:5px 8px}.row-btn--icon:hover{background:#eef1fe;background:var(--blue-lt);color:#4b65f5;color:var(--blue)}.row-btn--delete{background:#fef2f2;border:none;color:#ef4444;padding:5px 8px}.row-btn--delete:hover{background:#ef4444;color:#fff}.th-sort{cursor:pointer;-webkit-user-select:none;user-select:none}.th-sort:hover{color:#0f1733;color:var(--text-1)}.sort-icon{color:#4b65f5;color:var(--blue);font-size:11px;margin-left:2px}.sort-icon--neutral{color:#9ca3af;color:var(--text-3)}.quote-block{border-left:3px solid #c3cdfb;border-left:3px solid var(--blue-mid);display:flex;flex-direction:column;gap:10px;padding:16px 0 0 16px}.quote-icon{color:#c3cdfb;color:var(--blue-mid);line-height:1}.quote-text{color:#4b5563;color:var(--text-2);font-size:12.5px;font-style:italic;font-weight:500;line-height:1.65}.quote-author{color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:600;letter-spacing:.2px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f173373;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.modal{animation:modal-in .2s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:20px;box-shadow:0 24px 64px #4b65f52e;max-height:90vh;max-width:560px;overflow-y:auto;width:100%}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e8ebf5;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:22px 26px 18px}.modal-title{color:#0f1733;color:var(--text-1);font-size:15px;font-weight:800}.modal-close{align-items:center;background:none;border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:8px;color:#9ca3af;color:var(--text-3);cursor:pointer;display:flex;height:30px;justify-content:center;transition:background .13s,color .13s;width:30px}.modal-close:hover{background:#f5f6fb;background:var(--bg);color:#0f1733;color:var(--text-1)}.modal-form{display:flex;flex-direction:column;gap:10px;padding:22px 26px 26px}.modal-section-label{color:#9ca3af;color:var(--text-3);font-size:10.5px;font-weight:700;letter-spacing:.6px;margin-bottom:2px;text-transform:uppercase}.modal-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.modal-field{display:flex;flex-direction:column;gap:5px}.modal-field label{color:#4b5563;color:var(--text-2);font-size:11.5px;font-weight:700;margin-bottom:0}.modal-required{color:#4b65f5;color:var(--blue)}.modal-field input,.modal-field select,.modal-field textarea{background:#fff;border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;box-sizing:border-box;color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-size:13px;font-weight:500;outline:none;padding:9px 12px;resize:none;transition:border-color .14s;width:100%}.modal-field textarea{max-height:calc(4.8em + 18px);min-height:calc(4.8em + 18px);overflow-y:auto;resize:none;width:100%}.modal-field input:focus,.modal-field select:focus,.modal-field textarea:focus{border-color:#4b65f5;border-color:var(--blue)}.modal-field input::placeholder,.modal-field textarea::placeholder{color:#9ca3af;color:var(--text-3)}.modal-error{background:#fef2f2;border:1.5px solid #fecaca;border-radius:10px;color:var(--red);font-size:12.5px;font-weight:600;padding:9px 14px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.modal-btn{border:none;border-radius:10px;cursor:pointer;font-family:Montserrat,sans-serif;font-size:13px;font-weight:700;padding:10px 22px;transition:background .14s,color .14s,border-color .14s}.modal-btn--cancel{background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);color:#4b5563;color:var(--text-2)}.modal-btn--cancel:hover{background:#e8ebf5}.modal-btn--save{background:#4b65f5;background:var(--blue);color:#fff}.modal-btn--save:hover:not(:disabled){background:#3550e0;background:var(--blue-dk)}.modal-btn--save:disabled{cursor:not-allowed;opacity:.6}@media (max-width:540px){.modal-row{grid-template-columns:1fr}.modal{border-radius:16px}.modal-form{padding:18px 18px 22px}.modal-header{padding:18px 18px 14px}}.modal--credentials{max-width:440px}.credentials-body{display:flex;flex-direction:column;gap:14px;padding:20px 24px 24px}.credentials-hint{align-items:flex-start;background:#fef08a;border:2px solid #eab308;border-radius:10px;color:#92400e;display:flex;font-size:13px;font-weight:600;gap:8px;line-height:1.5;padding:11px 14px}.credentials-hint-icon{flex-shrink:0;font-size:16px;margin-top:1px}.credentials-row{align-items:center;background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;display:flex;gap:10px;padding:10px 14px}.credentials-label{color:#9ca3af;color:var(--text-3);font-size:12px;font-weight:600;min-width:52px}.credentials-value{color:#0f1733;color:var(--text-1);flex:1 1;font-family:Courier New,monospace;font-size:14px;font-weight:700;letter-spacing:.5px}.credentials-value--password{color:#4b65f5;color:var(--blue)}.credentials-message{display:flex;flex-direction:column;gap:6px}.credentials-message-label{color:#9ca3af;color:var(--text-3);font-size:11.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.credentials-message-text{background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:10px;color:#0f1733;color:var(--text-1);line-height:1.6;margin:0;padding:12px 14px;white-space:pre-wrap;word-break:break-word}.credentials-copy-all,.credentials-message-text{font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px}.credentials-copy-all{align-items:center;align-self:stretch;background:#4b65f5;background:var(--blue);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:700;justify-content:center;padding:11px 20px;transition:background .14s}.credentials-copy-all:hover{background:#3550e0;background:var(--blue-dk)}.modal--profile{max-width:520px}.profile-modal-body{display:flex;flex-direction:column;gap:20px;padding:0 24px 24px}.profile-hero{align-items:center;background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:14px;display:flex;gap:16px;padding:20px}.profile-avatar-lg{align-items:center;background:#4b65f5;background:var(--blue);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:20px;font-weight:700;height:56px;justify-content:center;width:56px}.profile-hero-info{display:flex;flex-direction:column;gap:6px}.profile-hero-name{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:18px;font-weight:700;margin:0}.profile-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.profile-section{display:flex;flex-direction:column;gap:8px}.profile-section-title{color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase}.profile-rows{display:flex;flex-direction:column;gap:6px}.profile-row{align-items:center;background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:10px;display:flex;gap:8px;justify-content:space-between;padding:7px 12px}.profile-row-label{color:#9ca3af;color:var(--text-3);flex-shrink:0;font-size:12px;font-weight:500}.profile-row-value{color:#0f1733;color:var(--text-1);font-size:13px;font-weight:600;text-align:right;word-break:break-all}.profile-goal{display:flex;flex-direction:column;gap:8px}.profile-goal-text{background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:10px;color:#0f1733;color:var(--text-1);font-size:13px;line-height:1.6;margin:0;padding:12px 14px}.lesson-type-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11.5px;font-weight:600;gap:4px;padding:3px 9px;white-space:nowrap}.lesson-type-badge--individual{background:#eff6ff;border:1px solid #bfdbfe;color:#3b82f6}.lesson-type-badge--group{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}.modal--lesson{max-width:440px}.lesson-modal-body{display:flex;flex-direction:column;gap:14px;padding:0 24px 24px}.lesson-tabs{background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:12px;display:flex;gap:6px;padding:4px}.lesson-tab{align-items:center;background:none;border:none;border-radius:9px;color:#9ca3af;color:var(--text-3);cursor:pointer;display:flex;flex:1 1;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:9px 12px;transition:all .15s}.lesson-tab:hover{color:#0f1733;color:var(--text-1)}.lesson-tab--active,.lesson-tab:hover{background:#fff;background:var(--surface)}.lesson-tab--active{box-shadow:0 1px 4px #00000014;color:#4b65f5;color:var(--blue)}.lesson-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.lesson-empty{color:#9ca3af;color:var(--text-3);font-size:13px;margin:0;padding:24px 0;text-align:center}.lesson-item{align-items:center;background:#f5f6fb;background:var(--bg);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;display:flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);gap:12px;padding:10px 12px;text-align:left;transition:border-color .15s,background .15s;width:100%}.lesson-item:hover{background:#eef1fe;background:var(--blue-lt);border-color:#c3cdfb;border-color:var(--blue-mid)}.lesson-item:hover .lesson-item-arrow{color:#4b65f5;color:var(--blue);opacity:1}.lesson-item-avatar{align-items:center;background:#4b65f5;background:var(--blue);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:14px;font-weight:700;height:38px;justify-content:center;width:38px}.lesson-item-avatar--group{background:#16a34a}.lesson-item-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.lesson-item-name{color:#0f1733;color:var(--text-1);font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-item-sub{color:#9ca3af;color:var(--text-3);font-size:11.5px;font-weight:500}.lesson-item-arrow{flex-shrink:0;opacity:0;transition:opacity .15s,color .15s}.lesson-hint{font-size:11.5px;line-height:1.5;margin:0;text-align:center}.lesson-hint,.profile-back-btn{color:#9ca3af;color:var(--text-3)}.profile-back-btn{align-items:center;background:none;border:none;cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;gap:6px;margin-bottom:20px;padding:0;transition:color .15s}.profile-back-btn:hover{color:#4b65f5;color:var(--blue)}.sp-hero{background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:22px;border-radius:var(--radius-lg);gap:20px;margin-bottom:20px;padding:24px}.sp-avatar,.sp-hero{align-items:center;display:flex}.sp-avatar{background:#4b65f5;background:var(--blue);border-radius:50%;color:#fff;flex-shrink:0;font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:26px;font-weight:700;height:72px;justify-content:center;width:72px}.sp-hero-info{display:flex;flex-direction:column;gap:10px}.sp-name{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:22px;font-weight:700;margin:0}.sp-hero-badges{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.sp-stats-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.sp-stat-card{background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;padding:16px 18px}.sp-stat-icon{font-size:20px;margin-bottom:4px}.sp-stat-value{color:#0f1733;color:var(--text-1);font-family:Montserrat,sans-serif;font-family:var(--font-head);font-size:24px;font-weight:700;line-height:1}.sp-stat-label{color:#9ca3af;color:var(--text-3);font-size:11.5px;font-weight:500;margin-top:2px}.sp-stat-card--blue{border-left:3px solid #4b65f5;border-left:3px solid var(--blue)}.sp-stat-card--purple{border-left:3px solid #8b5cf6}.sp-stat-card--green{border-left:3px solid #16a34a}.sp-stat-card--yellow{border-left:3px solid #eab308}.sp-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:14px}.sp-card{background:#fff;background:var(--surface);border:1.5px solid #e8ebf5;border:1.5px solid var(--border);border-radius:16px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:12px;padding:18px 20px}.sp-card--full{grid-column:1/-1}.sp-card--placeholder{opacity:.65}.sp-card-title{color:#9ca3af;color:var(--text-3);font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase}.sp-rows{display:flex;flex-direction:column;gap:6px}.sp-row{align-items:center;background:#f5f6fb;background:var(--bg);border:1px solid #e8ebf5;border:1px solid var(--border);border-radius:10px;display:flex;gap:8px;justify-content:space-between;min-height:38px;padding:8px 12px}.sp-row-label{color:#9ca3af;color:var(--text-3);flex-shrink:0;font-size:12.5px;font-weight:500}.sp-row-value{color:#0f1733;color:var(--text-1);font-size:13px;font-weight:600;text-align:right;word-break:break-all}.sp-goal-text,.sp-placeholder-text{color:#4b5563;color:var(--text-2);font-size:13.5px;line-height:1.65;margin:0}.sp-placeholder-text{color:#9ca3af;color:var(--text-3);font-style:italic}
/*# sourceMappingURL=main.1c04e22a.css.map*/