.header{background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(128,128,128,.15);position:sticky;top:0;z-index:100}.header-container{max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;justify-content:space-between;align-items:center}.header-logo{text-decoration:none;color:var(--text)}.header-left{display:flex;align-items:center;gap:16px}.header-burger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;transition:var(--transition)}.header-burger:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.header-burger-icon{font-size:1.35rem;line-height:1}.logo-text{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;gap:8px;align-items:center;position:relative;flex-wrap:nowrap}.nav-link{color:var(--text);text-decoration:none;padding:8px 14px;border-radius:var(--radius-sm);font-weight:500;transition:var(--transition)}.nav-link:hover{background:var(--accent-soft);color:var(--accent)}.nav-dropdown{position:relative}.nav-dropdown-trigger{display:flex;align-items:center;gap:4px;padding:8px 14px;background:transparent;border:none;color:var(--text);font-size:1rem;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.nav-dropdown-trigger:hover{background:var(--accent-soft);color:var(--accent)}.dropdown-arrow{font-size:.7rem;opacity:.8}.nav-dropdown-menu{position:absolute;top:100%;left:0;margin:4px 0 0;padding:8px 0;min-width:180px;background:var(--bg-card);border:1px solid rgba(128,128,128,.15);border-radius:var(--radius);box-shadow:var(--shadow);list-style:none}.nav-dropdown-menu li a{display:block;padding:10px 16px;color:var(--text);text-decoration:none;font-weight:500;transition:var(--transition)}.nav-dropdown-menu li a:hover{background:var(--accent-soft);color:var(--accent)}.theme-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.15);border-radius:var(--radius-sm);cursor:pointer;font-size:1.2rem;transition:var(--transition);margin-left:4px}.theme-toggle:hover{background:var(--accent-soft);border-color:var(--accent)}.btn-register{padding:8px 18px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-weight:600;text-decoration:none;transition:var(--transition)}.btn-register:hover{background:var(--accent-hover)}.btn-logout{background:transparent;border:1px solid var(--text-muted);color:var(--text);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:var(--transition)}.btn-logout:hover{border-color:var(--error);color:var(--error)}@media (max-width: 768px){.header-container{padding:10px 12px;gap:8px;flex-wrap:nowrap}.header-left{flex-shrink:0;gap:8px}.header-nav{flex-shrink:0;flex-wrap:nowrap;gap:4px}.header-home{display:none}.nav-dropdown-trigger,.nav-link{padding:6px 8px;font-size:.8rem}.logo-text{font-size:1.05rem}.header-burger-icon{font-size:1.2rem}.theme-toggle{width:36px;height:36px;min-width:36px;font-size:1rem}.btn-logout{padding:6px 10px;font-size:.8rem;white-space:nowrap}.btn-register{padding:6px 12px;font-size:.85rem}}@media (max-width: 480px){.nav-link.nav-cabinet{padding:6px;font-size:.75rem}.btn-logout{padding:6px 8px;font-size:.75rem}}.footer{background:var(--bg-card);border-top:1px solid rgba(255,255,255,.06);margin-top:auto;padding:32px 20px;min-height:96px;box-sizing:border-box}.footer-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}.footer-copyright{color:var(--text-muted);font-size:.9rem;margin:0}.footer-privacy-link{color:var(--text-muted);text-decoration:none}.footer-privacy-link:hover{color:var(--accent);text-decoration:underline}.footer-contacts{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}.footer-contact{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text);text-decoration:none;font-weight:500;font-size:.95rem;transition:var(--transition);border:1px solid rgba(128,128,128,.15)}.footer-contact:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.footer-contact-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--accent)}.footer-contact:nth-child(2) .footer-contact-icon{color:#08c}.footer-contact:nth-child(3) .footer-contact-icon{color:#25d366}.footer-contact:hover .footer-contact-icon{color:inherit}@media (max-width: 768px){.footer{padding:24px 16px}.footer-container{flex-direction:column;text-align:center;gap:16px}.footer-contacts{flex-wrap:nowrap;justify-content:center;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.footer-contact{padding:8px 12px;font-size:.9rem;flex-shrink:0}}@media (max-width: 480px){.footer-contact{padding:8px 10px;font-size:.85rem}.footer-copyright{font-size:.8rem}}.review-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px;animation:reviewModalFadeIn .2s ease-out}@keyframes reviewModalFadeIn{0%{opacity:0}to{opacity:1}}.review-modal{background:var(--bg-card);border-radius:var(--radius-md, 12px);max-width:440px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000040;position:relative;animation:reviewModalSlideIn .25s ease-out}@keyframes reviewModalSlideIn{0%{opacity:0;transform:scale(.96) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.review-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;background:var(--bg-elevated);color:var(--text-muted);font-size:1.5rem;line-height:1;border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,background .15s}.review-modal-close:hover{color:var(--text);background:#80808033}.review-modal-title{margin:0 0 20px;padding:24px 24px 0;font-size:1.35rem;color:var(--text)}.review-modal-form{padding:0 24px 24px}.review-modal-user{margin:0 0 16px;font-size:.95rem;color:var(--text-muted)}.review-modal-label{font-weight:600;color:var(--text);font-size:.9rem}.review-modal-field{margin-bottom:16px}.review-modal-field .review-modal-label{display:block;margin-bottom:6px}.review-modal-stars{display:flex;gap:4px;margin-top:4px}.review-modal-star{width:40px;height:40px;border:none;background:var(--bg-elevated);color:var(--text-muted);font-size:1.6rem;line-height:1;border-radius:var(--radius-sm);cursor:pointer;transition:transform .15s,color .15s,background .15s}.review-modal-star:hover{transform:scale(1.1);color:#fbbf24;background:#fbbf2426}.review-modal-star.active{color:#fbbf24;background:#fbbf2433}.review-modal-input,.review-modal-textarea{width:100%;padding:10px 12px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;box-sizing:border-box}.review-modal-input:focus,.review-modal-textarea:focus{outline:none;border-color:var(--accent)}.review-modal-textarea{resize:vertical;min-height:100px}.review-modal-hint{display:block;font-size:.8rem;color:var(--text-muted);margin-top:4px}.review-modal-error{color:var(--error, #ef4444);font-size:.9rem;margin:0 0 12px}.review-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.review-modal-btn{padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;cursor:pointer;transition:opacity .15s,background .15s;border:none}.review-modal-btn-cancel{background:var(--bg-elevated);color:var(--text-muted)}.review-modal-btn-cancel:hover{background:#80808033;color:var(--text)}.review-modal-btn-submit{background:var(--accent);color:#fff}.review-modal-btn-submit:hover:not(:disabled){opacity:.95}.review-modal-btn-submit:disabled{opacity:.5;cursor:not-allowed}.question-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px;animation:questionModalFadeIn .2s ease-out}@keyframes questionModalFadeIn{0%{opacity:0}to{opacity:1}}.question-modal{background:var(--bg-card);border-radius:var(--radius-md, 12px);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000040;position:relative;animation:questionModalSlideIn .25s ease-out}@keyframes questionModalSlideIn{0%{opacity:0;transform:scale(.96) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.question-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;background:var(--bg-elevated);color:var(--text-muted);font-size:1.5rem;line-height:1;border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,background .15s}.question-modal-close:hover{color:var(--text);background:#80808033}.question-modal-title{margin:0 0 8px;padding:24px 24px 0;font-size:1.35rem;color:var(--text)}.question-modal-desc{margin:0 0 20px;padding:0 24px;font-size:.95rem;color:var(--text-muted)}.question-modal-form{padding:0 24px 24px}.question-modal-field{margin-bottom:16px}.question-modal-label{display:block;font-weight:600;color:var(--text);font-size:.9rem;margin-bottom:6px}.question-modal-email{margin:0;padding:10px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.95rem}.question-modal-textarea{width:100%;padding:10px 12px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;box-sizing:border-box;resize:vertical;min-height:120px}.question-modal-textarea:focus{outline:none;border-color:var(--accent)}.question-modal-hint{display:block;font-size:.8rem;color:var(--text-muted);margin-top:4px}.question-modal-error{color:var(--error, #ef4444);font-size:.9rem;margin:0 0 12px}.question-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.question-modal-btn{padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;cursor:pointer;transition:opacity .15s,background .15s;border:none}.question-modal-btn-cancel{background:var(--bg-elevated);color:var(--text-muted)}.question-modal-btn-cancel:hover{background:#80808033;color:var(--text)}.question-modal-btn-submit{background:var(--accent);color:#fff}.question-modal-btn-submit:hover:not(:disabled){opacity:.95}.question-modal-btn-submit:disabled{opacity:.5;cursor:not-allowed}.sidebar{width:260px;flex-shrink:0;background:var(--bg-card);border-right:1px solid rgba(128,128,128,.12);padding:20px 0;overflow-y:auto}.sidebar-search{padding:0 14px 16px}.sidebar-search-form{display:flex;flex-direction:column;gap:8px}.sidebar-search-input{padding:10px 12px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem}.sidebar-search-input::placeholder{color:var(--text-muted)}.sidebar-search-input:focus{outline:none;border-color:var(--accent)}.sidebar-buttons{display:flex;flex-direction:column;gap:8px;padding:0 14px 16px}.sidebar-btn{display:block;width:100%;padding:12px 16px;border-radius:var(--radius-sm);font-weight:600;text-align:center;font-size:.95rem;cursor:pointer;transition:var(--transition);border:1px solid rgba(128,128,128,.2);background:var(--bg-elevated);color:var(--text);text-decoration:none;box-sizing:border-box}.sidebar-btn:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.sidebar-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-btn-selected{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.sidebar-btn-selected:hover{background:var(--accent-soft);color:var(--accent)}.sidebar-btn-variant{background:linear-gradient(135deg,var(--warm),#fbbf24);border-color:transparent;color:#fff}.sidebar-btn-variant:hover:not(:disabled){opacity:.95;background:linear-gradient(135deg,var(--warm),#fbbf24);color:#fff;border-color:transparent}.sidebar-search-btn{margin:0}.sidebar-search-results{margin:0 14px 16px;padding:12px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid rgba(128,128,128,.15);position:relative;max-height:280px;overflow-y:auto}.sidebar-search-close{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;line-height:1}.sidebar-search-close:hover{color:var(--text)}.sidebar-search-empty{font-size:.9rem;color:var(--text-muted);margin:0}.sidebar-search-block{margin-bottom:10px}.sidebar-search-block:last-child{margin-bottom:0}.sidebar-search-block-title{display:block;font-size:.75rem;font-weight:600;color:var(--accent);margin-bottom:6px}.sidebar-search-block ul{list-style:none;margin:0;padding:0}.sidebar-search-block li{margin-bottom:4px}.sidebar-search-block a{font-size:.9rem;color:var(--text);text-decoration:none}.sidebar-search-block a:hover{color:var(--accent)}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-muted);text-decoration:none;border-radius:var(--radius-sm);transition:var(--transition);font-weight:500;border:none;background:none;width:100%;text-align:left;font-size:1rem;cursor:pointer;box-sizing:border-box}a.sidebar-item{cursor:pointer}button.sidebar-item{cursor:pointer;font-family:inherit}.sidebar-item:hover{background:var(--accent-soft);color:var(--text)}.sidebar-item.active{background:var(--accent-soft);color:var(--accent)}.sidebar-item-logout{width:100%;text-align:left;margin-top:4px}.sidebar-item-logout:hover{background:#ef44441f;color:var(--error)}.sidebar-icon{font-size:1.25rem}.sidebar-divider{height:1px;background:#80808026;margin:8px 0}.sidebar-dropdown,.sidebar-dropdown-trigger{position:relative}.sidebar-dropdown-trigger .sidebar-dropdown-arrow{margin-left:auto;font-size:.7rem;opacity:.8;transition:transform var(--transition)}.sidebar-dropdown-trigger.open .sidebar-dropdown-arrow{transform:rotate(180deg)}.sidebar-dropdown-menu{list-style:none;margin:2px 0 0;padding:4px 0;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid rgba(128,128,128,.15)}.sidebar-dropdown-menu li{margin:0}.sidebar-dropdown-menu .sidebar-item{padding:10px 16px 10px 44px}@media (max-width: 768px){.sidebar{width:100%;min-height:auto;position:relative;max-height:none;padding:12px 0}.sidebar-search-input,.sidebar-btn,.sidebar-item{font-size:.875rem}.sidebar-btn{padding:10px 14px}.sidebar-item{padding:10px 14px;gap:10px}.sidebar-icon{font-size:1.1rem}.sidebar-buttons{flex-direction:column;gap:8px;padding:0 14px 12px}.sidebar-nav{flex-direction:column;overflow-x:visible;gap:2px;padding:0 12px}.sidebar-item{white-space:normal}.sidebar-divider{display:block}.sidebar-dropdown-menu{position:static;left:auto;right:auto;top:auto;z-index:20}}.variant-banner{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 16px;background:var(--warm-soft);border-top:1px solid rgba(245,158,11,.3);flex-wrap:wrap;z-index:90}.variant-banner-text{color:var(--text);font-size:.9rem}.variant-banner-link{color:var(--warm);font-weight:600;text-decoration:none}.variant-banner-link:hover{text-decoration:underline}.variant-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:14px 24px;background:var(--bg-card);border:1px solid var(--warm);border-radius:var(--radius);color:var(--text);font-weight:500;box-shadow:var(--shadow);z-index:1000;animation:variant-toast-in .3s ease}@keyframes variant-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.variant-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:20px}.variant-modal{background:var(--bg-card);padding:28px;border-radius:var(--radius);max-width:400px;width:100%;border:1px solid rgba(128,128,128,.2);box-shadow:var(--shadow)}.variant-modal h2{margin-bottom:16px;font-size:1.35rem}.variant-modal p{color:var(--text-muted);margin-bottom:20px}.variant-modal-result{color:var(--text)!important;font-size:1.1rem;font-weight:600}.variant-modal-close{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer}.variant-modal-close:hover{background:var(--accent-hover)}.layout{min-height:100vh;display:flex;flex-direction:column;position:relative}.layout-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background-color:var(--bg);background-image:linear-gradient(160deg,var(--bg) 0%,var(--bg-elevated) 40%,var(--bg) 100%),radial-gradient(circle at 20% 80%,rgba(99,102,241,.06) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(245,158,11,.04) 0%,transparent 45%);pointer-events:none}.layout-inner{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}body.variant-banner-visible .layout-inner{padding-bottom:52px}.layout-content{display:flex;flex:1;position:relative}.main-content{flex:1;padding:20px;width:100%;min-width:0;background:var(--bg);color:var(--text)}.main-content-full{max-width:1200px;margin:0 auto}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199;border:none;cursor:pointer;padding:0;animation:layout-fade-in .2s ease}.sidebar-drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:90vw;background:var(--bg);border-right:1px solid var(--border);z-index:200;display:flex;flex-direction:column;box-shadow:4px 0 24px #00000026;animation:layout-drawer-in .25s ease}.sidebar-drawer-close{position:absolute;top:12px;right:12px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1.4rem;cursor:pointer;z-index:2;transition:var(--transition)}.sidebar-drawer-close:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.sidebar-drawer-inner{flex:1;overflow-y:auto;padding:56px 16px 16px}.sidebar-drawer-inner .sidebar{position:static;max-height:none;width:100%}@keyframes layout-fade-in{0%{opacity:0}to{opacity:1}}@keyframes layout-drawer-in{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (max-width: 768px){.main-content,.main-content-full{padding:14px 12px}}@media (max-width: 480px){.main-content,.main-content-full{padding:12px 10px}}@keyframes landingFadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes landingFadeIn{0%{opacity:0}to{opacity:1}}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-15px) scale(1.05)}66%{transform:translate(-10px,10px) scale(.98)}}@keyframes landingScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes landingShine{to{background-position:200% center}}.landing{position:relative;padding:0 20px 64px;min-height:60vh;overflow-x:hidden}.landing-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:blobFloat 18s ease-in-out infinite}.blob-1{width:420px;height:420px;background:var(--blob-color);top:-120px;right:-100px;animation-delay:0s}.blob-2{width:320px;height:320px;background:var(--blob-color);bottom:15%;left:-100px;animation-delay:-6s}.blob-3{width:280px;height:280px;background:var(--blob-color);bottom:-60px;right:15%;animation-delay:-12s}.landing-hero{position:relative;text-align:center;padding:56px 20px 52px;max-width:800px;margin:0 auto;animation:landingFadeInUp .7s ease-out}.hero-badge{display:inline-block;font-size:.85rem;font-weight:600;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:20px;padding:8px 16px;background:var(--accent-soft);border-radius:999px;animation:landingFadeInUp .6s ease-out .1s both}.hero-title{font-size:clamp(2rem,5vw,3rem);font-weight:800;line-height:1.15;letter-spacing:-.03em;color:var(--text);margin:0 0 20px;animation:landingFadeInUp .6s ease-out .15s both}.hero-lead{font-size:clamp(1.05rem,2vw,1.2rem);color:var(--text-muted);line-height:1.65;max-width:560px;margin:0 auto 32px;animation:landingFadeInUp .6s ease-out .25s both}.hero-cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;animation:landingFadeInUp .6s ease-out .35s both}.landing-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;border-radius:var(--radius-sm);font-weight:700;font-size:1rem;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease;cursor:pointer}.landing-btn-primary{background:linear-gradient(135deg,var(--accent),#818cf8);color:#fff;border:none;box-shadow:0 4px 20px #6366f159}.landing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px #6366f166;color:#fff}.landing-btn-secondary{background:var(--bg-elevated);color:var(--text);border:2px solid rgba(128,128,128,.25)}.landing-btn-secondary:hover{transform:translateY(-2px);border-color:var(--accent);color:var(--accent);box-shadow:0 4px 16px #0000001a}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;max-width:1000px;margin:0 auto 48px;padding:0 8px}.feature-item{text-align:center;padding:24px 16px;background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(128,128,128,.12);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;animation:landingFadeInUp .6s ease-out both}.feature-item:nth-child(1){animation-delay:.1s}.feature-item:nth-child(2){animation-delay:.2s}.feature-item:nth-child(3){animation-delay:.3s}.feature-item:nth-child(4){animation-delay:.4s}.feature-item:hover{transform:translateY(-4px);border-color:#6366f14d;box-shadow:0 12px 32px #00000026}.feature-icon{font-size:2rem;display:block;margin-bottom:12px}.feature-item h3{font-size:1rem;font-weight:700;color:var(--text);margin:0 0 8px}.feature-item p{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin:0}.landing-divider{height:4px;margin:0;background:linear-gradient(90deg,transparent,rgba(128,128,128,.2),transparent)}.landing-divider-accent{background:linear-gradient(90deg,transparent,var(--accent-soft),var(--warm-soft),transparent);height:6px}.landing-section{animation:landingFadeInUp .6s ease-out both}.block-about{max-width:720px;margin:0 auto;padding:48px 0 40px;text-align:center;animation-delay:.08s}.block-reviews{animation-delay:.16s}.block-about .section-title{animation-delay:.05s}.about-text{font-size:1.05rem;color:var(--text-muted);line-height:1.75;margin:0 0 16px}.about-text:last-child{margin-bottom:0}.section-title{font-size:clamp(1.5rem,3vw,1.85rem);font-weight:700;margin-bottom:28px;text-align:center;color:var(--text)}.section-title:after{content:"";display:block;width:56px;height:4px;background:linear-gradient(90deg,var(--accent),var(--warm));margin:14px auto 0;border-radius:2px}.block-subjects{padding:48px 20px 44px;animation-delay:.12s}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1000px;margin:0 auto}.subject-card{padding:32px 28px;border-radius:var(--radius);border:2px solid rgba(128,128,128,.15);transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden;animation:landingScaleIn .5s ease-out both}.subject-card:nth-child(1){animation-delay:.1s}.subject-card:nth-child(2){animation-delay:.2s}.subject-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.03) 100%);pointer-events:none;opacity:0;transition:opacity .3s ease}.subject-card:hover{transform:translateY(-6px)}.subject-card:hover:before{opacity:1}.subject-card-math{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.08) 100%);border-color:#6366f140}.subject-card-math:hover{border-color:var(--accent);box-shadow:0 12px 32px #6366f133}.subject-card-phys{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(139,92,246,.08) 100%);border-color:#8b5cf640}.subject-card-phys:hover{border-color:#8b5cf6;box-shadow:0 12px 32px #8b5cf633}.subject-card-icon{font-size:2rem;display:block;margin-bottom:16px}.subject-card h3{font-size:1.35rem;margin-bottom:12px;color:var(--text)}.subject-card p{color:var(--text-muted);margin:0;line-height:1.6}.block-reviews{background:linear-gradient(180deg,transparent 0%,rgba(245,158,11,.04) 50%,transparent 100%);border-radius:var(--radius);margin:0 -20px;padding:48px 20px 64px}.reviews-loading,.reviews-empty{text-align:center;color:var(--text-muted);max-width:480px;margin:0 auto;line-height:1.6}.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1000px;margin:0 auto}.review-card{background:var(--bg-card);padding:26px;border-radius:var(--radius);border:1px solid rgba(128,128,128,.12);border-left:4px solid var(--accent);transition:transform .25s ease,border-left-color .25s ease,box-shadow .25s ease;animation:landingFadeInUp .5s ease-out both}.review-card:hover{transform:translateY(-3px);border-left-color:var(--warm);box-shadow:var(--shadow)}.review-rating{color:var(--warm);font-size:1rem;margin-bottom:10px;letter-spacing:2px}.review-text{color:var(--text);margin:0 0 12px;font-style:italic;line-height:1.65}.review-author{font-size:.9rem;color:var(--text-muted)}@media (max-width: 768px){.landing-hero{padding:40px 16px}.hero-title{font-size:clamp(1.4rem,4vw,2.25rem);margin-bottom:16px}.hero-lead{font-size:.95rem;margin-bottom:24px}.hero-cta{flex-direction:column}.landing-btn{width:100%;max-width:280px}.landing-features{grid-template-columns:1fr;margin-bottom:36px}.landing-feature-item h3{font-size:1.1rem}.landing-feature-item p{font-size:.9rem}.block-about,.block-reviews{margin-left:0;margin-right:0}}@media (max-width: 480px){.landing{padding:0 14px 48px}.landing-hero{padding:32px 12px}.hero-title{font-size:1.35rem}.hero-lead{font-size:.9rem}.hero-badge{font-size:.75rem;padding:6px 12px}}.login-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.login-card{background:var(--bg-card);padding:40px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);max-width:400px;width:100%}.login-card h1{margin-bottom:24px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-muted);font-weight:500}.form-group input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.login-success{color:var(--success, #22c55e);margin-bottom:16px;padding:12px;background:#22c55e1a;border-radius:var(--radius-sm)}.error{color:var(--error);margin-bottom:16px;padding:12px;background:#ef44441a;border-radius:var(--radius-sm)}.login-card .btn{display:inline-block;width:100%;padding:12px 20px;font-size:1rem;font-weight:600;font-family:inherit;text-align:center;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition),transform .1s ease}.login-card .btn:active{transform:scale(.98)}.login-card .btn-primary{background:var(--accent);color:#fff;margin-top:8px}.login-card .btn-primary:hover:not(:disabled){background:var(--accent-hover)}.login-card .btn-primary:disabled{opacity:.7;cursor:not-allowed}.form-footer{margin-top:20px;text-align:center;color:var(--text-muted)}.form-footer a{color:var(--accent);text-decoration:none}.form-footer a:hover{text-decoration:underline}.register-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.register-card{background:var(--bg-card);padding:40px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);max-width:400px;width:100%}.register-card h1{margin-bottom:24px;text-align:center}.register-card .form-group{margin-bottom:20px}.register-card .form-group label{display:block;margin-bottom:8px;color:var(--text-muted);font-weight:500}.register-card .form-group input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.register-card .form-group input:focus{outline:none;border-color:var(--accent)}.register-card .error{color:var(--error);margin-bottom:16px;padding:12px;background:#ef44441a;border-radius:var(--radius-sm)}.register-card .form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.register-card .form-actions .btn-primary{flex:1;min-width:140px}.register-card .form-actions .btn-secondary{flex:0 0 auto}.register-card .btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;font-size:1rem;font-weight:600;font-family:inherit;text-align:center;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition),border-color var(--transition),color var(--transition),transform .1s ease;text-decoration:none}.register-card .btn:active{transform:scale(.98)}.register-card .btn-primary{background:var(--accent);color:#fff;border:none}.register-card .btn-primary:hover:not(:disabled){background:var(--accent-hover)}.register-card .btn-primary:disabled{opacity:.7;cursor:not-allowed}.register-card .btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text)}.register-card .btn-secondary:hover{border-color:var(--text-muted);background:var(--bg-elevated)}.register-card .form-footer{margin-top:20px;text-align:center;color:var(--text-muted)}.register-card .form-footer a{color:var(--accent);text-decoration:none;font-weight:500}.register-card .form-footer a:hover{text-decoration:underline}.cabinet{max-width:1000px;margin:0 auto}.cabinet-loading,.cabinet-error{text-align:center;padding:40px;color:var(--text-muted)}.cabinet-error{color:var(--error)}.cabinet-profile,.cabinet-statistics{background:var(--bg-card);padding:32px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);margin-bottom:24px}.cabinet-profile h2,.cabinet-statistics h2{margin-bottom:20px}.cabinet .learning-stats{margin-bottom:40px}.cabinet .learning-section{margin-bottom:48px}.cabinet-stats-panel{margin-bottom:32px}.cabinet-stats-panel-toggle{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;text-align:left;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1.05rem;font-weight:600;cursor:pointer;transition:var(--transition)}.cabinet-stats-panel-toggle:hover{border-color:var(--accent);background:var(--bg-elevated)}.cabinet-stats-panel-title{flex:1}.cabinet-stats-panel-badge{font-size:.9rem;font-weight:500;color:var(--text-muted)}.cabinet-stats-panel-arrow{color:var(--text-muted);font-size:.75rem}.cabinet-stats-panel-content{margin-top:12px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.cabinet-stats-empty{color:var(--text-muted);margin:0}.cabinet-stats-error{color:var(--error, #ef4444);margin:0}.cabinet-attempts-summary{display:flex;flex-wrap:wrap;gap:16px 24px;margin-bottom:16px;font-size:.95rem}.cabinet-attempts-summary strong{color:var(--accent)}.cabinet-attempts-table-wrap{overflow-x:auto;margin-top:8px}.cabinet-attempts-table{width:100%;border-collapse:collapse;font-size:.9rem}.cabinet-attempts-table th,.cabinet-attempts-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.cabinet-attempts-table th{font-weight:600;color:var(--text-muted);background:var(--bg-elevated);white-space:nowrap}.cabinet-attempts-table tbody tr:hover{background:#ffffff05}.cabinet-attempt-code-link,.cabinet-attempt-open-link{color:var(--accent);text-decoration:none}.cabinet-attempt-code-link:hover,.cabinet-attempt-open-link:hover{text-decoration:underline}.cabinet-payments .cabinet-payments-desc,.cabinet-payments .cabinet-payments-empty{color:var(--text-muted);margin-bottom:12px}.cabinet-subscription-active{color:var(--success, #22c55e);font-weight:600;margin-bottom:12px}.btn-cabinet-subscription{display:inline-block;margin-bottom:16px;padding:10px 20px;background:var(--warm);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-cabinet-subscription:hover{background:#d97706;color:#fff}.payments-table-wrap{overflow-x:auto;margin-top:12px}.payments-table{width:100%;border-collapse:collapse;font-size:.9rem}.payments-table th,.payments-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.payments-table th{color:var(--text-muted);font-weight:600}.payment-status{font-weight:500}.payment-status-paid{color:var(--success, #22c55e)}.payment-status-pending{color:var(--warm)}.payment-status-cancelled,.payment-status-failed{color:var(--text-muted)}.payment-status-refunded{color:var(--error, #ef4444)}.cabinet-admin-block{margin-bottom:20px;display:flex;flex-wrap:wrap;gap:12px}.cabinet-admin-block .btn-cabinet-teacher{flex:1;min-width:200px;text-align:center;padding:12px 16px}.btn-cabinet-teacher{display:inline-block;padding:10px 20px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-cabinet-teacher:hover{background:var(--accent-hover);color:#fff}.cabinet-stats-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.cabinet-stats-buttons .btn-cabinet-stats{flex:1;min-width:180px;text-align:center;padding:12px 16px}.btn-cabinet-stats{display:inline-block;padding:10px 20px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-cabinet-stats:hover{background:var(--accent-hover);color:#fff}@media (max-width: 768px){.cabinet{padding:0 14px}.cabinet-profile,.cabinet-statistics{padding:20px}.cabinet-profile h2,.cabinet-statistics h2{font-size:1.2rem}}@media (max-width: 480px){.cabinet{padding:0 12px}.cabinet-profile,.cabinet-statistics{padding:16px}}.learning{max-width:1200px;margin:0 auto;padding:20px}.learning-loading,.learning-error{text-align:center;padding:40px;color:var(--text-muted)}.learning-error{color:var(--error)}.learning h1{margin-bottom:8px}.learning-subtitle{color:var(--text-muted);font-size:1rem;margin:0 0 24px}.learning-continue-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:32px}.learning-continue-block h2{margin:0 0 12px;font-size:1.1rem}.learning-continue-hint{color:var(--text-muted);margin:0 0 12px;font-size:.95rem}.btn-continue-primary{display:inline-block;padding:12px 20px;background:var(--accent);color:#fff;border-radius:var(--radius);font-weight:600;text-decoration:none;transition:opacity .2s}.btn-continue-primary:hover{opacity:.9;color:#fff}.learning-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.stat-card h3{margin-bottom:16px;color:var(--accent)}.stat-numbers{display:flex;gap:24px}.stat-numbers>div{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:2rem;font-weight:700;color:var(--text)}.stat-label{font-size:.875rem;color:var(--text-muted);margin-top:4px}.learning-section{margin-bottom:48px}.learning-section h2{margin-bottom:24px;font-size:1.5rem}.progress-cards{display:grid;gap:20px}.learning-empty{color:var(--text-muted);margin:0}.progress-card{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);transition:var(--transition)}.progress-card:hover{border-color:var(--accent);transform:translateY(-2px)}.progress-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-card-header h3{margin:0;font-size:1.25rem}.progress-badge{background:var(--accent-soft);color:var(--accent);padding:4px 12px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.progress-bar-container{background:var(--bg-elevated);height:32px;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:12px;position:relative}.progress-bar{background:linear-gradient(90deg,var(--accent),var(--accent-hover));height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;transition:width .3s ease}.progress-info{color:var(--text-muted);margin-bottom:16px;font-size:.9rem}.btn-continue{display:inline-block;color:var(--accent);text-decoration:none;font-weight:500;transition:var(--transition)}.btn-continue:hover{color:var(--accent-hover)}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.subject-card-link{text-decoration:none}.subject-card{background:var(--bg-card);padding:32px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);transition:var(--transition);height:100%}.subject-card:hover{border-color:var(--accent);transform:translateY(-4px)}.subject-card h3{margin-bottom:12px;color:var(--text)}.subject-card p{color:var(--text-muted);margin:0}.my-stats-page{max-width:900px;margin:0 auto;padding:24px;min-height:60vh;background:var(--bg);color:var(--text)}.my-stats-loading,.my-stats-error{text-align:center;padding:40px;color:var(--text-muted);background:var(--bg);min-height:200px;display:flex;align-items:center;justify-content:center}.my-stats-error{color:var(--error, #ef4444)}.my-stats-header{margin-bottom:24px}.my-stats-back{display:inline-block;color:var(--accent);text-decoration:none;margin-bottom:12px}.my-stats-back:hover{text-decoration:underline}.my-stats-desc{color:var(--text-muted);margin-top:8px}.my-stats-tabs{display:flex;gap:8px;margin-bottom:16px}.my-stats-tab{padding:10px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);cursor:pointer;font-size:1rem;transition:var(--transition)}.my-stats-tab:hover{border-color:var(--accent)}.my-stats-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.my-stats-reset-wrap{margin-bottom:20px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.my-stats-reset-btn{padding:10px 18px;border:1px solid var(--error, #ef4444);border-radius:var(--radius);background:transparent;color:var(--error, #ef4444);cursor:pointer;font-size:.95rem}.my-stats-reset-btn:hover:not(:disabled){background:#ef444426}.my-stats-reset-btn:disabled{opacity:.6;cursor:not-allowed}.my-stats-reset-hint{font-size:.9rem;color:var(--text-muted)}.my-stats-summary{display:flex;flex-wrap:wrap;gap:16px 24px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;font-size:.95rem}.my-stats-summary strong{color:var(--accent)}.my-stats-empty{color:var(--text-muted);margin:0}.my-stats-cards{display:none;flex-direction:column;gap:12px;margin-top:16px}.my-stats-card{padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.my-stats-card-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.my-stats-card-num{color:var(--text-muted);font-weight:600}.my-stats-card-pct{margin-left:auto;font-weight:600;color:var(--accent)}.my-stats-card-meta{font-size:.9rem;color:var(--text-muted);margin-top:6px}.my-stats-card-date{font-size:.85rem;color:var(--text-muted);margin-top:6px;display:flex;flex-direction:column;gap:2px}.my-stats-card .my-stats-open-link{display:inline-block;margin-top:8px;font-size:.9rem}@media (max-width: 768px){.my-stats-cards{display:flex}.my-stats-table-wrap{display:none}.my-stats-page{padding:16px}}.my-stats-table-wrap{overflow-x:auto;margin-top:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}@media (min-width: 769px){.my-stats-table-wrap{overflow-x:visible}.my-stats-table{table-layout:fixed;width:100%}}.my-stats-table{width:100%;border-collapse:collapse;font-size:.9rem}.my-stats-table th,.my-stats-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border)}.my-stats-table th{font-weight:600;color:var(--text-muted);background:var(--bg-elevated);white-space:nowrap}.my-stats-date-time-cell{min-width:10rem;vertical-align:top}.my-stats-date-time-cell .my-stats-cell-line{display:block;line-height:1.35}.my-stats-date-time-cell .my-stats-cell-date{margin-bottom:2px}.my-stats-date-time-cell .my-stats-cell-duration{font-size:.9em;color:var(--text-muted)}.my-stats-table tbody tr:hover{background:#ffffff05}.my-stats-code-link,.my-stats-open-link{color:var(--accent);text-decoration:none}.my-stats-code-link:hover,.my-stats-open-link:hover{text-decoration:underline}.subjects-page{max-width:1200px;margin:0 auto;padding:20px}.subjects-loading,.subjects-error{text-align:center;padding:40px;color:var(--text-muted)}.subjects-error{color:var(--error)}.subjects-header{margin-bottom:32px}.subjects-header h1{margin-bottom:12px}.btn-variant-subject{display:inline-block;margin-top:16px;padding:12px 24px;background:var(--warm);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-variant-subject:hover{background:#d97706;transform:translateY(-2px)}.subject-description{color:var(--text-muted);font-size:1.125rem}.search-container{margin-bottom:32px}.search-input{width:100%;max-width:500px;padding:12px 16px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);color:var(--text);font-size:1rem}.search-input:focus{outline:none;border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.topic-card-link{text-decoration:none;color:inherit}.topic-card-link-button{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;font:inherit;color:inherit;padding:0}.topic-card{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);transition:var(--transition);height:100%;display:flex;flex-direction:column}.topic-card:hover{border-color:var(--accent);transform:translateY(-4px)}.topic-card-locked{position:relative;opacity:.92}.topic-card-locked-hint{margin-top:8px;font-size:.85rem;color:var(--warm);margin-bottom:0}.topic-card h3{margin-bottom:12px;color:var(--text);font-size:1.25rem}.topic-card-title-wrap{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.topic-card-lock-inline{font-size:1.15rem;flex-shrink:0}.topic-description{color:var(--text-muted);margin-bottom:16px;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.6;font-size:.95rem}.no-results{text-align:center;padding:60px 20px;color:var(--text-muted)}.no-results p{font-size:1.125rem}@media (max-width: 768px){.subjects-page{padding:14px}.subjects-header h1{font-size:1.35rem}.subject-description{font-size:.95rem}.btn-variant-subject{padding:10px 20px;font-size:.9rem}.search-input{padding:10px 14px;font-size:.95rem}.topics-grid{grid-template-columns:1fr;gap:16px}.topic-card{padding:18px}.topic-card h3{font-size:1.1rem}.topic-description{font-size:.9rem}}@media (max-width: 480px){.subjects-page{padding:12px}.subjects-header h1{font-size:1.2rem}.topic-card{padding:14px}}.topic-page{max-width:1000px;margin:0 auto;padding:20px}.topic-loading,.topic-error{text-align:center;padding:40px;color:var(--text-muted)}.topic-error{color:var(--error)}.topic-header{margin-bottom:40px}.topic-header h1{margin-bottom:12px}.topic-description{color:var(--text-muted);font-size:1.125rem;line-height:1.6}.topic-control-section{margin-bottom:40px;padding:24px;background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.topic-control-section h2{margin:0 0 8px;font-size:1.25rem}.topic-control-desc{margin:0 0 16px;color:var(--text-muted);font-size:.95rem}.topic-control-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.topic-control-count-label{display:flex;align-items:center;gap:8px;color:var(--text);font-size:.95rem}.topic-control-select{padding:8px 12px;background:var(--bg-elevated, #1e1e2e);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.btn-topic-control{padding:12px 24px;background:var(--warm);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-topic-control:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.btn-topic-control:disabled{opacity:.7;cursor:not-allowed}.topic-control-error{margin:12px 0 0;color:var(--error, #ef4444);font-size:.9rem}.subtopics-section h2{margin-bottom:24px;font-size:1.5rem}.subtopics-list{display:grid;gap:16px}.subtopic-card-link{text-decoration:none;color:inherit}.subtopic-card-link-button{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;font:inherit;color:inherit;padding:0}.subtopic-card{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);transition:var(--transition)}.subtopic-card:hover{border-color:var(--accent);transform:translate(4px)}.subtopic-card-locked{position:relative;opacity:.92}.subtopic-card-title-wrap{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.subtopic-card-lock-inline{font-size:1.15rem;flex-shrink:0}.subtopic-card-title{margin:0 0 12px;color:var(--text);font-size:1.125rem}.subtopic-description{color:var(--text-muted);margin-bottom:20px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.95rem;line-height:1.5}.subtopic-actions{display:flex;justify-content:center}.subtopic-btn{display:inline-block;padding:12px 28px;background:var(--accent-soft);color:var(--accent);font-weight:600;font-size:.95rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.08);transition:var(--transition)}.subtopic-card-link:hover .subtopic-btn{background:var(--accent);color:#fff;border-color:var(--accent)}.no-subtopics{text-align:center;padding:40px;color:var(--text-muted)}@media (max-width: 768px){.topic-page{padding:14px}.topic-header h1{font-size:1.35rem}.topic-description{font-size:.95rem}.topic-control-section{padding:18px}.topic-control-section h2{font-size:1.15rem}.topic-control-actions{flex-direction:column;align-items:flex-start;gap:12px}.btn-topic-control{padding:10px 20px;font-size:.9rem}.subtopics-section h2{font-size:1.25rem}.subtopic-card{padding:18px}.subtopic-card-title{font-size:1.05rem}.subtopic-description{font-size:.9rem}.subtopic-btn{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){.topic-page{padding:12px}.topic-header h1{font-size:1.2rem}.subtopic-card{padding:14px}}.video-player{margin:1rem 0;width:100%;max-width:800px}.video-player-wrap{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--bg-elevated, #1e1e28);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000040;border:1px solid rgba(255,255,255,.06)}.video-player-iframe,.video-player-native{position:absolute;top:0;left:0;width:100%;height:100%;border:none;display:block}.video-player-native{object-fit:contain}.video-player-fallback{max-width:100%}.video-player-link{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--accent, #6366f1);color:#fff;text-decoration:none;border-radius:10px;font-weight:500;transition:transform .2s,box-shadow .2s}.video-player-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166;color:#fff}.video-player-fallback-hint{margin:.5rem 0 0;font-size:.875rem;color:var(--text-secondary, rgba(255, 255, 255, .7))}.video-player-link-inline{color:var(--accent, #6366f1);text-decoration:none}.video-player-link-inline:hover{text-decoration:underline}.subtopic-page{max-width:1000px;margin:0 auto;padding:20px}.subtopic-loading,.subtopic-error{text-align:center;padding:40px;color:var(--text-muted)}.subtopic-error{color:var(--error)}.subtopic-header{margin-bottom:32px}.subtopic-header h1{margin-bottom:12px}.subtopic-section{margin-bottom:40px}.subtopic-section h2{margin-bottom:24px;font-size:1.5rem}.theory-content{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);margin-bottom:24px;line-height:1.8}.theory-content p{margin:0;color:var(--text)}.theory-video{margin-bottom:24px}.video-iframe,.video-direct{width:100%;aspect-ratio:16 / 9;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.theory-pdf,.theory-photo{margin-bottom:24px}.pdf-link{display:inline-block;padding:12px 24px;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);color:var(--accent);text-decoration:none;transition:var(--transition)}.pdf-link:hover{border-color:var(--accent);background:var(--accent-soft)}.theory-image{max-width:100%;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.course-action{margin:24px 0;text-align:center}.course-action-top{margin-bottom:32px}.btn-course{display:inline-block;padding:16px 32px;background:var(--warm);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-course:hover{background:#d97706;transform:translateY(-2px)}.tasks-section-body .tasks-list.tasks-list-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media (max-width: 560px){.tasks-section-body .tasks-list.tasks-list-grid{grid-template-columns:1fr}}.task-card-link{text-decoration:none}.task-card{background:var(--bg-card);padding:20px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);transition:var(--transition);height:100%;display:flex;flex-direction:column}.task-card:hover{border-color:var(--accent);transform:translate(4px)}.task-card-title{margin:0 0 8px;color:var(--text);font-size:1.125rem;font-weight:600;line-height:1.3}.task-card-desc{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.5;flex:1}.tasks-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 0;background:none;border:none;cursor:pointer;color:var(--text);font:inherit;text-align:left}.tasks-section-toggle:hover{color:var(--accent)}.tasks-section-toggle h2{margin:0;font-size:1.5rem}.tasks-section-chevron{font-size:.9rem;opacity:.7}.tasks-section-body{padding-top:8px}.tasks-section-collapsed .tasks-section-body{display:none}.no-tasks{text-align:center;padding:40px;color:var(--text-muted)}.subtopic-minitest-section{margin-top:32px;padding:24px;background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.subtopic-minitest-section h2{margin:0 0 8px;font-size:1.25rem}.subtopic-minitest-desc{margin:0 0 16px;color:var(--text-muted);font-size:.95rem}.subtopic-minitest-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.subtopic-minitest-count-label{display:flex;align-items:center;gap:8px;color:var(--text);font-size:.95rem}.subtopic-minitest-select{padding:8px 12px;background:var(--bg-elevated, #1e1e2e);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.btn-subtopic-minitest{padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-subtopic-minitest:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-subtopic-minitest:disabled{opacity:.7;cursor:not-allowed}.subtopic-minitest-error{margin:12px 0 0;color:var(--error, #ef4444);font-size:.9rem}.theory-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 0;background:none;border:none;cursor:pointer;color:var(--text);font:inherit;text-align:left}.theory-section-toggle:hover{color:var(--accent)}.theory-section-toggle h2{margin:0;font-size:1.5rem}.theory-section-chevron{font-size:.9rem;opacity:.7}.theory-section-body{padding-top:8px}.theory-section-collapsed .theory-section-body{display:none}.theory-tabs-head{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.theory-tab-btn{padding:12px 20px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-weight:500;font-size:.95rem;transition:var(--transition);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.theory-tab-btn:hover{border-color:var(--accent);color:var(--text);background:var(--bg-elevated)}.theory-tab-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.theory-tabs-panel{min-height:80px}.theory-tab-content .theory-content{margin-bottom:1rem}.theory-tab-content .theory-content p{margin:0 0 .5em}@media (max-width: 768px){.subtopic-page{padding:14px}.subtopic-header h1{font-size:1.35rem}.subtopic-section h2,.theory-section-toggle h2,.tasks-section-toggle h2{font-size:1.25rem}.theory-content{padding:18px}.theory-tab-btn{padding:10px 16px;font-size:.9rem}.task-card{padding:16px}.task-card-title{font-size:1.05rem}.task-card-desc{font-size:.85rem}.subtopic-minitest-section{padding:18px}.subtopic-minitest-section h2{font-size:1.15rem}.btn-course{padding:12px 24px;font-size:.95rem}.btn-subtopic-minitest{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){.subtopic-page{padding:12px}.subtopic-header h1{font-size:1.2rem}.theory-content,.task-card,.subtopic-minitest-section{padding:14px}}.task-page{max-width:1000px;margin:0 auto;padding:20px}.task-loading,.task-error{text-align:center;padding:40px;color:var(--text-muted)}.task-error{color:var(--error)}.task-header{margin-bottom:32px}.back-link{display:inline-block;color:var(--accent);text-decoration:none;margin-bottom:16px;font-weight:500;transition:var(--transition)}.back-link:hover{color:var(--accent-hover)}.task-header h1{margin-bottom:12px}.task-description{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);margin-bottom:24px;line-height:1.8}.task-image{margin-bottom:24px}.task-image img{max-width:100%;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.task-content{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);margin-bottom:32px;line-height:1.8}.task-faq{margin-bottom:32px}.task-faq-title{margin-top:32px;margin-bottom:16px;font-size:1.2rem}.task-faq-empty{color:var(--text-muted);margin-bottom:16px}.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (max-width: 700px){.faq-grid{grid-template-columns:1fr}}.faq-item{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:border-color var(--transition)}.faq-item.open{border-color:var(--accent-soft)}.faq-q{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;cursor:pointer;font-weight:700;font-size:.95rem;color:var(--text);text-align:left;width:100%;border:none;background:transparent;font-family:inherit;transition:background var(--transition)}.faq-q:hover{background:#ffffff08}.faq-q .faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--success);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1;transition:transform var(--transition)}.faq-item.open .faq-icon{transform:rotate(45deg)}.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}.faq-a-inner{padding:0 16px 14px;font-size:.95rem;color:var(--text-muted);line-height:1.5;border-top:1px solid rgba(255,255,255,.06)}.faq-a-inner p{margin:0}.faq-a-inner p+p{margin-top:.5em}.faq-item.open .faq-a{max-height:400px}.task-hint-wrap{margin-bottom:24px}.task-hint-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--accent);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition)}.task-hint-toggle:hover{border-color:var(--accent);background:rgba(var(--accent-rgb, 99, 102, 241),.08)}.task-hint-icon{font-size:1.2rem}.task-hint-block{margin-top:12px;padding:20px;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);border-left:4px solid var(--accent)}.task-hint-text{line-height:1.7;margin-bottom:12px}.task-hint-text:last-child{margin-bottom:0}.task-hint-image img{max-width:100%;border-radius:var(--radius-sm)}.task-solution-block{margin-top:24px;padding:24px;background:var(--bg-card);border:1px solid rgba(34,197,94,.2);border-radius:var(--radius);border-left:4px solid var(--success)}.task-solution-title{margin:0 0 16px;font-size:1.15rem;color:var(--success)}.task-solution-text{line-height:1.7;margin-bottom:16px}.task-solution-text:last-of-type{margin-bottom:0}.task-solution-image{margin:16px 0}.task-solution-image img{max-width:100%;border-radius:var(--radius-sm)}.task-solution-video{margin-top:16px}.task-solution-iframe,.task-solution-video-el{width:100%;max-width:640px;aspect-ratio:16/9;border-radius:var(--radius-sm)}.task-solution-video-el{display:block}.task-answer-section{background:var(--bg-card);padding:24px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06)}.task-answer-section h2{margin-bottom:16px}.answer-form{display:flex;flex-direction:column;gap:20px}.task-btn-check-answer{align-self:center;min-height:48px;min-width:220px;padding:14px 36px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:1.05rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition),transform .15s ease;box-shadow:0 2px 8px rgba(var(--accent-rgb, 99, 102, 241),.35)}.task-btn-check-answer:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--accent-rgb, 99, 102, 241),.4)}.task-btn-check-answer:active:not(:disabled){transform:translateY(0)}.task-btn-check-answer:disabled{opacity:.6;cursor:not-allowed;transform:none}.answer-input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;font-family:inherit;resize:vertical}.check-result{margin-top:16px;padding:16px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:12px;font-weight:500}.check-result.correct{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.3)}.check-result.incorrect{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.3)}.task-variant-nav{margin-bottom:24px;padding:16px 20px;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}.task-variant-nav-counter{font-weight:600;color:var(--text-muted);font-size:.95rem}.task-variant-nav-buttons{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.btn-prev-task{display:inline-block;padding:10px 16px;background:var(--bg-elevated);color:var(--text);text-decoration:none;border-radius:var(--radius);border:1px solid rgba(128,128,128,.25);font-weight:500;transition:var(--transition)}.btn-prev-task:hover{border-color:var(--accent);color:var(--accent)}.btn-nav-disabled{padding:10px 16px;color:var(--text-muted);font-size:.95rem;cursor:default;opacity:.7}.task-variant-actions,.task-course-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid rgba(128,128,128,.12);justify-content:flex-end}.btn-next-task{display:inline-block;padding:12px 20px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-complete-course{display:inline-block;padding:12px 20px;background:var(--success);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-complete-course:hover{filter:brightness(1.1)}.btn-back-to-list{display:inline-block;padding:12px 20px;background:var(--bg-elevated);color:var(--text);text-decoration:none;border-radius:var(--radius);border:1px solid rgba(128,128,128,.25);font-weight:500;transition:var(--transition)}.btn-back-to-list:hover{border-color:var(--accent);color:var(--accent)}.variant-page{max-width:560px;margin:0 auto;padding:24px}.variant-header{margin-bottom:32px}.variant-header .back-link{display:inline-block;color:var(--accent);text-decoration:none;margin-bottom:12px;font-weight:500}.variant-header h1{font-size:1.75rem}.variant-card{background:var(--bg-card);padding:28px;border-radius:var(--radius);border:1px solid rgba(128,128,128,.12);margin-bottom:24px}.variant-card-title{font-size:1.2rem;margin-bottom:12px}.variant-card-topics .variant-desc{margin-bottom:16px}.variant-topics-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.variant-topic-row{display:flex;align-items:center;gap:16px}.variant-topic-name{flex:1;color:var(--text)}.variant-topic-row input{width:70px;padding:8px 12px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text)}.variant-sections-table{margin-bottom:20px}.variant-sections-header{display:grid;grid-template-columns:140px 1fr;gap:12px;padding:10px 0;font-size:.9rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:8px}.variant-sections-col-qty{min-width:0}.variant-section-block{border-bottom:1px solid rgba(128,128,128,.1)}.variant-section-block:last-child{border-bottom:none}.variant-section-row{display:grid;grid-template-columns:140px 1fr;gap:12px;align-items:center;min-height:48px}.variant-section-qty{display:flex;align-items:center;gap:6px}.variant-qty-btn{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1.1rem;cursor:pointer;transition:var(--transition)}.variant-qty-btn:hover{border-color:var(--accent);color:var(--accent)}.variant-qty-input{width:56px;padding:6px 8px;text-align:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem}.variant-section-title{display:flex;align-items:center;gap:8px;width:100%;padding:10px 0;text-align:left;background:none;border:none;color:var(--text);font-size:1rem;cursor:pointer;transition:var(--transition)}.variant-section-title:hover{color:var(--accent)}.variant-section-num{color:var(--text-muted);min-width:1.5em}.variant-section-arrow{margin-left:auto;color:var(--text-muted);font-size:.75rem}.variant-subtopics{padding:0 0 16px 140px;margin-left:0}@media (max-width: 560px){.variant-subtopics{padding-left:0}.variant-section-row,.variant-sections-header{grid-template-columns:1fr}}.variant-subtopics-loading{color:var(--text-muted);font-size:.9rem;padding:8px 0}.variant-subtopics-actions{margin-bottom:8px}.variant-subtopic-link{background:none;border:none;color:var(--accent);font-size:.85rem;cursor:pointer;padding:0 8px 0 0}.variant-subtopic-link:hover{text-decoration:underline}.variant-subtopics-list{list-style:none;margin:0;padding:0}.variant-subtopic-item{padding:4px 0}.variant-subtopic-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.95rem;color:var(--text)}.variant-subtopic-label input{flex-shrink:0}.variant-subtopic-name{flex:1}.variant-subtopic-count{color:var(--text-muted);font-size:.9rem}.variant-total-by-sections{margin-bottom:16px;font-size:.95rem;color:var(--text)}.variant-total-by-sections strong{color:var(--accent)}.variant-desc{color:var(--text-muted);margin-bottom:24px}.variant-form label{display:block;margin-bottom:16px}.variant-form input{display:block;margin-top:8px;padding:10px 14px;width:120px;background:var(--bg-elevated);border:1px solid rgba(128,128,128,.2);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.btn-generate{padding:12px 24px;background:var(--warm);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-generate:hover:not(:disabled){background:#d97706}.btn-generate:disabled{opacity:.7;cursor:not-allowed}.variant-form-inline{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.variant-code-input{padding:10px 14px;min-width:180px;font-size:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);color:var(--text)}.variant-result-code{margin:8px 0;font-size:.95rem;color:var(--text-muted)}.variant-result-code strong{color:var(--accent);letter-spacing:.05em}.variant-error{color:var(--error);margin-top:16px}.variant-result{margin-top:24px;padding-top:24px;border-top:1px solid rgba(128,128,128,.12)}.variant-result p{margin-bottom:16px;color:var(--text)}.btn-start{display:inline-block;padding:12px 24px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-start:hover{background:var(--accent-hover)}.variant-select-tasks .variant-select-tree{margin-bottom:24px}.variant-topic-block{margin-bottom:16px}.variant-topic-btn{display:block;width:100%;padding:12px 16px;text-align:left;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-weight:600;cursor:pointer}.variant-topic-btn:hover{border-color:var(--accent)}.variant-subtopic-block{margin:8px 0 8px 20px}.variant-subtopic-btn{display:block;width:100%;padding:10px 14px;text-align:left;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:.95rem}.variant-subtopic-btn:hover{border-color:var(--accent)}.variant-tasks-list{margin:8px 0 8px 24px;display:flex;flex-direction:column;gap:6px}.variant-task-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:var(--text-secondary)}.variant-task-name{color:var(--text-muted)}.variant-select-actions{padding:20px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-wrap:wrap}.variant-select-actions p{margin:0}.variant-pass-page{max-width:640px;margin:0 auto;padding:24px}.variant-pass-header{margin-bottom:24px}.variant-pass-header-links{display:flex;flex-wrap:wrap;gap:16px 24px;margin-bottom:12px}.variant-pass-header .back-link{display:inline-block;color:var(--accent);text-decoration:none;font-weight:500}.variant-pass-header .back-link-secondary{color:var(--text-muted)}.variant-pass-header .back-link-secondary:hover{color:var(--accent)}.back-variant{display:inline-block;margin-top:16px;color:var(--accent);text-decoration:none;font-weight:500}.variant-pass-meta{color:var(--text-muted);margin-top:8px}.variant-pass-actions{margin-bottom:28px}.btn-start-variant{display:inline-block;padding:14px 28px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-start-variant:hover{background:var(--accent-hover)}.variant-pass-list-caption{font-size:.9rem;color:var(--text-muted);margin-bottom:10px}.variant-pass-list{list-style:none;padding:0;margin:0}.variant-pass-list li{margin-bottom:6px}.variant-pass-list a{color:var(--text);text-decoration:none}.variant-pass-list a:hover{color:var(--accent)}.variant-pass-item--correct{background:#22c55e33;border-radius:var(--radius-sm)}.variant-pass-item--correct a{display:block;padding:10px 14px}.variant-pass-item--incorrect{background:#ef444426;border-radius:var(--radius-sm)}.variant-pass-item--incorrect a{display:block;padding:10px 14px}.variant-pass-all-done-banner{margin-top:20px;padding:14px 18px;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-sm);color:var(--text)}.variant-pass-all-done-banner p{margin:0;font-size:.95rem}.variant-pass-finish-wrap{margin-top:28px;padding-top:20px;border-top:1px solid rgba(128,128,128,.15)}.btn-finish-variant{display:inline-block;padding:12px 24px;background:var(--warm);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-finish-variant:hover:not(:disabled){background:#ea580c}.btn-finish-variant:disabled{opacity:.7;cursor:not-allowed}.variant-pass-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:20px}.variant-pass-modal{background:var(--bg-card);padding:28px;border-radius:var(--radius);max-width:400px;width:100%;border:1px solid rgba(128,128,128,.2);box-shadow:var(--shadow)}.variant-pass-modal h2{margin-bottom:16px;font-size:1.35rem}.variant-pass-modal p{color:var(--text-muted);margin-bottom:20px}.variant-pass-modal-result{color:var(--text);margin-bottom:16px}.variant-pass-modal-result p{margin-bottom:8px}.variant-pass-modal-stats,.variant-pass-modal-score{font-size:1.05rem;color:var(--text)}.variant-pass-modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.variant-pass-modal-close{padding:10px 24px;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-weight:600;cursor:pointer}.variant-pass-modal-close:hover{background:var(--bg-tertiary)}.variant-pass-modal-goto{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer}.variant-pass-modal-goto:hover{background:var(--accent-hover)}.variant-pass-modal-close:first-child{margin-right:0}.handbook-page{max-width:720px;margin:0 auto;padding:32px 24px 48px}.handbook-page h1{margin:0 0 12px;font-size:clamp(1.5rem,3vw,1.85rem);font-weight:800;color:var(--text)}.handbook-lead{color:var(--text-muted);line-height:1.6;margin:0 0 32px}.handbook-cards{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 520px){.handbook-cards{grid-template-columns:repeat(2,1fr)}}.handbook-card{position:relative;padding:28px 24px;background:var(--bg-elevated);border-radius:var(--radius-md, 12px);border:1px solid rgba(128,128,128,.15);transition:border-color .2s,box-shadow .2s}.handbook-card:hover{border-color:#80808040;box-shadow:0 8px 24px #0000001a}.handbook-card-available:hover{border-color:var(--accent)}.handbook-card-icon{font-size:2.5rem;margin-bottom:16px;line-height:1}.handbook-card h2{margin:0 0 10px;font-size:1.25rem;font-weight:700;color:var(--text)}.handbook-card p{margin:0 0 20px;color:var(--text-muted);font-size:.95rem;line-height:1.5}.handbook-card p:last-of-type{margin-bottom:0}.handbook-card-soon p:last-of-type{margin-bottom:0}.handbook-card-btn{display:inline-block;margin-top:16px;padding:12px 24px;background:var(--accent);color:#fff;text-decoration:none;font-weight:600;font-size:.95rem;border-radius:var(--radius-sm);transition:opacity .2s}.handbook-card-btn:hover{opacity:.95}.handbook-card-badge{position:absolute;top:16px;right:16px;padding:6px 12px;background:#80808033;color:var(--text-muted);font-size:.8rem;font-weight:600;border-radius:var(--radius-sm)}.help-page{max-width:780px;margin:0 auto;padding:2rem 1.5rem 4rem;position:relative;scroll-behavior:smooth}.help-hero{text-align:center;margin-bottom:2.5rem;padding:2rem 1.5rem 2.5rem;background:linear-gradient(180deg,var(--accent-soft) 0%,transparent 70%);border-radius:var(--radius);border:1px solid rgba(var(--accent-rgb, 99, 102, 241),.2)}.help-badge{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--bg-elevated);padding:.35rem .75rem;border-radius:999px;margin-bottom:1rem;border:1px solid var(--border)}.help-hero h1{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:800;color:var(--text);margin:0 0 1rem;letter-spacing:-.02em;line-height:1.2}.help-lead{font-size:1.05rem;line-height:1.65;color:var(--text-muted);max-width:540px;margin:0 auto}.help-nav{padding:1.25rem 1.5rem;background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:2.5rem}.help-nav-title{font-weight:600;color:var(--text-secondary);font-size:.85rem;margin-bottom:.75rem;display:block}.help-nav-links{display:flex;flex-wrap:wrap;gap:.5rem}.help-nav-pill{display:inline-block;color:var(--text-muted);text-decoration:none;font-size:.9rem;padding:.4rem .85rem;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);transition:background var(--transition),color var(--transition),border-color var(--transition)}.help-nav-pill:hover{background:var(--accent-soft);color:var(--accent);border-color:rgba(var(--accent-rgb, 99, 102, 241),.35)}.help-content{display:flex;flex-direction:column;gap:2.5rem}.help-section{scroll-margin-top:1.5rem;padding-left:1rem;border-left:3px solid var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.help-section h2{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.help-section-icon{font-size:1.2rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);border-radius:var(--radius-sm);flex-shrink:0}.help-section p{color:var(--text-muted);line-height:1.7;margin:0 0 .75rem;font-size:.98rem}.help-section p:last-of-type{margin-bottom:0}.help-section ul{margin:.5rem 0 0;padding-left:1.35em;color:var(--text-muted);line-height:1.75;font-size:.98rem}.help-section li{margin-bottom:.4rem}.help-section li:last-child{margin-bottom:0}.help-section a{color:var(--accent);text-decoration:none;font-weight:500}.help-section a:hover{text-decoration:underline}.help-menu-list{list-style:none;padding-left:0}.help-menu-list li{padding:.35rem 0;border-bottom:1px solid var(--border);margin-bottom:0}.help-menu-list li:last-child{border-bottom:none}.help-structure{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem .5rem;margin:1.25rem 0;padding:1.25rem 1.5rem;background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border)}.help-structure-item{display:flex;flex-direction:column;gap:.2rem}.help-structure-item strong{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}.help-structure-item span{font-size:.9rem;color:var(--text-muted)}.help-structure-arrow{color:var(--text-muted);opacity:.5;font-size:1rem}.help-cards{display:grid;grid-template-columns:1fr;gap:1rem;margin:1.25rem 0}@media (min-width: 560px){.help-cards{grid-template-columns:repeat(2,1fr)}}@media (min-width: 720px){.help-cards{grid-template-columns:repeat(3,1fr)}}.help-card{padding:1.25rem;background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border);transition:border-color var(--transition),box-shadow var(--transition)}.help-card:hover{border-color:rgba(var(--accent-rgb, 99, 102, 241),.3);box-shadow:0 4px 16px #0000001f}.help-card h3{font-size:.95rem;font-weight:700;color:var(--text);margin:0 0 .5rem}.help-card p{margin:0;font-size:.9rem;line-height:1.6;color:var(--text-muted)}.help-footer{margin-top:2.5rem;padding:1.5rem 1.75rem;background:linear-gradient(135deg,var(--accent-soft) 0%,var(--bg-elevated) 100%);border-radius:var(--radius);border:1px solid rgba(var(--accent-rgb, 99, 102, 241),.2)}.help-footer p{margin:0;color:var(--text-muted);line-height:1.6;font-size:.98rem}.help-footer strong{color:var(--text)}@media (max-width: 640px){.help-page{padding:1.5rem 1rem 3rem}.help-hero{padding:1.5rem 1rem 2rem}.help-nav-links{gap:.4rem}.help-nav-pill{font-size:.85rem;padding:.35rem .7rem}.help-section{padding-left:.75rem}}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.breadcrumbs-part{display:inline-flex;align-items:center;gap:.25rem}.breadcrumbs-sep{color:var(--text-tertiary);-webkit-user-select:none;user-select:none}.breadcrumbs-link{color:var(--text-secondary);text-decoration:none;transition:color .15s}.breadcrumbs-link:hover{color:var(--accent)}.breadcrumbs-current{color:var(--text-primary);font-weight:500}.course-program-page{max-width:1200px;margin:0 auto;padding:2rem}.course-program-loading,.course-program-error{text-align:center;padding:3rem}.course-program-error h2{margin-bottom:1rem;color:var(--text-primary)}.course-program-error p{margin-bottom:1.5rem;color:var(--text-secondary)}.course-program-header{margin-bottom:2rem}.course-program-header .back-link{margin-top:.25rem}.course-program-header h1{margin:.5rem 0 1rem;font-size:2rem;color:var(--text-primary)}.course-progress-overall{margin-top:1rem;padding:1rem 1.25rem;background:var(--bg-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;gap:1rem;flex-wrap:wrap;border:1px solid var(--border)}.progress-label{font-weight:500;color:var(--text-primary)}.progress-value{font-weight:600;color:var(--accent)}.progress-bar-overall{flex:1;min-width:200px;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s}.course-sections{display:flex;flex-direction:column;gap:2rem}.course-section{border:1px solid var(--border);border-radius:12px;padding:1.5rem;background:var(--bg-secondary)}.section-header{display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border)}.section-header:has(+.section-steps){margin-bottom:1rem}.course-section.is-section-complete .section-number{background:var(--success)}.section-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-weight:600;font-size:1.2rem;flex-shrink:0}.section-info{flex:1}.section-label{display:block;font-size:.9rem;font-weight:600;color:var(--accent);margin-bottom:.25rem}.section-title{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.section-progress{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.section-progress-icon{font-size:1.2rem;color:var(--accent)}.section-steps{display:flex;flex-direction:column;gap:.75rem}.step-link{display:flex;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);text-decoration:none;color:inherit;transition:all .2s}.step-link:hover{border-color:var(--accent);background:var(--bg-secondary);transform:translate(4px)}.step-link.step-completed{background:var(--bg-secondary);opacity:.9}.step-number{width:50px;flex-shrink:0;font-weight:600;color:var(--text-secondary);display:flex;align-items:center}.step-content{flex:1}.step-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.step-title{font-weight:500;color:var(--text-primary)}.step-check{color:var(--accent);font-weight:600}.step-type-badge{display:inline-block;padding:.25rem .75rem;background:var(--bg-tertiary);border-radius:12px;font-size:.875rem;color:var(--text-secondary)}.back-link,.btn-back{display:inline-block;margin-bottom:1rem;color:var(--accent);text-decoration:none;font-weight:500;transition:opacity .2s}.back-link:hover,.btn-back:hover{opacity:.8}.btn-back{margin-top:1rem;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border-radius:8px;display:inline-block}.btn-back:hover{opacity:1;background:var(--accent-hover)}.step-strip-wrap{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.step-strip{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.step-strip-item{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;text-decoration:none;background:var(--bg-tertiary);color:var(--text-secondary);border:2px solid transparent;transition:background .15s,border-color .15s,color .15s}.step-strip-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.step-strip-item.completed{background:var(--success-bg, rgba(34, 197, 94, .15));color:var(--success, #22c55e)}.step-strip-item.completed:hover{background:var(--success-bg);color:var(--success)}.step-strip-item.current{background:var(--accent);color:#fff;border-color:var(--accent)}.step-strip-item.current:hover{opacity:.95}.step-strip-icon{font-size:1rem;line-height:1}.step-strip-progress{font-size:.875rem;color:var(--text-secondary)}.course-step-page{display:flex;min-height:60vh;max-width:1400px;margin:0 auto;padding:0;gap:0}.course-step-sidebar{flex-shrink:0;width:280px;padding:1.5rem 1rem 2rem;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:1rem}.sidebar-back{display:inline-block;color:var(--accent);text-decoration:none;font-weight:500;font-size:.95rem;margin-bottom:.25rem;transition:opacity .2s}.sidebar-back:hover{opacity:.85}.sidebar-progress{padding:.75rem;background:var(--bg-tertiary);border-radius:8px}.sidebar-progress-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;margin-bottom:.5rem;color:var(--text-secondary)}.sidebar-progress-value{font-weight:600;color:var(--accent)}.sidebar-progress-bar{height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.sidebar-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.sidebar-nav{flex:1;overflow-y:auto}.sidebar-section{margin-bottom:1rem;padding:.75rem;border-radius:8px;transition:background .15s}.sidebar-section.current-section{background:#22c55e14;border-left:3px solid var(--success);margin-left:-3px;padding-left:calc(.75rem + 3px)}.sidebar-section-title{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;padding-bottom:.25rem}.sidebar-section-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-size:.75rem;flex-shrink:0}.sidebar-steps{list-style:none;margin:0;padding:0}.sidebar-steps li{margin:0}.sidebar-step-link{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;text-decoration:none;color:var(--text-secondary);font-size:.875rem;transition:background .15s,color .15s;border-left:3px solid transparent}.sidebar-step-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-step-link.current{background:rgba(var(--accent-rgb, 59, 130, 246),.12);color:var(--accent);border-left-color:var(--accent);font-weight:500}.sidebar-step-link.completed:not(.current){color:var(--text-primary)}.sidebar-step-link .step-type-icon{flex-shrink:0;font-size:1rem;opacity:.9}.sidebar-step-num{flex-shrink:0;width:2em;font-size:.8rem;color:var(--text-secondary)}.sidebar-step-link.current .sidebar-step-num{color:var(--accent)}.sidebar-step-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-step-done{color:var(--success);font-weight:600;flex-shrink:0}.course-step-main{flex:1;min-width:0;padding:2rem;display:flex;flex-direction:column}.course-step-loading,.course-step-error{text-align:center;padding:3rem}.course-step-error p{margin-bottom:1.5rem;color:var(--text-secondary)}.course-step-header{margin-bottom:2rem}.course-step-main .back-link{display:inline-block}.course-step-page:has(.course-step-sidebar) .course-step-main .back-link{display:none}@media (max-width: 900px){.course-step-sidebar{display:none}.course-step-main .back-link{display:inline-block!important}.course-step-main{padding:1.5rem}}@media (max-width: 768px){.course-step-main{padding:1rem}.course-step-title,.course-step-header h1{font-size:1.35rem}.step-block{padding:1.25rem}.course-step-navigation{margin-top:2rem;padding-top:1.5rem}}.course-step-title{display:flex;align-items:center;gap:.5rem;margin:.5rem 0;font-size:clamp(1.25rem,4vw,2rem);color:var(--text-primary)}.course-step-title .step-type-icon{font-size:1.5rem}.step-breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;color:var(--text-secondary)}.breadcrumb-item{color:var(--accent)}.breadcrumb-link{text-decoration:none}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-separator{color:var(--text-secondary)}.course-step-header h1{margin:.5rem 0;font-size:clamp(1.25rem,4vw,2rem);color:var(--text-primary)}.course-step-content{margin-bottom:3rem}.step-block{position:relative;background:var(--bg-secondary);border-radius:12px;padding:2rem;border:1px solid var(--border)}.step-block-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;margin-bottom:1.25rem}.step-block-badge-theory{background:#3b82f626;color:var(--accent)}.step-block-badge-practice{background:#22c55e26;color:var(--success)}.step-theory,.step-practice{background:transparent;border-radius:0;padding:0;border:none}.step-description{margin-bottom:2rem;line-height:1.7;color:var(--text-primary)}.step-description p{margin-bottom:1rem}.step-description h2,.step-description h3{margin-top:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.step-video{margin:2rem 0}.video-iframe,.video-direct{width:100%;max-width:800px;height:450px;border-radius:8px}.step-pdf{margin:1.5rem 0}.pdf-link{display:inline-block;padding:.75rem 1.5rem;background:var(--accent);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:background .2s}.pdf-link:hover{background:var(--accent-hover)}.step-photo{margin:2rem 0;text-align:center}.step-image{max-width:100%;height:auto;border-radius:8px;box-shadow:0 2px 8px #0000001a}.practice-task h2{margin-bottom:1rem;color:var(--text-primary)}.task-description{margin-bottom:1rem;color:var(--text-secondary)}.task-content{margin:1.5rem 0;line-height:1.7;color:var(--text-primary)}.task-image{max-width:100%;height:auto;margin:1rem 0;border-radius:8px}.practice-answer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.practice-answer-title{margin:0 0 .75rem;font-size:1.1rem;color:var(--text-primary)}.practice-answer-form{display:flex;flex-direction:column;gap:.75rem}.practice-answer-input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;font-family:inherit;resize:vertical}.practice-answer-input:focus{outline:none;border-color:var(--accent)}.btn-check-answer{align-self:flex-start;padding:.6rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background .2s}.btn-check-answer:hover:not(:disabled){background:var(--accent-hover)}.btn-check-answer:disabled{opacity:.6;cursor:not-allowed}.practice-check-result{display:flex;align-items:center;gap:.5rem;padding:12px;border-radius:var(--radius-sm);font-weight:500}.practice-check-result.correct{background:#22c55e1f;color:var(--success);border:1px solid rgba(34,197,94,.3)}.practice-check-result.incorrect{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.3)}.practice-check-result .result-icon{font-size:1.2rem}.practice-hint-wrap{margin:1rem 0}.practice-hint-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--accent);font-size:.95rem;font-weight:500;cursor:pointer;transition:border-color .2s,background .2s}.practice-hint-toggle:hover{border-color:var(--accent);background:rgba(var(--accent-rgb, 99, 102, 241),.08)}.practice-hint-icon{font-size:1.2rem}.practice-hint-block{margin-top:12px;padding:1.25rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;border-left:4px solid var(--accent)}.practice-hint-text{line-height:1.7;margin-bottom:12px}.practice-hint-text:last-child{margin-bottom:0}.practice-hint-image img{max-width:100%;border-radius:8px}.practice-solution-block{margin-top:1.5rem;padding:1.5rem;background:var(--bg-tertiary);border:1px solid rgba(34,197,94,.2);border-radius:8px;border-left:4px solid var(--success)}.practice-solution-title{margin:0 0 1rem;font-size:1.15rem;color:var(--success)}.practice-solution-text{line-height:1.7;margin-bottom:1rem}.practice-solution-image{margin:1rem 0}.practice-solution-image img{max-width:100%;border-radius:8px}.practice-solution-video{margin-top:1rem}.practice-solution-video .video-iframe,.practice-solution-video .video-direct{width:100%;max-width:640px;aspect-ratio:16/9;border-radius:8px}.practice-open-full{display:inline-block;margin-top:1rem;font-size:.9rem;color:var(--text-muted);text-decoration:none}.practice-open-full:hover{color:var(--accent)}.practice-note{margin-top:2rem;padding:1.5rem;background:var(--bg-tertiary);border-radius:8px;border-left:4px solid var(--accent)}.practice-note p{margin-bottom:1rem;color:var(--text-primary)}.btn-task-link{display:inline-block;padding:.75rem 1.5rem;background:var(--accent);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:background .2s}.btn-task-link:hover{background:var(--accent-hover)}.practice-error{padding:2rem;text-align:center;color:var(--text-secondary)}.course-step-navigation{margin-top:3rem;padding-top:2rem;border-top:2px solid var(--border)}.course-step-hint-nav{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem;margin-top:0}.step-nav-buttons{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.btn-nav{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s;display:inline-block}.btn-nav-prev,.btn-nav-next{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-nav-prev:hover,.btn-nav-next:hover{background:var(--bg-tertiary);border-color:var(--accent)}.btn-nav-complete{background:var(--accent);color:#fff;flex:1;min-width:200px}.btn-nav-complete:hover:not(:disabled){background:var(--accent-hover)}.btn-nav-complete:disabled{opacity:.9;cursor:wait}.btn-nav-spinner{display:inline-block;width:1em;height:1em;margin-right:.5em;vertical-align:-.15em;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:course-step-spin .7s linear infinite}@keyframes course-step-spin{to{transform:rotate(360deg)}}.btn-nav-disabled{padding:.75rem 1.5rem;color:var(--text-secondary);opacity:.5;cursor:not-allowed}.back-link{display:inline-block;margin-bottom:1rem;color:var(--accent);text-decoration:none;font-weight:500;transition:opacity .2s}.back-link:hover{opacity:.8}.btn-back{margin-top:1rem;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border-radius:8px;display:inline-block;text-decoration:none}.btn-back:hover{background:var(--accent-hover)}.classrooms-page{max-width:1200px;margin:0 auto;padding:2rem}.classrooms-loading,.classrooms-error{text-align:center;padding:3rem}.classrooms-error{color:var(--error);background:#ef44441a;padding:1rem;border-radius:var(--radius-sm);margin-bottom:1rem}.classrooms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.classrooms-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.btn-create-room{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-create-room:hover{background:var(--accent-hover)}.classrooms-empty{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.classrooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.classroom-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:transform .2s,box-shadow .2s}.classroom-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.classroom-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.classroom-card-header h2{margin:0;font-size:1.25rem;color:var(--text-primary);flex:1}.classroom-code{background:var(--bg-tertiary);padding:.25rem .75rem;border-radius:6px;font-family:monospace;font-size:.875rem;color:var(--accent);font-weight:600}.classroom-card-info{color:var(--text-secondary);font-size:.9rem}.classroom-card-actions{display:flex;gap:.75rem;margin-top:auto}.btn-room-open{flex:1;padding:.75rem;background:var(--accent);color:#fff;text-decoration:none;text-align:center;border-radius:var(--radius-sm);font-weight:500;transition:background .2s}.btn-room-open:hover{background:var(--accent-hover)}.btn-room-copy{padding:.75rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s}.btn-room-copy:hover{background:var(--bg-elevated)}.btn-room-delete{padding:.75rem 1rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;transition:border-color .2s,color .2s}.btn-room-delete:hover:not(:disabled){border-color:#dc2626;color:#dc2626}.btn-room-delete:disabled{opacity:.6;cursor:not-allowed}.btn-room-leave{padding:.75rem 1rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;transition:border-color .2s,color .2s}.btn-room-leave:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-room-leave:disabled{opacity:.6;cursor:not-allowed}.form-group input{width:100%;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem}.form-group input:focus{outline:none;border-color:var(--accent)}.modal-content-success{max-width:600px}.created-room-hint{margin:0 0 1rem;color:var(--text-secondary);font-size:.95rem}.created-room-info{margin:1.5rem 0}.info-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.info-label{font-weight:500;color:var(--text-secondary);font-size:.9rem}.info-value{color:var(--text-primary);font-size:1.1rem}.code-value{font-family:monospace;font-size:1.5rem;color:var(--accent);font-weight:600}.info-row-code .info-value-code{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.info-value-link{display:flex;gap:.5rem;align-items:center}.link-input{flex:1;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;font-family:monospace}.btn-copy-link{padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:1.25rem;transition:background .2s}.btn-copy-link:hover{background:var(--bg-elevated)}.task-selector{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);max-height:500px;display:flex;flex-direction:column}.task-selector-list{max-height:400px}.task-selector-filters{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.filter-group label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.filter-select{padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem}.filter-select:focus{outline:none;border-color:var(--accent)}.btn-toggle-tasks{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:background .2s}.btn-toggle-tasks:hover{background:var(--bg-elevated)}.btn-toggle-tasks.active{background:var(--accent);color:#fff}.task-selector-list{flex:1;overflow-y:auto;padding:.5rem;width:100%;box-sizing:border-box}.task-selector-loading,.task-selector-empty{text-align:center;padding:2rem;color:var(--text-secondary)}.tasks-list{display:flex;flex-direction:column;gap:.25rem;width:100%}.task-item{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);cursor:pointer;transition:background .15s,border-color .15s;width:100%;box-sizing:border-box}.task-item:hover{background:var(--bg-tertiary)}.task-item.selected{border-color:var(--accent);background:rgba(var(--accent-rgb, 99, 102, 241),.1)}.task-checkbox{flex-shrink:0;margin-top:.125rem;cursor:pointer;width:16px;height:16px;min-width:16px;max-width:16px;min-height:16px;max-height:16px}.task-item-content{flex:1;min-width:0;display:flex;flex-direction:column;width:100%;overflow:visible}.task-item-name{color:var(--text-primary);margin:0 0 .25rem;font-size:.875rem;line-height:1.4;display:flex;align-items:flex-start;gap:.5rem;font-weight:500;width:100%;flex-wrap:wrap}.task-item-name strong{color:var(--accent);font-size:.85rem;flex-shrink:0;font-weight:600;white-space:nowrap}.task-name-text{flex:1;min-width:0;color:var(--text-primary);word-wrap:break-word;word-break:break-word;line-height:1.4;overflow-wrap:break-word;display:inline;white-space:normal}.task-item-path{font-size:.7rem;color:var(--text-secondary);margin-bottom:.25rem;line-height:1.2}.task-item-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:2.6em;margin-top:.125rem;min-height:.75rem}.task-selector-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-top:1px solid var(--border);background:var(--bg-secondary);font-weight:500;color:var(--text-primary)}.btn-clear-selection{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:background .2s}.btn-clear-selection:hover{background:var(--bg-elevated)}.room-page{display:flex;height:calc(100vh - 80px);max-height:calc(100vh - 80px);overflow:hidden}.room-page--loading{display:flex;align-items:center;justify-content:center;min-height:200px}.room-loading,.room-error{text-align:center;padding:3rem;color:var(--text, #333);min-height:120px;display:flex;align-items:center;justify-content:center;flex-direction:column}.room-loading p{margin:0}.room-loading p+p,.room-error p+p{margin-top:.5rem}.room-error p{margin:0 0 1rem;color:var(--error, #c00)}.room-chat-wrapper{display:flex;flex-shrink:0;position:relative}.room-chat-wrapper--collapsed{width:44px;min-width:44px}.room-chat-wrapper--collapsed .room-chat{width:0;min-width:0;overflow:hidden;border-right:none;opacity:0;pointer-events:none}.room-chat-toggle{position:absolute;left:0;top:50%;transform:translateY(-50%);width:44px;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover, #7c4dff) 100%);border:none;border-left:3px solid rgba(255,255,255,.4);border-radius:12px 0 0 12px;cursor:pointer;color:#fff;font-size:1.1rem;z-index:10;transition:transform .2s,box-shadow .2s,opacity .2s;box-shadow:-4px 0 16px #00000040}.room-chat-toggle:hover{transform:translateY(-50%) translate(-2px);box-shadow:-6px 0 20px #0000004d;opacity:1}.room-chat-wrapper:not(.room-chat-wrapper--collapsed) .room-chat-toggle{display:none}.room-chat-toggle-icon{display:block;font-size:1.25rem;line-height:1}.room-chat-toggle-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);line-height:1.2}.room-chat-unread-badge{position:absolute;top:6px;right:6px;min-width:20px;height:20px;padding:0 5px;display:flex;align-items:center;justify-content:center;background:#ff1744;color:#fff;font-size:.75rem;font-weight:700;border-radius:10px;line-height:1;box-shadow:0 2px 6px #0000004d}.room-chat{width:350px;min-width:350px;display:flex;flex-direction:column;background:var(--bg-secondary);border-right:1px solid var(--border);transition:width .25s ease,opacity .25s ease,min-width .25s ease}.chat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:1rem;border-bottom:1px solid var(--border)}.chat-header h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary);flex:1}.chat-header-collapse-btn{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.9rem;transition:border-color .2s,color .2s}.chat-header-collapse-btn:hover{border-color:var(--accent);color:var(--text-primary)}.chat-room-name{font-size:.875rem;color:var(--text-secondary);display:block}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg-secondary)}.chat-empty{text-align:center;color:var(--text-secondary);padding:2rem}.chat-message{display:flex;flex-direction:column;gap:.25rem;max-width:85%;min-width:0}.chat-message--mine{align-self:flex-end;margin-left:auto}.chat-message--mine .message-author,.chat-message--mine .message-time{text-align:right;padding-right:.5rem;padding-left:0}.chat-message--other{align-self:flex-start;margin-right:auto}.message-author{font-size:.75rem;color:var(--text-secondary);font-weight:500}.message-content{background:var(--bg-tertiary);padding:.75rem;border-radius:var(--radius-sm);max-width:100%;overflow-wrap:break-word;word-break:break-word;overflow:hidden}.message-content p{margin:0;color:var(--text-primary);overflow-wrap:break-word;word-break:break-word}.message-content a{color:var(--accent);text-decoration:none;overflow-wrap:break-word;word-break:break-word}.message-content a:hover{text-decoration:underline}.message-file{margin-top:.5rem;overflow-wrap:break-word;word-break:break-word}.message-image{margin-top:.5rem}.message-image img{max-width:100%;max-height:240px;border-radius:var(--radius-sm);display:block}.message-time{font-size:.7rem;color:var(--text-tertiary, var(--text-secondary));padding-left:.5rem}.chat-emoji-picker{display:flex;flex-wrap:wrap;gap:.35rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-secondary);max-height:120px;overflow-y:auto}.chat-emoji-btn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,border-color .2s}.chat-emoji-btn:hover{background:var(--accent);border-color:var(--accent)}.chat-file-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.chat-input-form{display:flex;align-items:flex-end;gap:.35rem;padding:.5rem .5rem .5rem .65rem;background:var(--bg-secondary);border-top:1px solid var(--border);width:100%;box-sizing:border-box}.chat-attach-btn,.chat-emoji-toggle{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);box-sizing:border-box;transition:background .2s,border-color .2s,color .2s;margin-bottom:2px}.chat-attach-btn:hover:not(:disabled),.chat-emoji-toggle:hover{border-color:var(--accent);color:var(--accent)}.chat-input-wrap{flex:1;min-width:0;display:flex;align-items:flex-end}.chat-input{flex:1;min-width:0;min-height:36px;max-height:120px;padding:.5rem .75rem;box-sizing:border-box;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;font-family:inherit;line-height:1.4;resize:none;overflow-y:auto}.chat-input::placeholder{color:var(--text-tertiary, var(--text-secondary))}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-send-btn{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;padding:0;background:var(--accent);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s,transform .15s;box-sizing:border-box;margin-bottom:2px}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-icon{font-size:1rem;line-height:1;margin-left:2px}.room-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;padding:2rem}.room-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:1.5rem}.room-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.room-header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.btn-start-session{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background .2s}.btn-start-session:hover:not(:disabled){background:var(--accent-hover)}.btn-start-session:disabled{opacity:.6;cursor:not-allowed}.btn-finish-session{padding:.75rem 1.5rem;background:transparent;color:var(--danger, #c0392b);border:1px solid var(--danger, #c0392b);border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background .2s,color .2s}.btn-finish-session:hover{background:var(--danger, #c0392b);color:#fff}.btn-delete-room{padding:.5rem 1rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:border-color .2s,color .2s}.btn-delete-room:hover:not(:disabled){border-color:var(--error, #dc2626);color:var(--error, #dc2626)}.btn-delete-room:disabled{opacity:.6;cursor:not-allowed}.btn-leave-room{padding:.5rem 1rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:border-color .2s,color .2s}.btn-leave-room:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-leave-room:disabled{opacity:.6;cursor:not-allowed}.room-no-session{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.room-session{max-width:900px;margin:0 auto;width:100%}.session-task{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;min-width:0}.task-header{margin-bottom:1.5rem}.task-header-top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem 1rem;margin-bottom:1rem}.task-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.task-status-badge{display:inline-block;padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500}.task-status-badge--done{background:#22c55e33;color:var(--success, #22c55e)}.task-status-badge--current{background:var(--bg-tertiary);color:var(--accent);border:1px solid var(--accent)}.task-status-badge--pending{background:var(--bg-tertiary);color:var(--text-secondary)}.viewing-past-task{font-size:.875rem;color:var(--text-secondary);font-weight:400;margin-left:.5rem}.btn-back-to-current{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-back-to-current:hover{background:var(--accent-hover)}.task-navigation{display:flex;align-items:center;gap:.5rem 1rem;padding:.75rem;background:var(--bg-primary);border-radius:var(--radius-sm);margin-top:1rem;flex-wrap:nowrap;min-width:0}.session-all-done-banner{margin-top:1rem;padding:.75rem 1rem;background:#4caf5026;border:1px solid rgba(76,175,80,.4);border-radius:var(--radius-sm);color:var(--text-primary);font-weight:500;text-align:center}.btn-nav-task{padding:.5rem .75rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0;white-space:nowrap}.btn-nav-task:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent)}.btn-nav-task-short{display:none}@media (max-width: 480px){.btn-nav-task-full{display:none}.btn-nav-task-short{display:inline}}.btn-nav-task:disabled{opacity:.5;cursor:not-allowed}.task-nav-indicators{display:flex;gap:.35rem;flex:1;min-width:0;justify-content:center;align-items:center;flex-shrink:1}.task-nav-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;transition:all .2s;padding:0}.task-nav-dot:hover{transform:scale(1.2);border-color:var(--accent)}.task-nav-dot.active{background:var(--accent);border-color:var(--accent)}.task-nav-dot.current{border-color:var(--success);border-width:3px}.task-nav-dot.active.current,.task-nav-dot--done{background:var(--success);border-color:var(--success)}.task-nav-dot--locked,.task-nav-dot:disabled{opacity:.4;cursor:not-allowed}.task-nav-dot--locked:hover,.task-nav-dot:disabled:hover{transform:none;border-color:var(--border)}.task-content h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.25rem}.task-description,.task-content-html{margin-bottom:1rem;color:var(--text-primary);line-height:1.6}.task-image{margin:1rem 0}.task-image img{max-width:100%;height:auto;border-radius:var(--radius-sm)}.task-answer-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.task-answer-section h3{margin:0 0 1rem;color:var(--text-primary)}.answer-input{width:100%;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem}.answer-input:focus{outline:none;border-color:var(--accent)}.btn-submit-answer{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background .2s}.btn-submit-answer:hover:not(:disabled){background:var(--accent-hover)}.btn-submit-answer:disabled{opacity:.6;cursor:not-allowed}.answer-result{margin-top:1.5rem;padding:1rem;border-radius:var(--radius-sm);display:flex;align-items:center;gap:.75rem;font-weight:500}.answer-result.correct{background:#22c55e26;color:var(--success)}.answer-result.incorrect{background:#ef444426;color:var(--error)}.result-icon{font-size:1.5rem}.task-solution{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.task-solution h3{margin:0 0 1rem;color:var(--text-primary)}.solution-text{margin-bottom:1rem;color:var(--text-primary);line-height:1.6}.solution-image{margin:1rem 0}.solution-image img{max-width:100%;height:auto;border-radius:var(--radius-sm)}.solution-video{margin:1rem 0}.correct-answers-list{margin-top:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.correct-answers-list h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.correct-answers-list ul{margin:0;padding-left:1.5rem;color:var(--text-secondary)}.session-scores-block{margin-top:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.session-scores-block h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.session-scores-table{width:100%;border-collapse:collapse;font-size:.95rem}.session-scores-table th,.session-scores-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.session-scores-table th{color:var(--text-secondary);font-weight:600}.session-scores-table td{color:var(--text-primary)}.session-controls{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border);text-align:right}.btn-next-task{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background .2s}.btn-next-task:hover{background:var(--accent-hover)}.room-no-task,.room-loading-task{text-align:center;padding:2rem;color:var(--text-secondary)}.room-task-error .task-error-message{color:var(--danger, #c0392b);margin-bottom:1rem}.room-task-error .btn-submit{margin-top:.5rem}.task-id-hint{font-size:.875rem;color:var(--text-tertiary);margin-top:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-secondary);border-radius:var(--radius);padding:2rem;max-width:500px;width:90%;box-shadow:var(--shadow)}.modal-content h2{margin:0 0 1.5rem;color:var(--text-primary)}.modal-content--transition{position:relative;text-align:center;max-width:420px}.transition-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);font-size:1.75rem;line-height:1;cursor:pointer;border-radius:var(--radius-sm);transition:color .2s,background .2s}.transition-modal-close:hover{color:var(--text-primary);background:var(--bg-elevated)}.modal-content--transition .transition-modal-icon{font-size:3rem;margin-bottom:.75rem;line-height:1}.modal-content--transition .transition-modal-title{margin:0 0 .5rem;font-size:1.5rem}.modal-content--transition .transition-modal-who{margin:0 0 1rem;color:var(--text-secondary);font-size:1rem}.modal-content--transition .transition-modal-who strong{color:var(--text-primary)}.modal-content--transition .transition-modal-who--hint{font-size:.9rem;opacity:.9;margin-top:.25rem}.modal-content--transition .transition-modal-countdown{margin:0 0 1.5rem;color:var(--text-secondary);font-size:1.1rem}.modal-content--transition .transition-modal-countdown strong{color:var(--accent);font-variant-numeric:tabular-nums}.btn-transition-now{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s,transform .1s}.btn-transition-now:hover{background:var(--accent-hover, #7c4dff)}.btn-transition-now:active{transform:scale(.98)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.form-select,.form-input{width:100%;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem}.form-select:focus,.form-input:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel{padding:.75rem 1.5rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s}.btn-cancel:hover{background:var(--bg-elevated)}.btn-submit{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:background .2s}.btn-submit:hover:not(:disabled){background:var(--accent-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-back{padding:.75rem 1.5rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s}.btn-back:hover{background:var(--bg-elevated)}.form-hint{display:block;margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.task-selector-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.tab-btn{flex:1;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-weight:500;transition:background .2s,border-color .2s}.tab-btn:hover{background:var(--bg-elevated)}.tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}@media (max-width: 768px){.room-page{height:auto;min-height:calc(100vh - 70px);flex-direction:row}.room-main{padding:1rem;flex:1;min-width:0}.room-page--chat-collapsed .room-main{padding-right:52px}.room-header h1{font-size:1.35rem}.room-header-actions{gap:.4rem}.btn-start-session,.btn-finish-session,.btn-leave-room{padding:.5rem .75rem;font-size:.85rem}.task-navigation{padding:.5rem;gap:.35rem .5rem}.btn-nav-task{padding:.4rem .5rem;font-size:.8rem}.task-nav-dot{width:8px;height:8px}.session-task{padding:1rem}.task-header h2{font-size:1.25rem}.room-chat-wrapper--collapsed{position:fixed;right:0;top:0;bottom:0;width:44px;min-width:44px;left:auto;z-index:50}.room-chat-wrapper--collapsed .room-chat-toggle{left:0;right:auto;border-radius:12px 0 0 12px;border-left:3px solid rgba(255,255,255,.4)}.room-chat-wrapper:not(.room-chat-wrapper--collapsed){width:0;min-width:0}.room-chat-wrapper:not(.room-chat-wrapper--collapsed) .room-chat{position:fixed;top:0;right:0;bottom:0;left:0;width:100%!important;min-width:100%!important;z-index:150;border-radius:0;max-height:100vh;opacity:1;pointer-events:auto}.room-chat-wrapper:not(.room-chat-wrapper--collapsed) .room-chat-toggle{position:fixed;top:12px;right:12px;left:auto;transform:none;border-radius:var(--radius-sm);z-index:151;min-height:44px}}.privacy-page{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.privacy-content h1{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-primary)}.privacy-updated{color:var(--text-tertiary);font-size:.9rem;margin-bottom:2rem}.privacy-content section{margin-bottom:1.75rem}.privacy-content h2{font-size:1.15rem;margin-bottom:.5rem;color:var(--text-primary)}.privacy-content p,.privacy-content ul{color:var(--text-secondary);line-height:1.6;margin-bottom:.75rem}.privacy-content ul{padding-left:1.5rem;margin-bottom:1rem}.privacy-contact{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.95rem}.forgot-password-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.forgot-password-card{background:var(--bg-card);padding:40px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);max-width:400px;width:100%}.forgot-password-card h1{margin-bottom:24px;text-align:center}.forgot-password-success{margin-bottom:20px;color:var(--text-secondary);line-height:1.6}.forgot-password-success p{margin-bottom:1rem}.forgot-password-success a{color:var(--accent)}.forgot-password-card .form-group{margin-bottom:20px}.forgot-password-card .form-group label{display:block;margin-bottom:8px;color:var(--text-muted);font-weight:500}.forgot-password-card .form-group input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.forgot-password-card .error{color:var(--error);margin-bottom:16px;padding:12px;background:#ef44441a;border-radius:var(--radius-sm)}.forgot-password-card .form-footer{margin-top:20px;text-align:center;color:var(--text-muted);font-size:.95rem}.forgot-password-card .form-footer a{color:var(--accent)}.reset-password-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.reset-password-card{background:var(--bg-card);padding:40px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);max-width:400px;width:100%}.reset-password-card h1{margin-bottom:24px;text-align:center}.reset-password-success{margin-bottom:20px;color:var(--text-secondary);line-height:1.6}.reset-password-card .form-group{margin-bottom:20px}.reset-password-card .form-group label{display:block;margin-bottom:8px;color:var(--text-muted);font-weight:500}.reset-password-card .form-group input{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.reset-password-card .error{color:var(--error);margin-bottom:16px;padding:12px;background:#ef44441a;border-radius:var(--radius-sm)}.reset-password-card .form-footer{margin-top:20px;text-align:center;color:var(--text-muted);font-size:.95rem}.reset-password-card .form-footer a{color:var(--accent)}.confirm-email-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}.confirm-email-card{background:var(--bg-card);padding:40px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);max-width:420px;width:100%}.confirm-email-card h1{margin-bottom:24px;text-align:center}.confirm-email-success{color:var(--text-secondary);line-height:1.6}.confirm-email-success p{margin-bottom:1rem}.confirm-email-card .btn-link{color:var(--accent);font-weight:500}.confirm-email-card .error{color:var(--error);margin-bottom:16px;padding:12px;background:#ef44441a;border-radius:var(--radius-sm)}.confirm-email-card .form-footer{margin-top:20px;text-align:center;color:var(--text-muted);font-size:.95rem}.confirm-email-card .form-footer a{color:var(--accent)}.subscription-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:24px}.subscription-card{max-width:480px;width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;text-align:center;box-shadow:var(--shadow)}.subscription-icon{font-size:3rem;margin-bottom:16px;line-height:1}.subscription-card h1{font-size:clamp(1.25rem,4vw,1.5rem);margin-bottom:16px;color:var(--text-primary)}.subscription-message{color:var(--warm);margin-bottom:12px;font-size:.95rem}.subscription-desc{color:var(--text-secondary);margin-bottom:16px;line-height:1.6}.subscription-note{color:var(--text-muted);font-size:.9rem;margin-bottom:24px;line-height:1.5}.subscription-plans-loading{color:var(--text-muted);margin-bottom:24px}.subscription-plans{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;text-align:center}.subscription-plan-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;align-items:center;gap:8px}.subscription-plan-name{font-size:1.1rem;margin:0;color:var(--text-primary)}.subscription-plan-price{font-size:1.25rem;font-weight:700;margin:0;color:var(--accent)}.subscription-plan-duration{font-size:.9rem;color:var(--text-muted);margin:0}.btn-subscription.btn-plan{margin-top:auto;padding:10px 20px;background:var(--warm);color:#fff;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-subscription.btn-plan:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.btn-subscription.btn-plan:disabled{opacity:.8;cursor:not-allowed}.subscription-message.subscription-success{color:var(--success, #22c55e)}@media (max-width: 480px){.subscription-plans{grid-template-columns:1fr}}.subscription-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.btn-subscription{display:inline-block;padding:12px 24px;border-radius:var(--radius);font-weight:600;text-decoration:none;transition:var(--transition)}.btn-subscription.btn-primary{background:var(--accent);color:#fff}.btn-subscription.btn-primary:hover{background:var(--accent-hover)}.btn-subscription.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-subscription.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.teacher-page{max-width:900px;margin:0 auto;padding:24px;min-height:60vh;background:var(--bg);color:var(--text)}.teacher-loading,.teacher-error{text-align:center;padding:40px;color:var(--text-muted);background:var(--bg);min-height:200px;display:flex;align-items:center;justify-content:center}.teacher-empty{text-align:center;padding:40px;color:var(--text-muted)}.teacher-error{color:var(--error, #ef4444)}.teacher-header{margin-bottom:24px}.teacher-header .back-link{display:inline-block;color:var(--accent);text-decoration:none;margin-bottom:12px}.teacher-header .back-link:hover{text-decoration:underline}.teacher-tabs{display:flex;gap:8px;margin-bottom:16px}.teacher-tab{padding:10px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);cursor:pointer;font-size:1rem;transition:var(--transition)}.teacher-tab:hover{border-color:var(--accent)}.teacher-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.teacher-desc{color:var(--text-muted);margin-top:8px;font-size:.95rem}.teacher-students-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.teacher-attempts-summary{display:flex;flex-wrap:wrap;gap:16px 24px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;font-size:.95rem}.teacher-attempts-summary strong{color:var(--accent)}.teacher-attempts-list{display:flex;flex-direction:column;gap:12px}.teacher-student-card,.teacher-attempt-card{display:block;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:var(--transition)}.teacher-student-card:hover,.teacher-attempt-card:hover{border-color:var(--accent);background:var(--bg-elevated)}.teacher-student-name,.teacher-attempt-code{font-weight:600;font-size:1.05rem;display:block;margin-bottom:4px}.teacher-student-email,.teacher-attempt-meta{font-size:.9rem;color:var(--text-muted)}a.teacher-student-email{color:inherit;text-decoration:none}a.teacher-student-email:hover{text-decoration:underline}.teacher-student-rooms{font-size:.85rem;color:var(--text-muted);margin-top:4px}.teacher-student-variant-stats{display:block;font-size:.9rem;color:var(--accent);margin-top:6px;font-weight:500}.teacher-attempt-score{display:inline-block;margin-top:8px;font-weight:600;color:var(--accent)}.teacher-attempt-date{display:block;font-size:.85rem;color:var(--text-muted);margin-top:4px}.teacher-attempts-cards{display:none;flex-direction:column;gap:12px;margin-top:16px}.teacher-attempt-card{padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.teacher-attempt-card-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.teacher-attempt-card-num{color:var(--text-muted);font-weight:600}.teacher-attempt-card-pct{margin-left:auto;font-weight:600;color:var(--accent)}.teacher-attempt-card .teacher-attempt-meta{margin-top:6px}.teacher-attempt-card .teacher-attempt-date{margin-top:6px;display:flex;flex-direction:column;gap:2px;font-size:.85rem;color:var(--text-muted)}.teacher-attempt-card .teacher-attempt-open-link{display:inline-block;margin-top:8px;font-size:.9rem}@media (max-width: 768px){.teacher-attempts-cards{display:flex}.teacher-attempts-table-wrap{display:none}.teacher-page{padding:16px}}.teacher-attempts-table-wrap{overflow-x:visible;margin-top:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.teacher-attempts-table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:fixed}.teacher-attempts-table th,.teacher-attempts-table td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--border)}.teacher-attempts-table th{font-weight:600;color:var(--text-muted);background:var(--bg-elevated);white-space:nowrap}.teacher-attempt-date-time-cell{min-width:10rem;vertical-align:top}.teacher-attempt-date-time-cell .teacher-attempt-cell-line{display:block;line-height:1.35}.teacher-attempt-date-time-cell .teacher-attempt-cell-date{margin-bottom:2px}.teacher-attempt-date-time-cell .teacher-attempt-cell-duration{font-size:.9em;color:var(--text-muted)}.teacher-attempts-table tbody tr:hover{background:#ffffff05}.teacher-attempts-table tbody tr:last-child td{border-bottom:none}.teacher-attempts-table td:nth-child(3){max-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.teacher-attempt-code-link{color:var(--accent);font-weight:500;text-decoration:none}.teacher-attempt-code-link:hover{text-decoration:underline}.teacher-attempt-open-link{color:var(--accent);font-size:.9rem;text-decoration:none}.teacher-attempt-open-link:hover{text-decoration:underline}.attempt-summary{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px}.attempt-summary p{margin:4px 0}.tasks-detail-title{font-size:1.15rem;margin-bottom:12px}.tasks-detail-list{display:flex;flex-direction:column;gap:12px}.task-detail-row{padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);border-left:4px solid var(--border)}.task-detail-row.task-detail-correct{border-left-color:var(--success, #22c55e)}.task-detail-row.task-detail-incorrect{border-left-color:var(--error, #ef4444)}.task-detail-num{font-weight:600;display:block;margin-bottom:4px}.task-detail-result{font-size:.95rem;display:block;margin-bottom:8px}.task-detail-correct .task-detail-result{color:var(--success, #22c55e)}.task-detail-incorrect .task-detail-result{color:var(--error, #ef4444)}.task-detail-answer{font-size:.9rem;color:var(--text-muted)}.task-detail-answer strong{color:var(--text)}.task-detail-link{display:inline-block;margin-top:8px;font-size:.9rem;color:var(--accent);text-decoration:none}.task-detail-link:hover{text-decoration:underline}.topic-stats-page{max-width:900px;margin:0 auto;padding:24px;min-height:60vh;background:var(--bg);color:var(--text)}.topic-stats-loading,.topic-stats-error{text-align:center;padding:40px;color:var(--text-muted);background:var(--bg);min-height:200px;display:flex;align-items:center;justify-content:center}.topic-stats-error{color:var(--error, #ef4444)}.topic-stats-header{margin-bottom:24px}.topic-stats-back{display:inline-block;color:var(--accent);text-decoration:none;margin-bottom:12px}.topic-stats-back:hover{text-decoration:underline}.topic-stats-subtitle,.topic-stats-desc{color:var(--text-muted);margin-top:8px;font-size:.95rem}.topic-stats-teacher-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:24px}.topic-stats-teacher-desc{margin:0 0 12px;color:var(--text-muted);font-size:.95rem}.topic-stats-students{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.topic-stats-student-link{display:block;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:inherit;text-decoration:none;transition:var(--transition)}.topic-stats-student-link:hover{border-color:var(--accent);background:var(--bg-card)}.topic-stats-empty{color:var(--text-muted);margin:0}.topic-stats-tabs{display:flex;gap:8px;margin-bottom:20px}.topic-stats-tab{padding:10px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);cursor:pointer;font-size:1rem;transition:var(--transition)}.topic-stats-tab:hover{border-color:var(--accent)}.topic-stats-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.topic-stats-reset-wrap{margin-bottom:20px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.topic-stats-reset-btn{padding:10px 18px;border:1px solid var(--error, #ef4444);border-radius:var(--radius);background:transparent;color:var(--error, #ef4444);cursor:pointer;font-size:.95rem}.topic-stats-reset-btn:hover:not(:disabled){background:#ef444426}.topic-stats-reset-btn:disabled{opacity:.6;cursor:not-allowed}.topic-stats-reset-hint{font-size:.9rem;color:var(--text-muted)}.topic-stats-loading-inline{color:var(--text-muted);margin:0 0 20px}.topic-stats-chart-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.topic-stats-chart-title{margin:0 0 8px;font-size:1.15rem}.topic-stats-legend{font-size:.9rem;color:var(--text-muted);margin-bottom:20px}.topic-stats-old-format-hint{font-size:.9rem;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin:0 0 16px}.topic-stats-horizontal-chart{display:flex;flex-direction:column;gap:6px;padding:4px 0}.topic-stats-horizontal-row{display:flex;align-items:center;gap:12px;min-height:28px;flex-wrap:nowrap}.topic-stats-row-label{flex:0 0 200px;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:0}.topic-stats-row-section{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topic-stats-row-theme{font-size:.9rem;color:var(--text-muted);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topic-stats-row-bar-wrap{flex:1 1 120px;min-width:80px;max-width:320px}.topic-stats-row-bar-track{height:14px;background:var(--bg-elevated);border-radius:7px;overflow:hidden}.topic-stats-row-bar-fill{height:100%;min-width:2px;border-radius:7px;transition:width .35s ease}.topic-stats-row-meta{flex:0 0 auto;display:flex;align-items:center;gap:8px;min-width:0;font-variant-numeric:tabular-nums}.topic-stats-row-value{flex:0 0 auto;font-size:.85rem;font-weight:600;color:var(--text-muted);text-align:right}.topic-stats-row-fraction{flex:0 0 auto;font-size:.85rem;color:var(--text-muted);text-align:right}.topic-stats-no-data{color:var(--text-muted);margin:0;padding:20px 0}@media (max-width: 640px){.topic-stats-page{padding:16px 12px}.topic-stats-chart-wrap{padding:16px}.topic-stats-horizontal-row{gap:8px;min-height:26px}.topic-stats-row-label{flex:0 0 100px;min-width:0}.topic-stats-row-section,.topic-stats-row-theme{font-size:.8rem}.topic-stats-row-bar-wrap{flex:1 1 60px;min-width:50px;max-width:120px}.topic-stats-row-bar-track{height:12px}.topic-stats-row-meta{gap:6px;flex-shrink:0}.topic-stats-row-fraction,.topic-stats-row-value{font-size:.8rem}}:root{--bg: #0f0f14;--bg-secondary: #14141c;--bg-card: #18181f;--bg-elevated: #1e1e28;--bg-tertiary: #1a1a24;--text: #e4e4eb;--text-primary: #e4e4eb;--text-secondary: #b4b4c0;--text-muted: #9898a6;--text-tertiary: #9898a6;--accent: #6366f1;--accent-rgb: 99, 102, 241;--accent-hover: #818cf8;--accent-soft: rgba(99, 102, 241, .15);--border: rgba(128, 128, 128, .2);--warm: #f59e0b;--warm-soft: rgba(245, 158, 11, .12);--success: #22c55e;--error: #ef4444;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .25);--transition: .2s ease;--header-bg: rgba(15, 15, 20, .9);--blob-color: rgba(99, 102, 241, .08)}[data-theme=light]{--bg: #f4f4f8;--bg-secondary: #ebebf2;--bg-card: #ffffff;--bg-elevated: #eaeaf0;--bg-tertiary: #e0e0e8;--text: #1a1a24;--text-primary: #1a1a24;--text-secondary: #4a4a5a;--text-muted: #5c5c6e;--text-tertiary: #6b6b7a;--accent: #4f46e5;--accent-rgb: 79, 70, 229;--accent-hover: #6366f1;--accent-soft: rgba(79, 70, 229, .12);--border: rgba(0, 0, 0, .1);--warm: #d97706;--warm-soft: rgba(217, 119, 6, .12);--shadow: 0 4px 24px rgba(0, 0, 0, .08);--header-bg: rgba(255, 255, 255, .9);--blob-color: rgba(99, 102, 241, .06)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#root{min-height:100vh;display:block;color:inherit}
