:root,:root[data-theme=light],:root[data-theme=dark]{--color-bg:#f3f5f9;--color-surface:#fff;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-text:#101828;--color-text-secondary:#667085;--color-border:#e4e7ec;--portal-sidebar-width:210px;--portal-shadow:16px 0 36px #10182814}html{scrollbar-color:#d0d5dd var(--color-bg)}body{background-color:var(--color-bg);color:var(--color-text)}.portal-shell{background:var(--color-bg);min-height:100vh;color:var(--color-text)}.portal-sidebar{z-index:20;width:var(--portal-sidebar-width);background:var(--color-surface);border:1px solid var(--color-border);min-height:100vh;box-shadow:var(--portal-shadow);border-left:0;border-radius:0 18px 18px 0;flex-direction:column;display:flex;position:fixed;inset:0 auto 0 0;overflow:hidden auto}.portal-sidebar__top,.portal-sidebar__bottom{flex-direction:column;display:flex}.portal-sidebar__top{flex:none;padding:24px 14px}.portal-sidebar__bottom{border-top:1px solid var(--color-border);flex:auto;gap:12px;padding:20px 14px}.sidebar-cards{flex-direction:column;flex:none;gap:12px;display:flex}.sidebar-card{background:var(--color-bg);border:1px solid var(--color-border);text-align:center;border-radius:14px;flex-direction:column;flex:none;justify-content:space-between;align-items:center;gap:10px;min-height:184px;padding:14px 12px;display:flex}.sidebar-ring{flex:none;width:76px;height:76px}.sidebar-ring__track{fill:none;stroke:var(--color-border);stroke-width:7px}.sidebar-ring__bar{fill:none;stroke:#17b26a;stroke-width:7px;stroke-linecap:round;transition:stroke-dashoffset .4s}.sidebar-ring__label{fill:var(--color-text);text-anchor:middle;dominant-baseline:central;font-size:16px;font-weight:700}.sidebar-card__title{color:var(--color-text);margin:0;font-size:.92rem;font-weight:700}.sidebar-card__text{color:var(--color-text-secondary);margin:0;font-size:.76rem;line-height:1.4}.sidebar-card__btn{background:var(--color-accent);color:#fff;width:100%;min-height:36px;transition:background-color var(--transition-fast);border-radius:10px;justify-content:center;align-items:center;padding:8px 10px;font-size:.78rem;font-weight:600;line-height:1.2;text-decoration:none;display:inline-flex}.sidebar-card__btn:hover{background:var(--color-accent-hover)}.portal-sidebar__logout-form{flex:none;margin-top:auto}.portal-sidebar__logo{justify-content:center;align-items:center;width:100%;margin:0 0 28px;display:flex}.portal-sidebar__logo-divider{background:var(--color-border);border-radius:99px;height:3px;margin:0 14px 24px;box-shadow:0 6px 18px #10182817}.portal-sidebar__nav{flex-direction:column;gap:10px;margin-top:8px;display:flex}.portal-sidebar__link{min-height:44px;color:var(--color-text-secondary);transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:600;line-height:1.25;text-decoration:none;display:flex}.portal-sidebar__link:hover{color:var(--color-text);background:#f8fafc}.portal-sidebar__link--active{color:var(--color-accent);background:#eaf1ff;border-color:#d6e4ff}.portal-sidebar__icon{color:currentColor;flex:0 0 20px;width:20px;height:20px}.portal-sidebar__icon svg{stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;fill:none;width:20px;height:20px}.portal-sidebar__logout{border:1px solid var(--color-border);width:100%;min-height:42px;color:var(--color-text-secondary);font-family:var(--font-primary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:#fff;border-radius:12px;font-size:.875rem;font-weight:600}.portal-sidebar__logout:hover{color:var(--color-text);background:#f8fafc;border-color:#d0d5dd}.portal-main{min-height:100vh;margin-left:var(--portal-sidebar-width);padding:48px clamp(24px,5vw,72px)}@media (max-width:860px){.portal-sidebar{border:0;border-bottom:1px solid var(--color-border);border-radius:0 0 18px 18px;width:auto;min-height:auto;position:static}.portal-sidebar__top,.portal-sidebar__bottom{flex:initial;padding:16px}.portal-sidebar__bottom{border-top:0}.portal-sidebar__logout-form{margin-top:0}.portal-sidebar__logo{margin-bottom:16px}.sidebar-cards{flex-direction:row;align-items:stretch}.sidebar-card{flex:1 1 0;min-height:0}.portal-main{margin-left:0;padding:28px 16px}}.dashboard-page{flex-direction:column;gap:28px;display:flex}.dashboard-page__header,.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:22px;box-shadow:0 10px 30px #1018280a}.dashboard-page__header{padding:clamp(28px,4vw,48px)}.dashboard-page__eyebrow,.dashboard-card__label{color:var(--color-accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;font-size:.78rem;font-weight:700;display:inline-block}.dashboard-page__title{max-width:760px;color:var(--color-text);margin:0;font-size:clamp(2rem,4vw,3.5rem);line-height:1.05}.dashboard-page__subtitle{max-width:720px;color:var(--color-text-secondary);margin:16px 0 0;font-size:1rem}.dashboard-page__admin{flex-direction:column;gap:28px;display:flex}.dashboard-page__admin .admin-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:22px;padding:clamp(20px,3vw,32px);box-shadow:0 10px 30px #1018280a}.dashboard-card{padding:clamp(24px,4vw,40px)}.dashboard-card__title{color:var(--color-text);margin:0;font-size:clamp(1.35rem,2vw,1.75rem);line-height:1.2}.dashboard-card__text{max-width:620px;color:var(--color-text-secondary);margin:12px 0 0}.dashboard-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:28px;display:grid}@media (max-width:960px){.dashboard-grid{grid-template-columns:1fr}}.account-card__divider{border:none;border-top:1px solid var(--color-border);margin:24px 0}.account-info{flex-direction:column;gap:12px;margin:18px 0 0;display:flex}.account-info__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:4px 16px;display:flex}.account-info__key{color:var(--color-text-secondary);margin:0;font-size:.9rem}.account-info__value{color:var(--color-text);word-break:break-word;margin:0;font-weight:600}.sessions{flex-direction:column;gap:14px;display:flex}.sessions__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px 16px;display:flex}.sessions__list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.session-item{border:1px solid var(--color-border);background:var(--color-bg);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px 16px;padding:12px 14px;display:flex}.session-item__info{flex-direction:column;gap:4px;min-width:0;display:flex}.session-item__device{color:var(--color-text);align-items:center;gap:8px;font-weight:600;display:inline-flex}.session-item__badge{color:#067647;background:#ecfdf3;border:1px solid #abefc6;border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:700}.session-item__meta{color:var(--color-text-secondary);word-break:break-word;font-size:.82rem}.account-logout-confirm{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.account-logout-confirm__text{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.account-form{flex-direction:column;gap:14px;display:flex}.account-form__title{color:var(--color-text);margin:0;font-size:1.05rem;font-weight:600}.account-field{flex-direction:column;gap:6px;display:flex}.account-form__success{color:#067647;background:#ecfdf3;border:1px solid #abefc6;border-radius:10px;padding:10px 14px;font-size:.88rem}.account-form .btn,.account-danger .btn{align-self:flex-start}.account-collapse{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px;display:flex}.account-form__actions{flex-wrap:wrap;gap:10px;display:flex}.account-danger{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px;display:flex}.account-danger--confirm{flex-direction:column;align-items:stretch}.account-danger__text{color:var(--color-text-secondary);max-width:420px;margin:4px 0 0;font-size:.88rem}.account-danger__actions{flex-wrap:wrap;gap:10px;display:flex}.course-progress{margin-top:20px}.course-progress__head{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.course-progress__percent{color:var(--color-accent);font-size:1.6rem;font-weight:700}.course-progress__count{color:var(--color-text-secondary);font-size:.88rem}.progress-bar{background:var(--color-border);border-radius:999px;height:8px;overflow:hidden}.progress-bar__fill{border-radius:inherit;background:var(--color-accent);height:100%;transition:width var(--transition-fast,.2s) ease;display:block}.course-progress__modules{flex-direction:column;gap:14px;margin:22px 0 0;padding:0;list-style:none;display:flex}.course-progress__module-head{justify-content:space-between;gap:12px;margin-bottom:6px;display:flex}.course-progress__module-title{color:var(--color-text);font-size:.9rem;font-weight:500}.course-progress__module-count{color:var(--color-text-secondary);white-space:nowrap;font-size:.85rem}.course-progress__cta,.course-progress__resume{margin-top:24px}.course-progress__resume-hint{color:var(--color-text-secondary);margin:0 0 14px;font-size:.9rem;line-height:1.5}.course-progress__resume-module,.course-progress__resume-lesson{color:var(--color-text);font-weight:600}.course-progress__resume .course-progress__cta{margin-top:0}.course-progress__done{background:#ecfdf3;border:1px solid #abefc6;border-radius:16px;margin-top:24px;padding:20px}.course-progress__done-badge{color:#fff;background:#17b26a;border-radius:999px;padding:6px 14px;font-size:.9rem;font-weight:700;display:inline-block}.course-progress__done-text{color:#085d3a;margin:14px 0 18px;font-size:.92rem;line-height:1.5}.course-progress__done .course-progress__cta{background:#17b26a;margin-top:0}.course-progress__done .course-progress__cta:hover{background:#099250;box-shadow:0 4px 20px #17b26a59}.auth-layout{min-height:100vh;padding:var(--space-xl) var(--space-md);background-color:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;display:flex}.auth-layout__logo{margin-bottom:var(--space-2xl);opacity:.9;transition:opacity var(--transition-fast);align-items:center;display:inline-flex}.auth-layout__logo:hover{opacity:1}.auth-form{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;max-width:420px;padding:var(--space-2xl) var(--space-xl)}@media (max-width:480px){.auth-form{padding:var(--space-xl) var(--space-md)}}.auth-form__title{color:var(--color-text);margin:0 0 var(--space-xs);font-size:1.5rem;font-weight:700;line-height:1.3}.auth-form__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-xl)}.auth-form__fields{gap:var(--space-md);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.auth-field{gap:var(--space-xs);flex-direction:column;display:flex}.auth-field__label{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.auth-field__input{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);font-family:var(--font-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast);box-sizing:border-box;padding:10px 14px;line-height:1.5}.auth-field__input::placeholder{color:var(--color-text-secondary)}.auth-field__input:focus{border-color:var(--color-accent);outline:none}.auth-field__input:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.auth-field__input--error{border-color:#e05454}.auth-field__password-wrapper{align-items:center;display:flex;position:relative}.auth-field__input--password{padding-right:44px}.auth-field__toggle{cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:12px}.auth-field__toggle:hover{color:var(--color-text)}.auth-field__hint{color:var(--color-text-secondary);font-size:.8125rem}.auth-form__error{align-items:flex-start;gap:var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#f07070;margin-bottom:var(--space-md);background-color:#e054541a;border:1px solid #e054544d;padding:12px 14px;line-height:1.5;display:flex}.auth-form__success{align-items:flex-start;gap:var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:#6ad68e;margin-bottom:var(--space-md);background-color:#34a8531a;border:1px solid #34a8534d;padding:12px 14px;line-height:1.5;display:flex}.auth-form__submit{border-radius:var(--radius-pill);width:100%;font-size:var(--font-size-base);padding:12px 24px;font-weight:600}.auth-form__submit:disabled{opacity:.6;cursor:not-allowed}.auth-form__resend{gap:var(--space-md);flex-direction:column;display:flex}.auth-form__resend-target{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.auth-form__resend-email{color:var(--color-text);word-break:break-all;font-weight:600}.auth-form__resend-hint{color:var(--color-text-secondary);text-align:center;margin:0;font-size:.8125rem}.auth-form__resend .auth-form__links{margin-top:var(--space-xs)}.auth-form__links{align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);flex-direction:column;display:flex}.auth-form__link{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.auth-form__link:hover,.auth-form__link--accent{color:var(--color-accent)}.auth-form__link--accent:hover{color:var(--color-accent-hover)}.dashboard-stub{min-height:100vh;padding:var(--space-xl) var(--space-md);background-color:var(--color-bg);justify-content:center;align-items:center;display:flex}.dashboard-stub__card{align-items:center;gap:var(--space-md);padding:var(--space-2xl) var(--space-xl);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center;flex-direction:column;width:100%;max-width:420px;display:flex}.dashboard-stub__title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:700}.dashboard-stub__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.dashboard-stub__logout{margin-top:var(--space-sm)}.admin-shell{background-color:var(--color-bg);min-height:100vh}.admin-header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:10;position:sticky;top:0}.admin-header__inner{align-items:center;gap:var(--space-lg);padding:0 var(--space-xl);max-width:1200px;height:56px;margin-inline:auto;display:flex}.admin-header__brand{color:var(--color-text);white-space:nowrap;margin-right:auto;font-size:1rem;font-weight:700}.admin-nav{align-items:center;gap:var(--space-md);display:flex}.admin-nav__link{font-size:var(--font-size-sm);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:color var(--transition-fast), background-color var(--transition-fast);padding:6px 12px;font-weight:500;text-decoration:none}.admin-nav__link:hover{color:var(--color-text);background-color:var(--color-bg)}.admin-main{max-width:1200px;padding:var(--space-2xl) var(--space-xl);margin-inline:auto}.admin-section__header{align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.admin-section__title{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:700}.admin-section__count{color:var(--color-text-secondary);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;padding:2px 10px;font-size:.85rem;font-weight:600}.admin-section__stats{gap:var(--space-sm);flex-wrap:wrap;display:flex}.admin-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;margin-top:var(--space-lg);overflow-x:auto}.admin-table-wrap--scroll{max-height:280px;overflow-y:auto}.admin-table-wrap--scroll .admin-table__th{z-index:1;position:sticky;top:0}.admin-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.admin-table__th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 16px;font-size:.75rem;font-weight:600}.admin-table__th--action{text-align:right}.admin-table__row{transition:background-color var(--transition-fast)}.admin-table__row:not(:last-child){border-bottom:1px solid var(--color-border)}.admin-table__row:hover{background-color:var(--color-bg)}.admin-table__td{color:var(--color-text);vertical-align:middle;padding:12px 16px}.admin-table__td--mono{word-break:break-all;font-family:Courier New,monospace;font-size:.8rem}.admin-table__td--secondary{color:var(--color-text-secondary);font-size:.8rem}.admin-table__td--empty{text-align:center;color:var(--color-text-secondary);padding:var(--space-2xl)}.admin-badge{white-space:nowrap;border-radius:999px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.admin-badge--admin{color:var(--color-accent);background-color:#0070c026}.admin-badge--user{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}.admin-badge--free{color:#27ae60;background-color:#27ae6026}.admin-badge--used{color:var(--color-text-secondary);background-color:#7f8c8d26}.invite-generate{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.invite-generate__error{color:#c0392b;font-size:var(--font-size-sm);margin:0}.invite-generate__result{align-items:center;gap:var(--space-sm);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-wrap:wrap;padding:6px 12px;display:flex}.invite-generate__code{color:var(--color-text);word-break:break-all;font-family:Courier New,monospace;font-size:.85rem}.revoke-confirm{align-items:center;gap:var(--space-xs);flex-wrap:wrap;display:flex}.revoke-confirm__text{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.revoke-confirm__error{color:#f07070;margin-top:2px;font-size:.8rem;display:block}.admin-section__loading{color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:var(--space-xl) 0}.admin-section__error-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--space-md)}.enrollment-toggle{gap:var(--space-sm);padding:var(--space-lg);margin-bottom:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;display:flex}.enrollment-toggle__header{align-items:center;gap:var(--space-sm);display:flex}.enrollment-toggle__title{color:var(--color-text);margin:0;font-size:1rem;font-weight:600}.enrollment-toggle__status{letter-spacing:.03em;border-radius:20px;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-block}.enrollment-toggle__status--open{color:#22c55e;background:#22c55e26}.enrollment-toggle__status--closed{color:#ef4444;background:#ef444426}.enrollment-toggle__desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.enrollment-toggle__btn{margin-top:var(--space-xs);align-self:flex-start}.enrollment-toggle__error{color:#f07070;margin:0;font-size:.8rem}.admin-content{gap:var(--space-xl);grid-template-columns:minmax(220px,280px) 1fr;align-items:start;display:grid}@media (max-width:860px){.admin-content{grid-template-columns:1fr}}.admin-content__rail{gap:var(--space-lg);flex-direction:column;max-height:520px;padding-right:6px;display:flex;overflow-y:auto}@media (max-width:860px){.admin-content__rail{max-height:280px}}.admin-content__module-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 8px;font-size:.72rem;font-weight:700}.admin-content__lessons{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.admin-content__lesson{text-align:left;border-radius:var(--radius-md);width:100%;color:var(--color-text);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:1px solid #0000;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.admin-content__lesson:hover{background:var(--color-bg)}.admin-content__lesson--active{background:var(--color-bg);border-color:var(--color-accent)}.admin-content__lesson-num{color:var(--color-text-secondary);font-size:.7rem;font-weight:600}.admin-content__lesson-name{font-size:.85rem;line-height:1.3}.admin-content__panel{gap:var(--space-xl);flex-direction:column;min-width:0;display:flex}.admin-content__panel-eyebrow{text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);font-size:.72rem;font-weight:700}.admin-content__panel-title{color:var(--color-text);margin:4px 0 0;font-size:1.15rem;font-weight:700}.admin-content__empty{color:var(--color-text-secondary)}.admin-content-block{gap:var(--space-md);padding:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);flex-direction:column;display:flex}.admin-content-block__title{color:var(--color-text);margin:0;font-size:1rem;font-weight:700}.admin-content-field{flex-direction:column;gap:6px;display:flex}.admin-content-textarea{resize:vertical;width:100%;min-height:120px;font:inherit;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;font-size:.9rem;line-height:1.5}.admin-content-textarea:focus{border-color:var(--color-accent);outline:none}.admin-content-field__actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.admin-content-field__status{color:var(--color-text-secondary);font-size:.82rem}.admin-content-field__status--error{color:#f07070}.admin-content-files{flex-direction:column;gap:10px;display:flex}.admin-content-files__list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.admin-content-files__item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:8px 12px;display:flex}.admin-content-files__name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.88rem;overflow:hidden}.admin-content-files__size{color:var(--color-text-secondary);white-space:nowrap;font-size:.78rem}.admin-content-files__empty{color:var(--color-text-secondary);margin:0;font-size:.85rem}.admin-content-files__upload{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-content-files__input{color:var(--color-text-secondary);font-size:.82rem}.admin-content-files__progress{align-items:center;gap:10px;display:flex}.admin-content-files__progress-bar{background:var(--color-border);border-radius:999px;flex:1;height:6px;overflow:hidden}.admin-content-files__progress-fill{background:var(--color-accent);border-radius:999px;height:100%;transition:width .15s}
