@import "https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=Manrope:wght@300;400;500;600;700&display=swap";:root{--sidebar-w:260px;--topbar-h:62px}[data-theme=dark]{--bg:#0f0f13;--surface:#17171f;--surface2:#1e1e28;--border:#252533;--accent:#4f6ef7;--accent2:#e8f03a;--text:#dcdcec;--muted:#6b6b88;--topbar-bg:#0f0f13f0;--card-bg:#17171f;--map-bg:#0f0f13;--green:#34d399;--red:#f87171;--yellow:#fbbf24}[data-theme=light]{--bg:#f4f4f8;--surface:#fff;--surface2:#f0f0f5;--border:#e0e0ea;--accent:#3a5cf5;--accent2:#c8b800;--text:#1a1a2e;--muted:#7070a0;--topbar-bg:#fffffff0;--card-bg:#fff;--map-bg:#f0f0f5;--green:#059669;--red:#dc2626;--yellow:#d97706}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Manrope,sans-serif;font-weight:400;transition:background .3s,color .3s;overflow-x:hidden}.topbar{height:var(--topbar-h);z-index:300;background:var(--topbar-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 28px;transition:background .3s,border-color .3s;display:flex;position:fixed;top:0;left:0;right:0}.topbar-left{align-items:center;gap:12px;display:flex}.sidebar-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:6px;display:none}.sidebar-toggle span{background:var(--muted);border-radius:2px;width:20px;height:2px;display:block}.logo{color:var(--text);cursor:pointer;align-items:center;font-family:Syne,sans-serif;font-size:20px;font-weight:800;text-decoration:none;transition:color .3s;display:flex}[data-theme=dark] .logo{color:#fff}.logo-dot{color:var(--accent)}.topbar-right{align-items:center;gap:10px;display:flex}.theme-toggle{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:38px;height:38px;color:var(--text);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .2s,background .2s;display:flex}.theme-toggle:hover{border-color:var(--accent)}.btn-login{border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:8px 18px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;text-decoration:none;transition:border-color .2s,color .2s}.btn-login:hover{border-color:var(--accent);color:var(--accent)}.btn-register{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:8px;padding:8px 18px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:600;text-decoration:none;transition:opacity .2s,box-shadow .2s;box-shadow:0 0 20px #4f6ef74d}.btn-register:hover{opacity:.87;box-shadow:0 0 28px #4f6ef785}.btn-cabinet{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:7px 14px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;text-decoration:none;transition:border-color .2s,color .2s;display:flex}.btn-cabinet:hover{border-color:var(--accent);color:var(--accent)}.btn-cabinet-ava{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}@keyframes gpulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.08)}}.overlay{z-index:190;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;background:#00000080;transition:opacity .28s;display:none;position:fixed;inset:0}.overlay.open{opacity:1;pointer-events:all;display:block}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;padding:20px;transition:opacity .28s;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:100%;max-width:420px;max-height:90vh;padding:36px 36px 32px;transition:transform .3s cubic-bezier(.34,1.3,.64,1),opacity .25s;position:relative;overflow-y:auto;transform:translateY(18px)scale(.97)}.modal-backdrop.open .modal{transform:translateY(0)scale(1)}.modal::-webkit-scrollbar{width:4px}.modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-close{border:1px solid var(--border);width:30px;height:30px;color:var(--muted);cursor:pointer;background:#7f7fb414;border-radius:8px;justify-content:center;align-items:center;font-size:14px;transition:background .2s,color .2s;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--red);background:#f871711f}.modal-logo{align-items:center;gap:6px;margin-bottom:20px;display:flex}.modal-logo-mark{background:var(--accent);color:#fff;border-radius:6px;padding:4px 8px;font-family:Syne,sans-serif;font-size:13px;font-weight:800}.modal-logo-text{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:800;transition:color .3s}.modal-logo-text span{color:var(--accent)}.modal h2{color:var(--text);margin-bottom:6px;font-family:Syne,sans-serif;font-size:22px;font-weight:800;transition:color .3s}[data-theme=dark] .modal h2{color:#fff}.modal-sub{color:var(--muted);margin-bottom:24px;font-size:13.5px}.modal-tabs{background:var(--surface2);border-radius:9px;gap:0;margin-bottom:20px;padding:3px;display:flex}.modal-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:8px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:background .18s,color .18s}.modal-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #00000026}[data-theme=dark] .modal-tab.active{color:#fff}.form-panel{display:none}.form-panel.active{display:block}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:9px;outline:none;padding:10px 13px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s,background .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--muted)}.form-input--error{border-color:#ef4444!important}.form-input--error:focus{box-shadow:0 0 0 3px #ef444426;border-color:#ef4444!important}.field-error{color:#ef4444;margin-top:5px;font-size:12px;display:block}.field-hint{color:var(--muted);margin-top:5px;font-size:11.5px;display:block}.pwd-strength{align-items:center;gap:8px;margin-top:8px;display:flex}.pwd-strength-bar{flex:1;gap:4px;display:flex}.pwd-strength-seg{border-radius:4px;flex:1;height:4px;transition:background .25s}.pwd-strength-label{white-space:nowrap;font-size:12px;font-weight:600}.form-hint{margin-top:6px;font-size:12px}.form-error{color:var(--red);background:#f871711a;border:1px solid #f871714d;border-radius:8px;margin-bottom:14px;padding:10px 12px;font-size:13px}.form-btn:disabled{opacity:.6;cursor:not-allowed}.form-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:9px;width:100%;margin-top:4px;padding:12px;font-family:Manrope,sans-serif;font-size:14px;font-weight:700;transition:opacity .2s,box-shadow .2s;box-shadow:0 0 20px #4f6ef74d}.form-btn:hover{opacity:.88}.form-divider{text-align:center;color:var(--muted);margin:18px 0 14px;font-size:12px;position:relative}.form-divider:before,.form-divider:after{content:"";background:var(--border);width:calc(50% - 56px);height:1px;position:absolute;top:50%}.form-divider:before{left:0}.form-divider:after{right:0}.oauth-row{gap:8px;display:flex}.oauth-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:flex}.oauth-btn:hover{border-color:var(--accent);color:var(--accent)}.modal-switch{text-align:center;color:var(--muted);margin-top:18px;font-size:13px}.modal-switch a{color:var(--accent);cursor:pointer;text-decoration:none}.modal-switch a:hover{text-decoration:underline}.modal-success{text-align:center;padding:20px 0;display:none}.modal-success.show{display:block}.success-icon{width:60px;height:60px;color:var(--green);background:#34d3991f;border:1px solid #34d3994d;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;font-size:22px;display:flex}.modal-success h3{color:var(--text);margin-bottom:10px;font-family:Syne,sans-serif;font-size:20px;transition:color .3s}[data-theme=dark] .modal-success h3{color:#fff}.modal-success p{color:var(--muted);font-size:14px;line-height:1.6}@media (width<=900px){.sidebar-toggle{display:flex}}@media (width<=560px){.topbar{padding:0 16px}.btn-login,.btn-register{padding:7px 12px;font-size:12.5px}}.layout{padding-top:var(--topbar-h);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);top:var(--topbar-h);z-index:200;background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;transition:background .3s,border-color .3s,width .22s,transform .3s cubic-bezier(.77,0,.175,1);display:flex;position:fixed;bottom:0;left:0;overflow:hidden auto}.sidebar.collapsed{width:58px}.sidebar.collapsed .sidebar-link{justify-content:center;padding:9px 0}.sidebar.collapsed .sidebar-auth{padding:10px 6px 14px}.sidebar.collapsed .sidebar-cabinet-btn{justify-content:center;padding:8px}.sidebar.collapsed .sidebar-auth-btns{align-items:center}.sidebar.collapsed .sidebar-btn-icon{border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text);background:0 0;border-radius:9px;justify-content:center;align-items:center;transition:border-color .2s;display:flex}.sidebar.collapsed .sidebar-btn-icon:hover{border-color:var(--accent);color:var(--accent)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sidebar-body{flex:1;padding:16px 0 10px;overflow-x:hidden}.sidebar.collapsed .sidebar-collapse-btn{justify-content:center;padding:7px 0 10px}.sidebar-group-label{letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);padding:12px 20px 6px;font-size:10px;font-weight:700}.sidebar-link{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:11px;width:100%;padding:10px 20px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:400;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.sidebar-link:hover{color:var(--text);background:#4f6ef70f}.sidebar-link.active{color:var(--text);background:#4f6ef71a;font-weight:500}[data-theme=dark] .sidebar-link.active{color:#fff}[data-theme=light] .sidebar-link.active{color:var(--accent)}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:0}.sl-icon{width:30px;height:30px;color:var(--muted);background:#7f7fb414;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.sidebar-link:hover .sl-icon,.sidebar-link.active .sl-icon{color:var(--accent);background:#4f6ef729}.sidebar-div{background:var(--border);height:1px;margin:10px 18px}.sidebar-ai{cursor:pointer;background:linear-gradient(135deg,#4f6ef724,#e8f03a0f);border:1px solid #4f6ef74d;border-radius:11px;align-items:center;gap:11px;margin:8px 14px;padding:13px;text-decoration:none;transition:border-color .22s,transform .2s;display:flex}.sidebar-ai:hover{border-color:#4f6ef7a6;transform:translate(3px)}.sidebar-ai-icon{width:34px;height:34px;color:var(--accent2);background:#e8f03a21;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-ai-text strong{color:var(--text);margin-bottom:2px;font-size:13px;font-weight:600;transition:color .3s;display:block}[data-theme=dark] .sidebar-ai-text strong{color:#fff}.sidebar-ai-text span{color:var(--muted);font-size:11px;line-height:1.4}.ai-new{background:var(--accent2);color:#111;letter-spacing:1px;text-transform:uppercase;border-radius:3px;flex-shrink:0;align-self:flex-start;margin-left:auto;padding:3px 6px;font-size:8px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;padding:14px 14px 18px}.sidebar-auth{border-top:1px solid var(--border);flex-shrink:0;padding:12px 14px 18px}.sidebar-auth-btns{flex-direction:column;gap:8px;display:flex}.sidebar-btn-login{border:1px solid var(--border);width:100%;color:var(--text);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;background:0 0;border-radius:9px;padding:9px;transition:border-color .2s,color .2s}.sidebar-btn-login:hover{border-color:var(--accent);color:var(--accent)}.sidebar-btn-register{background:var(--accent);color:#fff;width:100%;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;border-radius:9px;padding:9px;transition:opacity .2s}.sidebar-btn-register:hover{opacity:.88}.sidebar-cabinet-btn{border:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:10px;align-items:center;gap:10px;width:100%;padding:9px 10px;transition:border-color .2s;display:flex}.sidebar-cabinet-btn:hover{border-color:var(--accent)}.sidebar-auth-ava{background:linear-gradient(135deg, var(--accent), #7c3aed);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.sidebar-auth-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.sidebar-cta{text-align:center;background:var(--accent);color:#fff;border-radius:9px;padding:11px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .2s;display:block;box-shadow:0 0 18px #4f6ef740}.sidebar-cta:hover{opacity:.85}.sidebar-socials{justify-content:center;gap:8px;margin-top:10px;display:flex}.sidebar-social{border:1px solid var(--border);width:34px;height:34px;color:var(--muted);background:#7f7fb40f;border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:background .2s,border-color .2s;display:flex}.sidebar-social:hover{border-color:var(--accent);color:var(--accent);background:#4f6ef724}.main-content{margin-left:var(--sidebar-w);flex:1;min-width:0;transition:margin-left .22s}.hero{min-height:calc(100vh - var(--topbar-h));flex-direction:column;padding:0 64px;display:flex;position:relative;overflow:hidden}.hero-grid{z-index:0;background-image:linear-gradient(#4f6ef70d 1px,#0000 1px),linear-gradient(90deg,#4f6ef70d 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0}[data-theme=light] .hero-grid{background-image:linear-gradient(#3a5cf514 1px,#0000 1px),linear-gradient(90deg,#3a5cf514 1px,#0000 1px)}.hero-glow{z-index:0;background:radial-gradient(circle,#4f6ef726 0%,#0000 70%);width:560px;height:560px;animation:7s ease-in-out infinite gpulse;position:absolute;top:-80px;right:-60px}.hero-glow2{z-index:0;background:radial-gradient(circle,#e8f03a12 0%,#0000 70%);width:360px;height:360px;animation:9s ease-in-out infinite reverse gpulse;position:absolute;bottom:80px;left:80px}.hero-content{z-index:1;flex-direction:column;flex:1;justify-content:center;max-width:720px;padding:80px 0 40px;display:flex;position:relative}.hero-badge{color:var(--accent);background:#4f6ef71f;border:1px solid #4f6ef747;border-radius:100px;align-items:center;gap:8px;width:fit-content;margin-bottom:28px;padding:5px 13px;font-size:12.5px;font-weight:500;animation:.6s both fadeUp;display:inline-flex}[data-theme=dark] .hero-badge{color:#8fa8ff;background:#4f6ef71f;border-color:#4f6ef747}[data-theme=light] .hero-badge{color:var(--accent);background:#3a5cf514;border-color:#3a5cf540}.hero-badge-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite blink}.hero h1{letter-spacing:-1.5px;color:var(--text);font-family:Syne,sans-serif;font-size:clamp(36px,5.5vw,70px);font-weight:800;line-height:1.06;transition:color .3s;animation:.72s 80ms both fadeUp}[data-theme=dark] .hero h1{color:#fff}[data-theme=light] .hero h1{color:#0f0f20}.hero h1 em{color:var(--accent2);font-style:normal}[data-theme=light] .hero h1 em{color:var(--accent)}.hero-sub{color:var(--muted);max-width:480px;margin-top:20px;font-size:16.5px;font-weight:300;line-height:1.72;animation:.72s .18s both fadeUp}.hero-bottom{flex-wrap:wrap;align-items:center;gap:28px;margin-top:34px;animation:.72s .28s both fadeUp;display:flex}.hero-actions{flex-wrap:wrap;flex-shrink:0;gap:12px;display:flex}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:12px 24px;font-family:Manrope,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 0 24px #4f6ef75c}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 34px #4f6ef78a}.btn-outline{color:var(--text);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:9px;padding:12px 24px;font-family:Manrope,sans-serif;font-size:14px;font-weight:400;text-decoration:none;transition:border-color .2s,color .2s,background .2s}.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:#4f6ef70f}.hero-inline-nav{border:1px solid var(--border);border-radius:9px;flex-shrink:0;align-items:center;gap:0;display:flex;overflow:hidden}.hero-inline-nav a{color:var(--muted);border-right:1px solid var(--border);white-space:nowrap;cursor:pointer;padding:11px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:background .18s,color .18s}.hero-inline-nav a:last-child{border-right:none}.hero-inline-nav a:hover{color:var(--accent);background:#4f6ef714}.about-strip{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:1fr 2fr;align-items:center;gap:54px;padding:54px 64px;transition:background .3s;display:grid}.about-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);font-size:10px;font-weight:700}.about-title{color:var(--text);margin-top:10px;font-family:Syne,sans-serif;font-size:27px;font-weight:700;line-height:1.2;transition:color .3s}[data-theme=dark] .about-title{color:#fff}.about-text{color:var(--muted);font-size:15px;line-height:1.8}.about-text p+p{margin-top:10px}.about-text a{color:var(--accent);text-decoration:none}.about-text a:hover{text-decoration:underline}.section{padding:88px 64px}.section.alt{background:var(--surface);transition:background .3s}.section-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-size:10px;font-weight:700}.section-title{color:var(--text);margin-bottom:42px;font-family:Syne,sans-serif;font-size:clamp(24px,3vw,36px);font-weight:700;line-height:1.15;transition:color .3s}[data-theme=dark] .section-title{color:#fff}.empty-state{text-align:center;border:1.5px dashed var(--border);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-title{color:var(--muted);margin-bottom:6px;font-family:Syne,sans-serif;font-size:16px;font-weight:700}.empty-state-sub{color:var(--muted);opacity:.7;font-size:13px}.links-grid{grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:14px;display:grid}.link-card{background:var(--card-bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:13px;flex-direction:column;gap:12px;padding:26px 22px;text-decoration:none;transition:border-color .22s,transform .22s,background .3s;display:flex}.link-card:hover{border-color:var(--accent);transform:translateY(-3px)}.lc-icon{width:40px;height:40px;color:var(--accent);background:#4f6ef71a;border-radius:9px;justify-content:center;align-items:center;display:flex}.link-card h3{color:var(--text);font-family:Syne,sans-serif;font-size:15px;font-weight:700;transition:color .3s}[data-theme=dark] .link-card h3{color:#fff}.link-card p{color:var(--muted);font-size:12.5px;line-height:1.55}.lc-arrow{color:var(--accent);opacity:0;margin-top:auto;font-size:16px;transition:opacity .2s,transform .2s;transform:translate(-4px)}.link-card:hover .lc-arrow{opacity:1;transform:translate(0)}.ai-card{color:var(--text);cursor:pointer;background:linear-gradient(135deg,#4f6ef71a,#e8f03a0a);border:1px solid #4f6ef747;border-radius:13px;align-items:center;gap:22px;padding:26px 28px;text-decoration:none;transition:border-color .22s,transform .22s;display:flex}[data-theme=light] .ai-card{background:linear-gradient(135deg,#3a5cf512,#c8b80008)}.ai-card:hover{border-color:#4f6ef78c;transform:translateY(-2px)}.ai-card-icon{width:56px;height:56px;color:var(--accent);background:#4f6ef726;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:24px;display:flex}.ai-card-body{flex:1}.ai-badge{background:var(--accent2);color:#111;letter-spacing:1.5px;text-transform:uppercase;border-radius:4px;margin-bottom:8px;padding:3px 7px;font-size:9px;font-weight:800;display:inline-block}.ai-card h3{color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .3s}[data-theme=dark] .ai-card h3{color:#fff}.circles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.circle-card{background:var(--card-bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:13px;flex-direction:column;gap:12px;padding:26px;text-decoration:none;transition:border-color .22s,transform .22s,background .3s;display:flex}.circle-card:hover{border-color:var(--accent);transform:translateY(-3px)}.circle-avatar{border:2px solid #4f6ef740;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;transition:border-color .22s;display:flex}.circle-card:hover .circle-avatar{border-color:var(--accent)}.circle-card h3{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .circle-card h3{color:#fff}.circle-card p{color:var(--muted);font-size:13px;line-height:1.55}.circle-meta{align-items:center;gap:8px;margin-top:auto;display:flex}.circle-count{color:var(--accent);background:#4f6ef71a;border-radius:100px;padding:3px 9px;font-size:12px;font-weight:600}.circle-tag{color:var(--muted);border:1px solid var(--border);background:#7f7fb414;border-radius:100px;padding:3px 9px;font-size:11px}.adv-grid{border:1px solid var(--border);border-radius:14px;grid-template-columns:repeat(3,1fr);gap:2px;display:grid;overflow:hidden}.adv-item{background:var(--bg);border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:34px 30px;transition:background .3s}.adv-item:nth-child(3n){border-right:none}.adv-item:nth-child(n+4){border-bottom:none}.adv-num{color:var(--accent);margin-bottom:10px;font-family:Syne,sans-serif;font-size:40px;font-weight:800;line-height:1}.adv-item h4{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .adv-item h4{color:#fff}.adv-item p{color:var(--muted);font-size:13px;line-height:1.65}.testimonials-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.testimonial{background:var(--surface2);border:1px solid var(--border);border-radius:13px;padding:26px;transition:background .3s}.stars{color:var(--accent2);margin-bottom:12px;font-size:13px}[data-theme=light] .stars{color:#b89e00}.testimonial blockquote{color:var(--muted);margin-bottom:20px;font-size:14px;line-height:1.7}.reviewer{align-items:center;gap:10px;display:flex}.avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.reviewer-info strong{color:var(--text);font-size:13px;font-weight:600;transition:color .3s;display:block}[data-theme=dark] .reviewer-info strong{color:#fff}.reviewer-info span{color:var(--muted);font-size:12px}.partners-row{flex-wrap:wrap;gap:10px;margin-top:32px;display:flex}.partner-chip{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:9px;padding:11px 18px;font-size:13px;font-weight:500;transition:border-color .2s,color .2s,background .3s}.partner-chip:hover{border-color:var(--accent);color:var(--accent)}.contact-grid{grid-template-columns:1fr 1fr;gap:52px;display:grid}.contact-info{flex-direction:column;gap:20px;display:flex}.contact-item{align-items:flex-start;gap:13px;display:flex}.contact-icon{width:38px;height:38px;color:var(--accent);background:#4f6ef71a;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-item h4{color:var(--muted);margin-bottom:3px;font-size:11px;font-weight:500}.contact-item p{color:var(--text);font-size:14px;transition:color .3s}.contact-item a{color:var(--accent);text-decoration:none}.contact-item a:hover{text-decoration:underline}.map-box{background:var(--map-bg);border:1px solid var(--border);height:270px;color:var(--muted);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:13px;transition:background .3s;display:flex;position:relative;overflow:hidden}.map-box:before{content:"";background-image:linear-gradient(#4f6ef70d 1px,#0000 1px),linear-gradient(90deg,#4f6ef70d 1px,#0000 1px);background-size:26px 26px;position:absolute;inset:0}.map-dot{background:var(--accent);z-index:1;border-radius:50%;width:13px;height:13px;animation:2s infinite ping;position:relative}@keyframes ping{0%,to{box-shadow:0 0 0 5px #4f6ef738}50%{box-shadow:0 0 0 13px #4f6ef712}}.map-box span{z-index:1;position:relative}.main-footer{border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:32px 64px;transition:background .3s;display:flex}.main-footer p{color:var(--muted);font-size:12px}.main-footer a{color:var(--accent);text-decoration:none}.main-footer a:hover{text-decoration:underline}.fade-in{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(14px)}.fade-in.visible{opacity:1;transform:none}@media (width<=900px){:root{--sidebar-w:0px}.sidebar{width:260px;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content,.main-footer{margin-left:0}.hero{padding:0 26px}.hero-content{padding:60px 0 36px}.about-strip{grid-template-columns:1fr;gap:18px;padding:38px 26px}.section{padding:60px 26px}.adv-grid{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}.main-footer{padding:26px}.ai-card{flex-direction:column}.hero-inline-nav{display:none}.hero-bottom{flex-direction:column;align-items:flex-start;gap:16px}}@media (width<=560px){.adv-grid{grid-template-columns:1fr}.adv-item{border-right:none!important}.circles-grid{grid-template-columns:1fr}}.hp-circles-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.hp-circle-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:16px;padding:20px;transition:border-color .2s,transform .2s;display:flex}.hp-circle-card:hover{border-color:var(--accent);transform:translateY(-2px)}.hp-circle-emoji{flex-shrink:0;font-size:32px;line-height:1}.hp-circle-info{flex-direction:column;gap:6px;min-width:0;display:flex}.hp-circle-title{font-family:var(--font-head);color:var(--text);font-size:15px;font-weight:700}.hp-circle-dir{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:11px;font-weight:600}.hp-circle-desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.hp-reviews-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.hp-review-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;padding:20px;display:flex}.hp-review-header{align-items:center;gap:12px;display:flex}.hp-review-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2,#7c3aed));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:700;display:flex}.hp-review-author{color:var(--text);font-size:14px;font-weight:600}.hp-review-course{color:var(--muted);margin-top:2px;font-size:12px}.hp-review-stars{color:#fbbf24;letter-spacing:1px;flex-shrink:0;margin-left:auto;font-size:14px}.hp-review-text{color:var(--muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.hp-circle-meta{color:var(--muted);flex-wrap:wrap;gap:8px;margin-top:2px;font-size:12px;display:flex}.admin-topbar{height:var(--topbar-h);z-index:300;background:var(--topbar-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 24px;transition:background .25s,border-color .25s;display:flex;position:fixed;top:0;left:0;right:0}.admin-topbar-left{align-items:center;gap:16px;display:flex}.admin-logo{color:var(--text);cursor:pointer;font-family:Syne,sans-serif;font-size:18px;font-weight:800;text-decoration:none;transition:color .25s}[data-theme=dark] .admin-logo{color:#fff}.admin-logo span{color:var(--accent)}.admin-badge{color:var(--accent);letter-spacing:1px;text-transform:uppercase;background:#4f6ef726;border:1px solid #4f6ef74d;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:600}.admin-topbar-right{align-items:center;gap:10px;display:flex}.theme-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text);border-radius:8px;justify-content:center;align-items:center;transition:border-color .2s;display:flex}.theme-btn:hover{border-color:var(--accent)}.user-chip{background:var(--surface2);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:9px;align-items:center;gap:9px;padding:6px 12px;font-size:13px;font-weight:500;transition:border-color .2s;display:flex}.user-chip:hover{border-color:var(--accent)}.user-ava{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:flex}.back-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:7px 14px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;text-decoration:none;transition:border-color .2s,color .2s}.back-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-layout{padding-top:var(--topbar-h);min-height:100vh;display:flex}.admin-sidebar{width:var(--sidebar-w);top:var(--topbar-h);z-index:200;background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;transition:width .22s,background .25s,border-color .25s;display:flex;position:fixed;bottom:0;left:0;overflow:hidden}.admin-sidebar.collapsed{width:58px}.admin-sidebar::-webkit-scrollbar{width:3px}.admin-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sidebar-inner{flex:1;padding:14px 0;overflow:hidden auto}.admin-sidebar-footer{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:7px;padding:10px 10px 14px;display:flex}.admin-user-chip{align-items:center;gap:9px;padding:6px 4px;display:flex;overflow:hidden}.admin-user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.admin-sidebar-btn{border:1px solid var(--border);width:100%;color:var(--muted);font-size:12.5px;font-weight:600;font-family:var(--font);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border-radius:8px;padding:8px 12px;transition:border-color .2s,color .2s}.admin-sidebar-btn:hover{border-color:var(--accent);color:var(--accent)}.admin-sidebar-btn--logout{color:#ef4444;border-color:#0000}.admin-sidebar-btn--logout:hover{color:#ef4444;background:#ef44440f;border-color:#ef4444}.admin-sidebar-btn--icon{text-align:center;justify-content:center;align-items:center;padding:8px;display:flex}.sidebar-collapse-btn{width:100%;color:var(--muted);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:4px;padding:8px 14px;transition:color .15s;display:flex;overflow:hidden}.sidebar-collapse-btn:hover{color:var(--accent)}.admin-sidebar.collapsed .sidebar-collapse-btn{justify-content:center;padding:8px}.admin-sidebar.collapsed .nav-item{justify-content:center;padding:9px 0}.admin-sidebar.collapsed .nav-icon{margin:0}.admin-sidebar.collapsed .nav-divider{margin:8px 10px}.admin-sidebar.collapsed .admin-user-chip{justify-content:center;padding:6px 0}.admin-sidebar.collapsed .admin-sidebar-footer{align-items:center;padding:10px 6px 14px}.nav-badge--dot{background:var(--accent);width:7px;height:7px;min-width:unset;border-radius:50%;padding:0;position:absolute;top:6px;right:6px}.admin-layout.sidebar-collapsed .admin-main{margin-left:58px}.nav-section-label{letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);padding:12px 18px 5px;font-size:9.5px;font-weight:700}.nav-item{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 18px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:400;text-decoration:none;transition:background .14s,color .14s;display:flex;position:relative}.nav-item:hover{color:var(--text);background:#4f6ef70f}.nav-item.active{color:var(--text);background:#4f6ef71c;font-weight:500}[data-theme=dark] .nav-item.active{color:#fff}[data-theme=light] .nav-item.active{color:var(--accent)}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:7px;bottom:7px;left:0}.nav-icon{width:28px;height:28px;color:var(--muted);background:#7f7fb412;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .14s;display:flex}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{color:var(--accent);background:#4f6ef726}.nav-badge{background:var(--accent);color:#fff;text-align:center;border-radius:100px;min-width:20px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:700}.nav-divider{background:var(--border);height:1px;margin:8px 16px}.admin-main{margin-left:var(--sidebar-w);flex:1;min-width:0;padding:32px 36px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{color:var(--text);font-family:Syne,sans-serif;font-size:26px;font-weight:800;line-height:1.1;transition:color .25s}[data-theme=dark] .page-title{color:#fff}.page-subtitle{color:var(--muted);margin-top:4px;font-size:13.5px}.btn-add{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:9px;align-items:center;gap:8px;padding:10px 18px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:600;transition:opacity .2s,box-shadow .2s;display:flex;box-shadow:0 0 20px #4f6ef747}.btn-add:hover{opacity:.87}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:20px 18px;transition:background .25s}.stat-label{color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{color:var(--text);font-family:Syne,sans-serif;font-size:30px;font-weight:800;line-height:1;transition:color .25s}[data-theme=dark] .stat-value{color:#fff}.stat-change{color:var(--green);margin-top:5px;font-size:11.5px}.stat-change.neg{color:var(--red)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:14px;transition:background .25s;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.search-box{background:var(--surface2);border:1px solid var(--border);max-width:300px;color:var(--muted);border-radius:9px;flex:1;align-items:center;gap:9px;padding:8px 13px;transition:border-color .2s;display:flex}.search-box:focus-within{border-color:var(--accent)}.search-box input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-family:Manrope,sans-serif;font-size:13.5px}.search-box input::placeholder{color:var(--muted)}.filter-row{flex-wrap:wrap;gap:8px;display:flex}.filter-chip{cursor:pointer;border:1px solid var(--border);color:var(--muted);background:0 0;border-radius:7px;padding:6px 13px;font-family:Manrope,sans-serif;font-size:12.5px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.filter-chip.active{border-color:var(--accent);color:var(--accent);background:#4f6ef726}table{border-collapse:collapse;width:100%}th{text-align:left;letter-spacing:1px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface2);padding:12px 20px;font-size:11px;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text);padding:14px 20px;font-size:13.5px}tr:last-child td{border-bottom:none}tr:hover td{background:#4f6ef708}.cell-title{color:var(--text);font-size:13.5px;font-weight:600;transition:color .25s}[data-theme=dark] .cell-title{color:#fff}.cell-meta{color:var(--muted);margin-top:2px;font-size:12px}.status-badge{border-radius:6px;align-items:center;gap:5px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.status-active{color:var(--green);background:#34d3991f}.status-draft{color:var(--muted);background:#7f7fb41a}.status-soon{color:var(--yellow);background:#fbbf241f}.status-archive{color:var(--red);background:#f871711f}.status-upcoming{color:var(--yellow);background:#fbbf241f}.status-closed{color:var(--red);background:#f871711f}.tag{color:var(--accent);background:#4f6ef71a;border-radius:5px;margin:2px 2px 0 0;padding:2px 8px;font-size:11px;display:inline-block}.action-btns{gap:6px;display:flex}.act-btn{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--muted);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:flex}.act-btn:hover{border-color:var(--accent);color:var(--accent);background:#4f6ef71a}.act-btn.del:hover{border-color:var(--red);color:var(--red);background:#f871711a}.fm-backdrop{z-index:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;padding:20px;transition:opacity .25s;display:flex;position:fixed;inset:0}.fm-backdrop.open{opacity:1;pointer-events:all}.fm-modal{background:var(--surface);border:1px solid var(--border);opacity:0;border-radius:18px;width:100%;max-width:600px;max-height:90vh;transition:transform .3s cubic-bezier(.34,1.3,.64,1),opacity .25s;overflow-y:auto;transform:translateY(16px);box-shadow:0 30px 80px #0000004d}.fm-backdrop.open .fm-modal{opacity:1;transform:translateY(0)}.fm-modal::-webkit-scrollbar{width:4px}.fm-modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.fm-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;border-radius:18px 18px 0 0;justify-content:space-between;align-items:center;padding:22px 26px;display:flex;position:sticky;top:0}.fm-title{color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:800;transition:color .25s}[data-theme=dark] .fm-title{color:#fff}.fm-close{border:1px solid var(--border);width:32px;height:32px;color:var(--muted);cursor:pointer;background:#7f7fb414;border-radius:8px;justify-content:center;align-items:center;font-size:16px;transition:background .2s,color .2s;display:flex}.fm-close:hover{color:var(--red);background:#f871711f}.fm-body{padding:24px 26px}.form-group{margin-bottom:18px}.form-label{color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:7px;font-size:12px;font-weight:700;display:block}.form-input,.form-select,.form-textarea{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:9px;outline:none;padding:11px 14px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s,background .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}.form-textarea{resize:vertical;min-height:90px}.form-select{cursor:pointer}.form-row2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.toggle-row{background:var(--surface2);border:1px solid var(--border);border-radius:9px;justify-content:space-between;align-items:center;padding:13px 14px;display:flex}.toggle-label{color:var(--text);font-size:13.5px;font-weight:500}.toggle-sub{color:var(--muted);margin-top:2px;font-size:12px}.toggle-switch{background:var(--border);cursor:pointer;border:none;border-radius:100px;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.toggle-switch.on{background:var(--accent)}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle-switch.on:after{transform:translate(18px)}.fm-footer{border-top:1px solid var(--border);background:var(--surface);border-radius:0 0 18px 18px;justify-content:flex-end;gap:10px;padding:18px 26px;display:flex;position:sticky;bottom:0}.btn-cancel{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:9px;padding:10px 18px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;transition:border-color .2s,color .2s}.btn-cancel:hover{border-color:var(--muted);color:var(--text)}.btn-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:10px 22px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:700;transition:opacity .2s;box-shadow:0 0 16px #4f6ef747}.btn-save:hover{opacity:.87}.section-panel{display:none}.section-panel.active{display:block}.news-cards-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:16px;display:grid}.news-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:20px 22px;transition:border-color .2s,background .25s;display:flex}.news-card:hover{border-color:#4f6ef766}.news-card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.news-card-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.news-cat-chip{color:var(--accent);background:#4f6ef71f;border-radius:6px;padding:3px 9px;font-size:11px;font-weight:600}.news-date{color:var(--muted);font-size:12px}.news-card-title{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;line-height:1.3;transition:color .25s}[data-theme=dark] .news-card-title{color:#fff}.news-card-summary{color:var(--muted);flex:1;font-size:13.5px;line-height:1.6}.news-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:4px;padding-top:12px;display:flex}.news-author{color:var(--muted);font-size:12.5px}.dashboard-grid{grid-template-columns:2fr 1fr;gap:18px;display:grid}.widget{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.widget-title{color:var(--text);border-bottom:1px solid var(--border);padding:16px 20px;font-family:Syne,sans-serif;font-size:15px;font-weight:700;transition:color .25s}[data-theme=dark] .widget-title{color:#fff}.activity-list{flex-direction:column;gap:0;display:flex}.activity-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:13px 20px;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.activity-col{flex-direction:column;display:flex}.activity-text{color:var(--text);font-size:13px;line-height:1.4}.activity-time{color:var(--muted);margin-top:2px;font-size:11px}.activity-section-tag{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--surface2);border-radius:4px;margin-right:2px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.dash-course-list{flex-direction:column;display:flex}.dash-course-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;font-size:13px;display:flex}.dash-course-row:last-child{border-bottom:none}.dash-rank{color:var(--muted);flex-shrink:0;width:24px;font-size:11px;font-weight:700}.dash-course-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.dash-enroll-count{color:var(--accent);white-space:nowrap;font-size:13px;font-weight:700}.dash-enroll-count span{color:var(--muted);margin-left:2px;font-size:11px;font-weight:400}.status-badge.status-student{color:#6366f1;background:#6366f11f}.status-badge.status-teacher{color:#b45309;background:#f59e0b1f}.status-badge.status-admin{color:#dc2626;background:#ef44441f}.quick-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;border-radius:10px;align-items:center;gap:10px;width:100%;padding:12px 16px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;transition:border-color .2s,background .2s;display:flex}.quick-btn:hover{border-color:var(--accent);background:#4f6ef70f}.quick-btn-icon{width:22px;height:22px;color:var(--muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:20px;display:grid}.course-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;transition:border-color .2s,transform .2s;overflow:hidden}.course-card--clickable{cursor:pointer}.course-card--clickable:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.course-card-top{border-bottom:1px solid var(--border);padding:20px}.course-card-dir{color:var(--accent);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.course-card-title{color:var(--text);margin-bottom:6px;font-family:Syne,sans-serif;font-size:16px;font-weight:800;line-height:1.2;transition:color .25s}[data-theme=dark] .course-card-title{color:#fff}.course-card-desc{color:var(--muted);font-size:12.5px;line-height:1.5}.course-card-body{padding:16px}.course-progress-label{color:var(--muted);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.course-progress-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.course-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.course-stats-row{gap:16px;margin-top:14px;display:flex}.course-stat{color:var(--muted);align-items:center;gap:5px;font-size:12px;display:flex}.course-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.course-add-card{cursor:pointer;min-height:220px;color:var(--muted);text-align:center;justify-content:center;align-items:center;display:flex;border:1.5px dashed var(--border)!important;background:0 0!important;transition:border-color .2s!important}.course-add-card:hover{border-color:var(--accent)!important}.settings-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.cb-page{z-index:400;background:var(--bg);padding-top:var(--topbar-h);flex-direction:column;transition:background .25s;display:none;position:fixed;inset:0}.cb-page.open{display:flex}.cb-topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.cb-title-area{align-items:center;gap:12px;display:flex}.cb-back{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-family:Manrope,sans-serif;font-size:13px;transition:color .2s;display:flex}.cb-back:hover{color:var(--text)}.cb-label{color:var(--muted);font-size:13px}.cb-label span{color:var(--text);font-weight:600;transition:color .25s}[data-theme=dark] .cb-label span{color:#fff}.cb-actions{gap:8px;display:flex}.cb-btn-secondary{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s}.cb-btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.cb-btn-publish{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:700}.cb-layout{flex:1;grid-template-columns:240px 1fr;display:grid;overflow:hidden}.cb-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow-y:auto}.cb-sidebar::-webkit-scrollbar{width:3px}.cb-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.cb-sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.cb-sidebar-title{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:12px;font-weight:700}.cb-add-stage{color:var(--accent);cursor:pointer;background:#4f6ef71f;border:1px solid #4f6ef740;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-family:Manrope,sans-serif;font-size:11.5px;font-weight:600;transition:background .2s;display:flex}.cb-add-stage:hover{background:#4f6ef738}.cb-stage-item{border-bottom:1px solid var(--border)}.cb-stage-header{cursor:pointer;align-items:center;gap:10px;padding:12px 14px;transition:background .14s;display:flex;position:relative}.cb-stage-header:hover{background:#4f6ef70d}.cb-stage-item.active .cb-stage-header{background:#4f6ef71a}.cb-stage-num{width:24px;height:24px;color:var(--muted);background:#7f7fb41a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.cb-stage-item.active .cb-stage-num{background:var(--accent);color:#fff}.cb-stage-num.final{color:var(--green);background:#34d39926}.cb-stage-name{color:var(--text);font-size:13px;font-weight:500}.cb-stage-item.active .cb-stage-name{color:var(--text);font-weight:600}[data-theme=dark] .cb-stage-item.active .cb-stage-name{color:#fff}[data-theme=light] .cb-stage-item.active .cb-stage-name{color:var(--accent)}.cb-stage-type{color:var(--muted);margin-top:2px;font-size:11px}.cb-stage-del{width:22px;height:22px;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;transition:background .15s,border-color .15s,color .15s;display:flex}.cb-stage-del:hover{border-color:var(--red);color:var(--red);background:#f871711f}.cb-test-item{border-bottom:1px solid var(--border)}.cb-test-header{cursor:pointer;align-items:center;gap:10px;padding:12px 14px;transition:background .14s;display:flex}.cb-test-header:hover{background:#34d3990d}.cb-test-item.active .cb-test-header{background:#34d39914}.cb-test-badge{letter-spacing:1px;color:var(--green);background:#34d3991f;border:1px solid #34d39933;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:8px;font-weight:700}.cb-content{padding:32px;overflow-y:auto}.cb-content::-webkit-scrollbar{width:4px}.cb-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.cb-placeholder{text-align:center;color:var(--muted);padding:80px 40px}.cb-placeholder-icon{opacity:.4;margin-bottom:16px}.cb-placeholder-title{color:var(--text);margin-bottom:10px;font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .25s}[data-theme=dark] .cb-placeholder-title{color:#fff}.cb-placeholder-sub{color:var(--muted);max-width:420px;margin:0 auto;font-size:13.5px;line-height:1.6}.cb-editor-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cb-editor-title{color:var(--text);font-family:Syne,sans-serif;font-size:20px;font-weight:800;transition:color .25s}[data-theme=dark] .cb-editor-title{color:#fff}.cb-stage-name-input{color:var(--text);background:0 0;border:none;border-bottom:2px solid #0000;outline:none;width:100%;font-family:Syne,sans-serif;font-size:20px;font-weight:800;transition:border-color .2s,color .25s}[data-theme=dark] .cb-stage-name-input{color:#fff}.cb-stage-name-input:focus{border-bottom-color:var(--accent)}.cb-block{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;transition:background .25s;overflow:hidden}.cb-block-header{border-bottom:1px solid var(--border);background:var(--surface2);align-items:center;gap:10px;padding:12px 16px;transition:background .25s;display:flex}.cb-block-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.cb-block-del{border:1px solid var(--border);width:24px;height:24px;color:var(--muted);cursor:pointer;background:0 0;border-radius:5px;justify-content:center;align-items:center;margin-left:auto;transition:all .15s;display:flex}.cb-block-del:hover{border-color:var(--red);color:var(--red);background:#f871711f}.cb-block-body{padding:14px 16px}.cb-block-textarea{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;border-radius:8px;outline:none;min-height:100px;padding:10px 13px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s}.cb-block-textarea:focus{border-color:var(--accent)}.cb-block-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;margin-bottom:8px;padding:10px 13px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s}.cb-block-input::placeholder{color:var(--muted)}.cb-block-input:focus{border-color:var(--accent)}.add-block-row{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.add-block-btn{color:var(--accent);cursor:pointer;background:#4f6ef714;border:1px solid #4f6ef72e;border-radius:7px;align-items:center;gap:6px;padding:7px 13px;font-family:Manrope,sans-serif;font-size:12px;font-weight:600;transition:background .15s;display:flex}.add-block-btn:hover{background:#4f6ef729}.cb-question{background:var(--surface2);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:14px}.cb-question-text{color:var(--text);margin-bottom:10px;font-size:13.5px;font-weight:500;transition:color .25s}[data-theme=dark] .cb-question-text{color:#fff}.cb-option{color:var(--muted);align-items:center;gap:8px;padding:5px 0;font-size:13px;display:flex}.cb-option.correct{color:var(--green)}.cb-option-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:6px;height:6px}.cb-option.correct .cb-option-dot{background:var(--green)}.add-question-btn{color:var(--green);cursor:pointer;background:#34d39914;border:1px solid #34d39933;border-radius:7px;align-items:center;gap:6px;margin-top:8px;padding:8px 14px;font-family:Manrope,sans-serif;font-size:12px;font-weight:600;transition:background .15s;display:flex}.add-question-btn:hover{background:#34d39926}.toast-container{z-index:900;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;min-width:260px;padding:13px 16px;transition:transform .35s cubic-bezier(.34,1.3,.64,1);display:flex;transform:translate(120%);box-shadow:0 8px 30px #00000026}.toast.show{transform:translate(0)}.toast-icon{flex-shrink:0;display:flex}.toast-text{flex-direction:column;display:flex}.toast-text strong{color:var(--text);font-size:13px;font-weight:600;transition:color .25s}[data-theme=dark] .toast-text strong{color:#fff}.toast-text span{color:var(--muted);margin-top:2px;font-size:11.5px}@media (width<=768px){:root{--sidebar-w:0px}.admin-sidebar{display:none}.admin-main{margin-left:0;padding:20px 16px}.dashboard-grid,.form-row2,.settings-grid,.cb-layout{grid-template-columns:1fr}.cb-sidebar{display:none}}.adm-part-overlay{z-index:400;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.adm-part-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:680px;max-height:80vh;display:flex;box-shadow:0 20px 60px #0000004d}.adm-part-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.adm-part-title{color:var(--text);font-size:15px;font-weight:700}.adm-part-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:18px;transition:background .15s}.adm-part-close:hover{background:var(--surface2)}.adm-part-empty{text-align:center;color:var(--muted);padding:40px;font-size:14px}.adm-part-table{border-collapse:collapse;width:100%;overflow-y:auto}.adm-part-modal .adm-part-table{display:block;overflow-y:auto}.adm-part-table thead th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface);padding:10px 16px;font-size:11px;position:sticky;top:0}.adm-part-table tbody tr{border-bottom:1px solid var(--border)}.adm-part-table tbody tr:last-child{border-bottom:none}.adm-part-table tbody tr:hover{background:var(--surface2)}.adm-part-table td{color:var(--text);padding:10px 16px;font-size:13px}.adm-part-table td:first-child{color:var(--muted);width:36px}.status-pending{color:#d97706;background:#f59e0b26;border:1px solid #f59e0b4d}.status-rejected{color:#dc2626;background:#ef44441f;border:1px solid #ef444440}.act-btn.approve{color:#22c55e}.act-btn.approve:hover{background:#22c55e1f}.act-btn.reject{color:#ef4444}.act-btn.reject:hover{background:#ef44441f}.course-card--pending{border-color:#f59e0b80}.row-pending{background:#f59e0b0a}.adm-pending-badge{color:#d97706;background:#f59e0b26;border-radius:20px;margin-left:10px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.adm-rejection-note{color:#ef4444;background:#ef444414;border-radius:6px;margin-top:5px;padding:4px 8px;font-size:11px}.adm-reject-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;box-shadow:0 20px 60px #0000004d}.adm-reject-body{padding:16px 20px}.adm-reject-hint{color:var(--muted);margin-bottom:12px;font-size:13px}.adm-reject-textarea{resize:vertical;background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);box-sizing:border-box;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13px}.adm-reject-textarea:focus{border-color:var(--accent);outline:none}.adm-reject-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.btn-reject-confirm{cursor:pointer;color:#fff;background:#ef4444;border:none;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600}.btn-reject-confirm:hover{background:#dc2626}.news-img-upload{flex-direction:column;gap:10px;display:flex}.news-img-preview{border:1px solid var(--border);border-radius:10px;width:100%;max-height:180px;position:relative;overflow:hidden}.news-img-preview img{object-fit:cover;width:100%;height:180px;display:block}.news-img-remove{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;display:flex;position:absolute;top:8px;right:8px}.news-img-remove:hover{background:#ef4444cc}.news-img-btn{cursor:pointer;border:1px dashed var(--border);background:var(--surface2);color:var(--muted);border-radius:9px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:inline-flex}.news-img-btn:hover{border-color:var(--accent);color:var(--accent)}.news-img-btn.loading{opacity:.6;cursor:default;pointer-events:none}.news-card-img{border-radius:14px 14px 0 0;width:calc(100% + 44px);margin:-20px -22px 0;overflow:hidden}.news-card-img img{object-fit:cover;width:100%;height:160px;display:block}.cp-topbar,.le-topbar{z-index:100;background:var(--card-bg);border-bottom:1px solid var(--border);align-items:center;gap:16px;height:56px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.cp-back,.le-back{border:1px solid var(--border);color:var(--text-2);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;transition:border-color .15s,color .15s;display:flex}.cp-back:hover,.le-back:hover{border-color:var(--accent);color:var(--accent)}.cp-course-title,.le-course-name{color:var(--text);font-size:15px;font-weight:600;font-family:var(--font-head);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.le-count{color:var(--text-2);white-space:nowrap;font-size:13px}.cp-progress-area{align-items:center;gap:10px;display:flex}.cp-progress-bar{background:var(--border);border-radius:3px;width:140px;height:6px;overflow:hidden}.cp-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s}.cp-progress-label{color:var(--text-2);white-space:nowrap;font-size:12px}.cp-root,.le-root{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.cp-layout,.le-layout{flex:1;padding-top:56px;display:flex}.cp-sidebar,.le-sidebar{border-right:1px solid var(--border);background:var(--card-bg);flex-direction:column;gap:2px;width:280px;min-width:240px;padding:16px 0;display:flex;overflow-y:auto}.cp-sidebar-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);padding:0 16px 10px;font-size:11px;font-weight:700}.cp-empty-lessons,.le-empty{text-align:center;color:var(--text-2);padding:24px 16px;font-size:13px}.cp-lesson-item{cursor:pointer;text-align:left;width:100%;color:var(--text);font-family:var(--font-body);background:0 0;border:none;border-radius:0;align-items:center;gap:10px;padding:10px 16px;font-size:13px;transition:background .12s;display:flex}.cp-lesson-item:hover:not(:disabled){background:var(--hover)}.cp-lesson-item.active{background:color-mix(in srgb, var(--accent) 10%, transparent)}.cp-lesson-item.done .cp-lesson-title{color:var(--text-2)}.cp-lesson-item.locked{opacity:.5;cursor:not-allowed}.cp-lesson-item.locked:hover{background:0 0}.cp-lesson-num{background:var(--border);width:24px;height:24px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;transition:background .2s,color .2s;display:flex}.cp-lesson-num.done{background:var(--accent);color:#000}.cp-lesson-num.locked{border:1.5px dashed var(--border);background:0 0}.cp-lesson-item.active .cp-lesson-num{background:var(--accent);color:#000}.cp-lesson-info{flex-direction:column;flex:1;gap:2px;display:flex}.cp-lesson-title{font-weight:500;line-height:1.3}.cp-lesson-dur{color:var(--text-2);font-size:11px}.cp-lesson-meta{color:var(--text-2);align-items:center;gap:4px;font-size:11px;display:flex}.cp-main,.le-editor{flex-direction:column;flex:1;padding:32px;display:flex;overflow-y:auto}.cp-enroll-banner{background:color-mix(in srgb, var(--accent) 8%, transparent);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);color:var(--text-2);border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:14px 18px;font-size:14px;display:flex}.cp-enroll-btn{background:var(--accent);color:#000;cursor:pointer;white-space:nowrap;font-size:13px;font-weight:700;font-family:var(--font-body);border:none;border-radius:8px;padding:8px 18px;transition:opacity .15s}.cp-enroll-btn:disabled{opacity:.5;cursor:not-allowed}.cp-enroll-promo-row{flex-direction:column;flex:1;gap:8px;display:flex}.cp-enroll-price-tag{color:var(--text);font-size:13px;font-weight:600}.cp-promo-input-wrap{align-items:center;gap:8px;display:flex}.cp-promo-input{border:1.5px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font-body);letter-spacing:.05em;border-radius:8px;outline:none;flex:1;padding:7px 12px;transition:border-color .15s}.cp-promo-input:focus{border-color:var(--accent)}.cp-promo-input--error{border-color:#f87171!important}.cp-promo-input--ok{border-color:#34d399!important}.cp-promo-check-btn{border:1.5px solid var(--border);background:var(--surface2);color:var(--text-2);font-size:13px;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border-radius:8px;padding:7px 14px;transition:border-color .15s,color .15s}.cp-promo-check-btn:hover{border-color:var(--accent);color:var(--accent)}.cp-promo-msg{font-size:12px}.cp-promo-msg--error{color:#f87171}.cp-promo-msg--ok{color:#34d399}.cp-lesson-content{flex-direction:column;gap:20px;max-width:780px;display:flex}.cp-lesson-header{align-items:center;gap:14px;display:flex}.cp-lesson-h1{color:var(--text);font-size:24px;font-weight:700;font-family:var(--font-head)}.cp-dur-chip{color:var(--text-2);background:var(--border);white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:12px}.cp-video-wrap{background:#000;border-radius:12px;padding-top:56.25%;position:relative;overflow:hidden}.cp-video{border:none;width:100%;height:100%;position:absolute;inset:0}.cp-content-text{color:var(--text);font-size:15px;line-height:1.75}.cp-content-text p{margin:0 0 8px}.cp-no-content{color:var(--text-2);font-size:14px;font-style:italic}.cp-type-badge{background:var(--border);color:var(--text-2);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.cp-type-badge[data-type=quiz]{color:#b45309;background:#f59e0b26}.cp-type-badge[data-type=code]{color:#1d4ed8;background:#3b82f626}@media (prefers-color-scheme:dark){.cp-type-badge[data-type=quiz]{color:#fbbf24}.cp-type-badge[data-type=code]{color:#60a5fa}}.cp-nav-row{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:10px;margin-top:auto;padding-top:16px;display:flex}.cp-lesson-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding-top:16px;display:flex}.cp-nav-btns{gap:10px;display:flex}.cp-nav-btn{background:var(--card-bg);border:1px solid var(--border);color:var(--text);cursor:pointer;font-family:var(--font-body);border-radius:8px;padding:8px 16px;font-size:13px}.cp-nav-btn.primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700}.cp-nav-btn:disabled{opacity:.4;cursor:default}.cp-complete-btn{border:1.5px solid var(--border);color:var(--text-2);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;border-radius:8px;align-items:center;gap:6px;padding:9px 20px;transition:all .15s;display:flex}.cp-complete-btn.done{background:var(--accent);border-color:var(--accent);color:#000}.cp-complete-btn:hover:not(.done){border-color:var(--accent);color:var(--accent)}.cp-complete-btn:disabled{opacity:.6;cursor:default}.cp-select-lesson,.le-select-hint{color:var(--text-2);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-size:15px;display:flex}.cp-loading,.le-loading{height:100vh;color:var(--text-2);justify-content:center;align-items:center;font-size:16px;display:flex}.le-add-row{flex-wrap:wrap;gap:6px;padding:12px 12px 10px;display:flex}.le-add-input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:var(--font-body);border-radius:8px;flex:1;padding:8px 12px}.le-add-input::placeholder{color:var(--text-2)}.le-add-input:focus{border-color:var(--accent);outline:none}.le-add-btn{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:20px;font-weight:700;display:flex}.le-add-btn:disabled{opacity:.5;cursor:default}.le-lesson-item{border-bottom:1px solid var(--border);align-items:center;gap:0;transition:background .1s;display:flex}.le-lesson-item:hover{background:var(--hover)}.le-lesson-item.active{background:color-mix(in srgb, var(--accent) 10%, transparent)}.le-lesson-select{cursor:pointer;text-align:left;font-family:var(--font-body);background:0 0;border:none;flex:1;align-items:center;gap:10px;padding:10px 12px;display:flex}.le-lesson-num{background:var(--border);width:22px;height:22px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.le-lesson-item.active .le-lesson-num{background:var(--accent);color:#000}.le-lesson-title{color:var(--text);font-size:13px;font-weight:500;line-height:1.3}.le-lesson-actions{gap:2px;padding-right:8px;display:flex}.le-lesson-actions button{width:26px;height:26px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:13px;display:flex}.le-lesson-actions button:hover{background:var(--hover);color:var(--text)}.le-lesson-actions button:disabled{opacity:.3;cursor:default}.le-del:hover{color:var(--red,#ef4444)!important}.le-del-sm{width:26px;height:26px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.le-del-sm:hover{color:var(--red,#ef4444);background:var(--hover)}.le-type-dot{width:20px;height:20px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.le-type-dot--quiz{color:#f59e0b}.le-type-dot--code{color:#3b82f6}.le-type-select{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:12px;font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:6px 8px}.le-type-select:focus{border-color:var(--accent);outline:none}.le-row2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.le-select{cursor:pointer}.le-field{flex-direction:column;gap:6px;display:flex}.le-field--grow{flex:1}.le-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.le-hint{text-transform:none;letter-spacing:0;font-size:11px;font-weight:400}.le-input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:14px;font-family:var(--font-body);border-radius:8px;padding:9px 12px}.le-input:focus{border-color:var(--accent);outline:none}.le-textarea{resize:vertical;background:var(--bg);border:1px solid var(--border);min-height:220px;color:var(--text);font-size:14px;font-family:var(--font-body);border-radius:8px;flex:1;padding:12px;line-height:1.6}.le-textarea:focus{border-color:var(--accent);outline:none}.le-footer{border-top:1px solid var(--border);padding-top:16px}.le-save-btn{background:var(--accent);color:#000;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);border:none;border-radius:8px;padding:10px 24px}.le-save-btn:disabled{opacity:.6;cursor:default}.le-editor{gap:20px}.quiz-root{flex-direction:column;gap:20px;max-width:680px;display:flex}.quiz-question{background:var(--card-bg);border:1.5px solid var(--border);border-radius:12px;flex-direction:column;gap:14px;padding:20px;transition:border-color .2s;display:flex}.quiz-question.correct{border-color:#22c55e}.quiz-question.wrong{border-color:#ef4444}.quiz-q-text{color:var(--text);font-size:16px;font-weight:600;line-height:1.4}.quiz-options{flex-direction:column;gap:8px;display:flex}.quiz-option{cursor:pointer;border:1.5px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:10px;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.quiz-option:hover:not(.is-correct):not(.is-wrong){border-color:var(--accent)}.quiz-option input[type=radio]{accent-color:var(--accent);flex-shrink:0;width:15px;height:15px}.quiz-option.is-correct{background:#22c55e1a;border-color:#22c55e}.quiz-option.is-wrong{background:#ef44441a;border-color:#ef4444}.quiz-option-text{color:var(--text);font-size:14px}.quiz-explanation{border-left:3px solid;border-radius:8px;align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;line-height:1.55;display:flex}.quiz-explanation.correct{color:var(--text);background:#22c55e14;border-color:#22c55e}.quiz-explanation.wrong{color:var(--text);background:#ef444414;border-color:#ef4444}.quiz-explanation-icon{flex-shrink:0;margin-top:1px;font-weight:700}.quiz-explanation.correct .quiz-explanation-icon{color:#16a34a}.quiz-explanation.wrong .quiz-explanation-icon{color:#dc2626}.quiz-submit-btn{background:var(--accent);color:#000;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);border:none;border-radius:8px;align-self:flex-start;padding:11px 28px;transition:opacity .15s}.quiz-submit-btn:disabled{opacity:.45;cursor:default}.quiz-result{text-align:center;border:2px solid;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:24px;display:flex}.quiz-result.pass{background:#22c55e14;border-color:#22c55e}.quiz-result.fail{background:#f59e0b14;border-color:#f59e0b}.quiz-result-score{color:var(--text);font-size:36px;font-weight:800}.quiz-result-text{color:var(--text-2);font-size:15px}.quiz-retry-btn{border:1.5px solid var(--border);color:var(--text);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border-radius:8px;margin-top:4px;padding:8px 20px}.quiz-retry-btn:hover{border-color:var(--accent);color:var(--accent)}.quiz-done-chip{color:#000;background:#22c55e;border-radius:20px;align-items:center;gap:5px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.quiz-editor{flex-direction:column;gap:16px;display:flex}.quiz-q-editor{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;flex-direction:column;gap:12px;padding:16px;display:flex}.quiz-q-header{justify-content:space-between;align-items:center;display:flex}.quiz-q-num{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:700}.quiz-opts-list{flex-direction:column;gap:6px;display:flex}.quiz-opt-row{border:1.5px solid var(--border);background:var(--card-bg);border-radius:8px;align-items:center;gap:8px;padding:6px 10px;transition:border-color .15s;display:flex}.quiz-opt-row.is-correct{background:#22c55e14;border-color:#22c55e}.quiz-opt-row input[type=radio]{accent-color:var(--accent);flex-shrink:0}.quiz-opt-input{background:0 0!important;border:none!important;padding:4px 8px!important}.quiz-opt-input:focus{outline:none}.quiz-add-opt-btn,.quiz-add-q-btn{border:1.5px dashed var(--border);color:var(--text-2);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border-radius:8px;align-self:flex-start;align-items:center;gap:6px;padding:7px 14px;transition:border-color .15s,color .15s;display:flex}.quiz-add-opt-btn:hover,.quiz-add-q-btn:hover{border-color:var(--accent);color:var(--accent)}.quiz-add-q-btn{margin-top:4px}.code-root{flex-direction:column;gap:16px;max-width:780px;display:flex}.code-task-desc{background:color-mix(in srgb, var(--accent) 6%, transparent);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);color:var(--text);border-radius:10px;padding:16px 20px;font-size:14px;line-height:1.7}.code-task-desc p{margin:0 0 6px}.code-editor-header{justify-content:space-between;align-items:center;display:flex}.code-lang-chip{color:#cdd6f4;font-size:12px;font-weight:700;font-family:var(--font-mono,"Fira Code", "JetBrains Mono", monospace);letter-spacing:.04em;background:#1e1e2e;border-radius:20px;padding:4px 12px}.code-editor-actions{gap:8px;display:flex}.code-run-btn,.code-check-btn{cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;transition:opacity .15s;display:flex}.code-run-btn{background:var(--border);color:var(--text)}.code-check-btn{background:var(--accent);color:#000}.code-run-btn:disabled,.code-check-btn:disabled{opacity:.45;cursor:default}.code-run-btn:hover:not(:disabled){border:1px solid var(--accent)}.code-editor{resize:vertical;color:#cdd6f4;width:100%;min-height:260px;font-size:13.5px;line-height:1.65;font-family:var(--font-mono,"Fira Code", "JetBrains Mono", monospace);tab-size:2;background:#1e1e2e;border:1.5px solid #313244;border-radius:10px;padding:16px}.code-editor:focus{border-color:#89b4fa;outline:none}.code-output{flex-direction:column;gap:6px;display:flex}.code-output-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);font-size:11px;font-weight:700}.code-output-pre{color:#cdd6f4;font-size:13px;font-family:var(--font-mono,"Fira Code", monospace);white-space:pre-wrap;word-break:break-word;background:#1e1e2e;border-radius:8px;min-height:48px;margin:0;padding:14px 16px;overflow-x:auto}.code-results{flex-direction:column;gap:6px;display:flex}.code-results-header{border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:700;display:flex}.code-results-header.pass{color:#15803d;background:#22c55e1f}.code-results-header.fail{color:#b91c1c;background:#ef44441f}.code-test-case{border:1.5px solid var(--border);border-radius:8px;flex-direction:column;gap:4px;padding:10px 14px;font-size:13px;display:flex}.code-test-case.pass{border-color:#22c55e}.code-test-case.fail{border-color:#ef4444}.code-test-header{color:var(--text);font-weight:600}.code-test-case.pass .code-test-header{color:#15803d}.code-test-case.fail .code-test-header{color:#b91c1c}.code-test-details{color:var(--text-2);flex-direction:column;gap:2px;font-size:12px;display:flex}.code-test-details code{font-family:var(--font-mono,monospace);background:var(--bg);border-radius:4px;padding:1px 5px}.code-running{color:var(--text-2);padding:8px 0;font-size:13px;font-style:italic}.code-editor-fields{flex-direction:column;gap:16px;display:flex}.le-textarea--sm{min-height:100px}.le-code-ta{min-height:200px;font-family:var(--font-mono,"Fira Code", "JetBrains Mono", monospace);color:#cdd6f4;background:#1e1e2e;border-color:#313244;font-size:13px}.le-code-ta:focus{border-color:#89b4fa}.code-test-editor-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.code-test-editor-row .le-input{flex:1}.ce-root{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.ce-topbar{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;align-items:center;gap:12px;height:56px;padding:0 20px;display:flex}.ce-back{border:1px solid var(--border);color:var(--text-2);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;transition:border-color .15s,color .15s;display:flex}.ce-back:hover{border-color:var(--accent);color:var(--accent)}.ce-title-input{min-width:0;color:var(--text);font-size:16px;font-weight:700;font-family:var(--font-head);background:0 0;border:none;border-bottom:1.5px solid #0000;flex:1;padding:4px 2px;transition:border-color .15s}.ce-title-input:focus{border-bottom-color:var(--accent);outline:none}.ce-title-input::placeholder{color:var(--text-2)}.ce-status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:20px;flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:700}.ce-status--draft{color:#64748b;background:#7f7fb424}.ce-status--soon{color:#b45309;background:#fbbf242e}.ce-status--active{color:#15803d;background:#22c55e2e}.ce-status--archive{color:#b91c1c;background:#ef444424}[data-theme=dark] .ce-status--active{color:#4ade80}[data-theme=dark] .ce-status--soon{color:#fcd34d}[data-theme=dark] .ce-status--archive{color:#f87171}[data-theme=dark] .ce-status--draft{color:#94a3b8}.ce-topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.ce-btn-save{background:var(--accent);color:#000;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-body);border:none;border-radius:8px;padding:7px 18px;transition:opacity .15s}.ce-btn-save:disabled{opacity:.55;cursor:default}.ce-btn-publish{color:#000;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-body);background:#22c55e;border:none;border-radius:8px;padding:7px 16px}.ce-btn-draft{border:1.5px solid var(--border);color:var(--text-2);cursor:pointer;font-size:13px;font-family:var(--font-body);background:0 0;border-radius:8px;padding:6px 14px}.ce-btn-draft:hover{border-color:var(--accent);color:var(--accent)}.ce-btn-save--saved{background:#22c55e!important}.ce-body{flex:1;min-height:0;display:flex;overflow:hidden}.ce-sidenav{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:200px;padding:10px 0 14px;display:flex;overflow-y:auto}.ce-sidenav::-webkit-scrollbar{width:3px}.ce-sidenav::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.ce-nav-back{text-align:left;width:100%;color:var(--muted);font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;align-items:center;gap:9px;margin-bottom:2px;padding:9px 16px;transition:color .13s;display:flex}.ce-nav-back svg{opacity:.7;flex-shrink:0}.ce-nav-back:hover{color:var(--accent)}.ce-nav-back:hover svg{opacity:1}.ce-sidenav-divider{background:var(--border);height:1px;margin:4px 12px 8px}.ce-nav-item{text-align:left;width:100%;color:var(--muted);font-size:13.5px;font-weight:400;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:9px 16px;transition:background .13s,color .13s;display:flex;position:relative}.ce-nav-item:hover{color:var(--text);background:#4f6ef70f}.ce-nav-item.active{color:var(--text);background:#4f6ef71c;font-weight:500}[data-theme=dark] .ce-nav-item.active{color:#fff}[data-theme=light] .ce-nav-item.active{color:var(--accent)}.ce-nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:7px;bottom:7px;left:0}.ce-nav-icon{width:28px;height:28px;color:var(--muted);background:#7f7fb412;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .13s;display:flex}.ce-nav-item:hover .ce-nav-icon,.ce-nav-item.active .ce-nav-icon{color:var(--accent);background:#4f6ef726}.ce-nav-label{white-space:nowrap}.ce-settings{flex:1;padding:28px 0;overflow-y:auto}.ce-settings-inner{flex-direction:column;gap:28px;max-width:680px;margin:0 auto;padding:0 32px;display:flex}.ce-settings-footer{border-top:1px solid var(--border);max-width:680px;margin:16px auto 0;padding:20px 32px 0}.ce-section{flex-direction:column;gap:16px;display:flex}.ce-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:6px;font-size:11px;font-weight:700}.ce-grid2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.ce-field-full{flex-direction:column;gap:6px;display:flex}.ce-desc-ta{min-height:140px}.ce-access-toggle{gap:8px;margin-top:6px;display:flex}.ce-access-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);border-radius:8px;flex:1;padding:10px 14px;transition:border-color .15s,color .15s,background .15s}.ce-access-btn:hover{border-color:var(--accent);color:var(--text)}.ce-access-btn.active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--text)}.ce-promo-wrap{flex:1;max-width:740px;padding:28px 32px;overflow-y:auto}.ce-promo-create{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.ce-promo-form-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ce-promo-code-input{letter-spacing:.06em;flex:1;min-width:140px;font-family:monospace;font-weight:700}.ce-promo-err{color:#f87171;margin-top:8px;font-size:13px}.ce-promo-empty{color:var(--text-2);padding:20px 0;font-size:14px}.ce-promo-list{flex-direction:column;gap:10px;display:flex}.ce-promo-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.ce-promo-item-row{flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex}.ce-promo-code{letter-spacing:.06em;color:var(--text);min-width:100px;font-family:monospace;font-size:14px;font-weight:700}.ce-promo-uses,.ce-promo-exp{color:var(--text-2);font-size:12px}.ce-promo-status{border-radius:20px;padding:3px 8px;font-size:11px;font-weight:700}.ce-promo-status.active{color:#34d399;background:#34d39926}.ce-promo-status.off{color:#f87171;background:#f871711f}.ce-promo-actions{gap:6px;margin-left:auto;display:flex}.ce-promo-btn{border:1px solid var(--border);background:var(--surface2);color:var(--text-2);cursor:pointer;border-radius:7px;align-items:center;gap:3px;padding:5px 10px;font-size:13px;transition:background .12s,color .12s;display:flex}.ce-promo-btn:hover{background:var(--border);color:var(--text)}.ce-promo-btn--del:hover{color:#f87171;background:#f8717126;border-color:#f87171}.ce-promo-usages{border-top:1px solid var(--border);background:color-mix(in srgb, var(--accent) 4%, transparent);padding:12px 16px}.ce-promo-usage-table{border-collapse:collapse;width:100%;font-size:13px}.ce-promo-usage-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:0 0 6px;font-size:11px;font-weight:700}.ce-promo-usage-table td{border-top:1px solid var(--border);color:var(--text);padding:6px 0}.ce-promo-usage-table tr:first-child td{border-top:none}.ce-lessons-wrap{flex:1;display:flex;overflow:hidden}.ce-lessons-wrap .le-layout{flex:1}.ce-stats{flex:1;padding:28px 0;overflow-y:auto}.ce-stats-inner{flex-direction:column;gap:28px;max-width:680px;margin:0 auto;padding:0 32px;display:flex}.ce-stats-loading{color:var(--text-2);text-align:center;padding:48px 32px;font-size:14px}.ce-stat-cards{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.ce-stat-card{background:var(--card-bg);border:1px solid var(--border);text-align:center;border-radius:12px;padding:18px 16px}.ce-stat-value{color:var(--text);font-size:28px;font-weight:800;font-family:var(--font-head);line-height:1}.ce-stat-label{color:var(--text-2);margin-top:6px;font-size:12px;font-weight:500}.ce-lessons-stat-list{flex-direction:column;gap:10px;display:flex}.ce-lesson-stat-row{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:10px 14px;display:flex}.ce-ls-dot{background:var(--border);width:22px;height:22px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:800;display:flex}.ce-ls-dot--lesson{color:#3b82f6;background:#3b82f633}.ce-ls-dot--quiz{color:#a855f7;background:#a855f733}.ce-ls-dot--code{color:#10b981;background:#10b98133}.ce-ls-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.ce-ls-bar-wrap{flex-shrink:0;align-items:center;gap:8px;width:160px;display:flex}.ce-ls-bar{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.ce-ls-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s}.ce-ls-pct{color:var(--text-2);text-align:right;width:32px;font-size:12px;font-weight:700}.ce-ls-count{color:var(--text-2);white-space:nowrap;text-align:right;flex-shrink:0;min-width:48px;font-size:12px}.ce-stats-empty{text-align:center;color:var(--text-2);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.ce-stats-empty p{max-width:320px;font-size:14px;line-height:1.6}.ce-stats-inner--wide{max-width:860px}.ce-stats-topbar{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.ce-stats-page-title{font-family:var(--font-head);color:var(--text);font-size:20px;font-weight:800}.ce-stats-page-sub{color:var(--text-2);margin-top:4px;font-size:13px}.ce-pdf-btn{background:var(--accent);color:#fff;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;padding:9px 18px;font-size:13px;font-weight:600;transition:opacity .18s,box-shadow .18s;display:inline-flex;box-shadow:0 0 18px #4f6ef747}.ce-pdf-btn:hover{opacity:.88}.ce-pdf-btn:disabled{opacity:.65;cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.ce-progress-dist{align-items:flex-end;gap:12px;height:120px;display:flex}.ce-dist-col{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.ce-dist-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;width:100%;display:flex}.ce-dist-count{color:var(--text-2);font-size:12px;font-weight:700}.ce-dist-bar-track{background:var(--border);border-radius:6px 6px 0 0;flex-direction:column;justify-content:flex-end;width:100%;height:80px;display:flex;overflow:hidden}.ce-dist-bar-fill{border-radius:6px 6px 0 0;width:100%;transition:height .5s}.ce-dist-label{color:var(--text-2);white-space:nowrap;font-size:11px}.ce-section-count{background:var(--accent);color:#fff;vertical-align:middle;border-radius:10px;justify-content:center;align-items:center;margin-left:8px;padding:1px 7px;font-size:11px;font-weight:700;display:inline-flex}.ce-students-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:4px;display:flex}.ce-students-search{background:var(--card-bg);border:1px solid var(--border);min-width:180px;color:var(--text);font-family:var(--font-body);border-radius:9px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:border-color .2s}.ce-students-search:focus{border-color:var(--accent)}.ce-students-search::placeholder{color:var(--text-2)}.ce-sort-tabs{gap:4px;display:flex}.ce-sort-tab{border:1px solid var(--border);background:var(--card-bg);color:var(--text-2);font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .18s,color .18s,border-color .18s}.ce-sort-tab.active,.ce-sort-tab:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.ce-students-list{flex-direction:column;gap:8px;display:flex}.ce-student-row{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:12px 16px;transition:border-color .18s;display:flex}.ce-student-row:hover{border-color:color-mix(in srgb, var(--accent) 40%, transparent)}.ce-student-ava{width:36px;height:36px;font-family:var(--font-head);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.ce-student-info{flex:1;min-width:0}.ce-student-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.ce-student-email{color:var(--text-2);margin-top:1px;font-size:12px}.ce-student-progress{flex:1.4;min-width:0}.ce-student-bar-wrap{align-items:center;gap:8px;display:flex}.ce-student-bar{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.ce-student-bar-fill{border-radius:3px;height:100%;transition:width .5s}.ce-student-pct{color:var(--text-2);text-align:right;width:32px;font-size:12px;font-weight:700}.ce-student-meta{color:var(--text-2);gap:10px;margin-top:3px;padding-left:2px;font-size:11px;display:flex}.ce-student-status{white-space:nowrap;border-radius:7px;flex-shrink:0;padding:4px 10px;font-size:11.5px;font-weight:700}.ce-student-wrap{flex-direction:column;display:flex}.ce-student-wrap.open .ce-student-row{border-bottom-color:#0000;border-radius:12px 12px 0 0}.ce-student-chevron{color:var(--text-2);flex-shrink:0;align-items:center;transition:transform .2s;display:flex}.ce-student-chevron.open{transform:rotate(180deg)}.ce-student-row{border-radius:12px}.ce-student-wrap.open .ce-student-row{border-radius:12px 12px 0 0}.ce-student-detail{background:var(--bg);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;flex-direction:column;gap:10px;padding:12px 16px 16px;display:flex}.ce-student-detail-loading{color:var(--text-2);padding:4px 0;font-size:13px}.ce-student-cert{color:var(--text);background:#34d39914;border:1px solid #34d39940;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.ce-student-cert strong{color:#34d399}.ce-student-lessons{flex-direction:column;gap:4px;display:flex}.ce-student-lesson{opacity:.5;border-radius:7px;align-items:center;gap:8px;padding:5px 8px;transition:opacity .15s;display:flex}.ce-student-lesson.done{opacity:1}.ce-sl-icon{background:var(--border);width:20px;height:20px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;display:flex}.ce-student-lesson.done .ce-sl-icon{color:#34d399;background:#34d3992e}.ce-sl-num{color:var(--text-2);flex-shrink:0;min-width:20px;font-size:12px}.ce-sl-title{color:var(--text);flex:1;font-size:13px}.ce-student-lesson:not(.done) .ce-sl-title{color:var(--text-2)}.ce-sl-date{color:var(--text-2);white-space:nowrap;flex-shrink:0;font-size:11px}.ce-print-footer{display:none}html.ce-printing .ce-root{height:auto!important;overflow:visible!important}html.ce-printing .ce-body{height:auto!important;min-height:0!important;display:block!important;overflow:visible!important}html.ce-printing .ce-stats{flex:none!important;height:auto!important;overflow:visible!important}@media print{html,body{height:auto!important;min-height:0!important;overflow:visible!important}.ce-root{flex-direction:column!important;height:auto!important;display:flex!important;overflow:visible!important}.ce-topbar,.ce-sidenav,.ce-no-print,.ce-students-toolbar,.ce-student-chevron,.ce-student-cert svg{display:none!important}.ce-body{height:auto!important;min-height:0!important;display:block!important;overflow:visible!important}.ce-stats{flex:none!important;height:auto!important;padding:16px 0!important;display:block!important;overflow:visible!important}.ce-stats-inner,.ce-stats-inner--wide{max-width:100%!important;padding:0 20px!important}.ce-settings,.ce-lessons-wrap{display:none!important}.ce-stat-cards{grid-template-columns:repeat(4,1fr)!important}.ce-stat-card,.ce-lesson-stat-row,.ce-student-row{break-inside:avoid;background:#fff!important;border:1px solid #e2e8f0!important}.ce-student-wrap.open .ce-student-row{border-bottom:1px solid #e2e8f0!important;border-radius:12px!important}.ce-student-detail{break-inside:avoid;background:#f8fafc!important;border:1px solid #e2e8f0!important}.ce-section{break-inside:avoid;margin-bottom:20px}.ce-student-bar-fill,.ce-ls-bar-fill,.ce-dist-bar-fill,.ce-student-ava{-webkit-print-color-adjust:exact;print-color-adjust:exact}.ce-print-footer{color:#64748b;border-top:1px solid #e2e8f0;justify-content:space-between;margin-top:32px;padding-top:12px;font-size:11px;display:flex!important}}@media (width<=860px){.ce-stat-cards{grid-template-columns:1fr 1fr}}@media (width<=680px){.ce-sidenav{width:52px}.ce-nav-label{display:none}.ce-nav-item,.ce-nav-back{justify-content:center;padding:10px}.ce-topbar{flex-wrap:wrap;gap:8px;height:auto;padding:10px 14px}.ce-title-input{order:-1;width:100%}.ce-settings-inner,.ce-stats-inner{padding:0 16px}.ce-grid2{grid-template-columns:1fr}.ce-settings-footer{padding:16px}.ce-stat-cards{grid-template-columns:1fr 1fr}.ce-ls-bar-wrap{width:100px}}.be-editor{flex-direction:column;gap:8px;display:flex}.be-empty-hint{text-align:center;color:var(--text-2);border:1.5px dashed var(--border);border-radius:10px;padding:24px 16px;font-size:13px;font-style:italic}.be-block{border:1.5px solid var(--border);background:var(--bg);border-radius:10px;transition:border-color .15s;overflow:hidden}.be-block:focus-within{border-color:var(--accent)}.be-block-header{background:color-mix(in srgb, var(--border) 40%, transparent);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.be-block-type-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-2);font-size:11px;font-weight:700}.be-block--heading .be-block-type-label{color:#7c3aed}.be-block--image .be-block-type-label{color:#0891b2}.be-block--video .be-block-type-label{color:#dc2626}.be-block--callout .be-block-type-label{color:#d97706}.be-block-controls{gap:2px;display:flex}.be-block-controls button{width:26px;height:26px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:13px;display:flex}.be-block-controls button:hover:not(:disabled){background:var(--hover);color:var(--text)}.be-block-controls button:disabled{opacity:.3;cursor:default}.be-block-controls .be-del:hover{color:var(--red,#ef4444)!important}.be-block .le-textarea,.be-block .le-input{border:none!important;border-bottom:1px solid var(--border)!important;border-radius:0!important}.be-block .le-textarea:last-child,.be-block .le-input:last-child{border-bottom:none!important}.be-block .le-textarea:focus,.be-block .le-input:focus{outline:none;border-color:var(--accent)!important}.be-block .le-textarea{min-height:120px}.be-heading-row{gap:0;display:flex}.be-heading-row .le-type-select{min-width:70px;font-weight:700;border:none!important;border-right:1px solid var(--border)!important;border-radius:0!important}.be-heading-row .le-input{flex:1;font-size:16px;font-weight:600}.be-img-fields{flex-direction:column;display:flex}.be-img-preview{background:var(--bg);padding:10px 12px}.be-img-preview img{object-fit:cover;border-radius:8px;max-width:100%;max-height:220px;display:block}.be-video-preview{justify-content:center;align-items:center;padding:10px 12px;display:flex;position:relative}.be-video-preview img{object-fit:cover;border-radius:8px;width:100%;max-height:180px}.be-video-play-icon{color:#ffffffe6;text-shadow:0 2px 8px #0006;pointer-events:none;font-size:40px;position:absolute}.be-callout-fields{flex-direction:column;display:flex}.be-callout-fields .le-type-select{border:none!important;border-bottom:1px solid var(--border)!important;border-radius:0!important}.be-divider-preview{padding:12px 16px}.be-divider-preview hr{border:none;border-top:2px dashed var(--border)}.be-add-bar{flex-wrap:wrap;gap:6px;padding:10px 0 2px;display:flex}.be-add-btn{border:1.5px dashed var(--border);color:var(--text-2);cursor:pointer;font-size:12px;font-family:var(--font-body);background:0 0;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;transition:border-color .15s,color .15s,background .15s;display:flex}.be-add-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 6%, transparent)}.be-add-icon{font-size:14px;line-height:1}.be-player{flex-direction:column;gap:20px;width:100%;display:flex}.be-p-text p{color:var(--text);margin:0 0 10px;font-size:15px;line-height:1.75}.be-p-text p:last-child{margin-bottom:0}.be-p-h{color:var(--text);font-family:var(--font-head);font-weight:700;line-height:1.25}.be-p-h1{margin:8px 0 4px;font-size:30px}.be-p-h2{margin:6px 0 2px;font-size:22px}.be-p-h3{margin:4px 0 2px;font-size:17px}.be-p-figure{flex-direction:column;gap:8px;margin:0;display:flex}.be-p-img{object-fit:cover;border-radius:10px;width:100%;max-height:480px;display:block}.be-p-caption{color:var(--text-2);text-align:center;padding:0 8px;font-size:13px;font-style:italic}.be-p-video-wrap{flex-direction:column;gap:8px;display:flex}.be-p-callout{border-left:4px solid;border-radius:10px;align-items:flex-start;gap:12px;padding:14px 18px;display:flex}.be-p-callout--info{background:#3b82f614;border-color:#3b82f6}.be-p-callout--warning{background:#f59e0b14;border-color:#f59e0b}.be-p-callout--success{background:#22c55e14;border-color:#22c55e}.be-p-callout--error{background:#ef444414;border-color:#ef4444}.be-p-callout-icon{flex-shrink:0;font-size:18px;line-height:1.4}.be-p-callout-text p{color:var(--text);margin:0 0 6px;font-size:14px;line-height:1.6}.be-p-callout-text p:last-child{margin:0}.be-p-divider{border:none;border-top:1.5px solid var(--border);margin:4px 0}@media (width<=700px){.cp-layout,.le-layout{flex-direction:column}.cp-sidebar,.le-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:240px}.cp-main,.le-editor{padding:16px}.cp-topbar,.le-topbar{flex-wrap:wrap;gap:10px;height:auto;padding:10px 16px}.cp-progress-area{width:100%}.cp-progress-bar{flex:1}.le-row2{grid-template-columns:1fr}.code-editor-header{flex-direction:column;align-items:flex-start;gap:8px}}.cp-final-test-item{border-top:1px solid var(--border);margin-top:8px}.cp-final-test-item.done .cp-lesson-num{color:#fff;background:#22c55e}.cp-final-test-item.locked{opacity:.55;cursor:not-allowed}.cp-final-test-item.active{background:color-mix(in srgb, var(--accent) 10%, transparent)}.ft-quiz-root{flex-direction:column;gap:20px;width:100%;display:flex}.cp-cert-page{flex-direction:column;align-items:center;gap:24px;width:100%;padding:24px 16px 40px;display:flex}.cp-cert-doc{aspect-ratio:210/297;background:#fff;border-radius:3px;width:100%;max-width:640px;box-shadow:0 16px 56px #00000038}.cp-cert-frame{box-sizing:border-box;border:5px solid var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='130'%3E%3Ctext x='110' y='75' font-family='Syne%2Csans-serif' font-size='28' font-weight='700' fill='%234f6ef7' fill-opacity='0.055' text-anchor='middle' transform='rotate(-30 110 75)'%3EIT Hub%3C%2Ftext%3E%3C%2Fsvg%3E"),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='130'%3E%3Ctext x='110' y='75' font-family='Syne%2Csans-serif' font-size='28' font-weight='700' fill='%234f6ef7' fill-opacity='0.055' text-anchor='middle' transform='rotate(-30 110 75)'%3EIT Hub%3C%2Ftext%3E%3C%2Fsvg%3E");background-position:0 0,110px 48px;background-repeat:repeat,repeat;background-size:220px 130px,220px 130px;border-radius:3px;flex-direction:column;width:100%;height:100%;padding:12px;display:flex;position:relative}.cp-cert-frame:before{content:"";border:1.5px solid color-mix(in srgb, var(--accent) 30%, transparent);pointer-events:none;border-radius:2px;position:absolute;inset:16px}.cp-cert-frame:after{content:"✦";color:var(--accent);opacity:.4;pointer-events:none;font-size:13px;position:absolute;bottom:20px;right:22px}.cp-cert-head{text-align:center;flex-shrink:0;padding:18px 24px 0;position:relative}.cp-cert-head:before{content:"✦";color:var(--accent);opacity:.4;font-size:13px;position:absolute;top:20px;left:26px}.cp-cert-logo{letter-spacing:1px;font-family:Syne,sans-serif;font-size:26px;font-weight:900;line-height:1}.cp-cert-logo-it{color:#1a1a2e}.cp-cert-logo-hub{color:var(--accent)}.cp-cert-logo-avpk{letter-spacing:3px;color:#1a1a2e;vertical-align:middle;font-size:14px;font-weight:700}.cp-cert-org-sub{letter-spacing:2px;text-transform:uppercase;color:#999;margin-top:4px;font-family:Manrope,sans-serif;font-size:8.5px}.cp-cert-divider{background:linear-gradient(to right, transparent, var(--accent) 20%, var(--accent) 80%, transparent);flex-shrink:0;width:100%;height:2px;margin:14px 0}.cp-cert-divider--thin{background:linear-gradient(to right, transparent, color-mix(in srgb, var(--accent) 30%, transparent) 20%, color-mix(in srgb, var(--accent) 30%, transparent) 80%, transparent);height:1px;margin:10px 0}.cp-cert-doc-title{text-align:center;flex-shrink:0;padding:0 24px}.cp-cert-doc-label{text-transform:uppercase;letter-spacing:6px;color:#1a1a2e;font-family:Syne,sans-serif;font-size:20px;font-weight:900}.cp-cert-doc-sub{letter-spacing:2.5px;text-transform:uppercase;color:#999;margin-top:2px;font-family:Manrope,sans-serif;font-size:9px}.cp-cert-body{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:0 32px;display:flex}.cp-cert-intro{color:#999;letter-spacing:1.5px;text-transform:uppercase;margin:0 0 12px;font-family:Manrope,sans-serif;font-size:10px}.cp-cert-name-wrap{margin-bottom:12px}.cp-cert-name{color:#1a1a2e;border-bottom:2.5px solid var(--accent);min-width:240px;padding-bottom:5px;font-family:Syne,sans-serif;font-size:26px;font-weight:800;line-height:1.2;display:inline-block}.cp-cert-verb{color:#777;margin:0 0 12px;font-family:Manrope,sans-serif;font-size:11px;line-height:1.5}.cp-cert-course-wrap{margin-bottom:0}.cp-cert-course-title{color:#1a1a2e;font-family:Syne,sans-serif;font-size:17px;font-weight:700;line-height:1.4}.cp-cert-direction{text-transform:uppercase;letter-spacing:2px;color:var(--accent);border:1px solid var(--accent);border-radius:20px;margin-top:8px;padding:3px 10px;font-family:Manrope,sans-serif;font-size:8.5px;font-weight:700;display:inline-block}.cp-cert-foot{flex-shrink:0;justify-content:space-between;align-items:center;width:100%;padding:0 24px 4px;display:flex}.cp-cert-foot-item{flex-direction:column;gap:2px;display:flex}.cp-cert-foot-label{text-transform:uppercase;letter-spacing:1.5px;color:#aaa;font-family:Manrope,sans-serif;font-size:8px}.cp-cert-foot-value{color:#1a1a2e;font-family:Syne,sans-serif;font-size:14px;font-weight:800}.cp-cert-foot-seal{justify-content:center;align-items:center;display:flex}.cp-cert-seal-ring{border:2.5px solid var(--accent);background:color-mix(in srgb, var(--accent) 6%, #fff);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative}.cp-cert-seal-ring:before{content:"";border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);border-radius:50%;position:absolute;inset:5px}.cp-cert-seal-inner{flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.cp-cert-seal-text{color:var(--accent);letter-spacing:1px;font-family:Syne,sans-serif;font-size:8.5px;font-weight:900;line-height:1.3}.cp-cert-seal-sub{color:var(--accent);letter-spacing:2px;text-transform:uppercase;font-family:Manrope,sans-serif;font-size:6.5px;font-weight:700}.cp-cert-id{text-align:center;color:#ccc;letter-spacing:2px;text-transform:uppercase;flex-shrink:0;padding-bottom:16px;font-family:Manrope,sans-serif;font-size:7.5px}.cp-cert-theme-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:10px;gap:6px;padding:4px;display:flex}.cp-cert-theme-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:7px;padding:6px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:600;transition:background .18s,color .18s}.cp-cert-theme-btn--active{background:var(--accent);color:#fff}.cp-cert-theme-btn:not(.cp-cert-theme-btn--active):hover{color:var(--text)}.cp-cert-doc--light{background:#fff}.cp-cert-doc--light .cp-cert-logo-it,.cp-cert-doc--light .cp-cert-logo-avpk,.cp-cert-doc--light .cp-cert-doc-label,.cp-cert-doc--light .cp-cert-name,.cp-cert-doc--light .cp-cert-course-title,.cp-cert-doc--light .cp-cert-foot-value{color:#1a1a2e}.cp-cert-doc--light .cp-cert-org-sub,.cp-cert-doc--light .cp-cert-doc-sub,.cp-cert-doc--light .cp-cert-intro{color:#999}.cp-cert-doc--light .cp-cert-verb{color:#777}.cp-cert-doc--light .cp-cert-foot-label{color:#aaa}.cp-cert-doc--light .cp-cert-id{color:#ccc}.cp-cert-doc--light .cp-cert-seal-ring{background:color-mix(in srgb, var(--accent) 6%, #fff)}.cp-cert-doc--dark{background:#0d0d18}.cp-cert-doc--dark .cp-cert-frame{border-color:var(--accent);background-color:#0d0d18;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='130'%3E%3Ctext x='110' y='75' font-family='Syne%2Csans-serif' font-size='28' font-weight='700' fill='%238fa3fc' fill-opacity='0.075' text-anchor='middle' transform='rotate(-30 110 75)'%3EIT Hub%3C%2Ftext%3E%3C%2Fsvg%3E"),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='130'%3E%3Ctext x='110' y='75' font-family='Syne%2Csans-serif' font-size='28' font-weight='700' fill='%238fa3fc' fill-opacity='0.075' text-anchor='middle' transform='rotate(-30 110 75)'%3EIT Hub%3C%2Ftext%3E%3C%2Fsvg%3E");background-position:0 0,110px 48px;background-size:220px 130px,220px 130px}.cp-cert-doc--dark .cp-cert-frame:before{border-color:color-mix(in srgb, var(--accent) 25%, transparent)}.cp-cert-doc--dark .cp-cert-frame:after,.cp-cert-doc--dark .cp-cert-head:before{color:var(--accent)}.cp-cert-doc--dark .cp-cert-logo-it,.cp-cert-doc--dark .cp-cert-logo-avpk,.cp-cert-doc--dark .cp-cert-doc-label{color:#e8e8f8}.cp-cert-doc--dark .cp-cert-name{color:#fff}.cp-cert-doc--dark .cp-cert-course-title{color:#e8e8f8}.cp-cert-doc--dark .cp-cert-foot-value{color:#fff}.cp-cert-doc--dark .cp-cert-org-sub,.cp-cert-doc--dark .cp-cert-doc-sub,.cp-cert-doc--dark .cp-cert-intro{color:#5a5a78}.cp-cert-doc--dark .cp-cert-verb{color:#6b6b88}.cp-cert-doc--dark .cp-cert-foot-label{color:#484868}.cp-cert-doc--dark .cp-cert-id{color:#335}.cp-cert-doc--dark .cp-cert-seal-ring{background:color-mix(in srgb, var(--accent) 12%, #0d0d18)}.cp-cert-doc--dark .cp-cert-divider,.cp-cert-doc--dark .cp-cert-divider--thin{opacity:.8}.cp-cert-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.cp-cert-print-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;padding:11px 28px;font-family:Manrope,sans-serif;font-size:14px;font-weight:600;transition:opacity .2s;display:flex}.cp-cert-print-btn:hover{opacity:.85}.cp-cert-retry-btn{color:var(--muted);border:1.5px solid var(--border);cursor:pointer;background:0 0;border-radius:10px;padding:11px 24px;font-family:Manrope,sans-serif;font-size:14px;font-weight:600;transition:border-color .2s,color .2s}.cp-cert-retry-btn:hover{border-color:var(--accent);color:var(--accent)}@media (width<=680px){.cp-cert-doc{max-width:100%}.cp-cert-name{min-width:0;font-size:20px}.cp-cert-course-title{font-size:14px}.cp-cert-doc-label{letter-spacing:3px;font-size:15px}.cp-cert-foot-seal{display:none}}.ce-ft-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.ce-ft-fields{flex-wrap:wrap;flex:1;gap:14px;display:flex}.ce-ft-empty{text-align:center;color:var(--muted);background:var(--surface2);border:1px dashed var(--border);border-radius:12px;margin-bottom:16px;padding:32px 24px;font-size:14px}.ce-ft-questions{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}.ce-ft-question{background:var(--surface2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;padding:18px 20px;display:flex}.ce-ft-q-top{justify-content:space-between;align-items:center;display:flex}.ce-ft-q-num{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.ce-ft-q-del{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:16px;transition:background .15s,color .15s}.ce-ft-q-del:hover{color:#f87171;background:#ef44441f}.ce-ft-options{flex-direction:column;gap:7px;display:flex}.ce-ft-option{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:7px 10px;transition:border-color .15s;display:flex}.ce-ft-option.is-correct{background:#34d39912;border-color:#34d39980}.ce-ft-option input[type=radio]{cursor:pointer;accent-color:var(--accent);flex-shrink:0}.ce-ft-opt-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:Manrope,sans-serif;font-size:13.5px}.ce-ft-correct-mark{color:#34d399;white-space:nowrap;font-size:11px;font-weight:700}.ce-ft-add-row{gap:10px;display:flex}.ce-ft-add-btn{border:1px dashed var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:10px;flex:1;padding:11px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .15s,color .15s}.ce-ft-add-btn:hover{border-color:var(--accent);color:var(--accent)}.ce-ft-add-btn--code:hover{color:#3b82f6;border-color:#3b82f6}.ce-ft-question--code{background:color-mix(in srgb, #3b82f6 4%, var(--surface2));border-color:#3b82f64d}.ce-ft-type-badge{border-radius:5px;justify-content:center;align-items:center;width:20px;height:20px;margin-right:4px;font-size:11px;font-weight:800;display:inline-flex}.ce-ft-type-badge.choice{color:var(--accent);background:#4f6ef726}.ce-ft-type-badge.code{color:#3b82f6;background:#3b82f626;font-family:monospace;font-size:10px}.ft-code-question{border-color:#3b82f64d!important}.ft-code-question.correct{border-color:#22c55e!important}.ft-code-question.wrong{border-color:#ef4444!important}.ft-code-q-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.quiz-q-num{color:var(--muted);font-size:12px;font-weight:600}.ft-quiz-root .code-editor{border:1px solid var(--border);border-radius:8px;min-height:140px;margin-top:0}@media print{@page{margin:0;size:A4 portrait}body *{visibility:hidden!important}#certificate-print,#certificate-print *{visibility:visible!important}#certificate-print{width:210mm!important;height:297mm!important;box-shadow:none!important;max-width:none!important;aspect-ratio:unset!important;margin:0!important;position:fixed!important;inset:0!important}.cp-cert-frame{border-color:var(--accent)!important}.no-print{display:none!important}}.st-root{background:var(--bg);min-height:100vh}.st-layout{min-height:calc(100vh - var(--topbar-h));display:flex}.st-sidebar{background:var(--surface);border-right:1px solid var(--border);width:240px;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));flex-direction:column;flex-shrink:0;padding:28px 0 24px;transition:background .3s,border-color .3s;display:flex;position:sticky;overflow-y:auto}.st-sidebar-profile{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:8px;margin-bottom:16px;padding:0 20px 24px;display:flex}.st-avatar{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-family:Syne,sans-serif;font-size:18px;font-weight:800;display:flex}.st-avatar-lg{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-family:Syne,sans-serif;font-size:26px;font-weight:800;display:flex}.st-sidebar-name{color:var(--text);text-align:center;font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:color .3s}[data-theme=dark] .st-sidebar-name{color:#fff}.st-sidebar-role{color:var(--muted);font-size:12px}.st-nav{flex-direction:column;flex:1;gap:2px;padding:0 12px;display:flex}.st-nav-item{cursor:pointer;color:var(--muted);text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;padding:10px 12px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;transition:background .16s,color .16s;display:flex}.st-nav-item:hover{background:var(--surface2);color:var(--text)}.st-nav-item.active{color:var(--accent);background:#4f6ef724}.st-nav-icon{flex-shrink:0;align-items:center;display:flex}.st-logout{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:9px;align-items:center;gap:9px;margin:12px 12px 0;padding:10px 12px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:color .2s,background .2s;display:flex}.st-logout:hover{color:var(--red);background:#f871711a}.st-main{flex:1;max-width:900px;padding:40px 48px 80px;animation:.4s both fadeUp}.st-section{flex-direction:column;gap:24px;display:flex}.st-section-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.st-section-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:6px;font-size:10px;font-weight:700}.st-section-title{color:var(--text);font-family:Syne,sans-serif;font-size:clamp(24px,3.5vw,36px);font-weight:800;line-height:1.1;transition:color .3s}[data-theme=dark] .st-section-title{color:#fff}.st-edit-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:9px;align-items:center;gap:7px;padding:9px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:flex}.st-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.st-profile-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:20px;padding:28px;transition:background .3s;display:flex}.st-profile-left{align-items:center;gap:20px;display:flex}.st-profile-name{color:var(--text);margin-bottom:4px;font-family:Syne,sans-serif;font-size:20px;font-weight:800;transition:color .3s}[data-theme=dark] .st-profile-name{color:#fff}.st-profile-role{color:var(--accent);margin-bottom:4px;font-size:13px;font-weight:600}.st-profile-joined{color:var(--muted);font-size:12px}.st-form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.st-field{flex-direction:column;gap:6px;display:flex}.st-field--full{grid-column:1/-1}.st-field-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.st-field-val{color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:9px;min-height:42px;padding:10px 14px;font-size:14px;transition:background .3s}[data-theme=dark] .st-field-val{color:#e8e8f0}.st-field-input{color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:9px;outline:none;width:100%;padding:10px 14px;font-family:Manrope,sans-serif;font-size:14px;transition:border-color .2s}.st-field-input:focus{border-color:var(--accent)}.st-field-textarea{resize:vertical;min-height:80px}.st-stats{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.st-stat{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:14px;padding:20px;transition:background .3s}.st-stat-val{color:var(--accent);margin-bottom:4px;font-family:Syne,sans-serif;font-size:30px;font-weight:800}.st-stat-label{color:var(--muted);font-size:12px}.st-group-title{color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-family:Syne,sans-serif;font-size:15px;font-weight:700}.st-courses-list{flex-direction:column;gap:14px;display:flex}.st-course-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:stretch;gap:0;transition:border-color .22s,background .3s;display:flex;overflow:hidden}.st-course-card:hover{border-color:var(--accent)}.st-course-card--done{opacity:.82}.st-course-stripe{flex-shrink:0;width:3px}.st-course-body{flex-direction:column;flex:1;gap:6px;padding:18px 20px;display:flex}.st-course-dir{text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.st-course-title{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .st-course-title{color:#fff}.st-course-teacher{color:var(--muted);font-size:12.5px}.st-course-stages{color:var(--muted);font-size:12px}.st-progress-row{align-items:center;gap:10px;margin-top:4px;display:flex}.st-progress-bar{background:var(--surface2);border-radius:3px;flex:1;height:5px;overflow:hidden}.st-progress-fill{border-radius:3px;height:100%;transition:width .4s}.st-progress-pct{color:var(--muted);white-space:nowrap;font-size:12px}.st-course-meta-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.st-course-card>.st-btn-primary,.st-course-card>.st-btn-outline{white-space:nowrap;align-self:center;margin:18px 18px 18px 0}.st-wish-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.st-wish-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;transition:border-color .22s,transform .22s,background .3s;display:flex;overflow:hidden}.st-wish-card:hover{border-color:var(--accent);transform:translateY(-3px)}.st-wish-body{flex-direction:column;flex:1;gap:6px;padding:18px 18px 14px;display:flex}.st-wish-price{color:var(--accent);margin-top:4px;font-family:Syne,sans-serif;font-size:16px;font-weight:800}.st-wish-actions{border-top:1px solid var(--border);align-items:center;gap:8px;padding:12px 18px 16px;display:flex}.st-wish-actions .st-btn-primary{flex:1}.st-btn-icon{background:var(--surface2);border:1px solid var(--border);width:36px;height:36px;color:var(--muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s,color .2s,border-color .2s;display:flex}.st-btn-icon:hover{color:var(--red);border-color:var(--red);background:#f871711f}.st-diplomas-grid{flex-direction:column;gap:14px;display:flex}.st-diploma-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:center;gap:18px;padding:22px 24px;transition:border-color .22s,background .3s;display:flex}.st-diploma-card:hover{border-color:var(--accent)}.st-diploma-icon{flex-shrink:0;font-size:36px}.st-diploma-body{flex-direction:column;flex:1;gap:7px;display:flex}.st-diploma-title{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:700;transition:color .3s}[data-theme=dark] .st-diploma-title{color:#fff}.st-diploma-meta{flex-wrap:wrap;gap:6px;display:flex}.st-diploma-dir{color:var(--accent);font-size:12px;font-weight:600}.st-diploma-actions{gap:8px;display:flex}.st-circles-list{flex-direction:column;gap:12px;display:flex}.st-circle-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:center;gap:16px;padding:18px 22px;transition:border-color .22s,background .3s;display:flex}.st-circle-card:hover{border-color:var(--accent)}.st-circle-emoji{flex-shrink:0;font-size:28px}.st-circle-body{flex-direction:column;flex:1;gap:6px;display:flex}.st-circle-name{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .st-circle-name{color:#fff}.st-circle-meta{flex-wrap:wrap;gap:6px;display:flex}.st-events-list{flex-direction:column;gap:12px;display:flex}.st-event-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;transition:border-color .22s,background .3s;display:flex}.st-event-card:hover{border-color:var(--accent)}.st-event-body{flex-direction:column;flex:1;gap:8px;display:flex}.st-event-title{color:var(--text);font-family:Syne,sans-serif;font-size:15px;font-weight:700;transition:color .3s}[data-theme=dark] .st-event-title{color:#fff}.st-event-meta{flex-wrap:wrap;gap:6px;display:flex}.st-meta-chip{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:6px;align-items:center;gap:5px;padding:3px 9px;font-size:12px;display:inline-flex}.st-badge{white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.st-badge--active{color:#34d399;background:#34d3991f}.st-badge--upcoming{color:#fbbf24;background:#fbbf241f}.st-badge--closed{color:#f87171;background:#f871711f}.st-empty{text-align:center;color:var(--muted);padding:56px 20px}.st-empty-icon{margin-bottom:14px;font-size:44px}.st-empty-title{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .3s}[data-theme=dark] .st-empty-title{color:#fff}.st-empty-sub{max-width:300px;margin:0 auto;font-size:14px;line-height:1.6}.st-btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:9px 18px;font-family:Manrope,sans-serif;font-size:13px;font-weight:600;transition:opacity .2s,box-shadow .2s;box-shadow:0 0 16px #4f6ef73d}.st-btn-primary:hover{opacity:.87}.st-btn-outline{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:9px;padding:9px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:background .2s}.st-btn-outline:hover{background:#4f6ef71a}@media (width<=900px){.st-sidebar{top:var(--topbar-h);z-index:200;transition:transform .28s;position:fixed;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0003}.st-sidebar.open{transform:translate(0)}.st-main{padding:28px 20px 60px}.st-stats{grid-template-columns:1fr 1fr}.st-form-grid{grid-template-columns:1fr}}@media (width<=560px){.st-stats{grid-template-columns:1fr 1fr}.st-diploma-card{flex-direction:column;align-items:flex-start}.st-diploma-actions{width:100%}.st-diploma-actions .st-btn-outline{text-align:center;flex:1}}.st-cert-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.st-cert-card{background:linear-gradient(135deg, var(--surface), #4f6ef70d);border:1px solid #4f6ef74d;border-radius:16px;align-items:flex-start;gap:16px;padding:20px 22px;transition:border-color .2s,box-shadow .2s;display:flex}.st-cert-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #4f6ef71f}.st-cert-emoji{flex-shrink:0;font-size:36px}.st-cert-info{flex-direction:column;gap:4px;min-width:0;display:flex}.st-cert-course{color:var(--text);font-family:Syne,sans-serif;font-size:15px;font-weight:700;line-height:1.3}[data-theme=dark] .st-cert-course{color:#fff}.st-cert-dir{color:var(--accent);font-size:12px;font-weight:600}.st-cert-meta{flex-direction:column;gap:2px;margin-top:6px;display:flex}.st-cert-score{color:var(--muted);font-size:13px}.st-cert-score strong{color:var(--accent)}.st-cert-date{color:var(--muted);font-size:12px}.st-cert-view-hint{color:var(--accent);opacity:0;margin-top:10px;font-size:11px;font-weight:600;transition:opacity .2s}.st-cert-card:hover .st-cert-view-hint{opacity:1}.st-cert-overlay{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.st-cert-overlay-inner{border-radius:8px;width:100%;max-width:820px;max-height:90vh;position:relative;overflow-y:auto}.st-cert-overlay-close{z-index:10;color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .2s;display:flex;position:fixed;top:16px;right:20px}.st-cert-overlay-close:hover{background:#000000d9}.st-reg-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.st-reg-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:14px;padding:16px;transition:border-color .2s;display:flex}.st-reg-card:hover{border-color:var(--accent)}.st-reg-emoji{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.st-reg-info{flex-direction:column;gap:3px;display:flex}.st-reg-title{color:var(--text);font-size:14px;font-weight:700}.st-reg-sub{color:var(--accent);font-size:12px;font-weight:600}.st-reg-meta{color:var(--muted);font-size:12px}.st-rate-prompt{flex-shrink:0;align-items:center;gap:10px;margin-top:auto;padding:10px 18px 14px 0;display:flex}.st-rate-hint{color:var(--muted);white-space:nowrap;font-size:12px}.st-rate-btn{color:var(--accent);cursor:pointer;white-space:nowrap;background:#4f6ef71a;border:1px solid #4f6ef740;border-radius:8px;padding:6px 13px;font-size:12.5px;font-weight:600;transition:background .2s,border-color .2s}.st-rate-btn:hover{border-color:var(--accent);background:#4f6ef733}.st-review-backdrop{z-index:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.st-review-modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;flex-direction:column;gap:18px;width:100%;max-width:460px;padding:28px 28px 24px;display:flex;box-shadow:0 24px 64px #00000040}.st-review-modal-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.st-review-modal-title{color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:800}[data-theme=dark] .st-review-modal-title{color:#fff}.st-review-modal-sub{color:var(--muted);margin-top:4px;font-size:13px}.st-review-close{background:var(--surface2);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;transition:background .2s,color .2s;display:flex}.st-review-close:hover{color:var(--red);background:#f871711f}.st-review-stars{align-items:center;gap:4px;display:flex}.st-review-star{cursor:pointer;color:var(--border);background:0 0;border:none;padding:0;font-size:32px;line-height:1;transition:color .15s,transform .15s}.st-review-star.active,.st-review-star:hover{color:#fbbf24;transform:scale(1.1)}.st-review-star-label{color:var(--muted);min-width:80px;margin-left:8px;font-size:13px;font-weight:600}.st-review-textarea{border:1px solid var(--border);background:var(--surface2);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:10px;outline:none;padding:12px 14px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s}.st-review-textarea:focus{border-color:var(--accent)}.st-review-textarea::placeholder{color:var(--muted)}.st-review-msg{text-align:center;color:var(--accent);padding:4px 0;font-size:13px;font-weight:600}.st-review-footer{justify-content:flex-end;gap:10px;display:flex}.st-review-footer .st-btn-primary:disabled{opacity:.5;cursor:not-allowed}.tp-root{background:var(--bg);min-height:100vh}.tp-layout{min-height:calc(100vh - var(--topbar-h));display:flex}.tp-sidebar{background:var(--surface);border-right:1px solid var(--border);width:240px;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));flex-direction:column;flex-shrink:0;padding:28px 0 24px;transition:background .3s,border-color .3s;display:flex;position:sticky;overflow-y:auto}.tp-sidebar-profile{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:6px;margin-bottom:16px;padding:0 20px 24px;display:flex}.tp-avatar{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-family:Syne,sans-serif;font-size:18px;font-weight:800;display:flex}.tp-avatar-lg{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-family:Syne,sans-serif;font-size:26px;font-weight:800;display:flex}.tp-sidebar-name{color:var(--text);text-align:center;font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-sidebar-name{color:#fff}.tp-role-chip{color:#34d399;background:#34d39924;border:1px solid #34d3994d;border-radius:20px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.tp-sidebar-spec{color:var(--muted);text-align:center;font-size:11.5px}.tp-nav{flex-direction:column;flex:1;gap:2px;padding:0 12px;display:flex}.tp-nav-item{cursor:pointer;color:var(--muted);text-align:left;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;padding:10px 12px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;transition:background .16s,color .16s;display:flex}.tp-nav-item:hover{background:var(--surface2);color:var(--text)}.tp-nav-item.active{color:var(--accent);background:#4f6ef724}.tp-nav-icon{flex-shrink:0;align-items:center;display:flex}.tp-logout{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:9px;align-items:center;gap:9px;margin:12px 12px 0;padding:10px 12px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:color .2s,background .2s;display:flex}.tp-logout:hover{color:var(--red);background:#f871711a}.tp-main{flex:1;max-width:960px;padding:40px 48px 80px;animation:.4s both tp-fadeUp}@keyframes tp-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.tp-section{flex-direction:column;gap:24px;display:flex}.tp-section-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.tp-section-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:6px;font-size:10px;font-weight:700}.tp-section-title{color:var(--text);font-family:Syne,sans-serif;font-size:clamp(24px,3.5vw,36px);font-weight:800;line-height:1.1;transition:color .3s}[data-theme=dark] .tp-section-title{color:#fff}.tp-profile-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:28px;transition:background .3s;display:flex}.tp-profile-left{align-items:center;gap:20px;display:flex}.tp-profile-name{color:var(--text);margin-bottom:4px;font-family:Syne,sans-serif;font-size:20px;font-weight:800;transition:color .3s}[data-theme=dark] .tp-profile-name{color:#fff}.tp-profile-role{color:#34d399;margin-bottom:3px;font-size:13px;font-weight:600}.tp-profile-spec{color:var(--accent);margin-bottom:3px;font-size:12.5px;font-weight:500}.tp-profile-joined{color:var(--muted);font-size:12px}.tp-profile-quick-stats{background:var(--surface2);border:1px solid var(--border);border-radius:12px;flex-shrink:0;align-items:center;gap:0;padding:12px 16px;display:flex}.tp-quick-stat{flex-direction:column;align-items:center;gap:2px;padding:0 16px;display:flex}.tp-quick-stat strong{color:var(--accent);font-family:Syne,sans-serif;font-size:20px;font-weight:800}.tp-quick-stat span{color:var(--muted);font-size:11px}.tp-quick-stat-div{background:var(--border);width:1px;height:28px}.tp-form-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;transition:background .3s}.tp-form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.tp-field{flex-direction:column;gap:6px;display:flex}.tp-field--full{grid-column:1/-1}.tp-field-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.tp-field-val{color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:9px;min-height:42px;padding:10px 14px;font-size:14px;transition:background .3s}[data-theme=dark] .tp-field-val{color:#e8e8f0}.tp-field-input{color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:9px;outline:none;width:100%;padding:10px 14px;font-family:Manrope,sans-serif;font-size:14px;transition:border-color .2s}.tp-field-input:focus{border-color:var(--accent)}.tp-field-textarea{resize:vertical;min-height:80px}.tp-btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:9px;align-items:center;gap:6px;padding:9px 18px;font-family:Manrope,sans-serif;font-size:13px;font-weight:600;transition:opacity .2s,box-shadow .2s;display:inline-flex;box-shadow:0 0 16px #4f6ef73d}.tp-btn-primary:hover{opacity:.87}.tp-btn-outline{color:var(--accent);border:1px solid var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:9px;padding:9px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:background .2s}.tp-btn-outline:hover{background:#4f6ef71a}.tp-edit-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:9px;align-items:center;gap:7px;padding:9px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:flex}.tp-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.tp-btn-icon{background:var(--surface2);border:1px solid var(--border);width:34px;height:34px;color:var(--muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s,color .2s,border-color .2s;display:flex}.tp-btn-icon:hover{color:var(--accent);border-color:var(--accent);background:#4f6ef71f}.tp-courses-list{flex-direction:column;gap:14px;display:flex}.tp-course-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:stretch;transition:border-color .22s,background .3s;display:flex;overflow:hidden}.tp-course-card:hover{border-color:var(--accent)}.tp-course-stripe{flex-shrink:0;width:3px}.tp-course-body{flex-direction:column;flex:1;gap:7px;padding:18px 20px;display:flex}.tp-course-head{align-items:center;gap:10px;display:flex}.tp-course-dir{text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.tp-course-title{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-course-title{color:#fff}.tp-course-meta{flex-wrap:wrap;gap:6px;display:flex}.tp-course-rating{color:var(--muted);align-items:center;gap:5px;font-size:12.5px;display:flex}.tp-course-rating strong{color:var(--text)}.tp-course-actions{flex-direction:column;justify-content:center;gap:8px;padding:16px 18px 16px 0;display:flex}.tp-progress-row{align-items:center;gap:10px;display:flex}.tp-progress-bar{background:var(--surface2);border-radius:3px;flex:1;height:5px;overflow:hidden}.tp-progress-fill{border-radius:3px;height:100%;transition:width .4s}.tp-progress-pct{color:var(--muted);white-space:nowrap;font-size:12px}.tp-students-count{color:var(--muted);align-self:center;font-size:13px}.tp-students-count strong{color:var(--accent);font-size:15px}.tp-students-filters{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.tp-filter-chips{flex-wrap:wrap;gap:6px;display:flex}.tp-chip{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:20px;padding:6px 14px;font-family:Manrope,sans-serif;font-size:12.5px;font-weight:500;transition:border-color .18s,color .18s}.tp-chip:hover{border-color:var(--accent);color:var(--text)}.tp-chip.active{border-color:var(--accent);color:var(--accent);background:#4f6ef71f}.tp-sort-select{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:9px;outline:none;padding:8px 12px;font-family:Manrope,sans-serif;font-size:13px;transition:border-color .2s}.tp-sort-select:hover{border-color:var(--accent)}.tp-students-list{flex-direction:column;gap:10px;display:flex}.tp-student-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;padding:16px 20px;transition:border-color .2s,background .3s;display:flex}.tp-student-card:hover{border-color:var(--accent)}.tp-student-ava{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-family:Syne,sans-serif;font-size:13px;font-weight:800;display:flex}.tp-student-body{flex:1;min-width:0}.tp-student-name{color:var(--text);margin-bottom:2px;font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-student-name{color:#fff}.tp-student-course{color:var(--muted);margin-bottom:2px;font-size:12.5px}.tp-student-activity{color:var(--muted);font-size:11.5px}.tp-student-progress-col{flex-direction:column;gap:6px;min-width:180px;display:flex}.tp-student-progress-row{align-items:center;gap:8px;display:flex}.tp-student-actions{gap:6px;display:flex}.tp-schedule-list{flex-direction:column;gap:12px;display:flex}.tp-schedule-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:center;gap:20px;padding:20px 22px;transition:border-color .22s,background .3s;display:flex;position:relative}.tp-schedule-card:hover{border-color:var(--accent)}.tp-schedule-card--next{background:#4f6ef70a;border-color:#4f6ef766}.tp-schedule-next-label{background:var(--accent);color:#fff;letter-spacing:1px;text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700;position:absolute;top:-10px;left:18px}.tp-schedule-date-col{text-align:center;flex-shrink:0;min-width:68px}.tp-schedule-date{color:var(--accent);font-family:Syne,sans-serif;font-size:15px;font-weight:700}.tp-schedule-time{color:var(--muted);margin-top:3px;font-size:12px}.tp-schedule-body{flex-direction:column;flex:1;gap:6px;display:flex}.tp-schedule-title{color:var(--text);font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-schedule-title{color:#fff}.tp-schedule-topic{color:var(--muted);font-size:12.5px}.tp-schedule-meta{flex-wrap:wrap;gap:6px;display:flex}.tp-schedule-actions{flex-shrink:0}.tp-circles-list{flex-direction:column;gap:12px;display:flex}.tp-circle-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:16px;padding:20px 22px;transition:border-color .22s,background .3s;display:flex}.tp-circle-card:hover{border-color:var(--accent)}.tp-circle-emoji{flex-shrink:0;margin-top:2px;font-size:32px}.tp-circle-body{flex-direction:column;flex:1;gap:7px;display:flex}.tp-circle-name{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-circle-name{color:#fff}.tp-circle-desc{color:var(--muted);font-size:13px;line-height:1.6}.tp-circle-meta{flex-wrap:wrap;gap:6px;display:flex}.tp-circle-right{flex-direction:column;flex-shrink:0;align-items:flex-end;display:flex}.tp-materials-list{flex-direction:column;gap:10px;display:flex}.tp-material-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:14px;padding:16px 20px;transition:border-color .2s,background .3s;display:flex}.tp-material-card:hover{border-color:var(--accent)}.tp-material-icon{flex-shrink:0;font-size:28px}.tp-material-body{flex-direction:column;flex:1;gap:5px;display:flex}.tp-material-title{color:var(--text);font-size:14px;font-weight:600;transition:color .3s}[data-theme=dark] .tp-material-title{color:#fff}.tp-material-meta{flex-wrap:wrap;gap:6px;display:flex}.tp-material-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.tp-stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.tp-stats-grid--4{grid-template-columns:repeat(4,1fr)}.tp-stat-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:14px;padding:22px;transition:background .3s}.tp-stat-icon{margin-bottom:10px;font-size:28px}.tp-stat-val{margin-bottom:4px;font-family:Syne,sans-serif;font-size:30px;font-weight:800}.tp-stat-label{color:var(--muted);font-size:12px}.tp-stats-block{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:16px;padding:24px;display:flex}.tp-stats-block-header{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:baseline;gap:12px;padding-bottom:14px;display:flex}.tp-stats-block-title{color:var(--text);font-family:Syne,sans-serif;font-size:15px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-stats-block-title{color:#fff}.tp-stats-block-sub{color:var(--muted);font-size:12.5px}.tp-stats-empty{color:var(--muted);text-align:center;padding:16px 0;font-size:13.5px}.tp-bar-list{flex-direction:column;gap:12px;display:flex}.tp-bar-row{align-items:center;gap:14px;display:flex}.tp-bar-label{flex-shrink:0;align-items:center;gap:10px;width:220px;display:flex}.tp-bar-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tp-bar-name{flex-direction:column;gap:1px;min-width:0;display:flex}.tp-bar-name>span:first-child{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;transition:color .3s;overflow:hidden}[data-theme=dark] .tp-bar-name>span:first-child{color:#e0e0ee}.tp-bar-dir{color:var(--muted);font-size:11px}.tp-bar-track{background:var(--surface2);border-radius:4px;flex:1;height:8px;overflow:hidden}.tp-bar-fill{border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.tp-bar-count{color:var(--text);text-align:right;flex-shrink:0;width:40px;font-family:Syne,sans-serif;font-size:14px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-bar-count{color:#fff}.tp-rating-table{flex-direction:column;gap:0;display:flex}.tp-rating-table-head{color:var(--muted);text-transform:uppercase;letter-spacing:1px;grid-template-columns:1fr 140px 90px 90px;padding:8px 12px;font-size:10.5px;font-weight:700;display:grid}.tp-rating-row{border-top:1px solid var(--border);grid-template-columns:1fr 140px 90px 90px;align-items:center;padding:12px;transition:background .18s;display:grid}.tp-rating-row:hover{background:var(--surface2);border-radius:8px}.tp-rating-course{color:var(--text);align-items:center;gap:10px;font-size:13.5px;font-weight:500;transition:color .3s;display:flex}[data-theme=dark] .tp-rating-course{color:#e0e0ee}.tp-rating-stars{color:#fbbf24;letter-spacing:1px;align-items:center;gap:5px;font-size:13px;display:flex}.tp-rating-num{color:var(--text);font-family:Syne,sans-serif;font-size:13px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-rating-num{color:#fff}.tp-rating-cell{color:var(--text);font-family:Syne,sans-serif;font-size:14px;font-weight:600;transition:color .3s}[data-theme=dark] .tp-rating-cell{color:#e0e0ee}.tp-status-summary{flex-wrap:wrap;gap:12px;display:flex}.tp-status-pill{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:120px;padding:12px 18px;display:flex}.tp-status-pill-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tp-status-pill-count{font-family:Syne,sans-serif;font-size:22px;font-weight:800;line-height:1}.tp-status-pill-label{color:var(--muted);font-size:12px}.tp-print-footer{display:none}.tp-stats-section{flex-direction:column;gap:14px;display:flex}.tp-stats-section-title{color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-family:Syne,sans-serif;font-size:15px;font-weight:700}.tp-students-progress-list,.tp-course-load-list{flex-direction:column;gap:10px;display:flex}.tp-stats-student-row,.tp-course-load-row{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:14px;padding:12px 16px;transition:background .3s;display:flex}.tp-stats-ava{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-family:Syne,sans-serif;font-size:11px;font-weight:800;display:flex}.tp-stats-student-info{flex-direction:column;flex-shrink:0;gap:1px;min-width:160px;display:flex}.tp-stats-student-name{color:var(--text);font-size:13.5px;font-weight:600;transition:color .3s}[data-theme=dark] .tp-stats-student-name{color:#e0e0ee}.tp-stats-progress-wrap{flex:1;align-items:center;gap:10px;display:flex}.tp-course-load-name{flex-direction:column;flex-shrink:0;gap:2px;min-width:200px;display:flex}.tp-course-load-name span{color:var(--text);font-size:13.5px;font-weight:600}[data-theme=dark] .tp-course-load-name span{color:#e0e0ee}.tp-course-load-bar-wrap{flex:1;align-items:center;gap:10px;display:flex}.tp-meta-chip{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:6px;align-items:center;gap:5px;padding:3px 9px;font-size:12px;display:inline-flex}.tp-badge{white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;padding:4px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.tp-badge--active{color:#34d399;background:#34d3991f}.tp-badge--upcoming{color:#fbbf24;background:#fbbf241f}.tp-badge--behind{color:#f87171;background:#f871711f}.tp-badge--done{color:#4f6ef7;background:#4f6ef71f}.tp-muted{color:var(--muted)}.tp-empty{text-align:center;color:var(--muted);padding:56px 20px}.tp-empty-icon{margin-bottom:14px;font-size:44px}.tp-empty-title{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .3s}[data-theme=dark] .tp-empty-title{color:#fff}.tp-empty-sub{max-width:300px;margin:0 auto;font-size:14px;line-height:1.6}@media (width<=900px){.tp-sidebar{top:var(--topbar-h);z-index:200;transition:transform .28s;position:fixed;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0003}.tp-sidebar.open{transform:translate(0)}.tp-main{padding:28px 20px 60px}.tp-stats-grid,.tp-stats-grid--4{grid-template-columns:1fr 1fr}.tp-form-grid{grid-template-columns:1fr}.tp-profile-card{flex-direction:column;align-items:flex-start}.tp-profile-quick-stats{justify-content:space-around;width:100%}.tp-student-progress-col{min-width:unset}.tp-rating-table-head,.tp-rating-row{grid-template-columns:1fr 110px 70px 70px}.tp-bar-label{width:160px}}@media (width<=640px){.tp-stats-grid,.tp-stats-grid--4{grid-template-columns:1fr 1fr}.tp-course-card{flex-wrap:wrap}.tp-course-actions{flex-direction:row;padding:0 16px 16px}.tp-stats-student-row,.tp-course-load-row,.tp-schedule-card{flex-wrap:wrap}.tp-rating-table-head,.tp-rating-row{grid-template-columns:1fr 100px 60px}.tp-rating-table-head span:last-child,.tp-rating-row .tp-rating-cell:last-child{display:none}.tp-bar-label{width:130px}.tp-status-summary{gap:8px}.tp-status-pill{min-width:100px;padding:10px 12px}}.tp-nav-badge{color:#fff;background:#f59e0b;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:10px;font-weight:700;display:flex}.tp-course-card--pending{border-color:#f59e0b80}.tp-act-btn{border:1px solid var(--border);background:var(--surface2);width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.tp-act-btn:hover{color:var(--accent);border-color:var(--accent);background:#4f6ef71a}.tp-act-btn--submit{color:#4f6ef7;border-color:#4f6ef74d}.tp-act-btn--submit:hover{background:#4f6ef726}.tp-act-btn--del:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.tp-rejection-reason{color:#dc2626;background:#ef444414;border:1px solid #ef444433;border-radius:8px;margin-top:4px;padding:8px 12px;font-size:12px}.tp-rejection-reason strong{font-weight:700}.tp-workflow-hint{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:10px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:16px;padding:10px 14px;font-size:12px;display:flex}.tp-wf-step{font-weight:600}.tp-wf-arrow{color:var(--border)}.tp-wf-ok{color:#16a34a}.tp-modal-overlay{z-index:300;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.tp-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.tp-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.tp-modal-title{color:var(--text);font-size:16px;font-weight:700}.tp-modal-close{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px}.tp-modal-close:hover{background:var(--surface2)}.tp-modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.tp-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.tp-form-row2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.tp-btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:9px 18px;font-size:13px;font-weight:600}.tp-btn-secondary:hover{border-color:var(--accent);color:var(--accent)}@media print{.topbar,.tp-sidebar,.tp-no-print,.tp-workflow-hint,.tp-toast{display:none!important}.tp-root{background:#fff}.tp-layout{padding-top:0;display:block}.tp-main{max-width:100%;padding:24px 32px;animation:none}.tp-section-header{margin-bottom:20px}.tp-stats-grid,.tp-stats-grid--4{gap:10px;grid-template-columns:repeat(4,1fr)!important}.tp-stat-card{border:1px solid #ddd;border-radius:8px;padding:14px}.tp-stats-block{break-inside:avoid;border:1px solid #ddd;border-radius:8px;padding:16px}.tp-bar-fill,.tp-status-pill-dot,.tp-bar-dot,.tp-rating-stars{-webkit-print-color-adjust:exact;print-color-adjust:exact}.tp-print-footer{color:#888;border-top:1px solid #ddd;justify-content:space-between;align-items:center;margin-top:32px;padding-top:14px;font-size:11px;display:flex}.tp-section-title{font-size:22px}.tp-section-label{font-size:9px}}.tp-toast{z-index:999;color:#fff;background:#22c55e;border-radius:12px;padding:12px 20px;font-size:13px;font-weight:600;animation:.25s tp-toast-in;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 24px #0003}.tp-toast--err{background:#ef4444}@keyframes tp-toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cs-root{min-height:100vh;padding-bottom:80px;animation:.4s both cs-fadeUp}@keyframes cs-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.cs-back-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;gap:8px;margin-bottom:28px;padding:0;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:600;transition:color .2s;display:inline-flex}.cs-back-btn:hover{color:var(--accent)}.cs-header{max-width:1200px;padding:40px 48px 0}.cs-hero-strip{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:32px;margin-bottom:32px;display:flex}.cs-hero-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:10px;font-weight:700}.cs-hero-title{color:var(--text);margin-bottom:10px;font-family:Syne,sans-serif;font-size:clamp(28px,4vw,44px);font-weight:800;line-height:1.1;transition:color .3s}[data-theme=dark] .cs-hero-title{color:#fff}.cs-hero-sub{color:var(--muted);max-width:520px;font-size:14.5px;line-height:1.65}.cs-hero-stats{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-shrink:0;align-items:center;gap:0;padding:14px 20px;transition:background .3s;display:flex}.cs-hero-stat{flex-direction:column;align-items:center;gap:2px;padding:0 18px;display:flex}.cs-hero-stat strong{color:var(--accent);font-family:Syne,sans-serif;font-size:22px;font-weight:800}.cs-hero-stat span{color:var(--muted);white-space:nowrap;font-size:11px}.cs-hero-stat-div{background:var(--border);width:1px;height:32px}.cs-dir-tabs{flex-wrap:wrap;gap:8px;padding-bottom:24px;display:flex;overflow-x:auto}.cs-dir-tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .18s,color .18s,background .18s;display:flex}.cs-dir-tab:hover{border-color:var(--accent);color:var(--text)}.cs-dir-tab.active{border-color:var(--accent);color:var(--accent);background:#4f6ef71f}.cs-dir-tab-count{background:var(--surface2);min-width:20px;height:18px;color:var(--muted);border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.cs-dir-tab.active .cs-dir-tab-count{color:var(--accent);background:#4f6ef733}.cs-toolbar{flex-wrap:wrap;align-items:center;gap:12px;max-width:1200px;padding:0 48px 20px;display:flex}.cs-search-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:10px;min-width:240px;padding:10px 14px;transition:border-color .2s;display:flex}.cs-search-wrap:focus-within{border-color:var(--accent)}.cs-search-wrap svg{color:var(--muted);flex-shrink:0}.cs-search-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:Manrope,sans-serif;font-size:13.5px}.cs-search-input::placeholder{color:var(--muted)}.cs-search-clear{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;padding:0;transition:color .2s;display:flex}.cs-search-clear:hover{color:var(--red)}.cs-toolbar-right{align-items:center;gap:8px;display:flex}.cs-filter-toggle{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:10px;align-items:center;gap:7px;padding:10px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:flex;position:relative}.cs-filter-toggle:hover,.cs-filter-toggle.active{border-color:var(--accent);color:var(--accent)}.cs-filter-badge{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-7px;right:-7px}.cs-sort-select{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;outline:none;padding:10px 14px;font-family:Manrope,sans-serif;font-size:13px;transition:border-color .2s}.cs-sort-select:hover{border-color:var(--accent)}.cs-view-toggle{background:var(--surface);border:1px solid var(--border);border-radius:10px;display:flex;overflow:hidden}.cs-view-btn{cursor:pointer;width:40px;height:40px;color:var(--muted);background:0 0;border:none;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.cs-view-btn.active{background:var(--surface2);color:var(--accent)}.cs-view-btn:hover{color:var(--text)}.cs-filters-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;align-items:flex-start;gap:20px;max-width:1104px;margin:0 48px 20px;padding:20px 24px;animation:.22s both cs-fadeUp;display:flex}.cs-filter-group{flex-direction:column;gap:10px;display:flex}.cs-filter-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.cs-filter-chips{flex-wrap:wrap;gap:6px;display:flex}.cs-chip{background:var(--surface2);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:20px;padding:6px 14px;font-family:Manrope,sans-serif;font-size:12.5px;font-weight:500;transition:border-color .18s,color .18s,background .18s}.cs-chip:hover{border-color:var(--accent);color:var(--text)}.cs-chip.active{border-color:var(--accent);color:var(--accent);background:#4f6ef71f}.cs-clear-filters{color:var(--red);cursor:pointer;background:#f871711a;border:1px solid #f871714d;border-radius:9px;align-self:flex-end;align-items:center;gap:6px;padding:8px 14px;font-family:Manrope,sans-serif;font-size:12.5px;font-weight:600;transition:background .2s;display:flex}.cs-clear-filters:hover{background:#f871712e}.cs-results-bar{align-items:center;gap:16px;max-width:1200px;padding:0 48px 16px;display:flex}.cs-results-count{color:var(--muted);font-size:13px;font-weight:600}.cs-wishlist-hint{color:var(--red);align-items:center;gap:5px;font-size:12.5px;font-weight:500;display:flex}.cs-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;max-width:1200px;padding:0 48px;display:grid}.cs-list{flex-direction:column;gap:14px;max-width:1200px;padding:0 48px;display:flex}.cs-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:16px;transition:border-color .22s,transform .22s,box-shadow .22s,background .3s;overflow:hidden}.cs-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 32px #4f6ef71f}.cs-card--grid{flex-direction:column;display:flex}.cs-card-top-bar{padding:0;position:relative}.cs-card-stripe-h{width:100%;height:3px}.cs-card-top-inner{justify-content:space-between;align-items:flex-start;padding:16px 16px 8px;display:flex}.cs-emoji-big{font-size:36px;line-height:1}.cs-card-dir-row{align-items:center;gap:8px;padding:0 16px 14px;display:flex}.cs-card-body{flex-direction:column;flex:1;gap:8px;padding:0 18px 14px;display:flex}.cs-card-badges{flex-wrap:wrap;gap:6px;display:flex}.cs-card-title{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;line-height:1.25;transition:color .3s}[data-theme=dark] .cs-card-title{color:#fff}.cs-card-desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.cs-card-footer{border-top:1px solid var(--border);padding:14px 18px 16px}.cs-card-stats{gap:14px;margin-bottom:10px;display:flex}.cs-card-bottom{justify-content:space-between;align-items:center;gap:12px;display:flex}.cs-card-price{color:var(--accent);font-family:Syne,sans-serif;font-size:17px;font-weight:800}.cs-card--list{align-items:stretch;gap:0;display:flex}.cs-card-stripe{flex-shrink:0;width:3px}.cs-card-emoji-col{flex-shrink:0;justify-content:center;align-items:center;width:72px;font-size:32px;display:flex}.cs-card-list-body{flex-direction:column;flex:1;gap:6px;padding:18px 16px;display:flex}.cs-card-list-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cs-card-list-right{flex-direction:column;flex-shrink:0;justify-content:center;align-items:flex-end;gap:8px;min-width:160px;padding:16px 20px 16px 12px;display:flex}.cs-card-list-actions{align-items:center;gap:8px;display:flex}.cs-card-params{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.cs-dir-label{text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:700}.cs-level-badge{border:1px solid;border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.cs-format-badge{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:500;display:inline-flex}.cs-upcoming-chip{color:#fbbf24;background:#fbbf2424;border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.cs-archive-chip{color:#f87171;background:#ef44441f}.cs-card--soon{cursor:default;opacity:.82}.cs-card--soon:hover{box-shadow:none!important;border-color:var(--border)!important;transform:none!important}.cs-soon-notice{background:var(--border);color:var(--text-2);text-align:center;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600}.cs-tag{background:var(--surface2);color:var(--muted);border:1px solid var(--border);border-radius:5px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.cs-card-tags{flex-wrap:wrap;gap:4px;display:flex}.cs-teacher-row{color:var(--muted);align-items:center;gap:7px;font-size:12.5px;display:flex}.cs-teacher-ava{color:#0f0f13;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:800;display:flex}.cs-teacher-ava--lg{width:42px;height:42px;font-size:17px}.cs-param{color:var(--muted);align-items:center;gap:4px;font-size:12px;display:inline-flex}.cs-stars{color:#fbbf24;align-items:center;gap:3px;display:inline-flex}.cs-stars strong{color:var(--text);font-size:12.5px}.cs-no-rating{color:var(--muted);font-size:12px}.cs-wish-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;color:var(--muted);border-radius:8px;align-items:center;gap:6px;padding:8px 10px;font-family:Manrope,sans-serif;font-size:12.5px;font-weight:500;transition:border-color .2s,color .2s,background .2s;display:flex}.cs-wish-btn:hover{border-color:var(--red);color:var(--red)}.cs-wish-btn.active{border-color:var(--red);color:var(--red);background:#f8717114}.cs-wish-btn--float{border-radius:8px;justify-content:center;width:32px;height:32px;padding:0}.cs-wish-btn--lg{border-radius:10px;padding:11px 18px;font-size:13.5px}.cs-btn-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:9px;padding:9px 18px;font-family:Manrope,sans-serif;font-size:13px;font-weight:600;transition:opacity .2s,box-shadow .2s;box-shadow:0 0 16px #4f6ef738}.cs-btn-primary:hover{opacity:.87}.cs-btn-primary--lg{border-radius:11px;padding:12px 28px;font-size:14.5px}.cs-empty{text-align:center;color:var(--muted);padding:80px 20px}.cs-empty-icon{margin-bottom:16px;font-size:52px}.cs-empty-title{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:20px;font-weight:700;transition:color .3s}[data-theme=dark] .cs-empty-title{color:#fff}.cs-empty-sub{max-width:320px;margin:0 auto;font-size:14px;line-height:1.6}.cs-modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000a6;justify-content:center;align-items:center;padding:20px;animation:.18s both cs-fadeUp;display:flex;position:fixed;inset:0}.cs-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:100%;max-width:580px;max-height:88vh;display:flex;position:relative;overflow-y:auto;box-shadow:0 24px 80px #00000059}.cs-modal::-webkit-scrollbar{width:4px}.cs-modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.cs-modal-close{z-index:2;border:1px solid var(--border);width:32px;height:32px;color:var(--muted);cursor:pointer;background:#7f7fb41a;border-radius:8px;justify-content:center;align-items:center;transition:background .2s,color .2s;display:flex;position:absolute;top:16px;right:16px}.cs-modal-close:hover{color:var(--red);background:#f871711f}.cs-modal-hero{border-bottom:1px solid var(--border);align-items:center;gap:18px;padding:28px 28px 22px;display:flex;position:relative}.cs-modal-stripe{border-radius:3px 0 0;width:3px;position:absolute;top:0;bottom:0;left:0}.cs-modal-emoji{font-size:46px;line-height:1}.cs-modal-title{color:var(--text);margin-top:6px;font-family:Syne,sans-serif;font-size:20px;font-weight:800;line-height:1.2;transition:color .3s}[data-theme=dark] .cs-modal-title{color:#fff}.cs-modal-body{flex-direction:column;flex:1;gap:18px;padding:22px 28px;display:flex}.cs-modal-badges{flex-wrap:wrap;gap:8px;display:flex}.cs-modal-desc{color:var(--muted);font-size:14px;line-height:1.7}.cs-modal-stats{background:var(--surface2);border:1px solid var(--border);border-radius:12px;gap:0;display:flex;overflow:hidden}.cs-modal-stat{text-align:center;border-right:1px solid var(--border);flex:1;padding:14px 16px}.cs-modal-stat:last-child{border-right:none}.cs-modal-stat-val{color:var(--text);justify-content:center;align-items:center;gap:5px;margin-bottom:4px;font-family:Syne,sans-serif;font-size:15px;font-weight:700;display:flex}[data-theme=dark] .cs-modal-stat-val{color:#fff}.cs-modal-stat-label{color:var(--muted);font-size:11px}.cs-modal-teacher{background:var(--surface2);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:14px 18px;display:flex}.cs-modal-teacher-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px;font-size:11px;font-weight:700}.cs-modal-teacher-name{color:var(--text);font-size:14px;font-weight:600}[data-theme=dark] .cs-modal-teacher-name{color:#fff}.cs-modal-tags{flex-wrap:wrap;gap:6px;display:flex}.cs-modal-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:6px;margin-bottom:12px;font-size:12px;font-weight:700;display:flex}.cs-modules-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.cs-module-item{color:var(--text);align-items:center;gap:10px;font-size:13px;display:flex}[data-theme=dark] .cs-module-item{color:#e0e0ee}.cs-module-num{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:800;display:flex}.cs-modal-footer{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 28px 24px;display:flex}.cs-modal-price{color:var(--accent);font-family:Syne,sans-serif;font-size:26px;font-weight:800}.cs-modal-price-note{color:var(--muted);margin-top:3px;font-size:12px}.cs-modal-actions{flex-wrap:wrap;gap:10px;display:flex}@media (width<=900px){.cs-header{padding:28px 20px 0}.cs-toolbar{padding:0 20px 16px}.cs-filters-panel{margin:0 20px 16px}.cs-results-bar{padding:0 20px 12px}.cs-grid{grid-template-columns:1fr 1fr;padding:0 20px}.cs-list{padding:0 20px}.cs-hero-stats{display:none}}@media (width<=640px){.cs-grid,.cs-modules-grid{grid-template-columns:1fr}.cs-card--list{flex-wrap:wrap}.cs-card-list-right{min-width:unset;flex-flow:wrap;align-items:center;padding:0 16px 16px}.cs-modal-footer{flex-direction:column;align-items:stretch}.cs-modal-actions{flex-direction:column}.cs-wish-btn--lg{justify-content:center}.cs-btn-primary--lg{text-align:center}}.cs-reviews{border-top:1px solid var(--border);flex-direction:column;gap:18px;margin-top:28px;padding-top:24px;display:flex}.cs-reviews-header{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.cs-reviews-title{color:var(--text);font-family:Syne,sans-serif;font-size:16px;font-weight:700;transition:color .3s}[data-theme=dark] .cs-reviews-title{color:#fff}.cs-reviews-summary{align-items:center;gap:8px;display:flex}.cs-reviews-avg{font-family:Syne,sans-serif;font-size:28px;font-weight:800;line-height:1}.cs-reviews-stars-big{color:#fbbf24;letter-spacing:2px;font-size:16px}.cs-reviews-count{color:var(--muted);font-size:12.5px}.cs-reviews-dist{flex-direction:column;gap:5px;display:flex}.cs-dist-row{align-items:center;gap:8px;display:flex}.cs-dist-star{color:var(--muted);text-align:right;flex-shrink:0;width:22px;font-size:11.5px}.cs-dist-bar{background:var(--surface2);border-radius:3px;flex:1;height:6px;overflow:hidden}.cs-dist-fill{border-radius:3px;height:100%;transition:width .5s}.cs-dist-pct{color:var(--muted);text-align:right;flex-shrink:0;width:20px;font-size:11.5px}.cs-review-form{background:var(--surface2);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;padding:18px 20px;display:flex}.cs-review-form-title{color:var(--text);text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:700;transition:color .3s}[data-theme=dark] .cs-review-form-title{color:#e0e0ee}.cs-star-picker{align-items:center;gap:4px;display:flex}.cs-star-btn{color:var(--border);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:26px;line-height:1;transition:color .15s,transform .1s}.cs-star-btn:hover,.cs-star-btn.active{color:#fbbf24}.cs-star-btn:hover{transform:scale(1.2)}.cs-star-label{color:var(--muted);margin-left:6px;font-size:13px}.cs-review-textarea{color:var(--text);background:var(--surface);border:1px solid var(--border);resize:vertical;border-radius:9px;outline:none;min-height:72px;padding:10px 14px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s}.cs-review-textarea:focus{border-color:var(--accent)}.cs-review-textarea::placeholder{color:var(--muted)}.cs-review-msg{color:#34d399;background:#34d3991f;border-radius:8px;padding:8px 12px;font-size:13px}.cs-review-msg--err{color:#f87171;background:#f871711f}.cs-review-login-btn{border:1px dashed var(--border);text-align:center;color:var(--muted);cursor:pointer;background:0 0;border-radius:12px;padding:14px;font-family:Manrope,sans-serif;font-size:13.5px;transition:border-color .2s,color .2s}.cs-review-login-btn:hover{border-color:var(--accent);color:var(--accent)}.cs-reviews-list{flex-direction:column;gap:0;display:flex}.cs-reviews-loading,.cs-reviews-empty{color:var(--muted);text-align:center;padding:20px 0;font-size:13.5px}.cs-review-item{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:16px 0;display:flex}.cs-review-item:first-child{border-top:none}.cs-review-top{align-items:center;gap:10px;display:flex}.cs-review-ava{color:#0f0f13;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-family:Syne,sans-serif;font-size:12px;font-weight:800;display:flex}.cs-review-meta{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.cs-review-author{color:var(--text);font-size:13px;font-weight:600;transition:color .3s}[data-theme=dark] .cs-review-author{color:#e0e0ee}.cs-review-date{color:var(--muted);font-size:11.5px}.cs-review-stars{letter-spacing:1px;flex-shrink:0;font-size:13px}.cs-review-del{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;padding:4px 6px;font-size:12px;transition:background .15s,color .15s}.cs-review-del:hover{color:#f87171;background:#f871711f}.cs-review-del:disabled{opacity:.4;cursor:default}.cs-review-comment{color:var(--muted);margin:0;padding-left:42px;font-size:13.5px;line-height:1.65}.cs-stars-btn{cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:5px;margin:0 -6px;padding:3px 6px;transition:background .18s;display:inline-flex}.cs-stars-btn:hover{background:#fbbf241a}.cs-reviews-hint{color:var(--muted);white-space:nowrap;font-size:11px}.cs-modal-reviews-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:8px;width:100%;margin-top:4px;padding:12px 18px;font-family:Manrope,sans-serif;font-size:14px;font-weight:600;transition:background .2s,border-color .2s;display:flex}.cs-modal-reviews-btn:hover{background:var(--bg)}.cs-rev-modal-backdrop{z-index:260;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.cs-rev-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:100%;max-width:560px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000038}.cs-rev-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px 18px;display:flex}.cs-rev-modal-hero{align-items:center;gap:10px;min-width:0;display:flex}.cs-rev-back-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--muted);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,color .18s,border-color .18s;display:flex}.cs-rev-back-btn:hover{background:var(--bg);color:var(--accent);border-color:var(--accent)}.cs-rev-modal-emoji{flex-shrink:0;font-size:32px}.cs-rev-modal-dir{text-transform:uppercase;letter-spacing:1px;margin-bottom:3px;font-size:11px;font-weight:700}.cs-rev-modal-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-family:Syne,sans-serif;font-size:16px;font-weight:800;overflow:hidden}[data-theme=dark] .cs-rev-modal-title{color:#fff}.cs-rev-modal-body{flex:1;padding:20px 24px 24px;overflow-y:auto}.cs-rev-modal-body .cs-reviews{border:none;padding:0}@media (width<=600px){.cs-rev-modal{border-radius:16px;max-height:92vh}.cs-rev-modal-header{padding:16px 18px 14px}.cs-rev-modal-body{padding:16px 18px 20px}}.sp-root{width:100%;max-width:1200px;margin:0 auto;padding:40px 48px 80px}.sp-header{margin-bottom:28px}.sp-hero-strip{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:32px;margin:20px 0 28px;display:flex}.sp-hero-left{flex:1;min-width:260px}.sp-label{letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:10px;font-weight:700}.sp-title{color:var(--text);margin:0 0 10px;font-family:Syne,sans-serif;font-size:clamp(28px,4vw,44px);font-weight:800;line-height:1.1;transition:color .3s}[data-theme=dark] .sp-title{color:#fff}.sp-hero-sub{color:var(--muted);max-width:520px;margin:0;font-size:14.5px;line-height:1.7}.sp-hero-stats{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-shrink:0;align-self:flex-start;gap:0;padding:14px 20px;display:flex}.sp-hero-stat-group{align-items:center;display:flex}.sp-hero-stat-div{background:var(--border);width:1px;height:36px;margin:0 20px}.sp-hero-stat{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:4px 8px;display:flex}.sp-hero-stat strong{color:var(--text);font-family:Syne,sans-serif;font-size:22px;font-weight:800;line-height:1;transition:color .3s}[data-theme=dark] .sp-hero-stat strong{color:#fff}.sp-hero-stat span{color:var(--muted);font-size:11px}.sp-dir-tabs{flex-wrap:wrap;gap:8px;display:flex}.sp-dir-tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:8px 16px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:background .18s,border-color .18s,color .18s;display:flex}.sp-dir-tab:hover{border-color:var(--accent);color:var(--text)}.sp-dir-tab.active{border-color:var(--accent);color:var(--accent);background:#4f6ef71f}.sp-tab-count{min-width:20px;height:18px;color:var(--muted);background:#7f7fb426;border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.sp-dir-tab.active .sp-tab-count{color:var(--accent);background:#4f6ef733}.sp-toolbar{align-items:center;gap:12px;margin-bottom:24px;display:flex}.sp-search-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:9px;max-width:400px;padding:10px 14px;transition:border-color .2s;display:flex}.sp-search-wrap:focus-within{border-color:var(--accent)}.sp-search-wrap svg{color:var(--muted);flex-shrink:0}.sp-search-input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-family:Manrope,sans-serif;font-size:13.5px}.sp-search-input::placeholder{color:var(--muted)}.sp-search-clear{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:0 2px;font-size:13px;transition:color .16s;display:flex}.sp-search-clear:hover{color:var(--text)}.sp-back-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:7px 14px;font-family:Manrope,sans-serif;font-size:13px;font-weight:500;transition:border-color .2s,color .2s;display:inline-flex}.sp-back-btn:hover{border-color:var(--accent);color:var(--accent)}.sp-empty{text-align:center;color:var(--muted);padding:80px 20px}.sp-empty-icon{margin-bottom:16px;font-size:48px}.sp-empty-title{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .3s}[data-theme=dark] .sp-empty-title{color:#fff}.sp-empty-sub{max-width:320px;margin:0 auto;font-size:14px;line-height:1.6}.sp-badge{white-space:nowrap;border-radius:6px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-active{color:#34d399;background:#34d3991f}.badge-upcoming{color:#fbbf24;background:#fbbf241f}.badge-draft{color:var(--muted);background:#7f7fb41a}.badge-closed{color:#f87171;background:#f871711f}.sp-level-badge{border:1px solid #0000;border-radius:6px;padding:3px 9px;font-size:12px;font-weight:600}.sp-tag{color:#8fa8ff;background:#4f6ef71a;border-radius:5px;padding:3px 9px;font-size:11.5px;font-weight:500;display:inline-block}.sp-tags-row{flex-wrap:wrap;gap:6px;margin:10px 0;display:flex}.sp-meta-chip{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:7px;align-items:center;gap:5px;padding:4px 10px;font-size:12.5px;display:inline-flex}.sp-clickable{cursor:pointer}.sp-btn-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:9px;padding:10px 20px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:600;transition:opacity .2s,box-shadow .2s;box-shadow:0 0 18px #4f6ef747}.sp-btn-primary:hover{opacity:.87;box-shadow:0 0 26px #4f6ef773}.sp-btn-outline{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:9px;padding:10px 20px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:500;transition:background .2s,color .2s}.sp-btn-outline:hover{background:#4f6ef71a}.sp-btn-registered{color:#fff;cursor:pointer;white-space:nowrap;background:#22c55e;border:none;border-radius:9px;padding:10px 20px;font-family:Manrope,sans-serif;font-size:13.5px;font-weight:600;transition:opacity .2s}.sp-btn-registered:hover{opacity:.85}.sp-btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:Manrope,sans-serif;font-size:13px;font-weight:600;transition:opacity .2s}.sp-btn-text:hover{opacity:.75}.sp-modal-backdrop{z-index:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000009e;justify-content:center;align-items:center;padding:20px;animation:.22s spFadeIn;display:flex;position:fixed;inset:0}@keyframes spFadeIn{0%{opacity:0}to{opacity:1}}.sp-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:540px;max-height:88vh;padding:36px 36px 32px;animation:.28s cubic-bezier(.34,1.3,.64,1) spSlideUp;position:relative;overflow-y:auto}@keyframes spSlideUp{0%{opacity:0;transform:translateY(22px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.sp-modal::-webkit-scrollbar{width:4px}.sp-modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sp-modal-close{background:var(--surface2);border:1px solid var(--border);width:30px;height:30px;color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .2s,color .2s;display:flex;position:absolute;top:16px;right:16px}.sp-modal-close:hover{color:#f87171;background:#f871711f}.sp-detail{flex-direction:column;gap:12px;display:flex}.sp-detail-top{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:4px;display:flex}.sp-detail-title{color:var(--text);font-family:Syne,sans-serif;font-size:22px;font-weight:800;line-height:1.25;transition:color .3s}[data-theme=dark] .sp-detail-title{color:#fff}.sp-detail-desc{color:var(--muted);font-size:14.5px;line-height:1.75}.sp-detail-summary{color:var(--text);font-size:15px;font-weight:500;line-height:1.65}.sp-detail-body{color:var(--text);border-top:1px solid var(--border);padding-top:14px;font-size:14px;line-height:1.85}.sp-detail-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:4px;display:grid}.sp-detail-param{background:var(--surface2);border-radius:10px;padding:12px 14px}.sp-detail-param-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:10.5px;font-weight:700}.sp-detail-param-val{color:var(--text);font-size:14px;font-weight:600;transition:color .3s}[data-theme=dark] .sp-detail-param-val{color:#fff}.sp-detail-price{color:var(--accent);margin-top:4px;font-family:Syne,sans-serif;font-size:22px;font-weight:800}.sp-detail-emoji{margin-bottom:4px;font-size:42px;line-height:1}.sp-detail-cover{border-radius:20px 20px 0 0;width:calc(100% + 72px);margin:-36px -36px 20px;overflow:hidden}.sp-detail-cover img{object-fit:cover;width:100%;height:260px;display:block}.sp-detail-modules{margin-top:4px}.sp-modules-list{flex-direction:column;gap:6px;display:flex}.sp-module-item{background:var(--surface2);color:var(--text);border-radius:8px;align-items:center;gap:12px;padding:10px 14px;font-size:13.5px;display:flex}[data-theme=dark] .sp-module-item{color:#e8e8f0}.sp-module-num{width:22px;height:22px;color:var(--accent);background:#4f6ef72e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.sp-circle-avatar-lg{border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex}.sp-events-list{flex-direction:column;gap:14px;display:flex}.sp-event-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:stretch;transition:border-color .22s,background .3s,transform .18s;display:flex;overflow:hidden}.sp-event-card:hover{border-color:var(--accent);transform:translate(3px)}.sp-event-accent{border-radius:14px 0 0 14px;flex-shrink:0;width:4px}.sp-event-date-col{text-align:center;border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:6px;width:110px;padding:20px 16px 20px 20px;display:flex}.sp-event-date{color:var(--text);font-family:Syne,sans-serif;font-size:13.5px;font-weight:700;transition:color .3s}[data-theme=dark] .sp-event-date{color:#fff}.sp-event-format{color:var(--muted);text-align:center;font-size:11.5px}.sp-event-body{flex:1;padding:20px 24px 20px 20px}.sp-event-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.sp-event-title{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:700;line-height:1.3;transition:color .3s}[data-theme=dark] .sp-event-title{color:#fff}.sp-event-desc{color:var(--muted);margin-bottom:12px;font-size:13.5px;line-height:1.65}.sp-event-meta{flex-wrap:wrap;gap:8px;display:flex}.sp-circles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;display:grid}.sp-circle-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .22s,transform .22s,background .3s;display:flex;overflow:hidden}.sp-circle-card:hover{border-color:var(--accent);transform:translateY(-4px)}.sp-circle-card-top{padding:20px 20px 16px;position:relative;overflow:hidden}.sp-circle-stripe{height:3px;position:absolute;top:0;left:0;right:0}.sp-circle-avatar{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:12px;font-size:22px;display:flex}.sp-circle-dir-tag{color:var(--muted);letter-spacing:.5px;background:#ffffff1a;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.sp-circle-body{flex-direction:column;flex:1;gap:8px;padding:16px 20px 20px;display:flex}.sp-circle-title{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:700;line-height:1.25;transition:color .3s}[data-theme=dark] .sp-circle-title{color:#fff}.sp-circle-desc{color:var(--muted);flex:1;font-size:13.5px;line-height:1.6}.sp-circle-meta{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.sp-admissions-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;display:grid}.sp-admission-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .22s,transform .22s,background .3s;display:flex;overflow:hidden}.sp-admission-card:hover{border-color:var(--accent);transform:translateY(-4px)}.sp-adm-top-bar{padding:20px 20px 16px;position:relative;overflow:hidden}.sp-adm-stripe{height:3px;position:absolute;top:0;left:0;right:0}.sp-adm-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.sp-admission-title{color:var(--text);margin:0 0 4px;font-family:Syne,sans-serif;font-size:18px;font-weight:800;line-height:1.2;transition:color .3s}[data-theme=dark] .sp-admission-title{color:#fff}.sp-adm-dir{font-size:12.5px;font-weight:600}.sp-adm-body{flex-direction:column;flex:1;gap:12px;padding:16px 20px 20px;display:flex}.sp-admission-desc{color:var(--muted);font-size:13.5px;line-height:1.65}.sp-admission-params{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.sp-param{background:var(--surface2);border-radius:8px;padding:10px 12px}.sp-param-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px;font-size:10.5px;font-weight:700}.sp-param-val{color:var(--text);font-size:13px;font-weight:600;transition:color .3s}[data-theme=dark] .sp-param-val{color:#fff}.sp-admission-footer{justify-content:space-between;align-items:center;gap:12px;margin-top:auto;display:flex}.sp-price{color:var(--accent);font-family:Syne,sans-serif;font-size:18px;font-weight:800}.sp-projects-list{flex-direction:column;gap:14px;display:flex}.sp-project-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;transition:border-color .22s,background .3s;display:flex;overflow:hidden}.sp-project-card:hover{border-color:var(--accent)}.sp-project-accent{background:linear-gradient(90deg, var(--accent), var(--accent2,#a78bfa));width:100%;height:3px}.sp-project-body{padding:22px 26px}.sp-project-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.sp-project-title{color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:700;transition:color .3s}[data-theme=dark] .sp-project-title{color:#fff}.sp-project-company{color:var(--accent);margin-top:3px;font-size:12.5px;font-weight:500}.sp-project-desc{color:var(--muted);margin-bottom:12px;font-size:13.5px;line-height:1.65}.sp-project-meta{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.sp-open-roles{flex-wrap:wrap;align-items:center;gap:6px;margin-top:10px;display:flex}.sp-roles-label{color:var(--muted);margin-right:2px;font-size:12px}.sp-role-chip{color:#34d399;background:#34d3991a;border-radius:5px;padding:3px 9px;font-size:11.5px;font-weight:600}.sp-news-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.sp-news-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;transition:border-color .22s,background .3s,transform .22s;display:flex;overflow:hidden}.sp-news-card:hover{border-color:#4f6ef766;transform:translateY(-2px)}.sp-news-card--has-img{padding:0}.sp-news-card:not(.sp-news-card--has-img){padding:18px 20px}.sp-news-card--featured{border-color:#4f6ef759;grid-column:1/-1}.sp-news-card--featured.sp-news-card--has-img{grid-template-columns:340px 1fr;display:grid}.sp-news-cover{flex-shrink:0;width:100%;overflow:hidden}.sp-news-cover img{object-fit:cover;width:100%;height:160px;transition:transform .4s;display:block}.sp-news-card:hover .sp-news-cover img{transform:scale(1.04)}.sp-news-card--featured .sp-news-cover,.sp-news-card--featured .sp-news-cover img{height:100%;min-height:220px}.sp-news-body{flex-direction:column;flex:1;padding:14px 16px;display:flex}.sp-news-card:not(.sp-news-card--has-img) .sp-news-body{padding:0}.sp-news-meta-top{align-items:center;gap:8px;margin-bottom:8px;display:flex}.sp-news-date{color:var(--muted);font-size:11.5px}.sp-news-title{color:var(--text);margin-bottom:6px;font-family:Syne,sans-serif;font-size:16px;font-weight:700;line-height:1.3;transition:color .3s}.sp-news-card--featured .sp-news-title{font-size:20px}[data-theme=dark] .sp-news-title{color:#fff}.sp-news-summary{color:var(--muted);flex:1;margin-bottom:10px;font-size:13.5px;line-height:1.6}.sp-news-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.sp-news-author{color:var(--muted);font-size:12.5px}.sp-ai-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.sp-ai-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .22s,transform .22s,background .3s;display:flex;overflow:hidden}.sp-ai-card:hover{border-color:var(--accent);transform:translateY(-4px)}.sp-ai-card-top{padding:20px 20px 16px;position:relative;overflow:hidden}.sp-ai-stripe{height:3px;position:absolute;top:0;left:0;right:0}.sp-ai-emoji{margin-bottom:10px;font-size:32px}.sp-ai-head{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sp-ai-body{flex-direction:column;flex:1;gap:8px;padding:14px 20px;display:flex}.sp-course-title{color:var(--text);font-family:Syne,sans-serif;font-size:17px;font-weight:800;line-height:1.25;transition:color .3s}[data-theme=dark] .sp-course-title{color:#fff}.sp-course-desc{color:var(--muted);font-size:13px;line-height:1.6}.sp-course-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:14px 20px 18px;display:flex}.sp-course-price{color:var(--accent);font-family:Syne,sans-serif;font-size:18px;font-weight:800}@media (width<=900px){.sp-root{padding:28px 20px 60px}.sp-hero-strip{gap:20px}.sp-hero-stats{display:none}}@media (width<=680px){.sp-title{font-size:28px}.sp-dir-tabs{gap:6px}.sp-dir-tab{padding:7px 12px;font-size:12px}.sp-event-card{flex-direction:column}.sp-event-accent{border-radius:14px 14px 0 0;width:100%;height:4px}.sp-event-date-col{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;justify-content:flex-start;width:100%;padding:12px 18px}.sp-event-body{padding:16px 18px}.sp-news-card--featured.sp-news-card--has-img{grid-template-columns:1fr}.sp-news-card--featured .sp-news-cover{height:auto;min-height:unset}.sp-news-card--featured .sp-news-cover img{height:200px;min-height:unset}.sp-admissions-grid,.sp-circles-grid,.sp-ai-grid{grid-template-columns:1fr}.sp-admission-params{grid-template-columns:1fr 1fr}.sp-detail-grid{grid-template-columns:1fr}.sp-modal{padding:28px 24px 24px}.sp-detail-cover{width:calc(100% + 48px);margin:-28px -24px 18px}}*{box-sizing:border-box;margin:0;padding:0}body,html,#root{width:100%;min-height:100vh}
