*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f6f6f7;color:#1a1a1a;-webkit-font-smoothing:antialiased}.portal-login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6f7ed1,#8b5cf6);padding:24px}.portal-login-card{background:#fff;border-radius:16px;padding:40px 32px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.2)}.portal-login-card h1{font-size:24px;font-weight:700;text-align:center;margin-bottom:4px}.portal-login-card p.subtitle{font-size:14px;color:#6d7175;text-align:center;margin-bottom:28px}.portal-input-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#1a1a1a}.portal-input,.portal-select,.portal-textarea{width:100%;padding:12px 14px;border:1px solid #d8dadb;border-radius:10px;font-size:14px;font-family:inherit;background:#fff;outline:none}.portal-input:focus,.portal-select:focus,.portal-textarea:focus{border-color:#6f7ed1;box-shadow:0 0 0 3px rgba(111,126,209,.15)}.portal-input-help{font-size:12px;color:#6d7175;margin-top:6px}.portal-button-primary{width:100%;padding:13px;background:#6f7ed1;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;margin-top:16px;transition:background .15s}.portal-button-primary:hover{background:#5d6cbe}.portal-button-primary:disabled{opacity:.6;cursor:not-allowed}.portal-button-secondary{display:inline-block;padding:8px 16px;background:transparent;color:#6f7ed1;border:1px solid #d8dadb;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;text-decoration:none}.portal-error{background:#fff4f4;border:1px solid #fecaca;color:#dc2626;border-radius:8px}.portal-error,.portal-success{padding:10px 14px;font-size:13px;margin-bottom:16px}.portal-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;border-radius:8px}.otp-input-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:8px;gap:8px;margin-bottom:16px;width:100%;min-width:0}.otp-input-grid input{width:100%;min-width:0;height:56px;font-size:24px;text-align:center;border:1px solid #d8dadb;border-radius:10px;font-weight:700;outline:none;font-family:inherit;padding:0}.otp-input-grid input:focus{border-color:#6f7ed1;box-shadow:0 0 0 3px rgba(111,126,209,.15)}.t-shell{min-height:100vh;display:flex;flex-direction:column}.t-header{background:#fff;border-bottom:1px solid #e1e3e5;padding:0 24px;height:56px;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100}.t-header,.t-logo{display:flex;align-items:center}.t-logo{gap:8px;text-decoration:none;color:inherit;font-weight:600}.t-logo-icon{font-size:20px}.t-logo-text{font-size:16px}.t-user{display:flex;align-items:center;gap:12px;font-size:14px}.t-role-badge{background:#fff4d6;color:#b8922f;font-size:11px;padding:3px 8px;border-radius:12px;font-weight:600;text-transform:uppercase}.t-logout{font-size:13px;color:#6d7175;text-decoration:none;padding:6px 10px;border-radius:6px}.t-logout:hover{background:#f1f2f3}.t-body{display:flex;flex:1 1}.t-sidebar{width:220px;background:#fff;border-right:1px solid #e1e3e5;padding:16px 8px;display:flex;flex-direction:column;gap:2px}.t-nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;text-decoration:none;color:#1a1a1a;font-size:14px;font-weight:500}.t-nav-item:hover{background:#f6f6f7}.t-nav-active{background:#fff4d6;color:#b8922f;font-weight:600}.t-nav-icon{font-size:16px}.t-main{flex:1 1;padding:24px;max-width:1100px}@media (max-width:800px){.t-sidebar{width:60px;padding:12px 4px}.t-nav-label{display:none}.t-nav-item{justify-content:center;padding:10px 6px}.t-main{padding:16px}.t-logo-text,.t-user-name{display:none}}@media (max-width:480px){.t-header{padding:0 12px;height:52px}.t-sidebar{width:56px}.t-main{padding:12px}.t-role-badge{font-size:10px;padding:2px 6px}}.portal-card{background:#fff;border:1px solid #e1e3e5;border-radius:12px;padding:20px;margin-bottom:16px}.portal-card-header{font-size:13px;font-weight:700;color:#6d7175;text-transform:uppercase;letter-spacing:.4px;margin-bottom:12px}.portal-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin-bottom:20px}.portal-stat{background:#fff;border:1px solid #e1e3e5;border-radius:12px;padding:16px}.portal-stat-value{font-size:28px;font-weight:700;color:#d4a843}.portal-stat-label{font-size:12px;color:#6d7175;margin-top:2px}.portal-list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f1f2f3}.portal-list-item:last-child{border-bottom:none}.portal-empty{text-align:center;color:#8c9196;font-size:14px;padding:32px 0}.portal-badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:10px;background:#f1f2f3;color:#6d7175;text-transform:uppercase}.portal-badge-gold{background:#fff4d6;color:#b8922f}.portal-badge-purple{background:#ede9fe;color:#7c3aed}.portal-badge-teal{background:#cffafe;color:#0891b2}.portal-next-lesson{background:linear-gradient(135deg,#d4a843,#b8922f);color:#fff;border-radius:12px;padding:20px;margin-bottom:20px}.portal-next-lesson h3{font-size:12px;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.portal-next-lesson .lesson-title{font-size:22px;font-weight:700;margin:8px 0 12px}.portal-next-lesson .lesson-details{display:flex;gap:16px;font-size:14px;flex-wrap:wrap}@media (max-width:600px){.portal-stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.stack-on-mobile{grid-template-columns:1fr!important;gap:16px!important}.stack-on-mobile-tight{grid-template-columns:1fr!important;gap:8px!important}.stack-on-mobile>.sidebar,.stack-on-mobile>aside{position:static!important}.portal-stat-grid{grid-template-columns:1fr!important}}@media (max-width:480px){.stack-on-mobile{padding:16px 12px!important}}