.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);z-index:999;transition:transform var(--transition-smooth);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(#00b7e008 0%,#0000 40%,#00001e33 100%);position:absolute;inset:0}.sidebar>*{z-index:1;position:relative}.sidebar__overlay{display:none}.sidebar__logo{align-items:center;gap:12px;margin-bottom:8px;padding:24px 20px 20px;display:flex}.sidebar__logo-mark{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--color-accent), #0091b3);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar__logo-mark span{color:#fff;letter-spacing:.02em;font-size:.75rem;font-weight:700}.sidebar__logo-text{color:var(--color-text-primary);letter-spacing:.02em;font-size:1.0625rem;font-weight:700}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:0 12px;display:flex}.sidebar__link{border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar__link:hover{color:var(--color-text-primary);background:#ffffff0a}.sidebar__link--active{color:var(--color-accent);background:var(--color-accent-subtle)}.sidebar__link--active:before{content:"";background:var(--color-accent);border-radius:0 4px 4px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar__icon{opacity:.85;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar__link--active .sidebar__icon{opacity:1}.sidebar__label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar__user{border-top:1px solid var(--color-border);align-items:center;gap:10px;margin-top:auto;padding:16px 16px 20px;display:flex}.sidebar__user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;letter-spacing:.02em;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.6875rem;font-weight:600;display:flex}.sidebar__user-info{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar__user-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.sidebar__user-email{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.6875rem;overflow:hidden}.sidebar__logout{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-xs);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:6px;display:flex}.sidebar__logout:hover{color:var(--color-danger);background:#f851491a}@media (width<=1024px){.sidebar{transform:translate(-100%)}.sidebar--open{box-shadow:var(--shadow-xl);transform:translate(0)}.sidebar__overlay{background:var(--color-overlay);z-index:998;animation:fadeIn .2s var(--ease-out);display:block;position:fixed;inset:0}}.topbar{z-index:100;height:var(--topbar-height);padding:0 var(--spacing-lg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);background:#030c19bf;align-items:center;gap:12px;display:flex;position:sticky;top:0}.topbar__hamburger{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-xs);transition:color var(--transition-fast);background:0 0;border:none;padding:6px;display:none}.topbar__hamburger:hover{color:var(--color-text-primary)}.topbar__breadcrumb{color:var(--color-text-muted);align-items:center;gap:4px;font-size:.8125rem;display:flex}.topbar__breadcrumb-sep{opacity:.4;margin:0 4px}.topbar__breadcrumb a{color:var(--color-text-secondary);transition:color var(--transition-fast)}.topbar__breadcrumb a:hover{color:var(--color-accent)}.topbar__search{flex:1;max-width:340px;position:relative}.topbar__search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.topbar__search-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-primary);font-size:.8125rem;font-family:var(--font-family);transition:all var(--transition-fast);background:#ffffff0a;outline:none;padding:8px 12px 8px 36px}.topbar__search-input:hover{border-color:var(--color-border-hover);background:#ffffff0f}.topbar__search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle);background:#ffffff0f}.topbar__search-input::placeholder{color:var(--color-text-muted)}.topbar__spacer{flex:1}.topbar__actions{align-items:center;gap:4px;display:flex}.topbar__icon-btn{cursor:pointer;width:36px;height:36px;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.topbar__icon-btn:hover{color:var(--color-text-primary);background:#ffffff0a}.topbar__user{position:relative}.topbar__user-btn{cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:4px;display:flex}.topbar__user-btn:hover{background:#ffffff0a}.topbar__avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;letter-spacing:.02em;justify-content:center;align-items:center;width:32px;height:32px;font-size:.6875rem;font-weight:600;display:flex}.topbar__user-name{color:var(--color-text-primary);font-size:.8125rem;font-weight:500}.topbar__dropdown{background:var(--color-surface-solid);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:220px;box-shadow:var(--shadow-xl);z-index:200;animation:slideDown .15s var(--ease-out);padding:6px;position:absolute;top:calc(100% + 8px);right:0}.topbar__dropdown-header{flex-direction:column;gap:2px;padding:10px 12px;display:flex}.topbar__dropdown-name{color:var(--color-text-primary);font-size:.8125rem;font-weight:600}.topbar__dropdown-email{color:var(--color-text-muted);font-size:.6875rem}.topbar__dropdown-divider{background:var(--color-border);height:1px;margin:4px 0}.topbar__dropdown-item{width:100%;color:var(--color-text-secondary);border-radius:var(--radius-xs);cursor:pointer;transition:all var(--transition-fast);font-size:.8125rem;font-weight:500;font-family:var(--font-family);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:8px 12px;text-decoration:none;display:flex}.topbar__dropdown-item:hover{color:var(--color-text-primary);background:#ffffff0a}.topbar__dropdown-item--danger:hover{color:var(--color-danger);background:#f8514914}@media (width<=1024px){.topbar{padding:0 var(--spacing-md)}.topbar__hamburger{justify-content:center;align-items:center;display:flex}.topbar__breadcrumb{display:none}}@media (width<=480px){.topbar__search{max-width:none}.topbar__user-name{display:none}}.app-layout{background:var(--color-bg);min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-smooth);flex-direction:column;flex:1;display:flex}.app-content{padding:var(--spacing-lg);max-width:var(--content-max-width);width:100%;animation:fadeIn .35s var(--ease-out);flex:1;margin:0 auto}.app-layout__overlay{display:none}@media (width<=1024px){.app-main{margin-left:0}.app-content{padding:var(--spacing-md)}.app-layout__overlay{background:var(--color-overlay);z-index:998;animation:fadeIn .2s var(--ease-out);-webkit-backdrop-filter:blur(2px);display:block;position:fixed;inset:0}}@media (width<=480px){.app-content{padding:var(--spacing-sm)}}.login-page{background:var(--color-bg);min-height:100vh;padding:var(--spacing-md);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#00b7e00f 0%,#0000 70%);width:500px;height:500px;position:absolute;top:-150px;right:-100px}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#0091b30a 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;left:-50px}.login-card{width:100%;max-width:400px;padding:var(--spacing-xl) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-xl);animation:scaleIn .4s var(--ease-out);z-index:1;position:relative}.login-card__logo{margin-bottom:var(--spacing-lg);justify-content:center;display:flex}.login-card__logo img{width:auto;height:40px}.login-card__title{text-align:center;color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.25rem;font-weight:700}.login-card__form{gap:var(--spacing-md);flex-direction:column;display:flex}.login-card__error{border-radius:var(--radius-sm);color:var(--color-danger);animation:slideDown .2s var(--ease-out);background:#f8514914;border:1px solid #f8514933;padding:10px 14px;font-size:.8125rem}.login-card__field{flex-direction:column;gap:6px;display:flex}.login-card__label{color:var(--color-text-primary);font-size:.8125rem;font-weight:500}.login-card__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family);transition:all var(--transition-fast);background:#ffffff0a;outline:none;width:100%;padding:11px 14px;font-size:.875rem}.login-card__input:hover{border-color:var(--color-border-hover)}.login-card__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.login-card__input::placeholder{color:var(--color-text-muted)}.login-card__submit{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);margin-top:var(--spacing-xs);border:none;padding:12px;font-size:.875rem;font-weight:600}.login-card__submit:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--glow-accent);transform:translateY(-1px)}.login-card__submit:disabled{opacity:.5;cursor:not-allowed}.login-card__submit:active:not(:disabled){transform:translateY(0)}.login-card__forgot{text-align:center;margin-top:var(--spacing-md)}.login-card__forgot a{color:var(--color-text-muted);transition:color var(--transition-fast);font-size:.8125rem}.login-card__forgot a:hover{color:var(--color-accent)}.login-card__link{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-family:inherit;font-size:.8125rem}.login-card__link:hover{color:var(--color-accent)}.login-card__info{background:var(--color-accent-subtle);border:1px solid var(--color-border-accent);border-radius:var(--radius-sm);color:var(--color-accent);animation:slideDown .2s var(--ease-out);padding:10px 14px;font-size:.8125rem}.progress-bar{border-radius:var(--radius-full);background:#ffffff0f;width:100%;height:4px;position:relative;overflow:hidden}.progress-bar--labeled{flex:1}.progress-bar__fill{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--color-accent), #00d4ff);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar__fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff26 50%,#0000 100%) 0 0/200% 100%;animation:2s ease-in-out infinite shimmer;position:absolute;inset:0}.progress-bar__wrapper{align-items:center;gap:10px;display:flex}.progress-bar__label{color:var(--color-accent);white-space:nowrap;text-align:right;min-width:32px;font-size:.75rem;font-weight:600}.progress-bar__inline-label{color:var(--color-text-muted);opacity:0;transition:opacity var(--transition-fast);font-size:.625rem;font-weight:600;position:absolute;top:-18px;right:0}.progress-bar:hover .progress-bar__inline-label{opacity:1}.course-card{border-radius:var(--radius-md);background:var(--color-surface-solid);border:1px solid var(--color-border);width:100%;transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);overflow:hidden}.course-card:hover{border-color:var(--color-border-accent);box-shadow:var(--glow-accent-card);transform:scale(1.02)}.course-card__link{color:inherit;text-decoration:none;display:block}.course-card__thumb-wrapper{aspect-ratio:16/9;background:var(--color-bg-elevated);position:relative;overflow:hidden}.course-card__thumb{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-smooth)}.course-card:hover .course-card__thumb{transform:scale(1.05)}.course-card__thumb-placeholder{background:linear-gradient(135deg, var(--color-bg-elevated), var(--color-surface-solid));width:100%;height:100%;color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.course-card__badge{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-full);color:var(--color-accent);text-transform:uppercase;letter-spacing:.03em;background:#000000b3;padding:4px 10px;font-size:.6875rem;font-weight:600;position:absolute;top:10px;right:10px}.course-card__lessons-badge{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-xs);color:var(--color-text-primary);background:#000000a6;padding:3px 8px;font-size:.6875rem;font-weight:500;position:absolute;bottom:10px;left:10px}.course-card__body{padding:14px 16px 12px}.course-card__title{color:var(--color-text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.875rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.course-card__progress{padding:0 16px 14px}@media (width<=768px){.course-card{width:220px}}@media (width<=480px){.course-card{width:200px}}.dashboard{animation:fadeIn .4s var(--ease-out)}.dashboard__greeting{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.dashboard__greeting span{color:var(--color-accent)}.dashboard__error{padding:var(--spacing-md);border-radius:var(--radius-md);color:var(--color-danger);background:#f8514914;border:1px solid #f8514933;font-size:.875rem}.dashboard__grid{gap:var(--spacing-lg);margin-top:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}@media (width<=640px){.dashboard__grid{gap:var(--spacing-md);grid-template-columns:1fr}}.lesson-item{border-radius:var(--radius-sm);transition:background var(--transition-fast);align-items:center;gap:12px;padding:10px 12px;display:flex;position:relative}.lesson-item:hover{background:#ffffff08}.lesson-item--active{background:var(--color-accent-subtle);border:1px solid var(--color-border-accent)}.lesson-item--active .lesson-item__title{color:var(--color-accent)}.lesson-item__icon{border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-muted);transition:all var(--transition-fast);background:#ffffff0a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lesson-item:hover .lesson-item__icon{color:var(--color-accent);background:var(--color-accent-subtle)}.lesson-item--completed .lesson-item__icon{color:var(--color-success);background:#3fb9501f}.lesson-item__content{flex:1;min-width:0}.lesson-item__title{color:var(--color-text-secondary);transition:color var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:500;text-decoration:none;display:block;overflow:hidden}.lesson-item__title:hover{color:var(--color-text-primary)}.lesson-item--completed .lesson-item__title{color:var(--color-text-muted)}.lesson-item__meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.lesson-item__duration{color:var(--color-text-muted);border-radius:var(--radius-xs);white-space:nowrap;background:#ffffff0a;padding:2px 8px;font-size:.6875rem}.module-accordion{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base);overflow:hidden}.module-accordion+.module-accordion{margin-top:8px}.module-accordion--open{border-color:var(--color-border-hover)}.module-accordion__header{cursor:pointer;width:100%;font-family:var(--font-family);transition:background var(--transition-fast);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.module-accordion__header:hover{background:#ffffff05}.module-accordion__header-left{align-items:center;gap:12px;min-width:0;display:flex}.module-accordion__title{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.module-accordion__count{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.module-accordion__chevron{color:var(--color-text-muted);transition:transform .3s var(--ease-in-out);flex-shrink:0;justify-content:center;align-items:center;display:flex}.module-accordion__chevron--open{transform:rotate(180deg)}.module-accordion__body{max-height:0;transition:max-height .35s var(--ease-in-out);overflow:hidden}.module-accordion__body-inner{padding:0 8px 8px}.course-page{animation:fadeIn .4s var(--ease-out)}.course-page__loading,.course-page__error{min-height:40vh;color:var(--color-text-secondary);justify-content:center;align-items:center;font-size:.875rem;display:flex}.course-page__error{color:var(--color-danger)}.course-page__layout{gap:var(--spacing-xl);grid-template-columns:1fr 1fr;align-items:start;display:grid}.course-info{animation:slideUp .5s var(--ease-out)}.course-info__category{background:var(--color-accent-subtle);color:var(--color-accent);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--spacing-sm);padding:4px 12px;font-size:.6875rem;font-weight:600;display:inline-block}.course-info__title{color:var(--color-text-primary);margin-bottom:var(--spacing-sm);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;line-height:1.25}.course-info__desc{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:.875rem;line-height:1.7}.course-info__stats{gap:var(--spacing-lg);margin-bottom:var(--spacing-md);display:flex}.course-info__stat{color:var(--color-text-secondary);align-items:center;gap:6px;font-size:.8125rem;display:flex}.course-info__stat strong{color:var(--color-text-primary);font-weight:600}.course-info__progress{margin-bottom:var(--spacing-md)}.course-info__btn{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);transition:all var(--transition-base);justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.course-info__btn:hover{background:var(--color-accent-hover);box-shadow:var(--glow-accent);color:var(--color-bg);transform:translateY(-1px)}.course-modules{animation:slideUp .5s var(--ease-out) .1s both}.course-modules__title{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:1.125rem;font-weight:600}@media (width<=900px){.course-page__layout{gap:var(--spacing-lg);grid-template-columns:1fr}}.rating-widget{padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.rating-widget__title{color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);font-size:.8125rem;font-weight:500}.rating-widget__faces{gap:8px;display:flex}.rating-widget__face{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);background:#ffffff0a;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.rating-widget__face:hover{border-color:var(--color-border-hover);background:#ffffff14;transform:scale(1.1)}.rating-widget__face--selected{background:var(--color-accent-subtle);border-color:var(--color-accent);box-shadow:var(--glow-accent);transform:scale(1.1)}.rating-widget__msg{color:var(--color-success);margin-top:var(--spacing-xs);animation:fadeIn .3s var(--ease-out);font-size:.75rem}.comment-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.comment-section__title{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:1rem;font-weight:600}.comment-section__form{margin-bottom:var(--spacing-md);gap:12px;display:flex}.comment-section__avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;letter-spacing:.02em;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.625rem;font-weight:600;display:flex}.comment-section__input-wrapper{flex-direction:column;flex:1;gap:8px;display:flex}.comment-section__textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;min-height:72px;color:var(--color-text-primary);font-family:var(--font-family);resize:vertical;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#ffffff0a;outline:none;padding:10px 14px;font-size:.8125rem}.comment-section__textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.comment-section__textarea::placeholder{color:var(--color-text-muted)}.comment-section__submit{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);border:none;align-self:flex-end;padding:8px 20px;font-size:.8125rem;font-weight:600}.comment-section__submit:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--glow-accent)}.comment-section__submit:disabled{opacity:.4;cursor:not-allowed}.comment-section__filters{margin-bottom:var(--spacing-md);gap:4px;display:flex}.comment-section__filter{border-radius:var(--radius-full);color:var(--color-text-muted);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:5px 12px;font-size:.75rem;font-weight:500}.comment-section__filter:hover{color:var(--color-text-primary);background:#ffffff0a}.comment-section__filter--active{color:var(--color-accent);background:var(--color-accent-subtle)}.comment-section__loading,.comment-section__empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);font-size:.8125rem}.comment{border-bottom:1px solid var(--color-border);gap:12px;padding:14px 0;display:flex}.comment:last-child{border-bottom:none}.comment__body{flex:1;min-width:0}.comment__header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.comment__name{color:var(--color-text-primary);font-size:.8125rem;font-weight:600}.comment__time{color:var(--color-text-muted);font-size:.6875rem}.comment__content{color:var(--color-text-secondary);font-size:.8125rem;line-height:1.6}.lesson-page{animation:fadeIn .4s var(--ease-out)}.lesson-page__error{min-height:40vh;color:var(--color-danger);justify-content:center;align-items:center;font-size:.875rem;display:flex}.lesson-page__layout{gap:var(--spacing-lg);grid-template-columns:1fr 280px;align-items:start;display:grid}.lesson-main{min-width:0}.lesson-main__breadcrumb{margin-bottom:var(--spacing-md);color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:2px;font-size:.8125rem;display:flex}.lesson-main__breadcrumb a{color:var(--color-text-secondary);transition:color var(--transition-fast)}.lesson-main__breadcrumb a:hover{color:var(--color-accent)}.lesson-main__breadcrumb-sep{opacity:.4;margin:0 4px}.lesson-main__title{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:clamp(1.25rem,2.5vw,1.625rem);font-weight:700;line-height:1.3}.lesson-main__progress-row{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px 16px;display:flex}.lesson-main__progress-text{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem}.lesson-main__actions{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.lesson-main__complete-btn{border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);background:0 0;align-items:center;gap:6px;padding:10px 20px;font-size:.8125rem;font-weight:600;display:inline-flex}.lesson-main__complete-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.lesson-main__complete-btn--done{color:var(--color-success);background:#3fb9501f;border-color:#3fb9504d}.lesson-main__complete-btn--done:hover{border-color:var(--color-success);color:var(--color-success);background:#3fb9502e}.lesson-main__content{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:.9375rem;line-height:1.75}.lesson-main__content h1,.lesson-main__content h2,.lesson-main__content h3{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.lesson-main__content p{margin-bottom:var(--spacing-sm)}.lesson-main__content ul,.lesson-main__content ol{padding-left:var(--spacing-md);margin-bottom:var(--spacing-sm)}.lesson-main__content a{color:var(--color-accent)}.lesson-main__content img{border-radius:var(--radius-sm);margin:var(--spacing-md) 0}.lesson-main__content code{border-radius:var(--radius-xs);color:var(--color-accent);background:#ffffff0f;padding:2px 6px;font-size:.85em}.lesson-main__content pre{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-md);overflow-x:auto}.lesson-main__content pre code{color:var(--color-text-primary);background:0 0;padding:0}.lesson-main__content blockquote{border-left:3px solid var(--color-accent);padding-left:var(--spacing-md);margin:var(--spacing-md) 0;color:var(--color-text-muted)}.lesson-main__nav{justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex}.lesson-main__nav-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:all var(--transition-base);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;max-width:45%;padding:10px 16px;font-size:.8125rem;font-weight:500;text-decoration:none;display:inline-flex;overflow:hidden}.lesson-main__nav-btn:hover{border-color:var(--color-accent);color:var(--color-text-primary);background:var(--color-accent-subtle)}.lesson-main__nav-btn--disabled{opacity:.35;pointer-events:none}.lesson-sidebar{top:calc(var(--topbar-height) + var(--spacing-lg));padding:var(--spacing-md);background:var(--color-surface-solid);border:1px solid var(--color-border);border-radius:var(--radius-md);position:sticky}.lesson-sidebar__title{margin-bottom:var(--spacing-xs);font-size:.9375rem;font-weight:600}.lesson-sidebar__title a{color:var(--color-text-primary);transition:color var(--transition-fast);text-decoration:none}.lesson-sidebar__title a:hover{color:var(--color-accent)}.lesson-sidebar__position{font-size:.75rem}@media (width<=900px){.lesson-page__layout{gap:var(--spacing-md);grid-template-columns:1fr}.lesson-sidebar{position:static}}.notifications-page{max-width:720px;animation:fadeIn .4s var(--ease-out)}.notifications-page__header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.notifications-page__title{color:var(--color-text-primary);font-size:1.5rem;font-weight:700}.notifications-page__mark-all{border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;padding:8px 16px;font-size:.8125rem;font-weight:500}.notifications-page__mark-all:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.notifications-page__loading,.notifications-page__empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:.875rem}.notification-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:flex-start;gap:14px;margin-bottom:4px;padding:16px;display:flex}.notification-item:hover{border-color:var(--color-border);background:#ffffff05}.notification-item--unread{background:var(--color-surface);border-color:var(--color-border)}.notification-item--unread:before{content:"";border-radius:var(--radius-full);background:var(--color-accent);flex-shrink:0;width:6px;height:6px;margin-top:8px}.notification-item__icon{text-align:center;flex-shrink:0;width:24px;font-size:1.25rem}.notification-item__body{flex:1;min-width:0}.notification-item__heading{color:var(--color-text-primary);margin-bottom:2px;font-size:.8125rem;font-weight:600}.notification-item__message{color:var(--color-text-secondary);font-size:.8125rem;line-height:1.5}.notification-item__time{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:.6875rem}.profile-page{max-width:640px;animation:fadeIn .4s var(--ease-out)}.profile-page__title{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem;font-weight:700}.profile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);-webkit-backdrop-filter:blur(var(--glass-blur));animation:slideUp .5s var(--ease-out)}.profile-card__avatar-section{margin-bottom:var(--spacing-lg);justify-content:center;display:flex}.profile-card__avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;letter-spacing:.02em;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.25rem;font-weight:700;display:flex}.profile-card__form{gap:var(--spacing-md);flex-direction:column;display:flex}.profile-card__field{flex-direction:column;gap:6px;display:flex}.profile-card__label{color:var(--color-text-primary);font-size:.8125rem;font-weight:500}.profile-card__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-family);transition:all var(--transition-fast);background:#ffffff0a;outline:none;width:100%;padding:11px 14px;font-size:.875rem}.profile-card__input:hover{border-color:var(--color-border-hover)}.profile-card__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.profile-card__input--readonly{opacity:.6;cursor:not-allowed}.profile-card__stats{gap:var(--spacing-sm);padding:var(--spacing-md) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);grid-template-columns:repeat(3,1fr);display:grid}.profile-card__stat{text-align:center}.profile-card__stat-value{color:var(--color-accent);font-size:1.5rem;font-weight:700}.profile-card__stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:.6875rem}.profile-card__msg{border-radius:var(--radius-sm);color:var(--color-success);animation:slideDown .2s var(--ease-out);background:#3fb95014;border:1px solid #3fb95033;padding:10px 14px;font-size:.8125rem}.profile-card__msg--error{color:var(--color-danger);background:#f8514914;border-color:#f8514933}.profile-card__submit{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);border:none;padding:12px;font-size:.875rem;font-weight:600}.profile-card__submit:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--glow-accent);transform:translateY(-1px)}.profile-card__submit:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.profile-card{padding:var(--spacing-md)}.profile-card__stats{gap:var(--spacing-md);grid-template-columns:1fr}}.communities-page{animation:fadeIn .4s var(--ease-out)}.communities-page__title{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem;font-weight:700}.communities-page__placeholder{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(var(--glass-blur));animation:slideUp .5s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;display:flex}.communities-page__icon{margin-bottom:var(--spacing-md);font-size:3rem;display:block}.communities-page__heading{color:var(--color-text-primary);margin-bottom:var(--spacing-sm);font-size:1.25rem;font-weight:700}.communities-page__desc{color:var(--color-text-secondary);max-width:420px;font-size:.875rem;line-height:1.7}.ranking-page{max-width:800px;animation:fadeIn .4s var(--ease-out)}.ranking-page__title{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem;font-weight:700}.ranking-page__loading,.ranking-page__empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:.875rem}.ranking-table{border-collapse:separate;border-spacing:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;-webkit-backdrop-filter:blur(var(--glass-blur));overflow:hidden}.ranking-table th,.ranking-table td{text-align:left;padding:14px 16px;font-size:.8125rem}.ranking-table__header{border-bottom:1px solid var(--color-border)}.ranking-table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;background:#ffffff05;font-size:.6875rem;font-weight:600}.ranking-row{transition:background var(--transition-fast);border-bottom:1px solid var(--color-border)}.ranking-row:last-child{border-bottom:none}.ranking-row:hover{background:#ffffff05}.ranking-row--me{background:var(--color-accent-subtle)}.ranking-row--me:hover{background:#00b7e026}.ranking-row td{color:var(--color-text-secondary)}.ranking-row__pos{min-width:40px;font-size:.9375rem;font-weight:700}.ranking-row__pos--gold,.ranking-row__pos--silver,.ranking-row__pos--bronze{font-size:1.25rem}.ranking-row__user{align-items:center;gap:10px;display:flex}.ranking-row__avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;letter-spacing:.02em;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.625rem;font-weight:600;display:flex}.ranking-row__name{color:var(--color-text-primary);font-weight:500}.ranking-row__points{color:var(--color-accent);font-weight:700}@media (width<=600px){.ranking-table th,.ranking-table td{padding:10px 12px;font-size:.75rem}.ranking-row__avatar{width:28px;height:28px;font-size:.5625rem}}.admin-page{max-width:var(--content-max-width);animation:fadeIn .4s var(--ease-out)}.admin-page__title{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.5rem;font-weight:700}.admin__loading{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:.875rem}.admin-stats{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);grid-template-columns:repeat(3,1fr);display:grid}.admin-stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));flex-direction:column;gap:4px;display:flex}.admin-stat__value{color:var(--color-accent);font-size:1.75rem;font-weight:700;font-family:var(--font-display)}.admin-stat__label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.admin-tabs{gap:var(--spacing-xs);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-lg);display:flex}.admin-tab{color:var(--color-text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 14px;font-size:.875rem;font-weight:500}.admin-tab:hover{color:var(--color-text-primary)}.admin-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.admin-table{border-collapse:separate;border-spacing:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;overflow:hidden}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:12px 16px;font-size:.8125rem}.admin-table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;background:#ffffff05;font-size:.6875rem;font-weight:600}.admin-table tr:last-child td{border-bottom:none}.admin-user{align-items:center;gap:10px;display:flex}.admin-user__avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), #0091b3);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.625rem;font-weight:600;display:flex}.admin-user__name{color:var(--color-text-primary);font-weight:500}.admin-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-body);transition:all var(--transition-fast);background:#ffffff0a;outline:none;width:100%;padding:8px 12px;font-size:.8125rem}.admin-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.admin-input--num{max-width:100px}.admin-textarea{resize:vertical;font-family:var(--font-body)}.admin-form{gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);max-width:560px;padding:var(--spacing-lg);flex-direction:column;display:flex}.admin-field{flex-direction:column;gap:6px;display:flex}.admin-label{color:var(--color-text-primary);font-size:.8125rem;font-weight:500}.admin-checkbox{color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.8125rem;display:flex}.admin-checkbox input{width:16px;height:16px;accent-color:var(--color-accent)}.admin-btn{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);border:none;align-self:flex-start;padding:10px 18px;font-size:.8125rem;font-weight:600}.admin-btn:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--glow-accent)}.admin-btn:disabled{opacity:.45;cursor:not-allowed}.admin-btn--sm{padding:6px 12px;font-size:.75rem}.admin-btn--danger{background:var(--color-danger);color:#fff}.admin-btn--danger:hover:not(:disabled){box-shadow:none;background:#d83b33}.admin-result{color:var(--color-accent);font-size:.8125rem}.admin-comments{gap:var(--spacing-sm);flex-direction:column;display:flex}.admin-comment{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex}.admin-comment__head{align-items:baseline;gap:10px;margin-bottom:4px;display:flex}.admin-comment__head strong{color:var(--color-text-primary);font-size:.8125rem}.admin-comment__meta{color:var(--color-text-muted);font-size:.6875rem}.admin-comment__text{color:var(--color-text-secondary);font-size:.8125rem;line-height:1.5}@media (width<=600px){.admin-stats{grid-template-columns:1fr}.admin-table th,.admin-table td{padding:10px 12px}}:root{--color-bg:#020206;--color-bg-elevated:#0b0d19;--color-surface:#0b0d19cc;--color-surface-solid:#0b0d19;--color-surface-hover:#111426e6;--color-sidebar:#0b0d19;--color-accent:#00b7df;--color-accent-hover:#009ebd;--color-accent-subtle:#00b7df1f;--color-accent-glow:#00b7df40;--color-secondary:#defd5f;--color-secondary-hover:#cbe654;--color-secondary-subtle:#defd5f1f;--color-secondary-glow:#defd5f40;--color-text-primary:#fff;--color-text-secondary:#9b9b9c;--color-text-muted:#788899;--color-border:#ffffff0f;--color-border-hover:#ffffff1f;--color-border-accent:#00b7df4d;--color-danger:#f85149;--color-success:#3fb950;--color-warning:#d29922;--color-overlay:#0009;--font-display:"Epilogue", system-ui, -apple-system, sans-serif;--font-body:"Roboto", system-ui, -apple-system, sans-serif;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--spacing-2xs:4px;--spacing-xs:8px;--spacing-sm:12px;--spacing-md:20px;--spacing-lg:32px;--spacing-xl:48px;--spacing-2xl:64px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 48px #0009;--glow-accent:0 4px 24px #00b7e026;--glow-accent-strong:0 4px 30px #00b7e04d;--glow-accent-card:0 0 40px #00b7e01a;--sidebar-width:260px;--topbar-height:60px;--content-max-width:1200px;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-base:.25s;--duration-slow:.4s;--transition-fast:var(--duration-fast) var(--ease-out);--transition-base:var(--duration-base) var(--ease-in-out);--transition-smooth:var(--duration-slow) var(--ease-in-out);--glass-bg:#0f1e37a6;--glass-border:#ffffff14;--glass-blur:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-body);color:var(--color-text-secondary);background-color:var(--color-bg);min-height:100vh;font-weight:400;line-height:1.6;overflow-x:hidden}#root{min-height:100vh}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text-primary);letter-spacing:-.01em;font-weight:600;line-height:1.3}h1{font-size:clamp(1.625rem,3.5vw,2.25rem);font-weight:700}h2{font-size:clamp(1.375rem,2.5vw,1.75rem);font-weight:700}h3{font-size:1.125rem;font-weight:600}h4{font-size:1rem;font-weight:600}h5{font-size:.9375rem;font-weight:500}h6{text-transform:uppercase;letter-spacing:.04em;font-size:.875rem;font-weight:500}p{max-width:68ch;color:var(--color-text-secondary)}small{color:var(--color-text-muted);font-size:.8125rem}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn{font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;line-height:1.4;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--color-accent);color:var(--color-bg)}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:var(--glow-accent);transform:translateY(-1px)}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--color-border-hover);background:0 0}.btn-secondary:hover{border-color:var(--color-accent);background:var(--color-accent-subtle);box-shadow:var(--glow-accent)}.btn-ghost{color:var(--color-text-secondary);background:0 0;padding:8px 14px}.btn-ghost:hover{color:var(--color-text-primary);background:#ffffff0a}.btn-danger{background:var(--color-danger);color:var(--color-text-primary)}.btn-danger:hover{background:#e04440;box-shadow:0 4px 20px #f8514940}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-lg{padding:14px 28px;font-size:.9375rem}.btn-block{width:100%}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}.btn:active:not(:disabled){transform:translateY(0)scale(.98)}.input,input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],textarea,select{font-family:var(--font-family);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);background:#ffffff0a;outline:none;padding:10px 14px;font-size:.875rem}.input:hover,input:hover,textarea:hover,select:hover{border-color:var(--color-border-hover);background:#ffffff0f}.input:focus,input:focus,textarea:focus,select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle);background:#ffffff0f}.input::placeholder,input::placeholder,textarea::placeholder{color:var(--color-text-muted)}label{color:var(--color-text-primary);margin-bottom:6px;font-size:.8125rem;font-weight:500;display:block}.form-group{margin-bottom:var(--spacing-md)}.card{background:var(--color-surface-solid);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base)}.card:hover{border-color:var(--color-border-hover)}.card-interactive:hover{border-color:var(--color-border-accent);box-shadow:var(--glow-accent-card);transform:translateY(-2px)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase;align-items:center;padding:3px 10px;font-size:.6875rem;font-weight:600;line-height:1;display:inline-flex}.badge-accent{background:var(--color-accent-subtle);color:var(--color-accent)}.badge-success{color:var(--color-success);background:#3fb95026}.badge-warning{color:var(--color-warning);background:#d2992226}.badge-count{background:var(--color-danger);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.6875rem;display:inline-flex}.text-center{text-align:center}.text-right{text-align:right}.text-accent{color:var(--color-accent)}.text-primary,.text-white{color:var(--color-text-primary)}.text-muted{color:var(--color-text-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.w-full{width:100%}.h-full{height:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}*{scrollbar-width:thin;scrollbar-color:#ffffff14 transparent}.spinner{border:3px solid #ffffff14;border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.spinner-sm{border-width:2px;width:18px;height:18px}.loading-screen{justify-content:center;align-items:center;gap:var(--spacing-md);flex-direction:column;min-height:60vh;display:flex}.loading-screen .spinner{width:44px;height:44px}.loading-screen p{color:var(--color-text-muted);font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #00b7e026}50%{box-shadow:0 0 0 8px #00b7e000}}.page-header{margin-bottom:var(--spacing-lg);animation:fadeIn .4s var(--ease-out)}.page-header h1,.page-header h2{margin-bottom:var(--spacing-xs)}.page-header p{color:var(--color-text-secondary);font-size:.875rem}.skeleton{background:linear-gradient(90deg, var(--color-surface-solid) 25%, #1e375acc 50%, var(--color-surface-solid) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.toast{background:var(--color-surface-solid);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);z-index:10000;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(var(--glass-blur));animation:slideUp .3s var(--ease-out);padding:12px 20px;font-size:.8125rem;position:fixed;bottom:24px;right:24px}.toast-success{border:1px solid var(--color-success);background:#3fb95014}.toast-error{border:1px solid var(--color-danger);background:#f8514914}.empty-state{padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;color:var(--color-text-secondary);animation:fadeIn .5s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--spacing-md);opacity:.35;font-size:3rem}.empty-state h3{color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}@media (width<=1024px){:root{--spacing-lg:24px;--spacing-xl:36px}}@media (width<=768px){:root{--spacing-lg:20px;--spacing-xl:32px;--spacing-2xl:48px}h1{font-size:1.375rem}h2{font-size:1.25rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (width<=480px){:root{--spacing-md:16px;--spacing-lg:16px}}
