:root{--bg:#ffffff;--card:#ffffff;--text:#1f2937;--muted:#6b7280;--ring:#e5e7eb;--primary:#1a73e8;--primary-ink:#0b57d0;--chip:#f1f5f9;--shadow:0 10px 30px rgba(0,0,0,.06);--radius:18px}[data-theme=dark]{--bg:#0b0f16;--card:#0e141b;--text:#e5e7eb;--muted:#94a3b8;--ring:#1f2937;--primary:#8ab4f8;--primary-ink:#a5c6fb;--chip:#111827;--shadow:0 12px 35px rgba(0,0,0,.35)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;font-size:15px;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.35}a{color:inherit;text-decoration:none}.nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(180%) blur(6px);backdrop-filter:saturate(180%) blur(6px);background:color-mix(in oklab,var(--bg) 85%,transparent);border-bottom:1px solid var(--ring)}.nav-inner{max-width:1120px;margin:auto;padding:14px 18px;display:flex;align-items:center;gap:14px}.logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}.logo-dot{width:11px;height:11px;border-radius:50%;background:var(--primary)}.nav-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--ring);background:var(--card);padding:10px 14px;border-radius:12px;cursor:pointer;font-weight:600;color:var(--text)}.btn:hover{box-shadow:var(--shadow)}.btn-primary{background:var(--primary);color:#fff;border-color:transparent}.btn-primary:hover{filter:brightness(.98)}.input{width:100%;padding:12px;border:1px solid var(--ring);border-radius:12px;background:var(--card);color:var(--text)}.input:focus{outline:2px solid color-mix(in oklab,var(--primary) 30%,transparent)}label{display:block;margin:8px 0 6px;font-weight:700}.auth-shell{position:relative;min-height:calc(100vh - 140px);display:grid;place-items:center;padding:40px 18px;overflow:hidden}.auth-shell:before{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:conic-gradient(from 180deg at 50% 50%,#5b7cfa,#00c2ff,#8b5cf6,#5b7cfa);filter:blur(80px);opacity:.18;animation:huerot 14s linear infinite}.auth-shell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,color-mix(in oklab,var(--ring) 60%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in oklab,var(--ring) 60%,transparent) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(ellipse at 50% -10%,rgba(0,0,0,.55),transparent 60%);mask-image:radial-gradient(ellipse at 50% -10%,rgba(0,0,0,.55),transparent 60%)}@keyframes huerot{to{filter:hue-rotate(360deg) blur(80px)}}.auth-anim{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.auth-anim span{position:absolute;display:inline-block;padding:6px 10px;border:1px solid var(--ring);border-radius:10px;background:color-mix(in oklab,var(--card) 85%,transparent);-webkit-backdrop-filter:saturate(180%) blur(4px);backdrop-filter:saturate(180%) blur(4px);color:var(--muted);font-size:12px;animation:float 16s linear infinite;white-space:nowrap}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-30px)}to{transform:translateY(0)}}.auth-anim span:nth-child(1){left:6%;top:18%;animation-delay:-2s}.auth-anim span:nth-child(2){left:72%;top:22%;animation-delay:-6s}.auth-anim span:nth-child(3){left:14%;top:68%;animation-delay:-9s}.auth-anim span:nth-child(4){left:80%;top:70%;animation-delay:-12s}.auth-anim span:nth-child(5){left:46%;top:12%;animation-delay:-4s}.auth-anim span:nth-child(6){left:52%;top:82%;animation-delay:-8s}.auth-anim span:nth-child(7){left:8%;top:42%;animation-delay:-10s}.auth-anim span:nth-child(8){left:86%;top:40%;animation-delay:-14s}.auth-card{position:relative;z-index:1;width:min(520px,92vw);padding:22px;border-radius:16px;background:color-mix(in oklab,var(--card) 92%,transparent);-webkit-backdrop-filter:saturate(160%) blur(8px);backdrop-filter:saturate(160%) blur(8px);border:1px solid var(--ring);box-shadow:0 18px 60px #00000026}.auth-card:hover{transform:translateY(-1px)}.auth-title{margin:0 0 6px;font-weight:800;letter-spacing:-.02em}.auth-sub{margin:0 0 14px;color:var(--muted)}.profile-wrap{position:relative}.avatar{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--ring);background:var(--chip);font-weight:800}.profile-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--card);border:1px solid var(--ring);border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:200px;z-index:50;display:flex;flex-direction:column;gap:6px}.profile-menu .pm-head{color:var(--muted);font-size:12px;padding:4px 6px;border-bottom:1px solid var(--ring);margin-bottom:6px}.profile-menu a{padding:6px;border-radius:8px}.profile-menu a:hover{background:var(--chip)}.profile-menu .linkish{background:none;border:0;text-align:left;padding:6px;border-radius:8px;cursor:pointer}.profile-menu .linkish:hover{background:var(--chip)}.profile-page{max-width:1120px;display:grid;grid-template-columns:280px 1fr;gap:16px;padding:18px}@media (max-width:900px){.profile-page{grid-template-columns:1fr}}.profile-drawer{border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:12px;height:max-content}.profile-head{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--ring);margin-bottom:8px}.avatar.lg{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--chip);border:1px solid var(--ring);font-weight:800}.p-name{font-weight:800}.p-email{color:var(--muted);font-size:12px}.profile-menu{display:flex;flex-direction:column;gap:6px}.profile-drawer .profile-menu{position:static;right:auto;top:auto;background:transparent;border:0;box-shadow:none;padding:0;min-width:auto}.p-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--ring);background:var(--card);padding:10px 12px;border-radius:10px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text);font-weight:600}.p-link:hover{background:var(--chip)}.p-link.active{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in oklab,var(--primary) 25%,transparent)}.p-link.logout{color:#b00020;border-color:#b00020}.profile-content{display:flex;flex-direction:column;gap:16px}.profile-content .cardish .course-grid{max-width:100%;padding:0}.my-course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;width:100%}.my-course-grid .card{grid-column:auto}@media (max-width:520px){.my-course-grid{grid-template-columns:1fr}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width:760px){.grid-2{grid-template-columns:1fr}}.listish{padding-left:18px}.tabs{display:flex;gap:8px;margin-bottom:8px}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--ring);background:var(--card);padding:8px 12px;border-radius:10px;cursor:pointer;color:var(--text);font-weight:600}.tab.active{background:var(--primary);border-color:transparent;color:#fff}.hero{max-width:880px;margin:34px auto 16px;padding:0 18px;text-align:center}.hero h1{font-size:clamp(28px,6vw,44px);margin:0 0 14px;font-weight:800;letter-spacing:-.02em}.hero p{margin:0;color:var(--muted)}.searchwrap{max-width:780px;margin:18px auto 28px;padding:0 18px}.search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--ring);border-radius:999px;padding:10px 14px;box-shadow:var(--shadow)}.search input{flex:1;border:0;outline:0;background:transparent;font-size:inherit;color:var(--text);padding:8px}.kbd{border:1px solid var(--ring);padding:2px 6px;border-radius:8px;color:var(--muted);font-size:12px}.chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:10px auto 24px;padding:0 18px}.chip{background:var(--chip);border:1px solid var(--ring);padding:8px 12px;border-radius:999px;font-weight:600;color:var(--muted);cursor:pointer}.chip.active{color:var(--text);border-color:var(--primary)}.grid{max-width:1120px;margin:0 auto;padding:0 18px 60px;display:grid;grid-template-columns:repeat(12,1fr);gap:16px}@media (max-width:1200px){.grid{grid-template-columns:repeat(8,1fr)}}@media (max-width:760px){.grid{grid-template-columns:repeat(4,1fr)}}.card{grid-column:span 4;background:var(--card);border:1px solid var(--ring);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px;transition:transform .15s ease,box-shadow .15s ease}.card:hover{transform:translateY(-2px);box-shadow:0 14px 40px #0000001f}@media (max-width:760px){.card{grid-column:span 4}}.app{display:flex;gap:12px;align-items:center}@media (max-width:520px){.app{flex-direction:column;align-items:flex-start}}.icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary-ink));display:grid;place-items:center;color:#fff;font-weight:800;overflow:hidden}.icon img{width:100%;height:100%;object-fit:cover;display:block;border-radius:14px}.app h3{margin:0;font-size:16px}.app small{color:var(--muted)}.price-badge{margin-left:auto;border:1px solid var(--ring);background:var(--chip);padding:4px 8px;border-radius:999px;font-weight:700;font-size:12px;line-height:1}.price-paid{background:var(--primary);color:#fff;border-color:transparent}.rating{display:flex;align-items:center;gap:6px;color:var(--muted);font-weight:600}.stars{--s:16px;display:inline-grid;grid-auto-flow:column;gap:2px}.star{display:inline-block;width:var(--s);height:var(--s);mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 17.27 18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z"/></svg>') no-repeat center/contain;background:var(--ring)}.star.filled{background:var(--primary)}.desc{color:var(--muted);margin:2px 0 0;min-height:40px}.actions{display:flex;gap:8px;margin-top:auto;flex-direction:column}.app-grid .card{grid-column:span 4}.app-card{display:block;padding:0;overflow:hidden}.app-card:hover{transform:translateY(-2px);box-shadow:0 14px 40px #0000001f}.app-thumb{position:relative;border:1px solid var(--ring);border-bottom:0;border-radius:14px 14px 0 0;background:var(--chip);aspect-ratio:4/3;display:block;overflow:hidden}.app-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}.app-letter{width:100%;height:100%;display:grid;place-items:center;font-weight:800;font-size:36px;color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-ink))}.app-card:hover .app-thumb img{transform:scale(1.05)}.app-thumb .price-badge{position:absolute;top:8px;right:8px}.app-body{padding:12px}.app-title{margin:0 0 6px;font-size:16px}.app-meta{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:600}.app-meta .dot{opacity:.6}@media (max-width:1200px){.app-grid .card{grid-column:span 6}}@media (max-width:760px){.app-grid .card{grid-column:span 12}}.pill{flex:0 0 auto;display:block;text-align:center;border:1px solid var(--ring);padding:10px 12px;border-radius:12px;font-weight:700;width:100%}.pill.primary{background:var(--primary);border-color:transparent;color:#fff}footer{border-top:1px solid var(--ring);padding:28px 18px;color:var(--muted)}.footer-inner{max-width:1120px;margin:auto;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page{max-width:880px;margin:28px auto;padding:0 18px}@media (max-width:520px){.page{margin:18px auto;padding:0 12px}}.page h2{font-size:clamp(22px,4.5vw,32px);margin:0 0 10px;font-weight:800}.page p,.page li{color:var(--muted)}.page .cardish{background:var(--card);border:1px solid var(--ring);border-radius:16px;box-shadow:var(--shadow);padding:18px}.details .app h2{font-size:clamp(22px,4.5vw,32px)}.media-rail{margin-top:12px;display:flex;gap:12px;overflow-x:auto;padding-bottom:6px}.media-rail .media{flex:0 0 auto;min-width:clamp(200px,60vw,380px)}@media (max-width:520px){.media-rail{gap:8px}}.media{position:relative;flex:0 0 auto;width:min(280px,80vw);aspect-ratio:9/16;border:1px solid var(--ring);border-radius:14px;background:var(--card);box-shadow:var(--shadow);overflow:hidden}.media:has(video):after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#00000073;border:1px solid rgba(255,255,255,.6);pointer-events:none}.media:has(video):before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;background:#fff;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8 5v14l11-7z"/></svg>') no-repeat center/contain}.media:hover:has(video):after{background:#0009}.page .cardish form{width:100%}.page .cardish form label{display:block;width:100%}.page .cardish form input,.page .cardish form select,.page .cardish form textarea{width:100%;max-width:100%;box-sizing:border-box}.page .cardish form textarea{resize:vertical;overflow-wrap:anywhere}.home-grid{grid-template-columns:repeat(2,1fr)}@media (max-width:760px){.home-grid{grid-template-columns:1fr}}.home-grid .card{grid-column:auto}.home-split{max-width:1120px;margin:0 auto;padding:0 18px 40px;display:grid;grid-template-columns:1fr 380px;gap:16px}@media (max-width:1000px){.home-split{grid-template-columns:1fr}}.home-left{display:flex;flex-direction:column;gap:16px}.home-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.home-menu .card{grid-column:auto}@media (max-width:900px){.home-menu{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.home-menu{grid-template-columns:1fr}}.home-right .promo{position:sticky;top:84px;border:1px solid var(--ring);border-radius:16px;overflow:hidden;background:#000;box-shadow:var(--shadow)}.home-right .promo video{display:block;width:100%;height:240px;object-fit:cover}@media (max-width:1000px){.home-right{order:-1}.home-right .promo{position:relative;top:auto}}.trend-section{border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:14px}.trend-title{margin:0 0 8px}.trend-sub{margin:8px 0}.trend-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width:760px){.trend-grid{grid-template-columns:1fr}}.home-card{display:flex;flex-direction:column}.home-card.card{padding:12px;gap:8px}.home-card .pill{padding:8px 10px;border-radius:10px}.home-card .desc{min-height:0}.svc-card{position:relative;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;gap:6px;padding:12px;min-height:160px;color:#fff;background-size:100%;background-position:center;overflow:hidden;transition:background-size .25s ease}.svc-card .svc-title{position:absolute;left:12px;right:12px;bottom:12px;z-index:1;margin:0;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.45)}.svc-card .svc-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#00000014,#00000073);z-index:0;transition:background .25s ease,opacity .25s ease}.svc-card:hover{background-size:110%}.svc-card:hover .svc-shade{background:linear-gradient(180deg,#0000000a,#00000059)}.svc-link{display:block}.svc-card .actions,.svc-card .pill{display:none}.home-slider{position:relative;overflow:hidden}.home-slider:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.home-slider-track{display:flex;transition:transform .3s ease}.home-slide{flex:0 0 100%;aspect-ratio:21/9;background:var(--card)}.home-slide img{width:100%;height:100%;object-fit:cover;display:block}.home-slider-arrow{position:absolute;top:50%;transform:translateY(-50%);background:color-mix(in oklab,var(--card) 90%,transparent);border:1px solid var(--ring);width:32px;height:32px;border-radius:50%;display:grid;place-items:center;cursor:pointer}.home-slider-arrow.left{left:10px}.home-slider-arrow.right{right:10px}.home-media-placeholder{background:var(--chip);aspect-ratio:16/9}.home-card .course-thumb{aspect-ratio:16/9}.home-card .course-thumb .home-slider{border:0;border-radius:0;box-shadow:none}.home-card .badge{top:8px;left:8px}.about-hero{margin:12px auto 0;border:1px solid var(--ring);border-radius:16px;background:linear-gradient(180deg,color-mix(in oklab,var(--bg) 85%,#0b0f16),color-mix(in oklab,var(--bg) 70%,#0b0f16));box-shadow:var(--shadow)}.about-hero-inner{max-width:1120px;margin:auto;padding:18px;display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center}.about-avatar{width:120px;height:120px;border-radius:16px;border:1px solid var(--ring);background:var(--card);object-fit:cover}.about-tagline{color:var(--muted);font-weight:700;margin:6px 0}.about-desc{color:var(--muted);max-width:820px}.about-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}@media (max-width:900px){.about-hero-inner{grid-template-columns:110px 1fr}.about-avatar{width:100px;height:100px}}@media (max-width:640px){.about-hero-inner{grid-template-columns:1fr;justify-items:center;text-align:center}.about-avatar{width:96px;height:96px;margin:0 auto}.about-desc{max-width:none}.about-actions{flex-direction:column;align-items:stretch;width:100%}.about-actions .pill{width:100%}}.about-grid{max-width:1120px;margin:16px auto;display:grid;grid-template-columns:2fr 2fr 1fr;gap:16px;padding:0 18px}@media (max-width:1000px){.about-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.about-grid{grid-template-columns:1fr}}.stat-card .stats{display:flex;gap:14px;flex-wrap:wrap;padding:0;margin:0}.stat-card .stats li{list-style:none;border:1px solid var(--ring);border-radius:12px;padding:10px 12px;min-width:110px;background:var(--card)}.stat-num{font-weight:800}.stat-label{color:var(--muted);font-weight:600}.socials{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.skills{display:flex;gap:8px;flex-wrap:wrap}.skill-chip{border:1px solid var(--ring);background:var(--chip);padding:6px 10px;border-radius:999px;font-weight:700}.about-side .actions{margin-top:12px}.about-list{padding-left:18px;color:var(--muted)}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:12px;top:6px;bottom:6px;width:2px;background:var(--ring);border-radius:2px}.timeline .timeline-item{position:relative;padding:10px 0 10px 26px;border-bottom:1px solid var(--ring)}.timeline .timeline-item:last-child{border-bottom:0}.timeline .timeline-item .dot{position:absolute;left:8px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px var(--card)}.tl-title{font-weight:800}.tl-range{font-size:12px;margin:2px 0 4px;color:var(--muted)}.tl-text{margin:0}.home-card h3{margin:10px 0 6px}.home-card .desc{margin:0 0 8px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-grid{grid-template-columns:repeat(12,1fr)}.course-grid .card{grid-column:span 4}@media (max-width:1200px){.course-grid .card{grid-column:span 6}}@media (max-width:760px){.course-grid .card{grid-column:span 12}}.course-card .desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-thumb{position:relative;border:1px solid var(--ring);border-radius:14px;overflow:hidden;background:var(--chip);aspect-ratio:16/9}.course-thumb img{width:100%;height:100%;object-fit:cover;display:block}.badge{position:absolute;top:8px;left:8px;background:var(--card);border:1px solid var(--ring);border-radius:999px;padding:4px 8px;font-weight:700;font-size:12px}.badge.price{right:8px;left:auto}.badge.paid{background:var(--primary);color:#fff;border-color:transparent}.exp-card .exp-list{display:block}.exp-card .exp-item{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--ring)}.exp-card .exp-item:last-child{border-bottom:0}.exp-card .exp-left{display:flex;align-items:center}.exp-card .exp-icon{width:44px;height:44px;border-radius:8px;border:1px solid var(--ring);background:var(--chip)}.exp-card .exp-right{flex:1}.exp-card .exp-title{font-weight:800}.exp-card .exp-sub{color:var(--muted);font-size:12px;margin:2px 0 4px}.exp-card .exp-desc{color:var(--muted);margin:6px 0}.course-meta{display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:600;margin-top:6px}.course-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--ring);background:var(--card);padding:10px 12px;border-radius:12px;color:var(--text)}.course-split{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}@media (max-width:760px){.course-split{grid-template-columns:1fr}}.learn-list,.req-list{padding-left:18px}.accordion{border:1px solid var(--ring);border-radius:12px;overflow:hidden;background:var(--card)}.accordion-item+.accordion-item{border-top:1px solid var(--ring)}.accordion-item summary{cursor:pointer;list-style:none;padding:12px 14px;font-weight:700;display:flex;align-items:center;gap:8px}.accordion-item summary:after{content:"";margin-left:auto;width:16px;height:16px;background:var(--muted);mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M6 9l6 6 6-6"/></svg>') no-repeat center/contain;transition:transform .2s ease}.accordion-item[open] summary:after{transform:rotate(180deg)}.accordion-item summary::-webkit-details-marker{display:none}.accordion-item ul{margin:0;padding:8px 14px 12px 24px}.accordion-item li{display:flex;justify-content:space-between;gap:8px;color:var(--muted);padding:6px 0}.accordion-item li .lec-title{display:flex;align-items:center;gap:8px;color:var(--text)}.accordion-item li .lec-meta{display:flex;align-items:center;gap:6px}.play-ico{position:relative;display:inline-block;width:20px;height:20px;border-radius:50%;background:var(--primary);flex:0 0 auto}.play-ico:before{content:"";position:absolute;left:50%;top:50%;transform:translate(-40%,-50%);width:0;height:0;border-left:8px solid #fff;border-top:5px solid transparent;border-bottom:5px solid transparent}.play-ico.sm{width:16px;height:16px}.play-ico.sm:before{border-left-width:6px;border-top-width:4px;border-bottom-width:4px}.course-wide{max-width:1120px;margin:0 auto;padding:0}.course-details{padding:0}.page .cardish.course-details{background:transparent;border:0;box-shadow:none;padding:0}.course-details>.btn{margin:18px 18px 0}.course-hero{margin:12px 18px 0;border:1px solid var(--ring);border-radius:16px;overflow:hidden;min-height:200px;background:linear-gradient(180deg,color-mix(in oklab,var(--bg) 80%,#0b0f16),color-mix(in oklab,var(--bg) 60%,#0b0f16))}.course-hero{padding:24px}.course-hero .crumbs{color:var(--muted);font-weight:600}.course-hero .crumbs a{color:inherit}.course-hero-title{margin:10px 0 8px;font-size:clamp(24px,4.8vw,36px)}.course-hero-sub{color:var(--muted);max-width:820px;margin:0 0 12px}.course-hero-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:var(--muted);font-weight:600}.pillish{border:1px solid var(--ring);background:var(--chip);padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px}.pillish.hot{background:var(--primary);color:#fff;border-color:transparent}.course-layout{display:grid;grid-template-columns:2fr 1fr;gap:18px;padding:18px}@media (max-width:900px){.course-layout{grid-template-columns:1fr}}.course-main .course-desc{color:var(--muted)}.course-side{position:relative}.side-card{position:sticky;top:84px;border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:12px}.side-thumb{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--ring);margin-bottom:10px}.side-thumb img{width:100%;height:160px;object-fit:cover;display:block}.side-thumb video{width:100%;height:160px;object-fit:cover;display:block;background:#000}.play-btn{position:absolute;inset:auto auto 10px 10px;width:36px;height:36px;border-radius:50%;border:0;background:var(--primary);color:#fff;cursor:pointer}.price-row{display:flex;gap:10px;align-items:center;font-weight:800}.price{font-size:20px}.strike{text-decoration:line-through;color:var(--muted)}.offer{color:#f59e0b;font-weight:700;margin:6px 0}.info-list{margin:10px 0 0}.info-list div{display:flex;justify-content:space-between;gap:8px;padding:6px 0;border-bottom:1px dashed var(--ring)}.info-list div:last-child{border-bottom:none}.info-list dt{color:var(--muted);font-weight:600}.info-list dd{margin:0}.panel{border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:16px}.panel+.panel{margin-top:16px}.panel .panel-head{display:flex;justify-content:space-between;align-items:flex-end}.expand-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--ring);background:var(--card);color:var(--muted);padding:6px 10px;border-radius:10px;cursor:pointer;font-weight:600}.expand-btn svg{transition:transform .2s ease}.expand-btn[aria-expanded=true] svg{transform:rotate(180deg)}.muted{color:var(--muted)}.collapsible.collapsed{max-height:220px;overflow:hidden;position:relative}.collapsible.collapsed:after{content:"";position:absolute;left:0;right:0;bottom:0;height:48px;background:linear-gradient(180deg,transparent,var(--card))}.learn-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media (max-width:760px){.learn-grid{grid-template-columns:1fr}}.learn-item{display:flex;gap:8px;align-items:flex-start}.tick{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;border:1px solid var(--ring);font-size:12px;color:var(--primary)}.editor-preview.collapsed{max-height:220px;overflow:hidden;position:relative}.editor-preview.collapsed:after{content:"";position:absolute;left:0;right:0;bottom:0;height:48px;background:linear-gradient(180deg,transparent,var(--card))}.blog-grid{grid-template-columns:repeat(12,1fr)}.blog-grid .card{grid-column:span 4}@media (max-width:1200px){.blog-grid .card{grid-column:span 6}}@media (max-width:760px){.blog-grid .card{grid-column:span 12}}.blog-card{display:flex;flex-direction:column}.blog-thumb{display:block;border:1px solid var(--ring);border-radius:14px;overflow:hidden;background:var(--chip)}.blog-thumb img{width:100%;height:160px;object-fit:cover;display:block}.blog-body{padding-top:8px}.blog-meta{display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:600}.blog-title{margin:6px 0}.blog-wide{max-width:1120px}.blog-details{padding:0}.blog-hero{margin:12px 18px 0;border:1px solid var(--ring);border-radius:16px;background:linear-gradient(180deg,color-mix(in oklab,var(--bg) 85%,#0b0f16),color-mix(in oklab,var(--bg) 70%,#0b0f16));padding:24px}.blog-title-xl{margin:10px 0 6px;font-size:clamp(24px,4.8vw,36px)}.blog-layout{display:grid;grid-template-columns:2fr 1fr;gap:18px;padding:18px}@media (max-width:900px){.blog-layout{grid-template-columns:1fr}}.blog-cover{margin:0 0 12px;border:1px solid var(--ring);border-radius:16px;overflow:hidden;background:var(--chip);aspect-ratio:16/9}.blog-cover img{width:100%;height:100%;object-fit:cover;display:block}.related{padding-left:18px}.related li{padding:6px 0}.related li a{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width:640px){.related li a{white-space:normal}}.prose{color:var(--text);line-height:1.65}.prose h2{font-size:1.25rem;margin:16px 0 8px}.prose p{margin:0 0 10px;color:var(--muted)}.prose ul{padding-left:18px;margin:0 0 10px}.prose img{max-width:100%;height:auto;border-radius:12px;border:1px solid var(--ring);background:var(--chip);display:block;margin:8px 0}.prose pre{border:1px solid var(--ring);background:#0f172a;color:#e5e7eb;border-radius:12px;padding:12px;overflow:auto;max-width:100%}.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}@media (max-width:640px){.prose pre{padding:10px;font-size:13px}}.blog-meta{display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:600;flex-wrap:wrap}@media (max-width:900px){.blog-hero{padding:16px}}@media (max-width:640px){.blog-hero,.blog-layout{padding:14px}.blog-side .side-card{position:static;top:auto}}.player-page{max-width:100vw;margin:0;padding:0}.drawer{position:sticky;top:72px;align-self:start;border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:8px;max-height:calc(100vh - 96px);overflow:auto}.drawer.hidden{display:none}.drawer-head{padding:8px;border-bottom:1px solid var(--ring);margin-bottom:6px}.drawer-top{display:flex;align-items:center;gap:8px}.drawer-head .hamburger{margin-left:auto}.drawer-title{margin:8px 0 0;font-size:16px;line-height:1.25}.drawer-head .back-btn{padding:6px 10px;font-size:13px;border-radius:10px}.drawer-body{padding:4px}.player-main{position:relative;padding:8px 8px 0 0}.drawer-head .back-btn{margin-right:8px}.player{width:100%;height:50vh;max-height:50vh;border:1px solid var(--ring);border-radius:16px;overflow:hidden;background:#000}.player video{width:100%;height:100%;object-fit:contain;display:block;background:#000}@media (max-width: 760px){.player{height:42vh;max-height:42vh}}.player-empty{display:grid;place-items:center;height:100%;color:var(--muted)}.hamburger{border:1px solid var(--ring);background:color-mix(in oklab,var(--card) 90%,transparent);-webkit-backdrop-filter:saturate(180%) blur(6px);backdrop-filter:saturate(180%) blur(6px);padding:8px;border-radius:10px;cursor:pointer;display:inline-grid;gap:3px}.hamburger span{display:block;width:18px;height:2px;background:var(--text)}.drawer-toggle{position:absolute;top:8px;left:8px}@media (min-width: 900px){.player-page{display:grid;grid-template-columns:320px 1fr;gap:16px}.player-page:has(.drawer.hidden){grid-template-columns:1fr}.drawer.hidden{display:none}}@media (max-width: 899px){.player-page{display:block}.drawer{position:fixed;left:8px;right:8px;top:8px;bottom:8px;width:auto;max-height:none;z-index:30;transition:transform .2s ease,opacity .2s ease;box-shadow:0 20px 60px #00000059}.drawer.hidden{display:block;transform:translate(-106%);opacity:0;pointer-events:none}.drawer-toggle{top:12px;left:12px;z-index:31}.player-main{padding:12px}.player{height:42vh;max-height:42vh}.player-page:has(.drawer:not(.hidden)):before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:25}}.accordion-item li.lec.active{background:color-mix(in oklab,var(--chip) 70%,transparent);border-radius:10px;color:var(--text)}.accordion-item li.lec.active .lec-title{font-weight:700}.home-two-col{max-width:1120px;margin:0 auto;padding:0 18px 40px;display:grid;grid-template-columns:1fr 420px;gap:16px}@media (max-width:1020px){.home-two-col{grid-template-columns:1fr}}.cardish.section,.svc,.upcoming,.apps-strip,.feat-course,.reviews{border:1px solid var(--ring);border-radius:16px;background:var(--card);box-shadow:var(--shadow);padding:14px}.svc{grid-column:1}.svc{background:linear-gradient(135deg,color-mix(in oklab,var(--card) 92%,var(--primary) 8%),color-mix(in oklab,var(--card) 92%,var(--primary-ink) 8%))}.sec-title,.sec-sub{margin:0 0 8px}.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width:760px){.svc-grid{grid-template-columns:repeat(2,1fr)}}.svc-box{display:grid;place-items:center;height:120px;border:1px solid var(--ring);border-radius:12px;background:var(--chip);font-weight:800}.upcoming,.feat-course{grid-column:2}@media (max-width:1020px){.upcoming,.feat-course{grid-column:1}}.promo-large{position:relative;border:1px solid var(--ring);border-radius:16px;overflow:hidden;background:#000}.promo-large video{width:100%;height:320px;object-fit:cover;display:block}.mute-toggle{position:absolute;right:10px;bottom:10px;border:1px solid var(--ring);background:color-mix(in oklab,var(--card) 80%,transparent);-webkit-backdrop-filter:saturate(160%) blur(4px);backdrop-filter:saturate(160%) blur(4px);padding:6px 10px;border-radius:999px;font-weight:700}.apps-strip{grid-column:1}.app-card-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}@media (max-width:900px){.app-card-row{grid-template-columns:repeat(3,1fr)}}@media (max-width:600px){.app-card-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:420px){.app-card-row{grid-template-columns:1fr}}.app-mini{position:relative;display:block;height:120px;border:1px solid var(--ring);background:var(--chip);border-radius:12px;overflow:hidden;text-align:center;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.app-mini:hover{transform:translateY(-2px);box-shadow:0 14px 40px #0000001f}.app-mini-icon{position:absolute;top:0;right:0;bottom:0;left:0}.app-mini-icon img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease;filter:saturate(110%)}.app-mini:hover .app-mini-icon img{transform:scale(1.05)}.app-mini:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000000f 20%,#00000073)}.app-mini-name{position:absolute;left:8px;right:8px;bottom:8px;color:#fff;font-size:13px;font-weight:800;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.45)}@media (max-width:600px){.app-mini{height:110px}}.feat-course{grid-column:2}@media (max-width:1020px){.feat-course{grid-column:1}}.home-course-grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:12px}@media (max-width:760px){.home-course-grid{grid-template-columns:1fr}}.home-course-card{display:block;border:1px solid var(--ring);border-radius:12px;overflow:hidden;background:var(--card);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.home-course-card:hover{transform:translateY(-2px);box-shadow:0 14px 40px #0000001f}.hc-thumb{position:relative;aspect-ratio:16/9;background:var(--chip)}.hc-thumb img{width:100%;height:100%;object-fit:cover;display:block}.hc-avatar{position:absolute;right:10px;bottom:-20px;width:56px;height:56px;border-radius:50%;border:3px solid var(--card);overflow:hidden;box-shadow:0 6px 18px #00000040}.hc-avatar img{width:100%;height:100%;object-fit:cover;display:block}.hc-body{padding:24px 12px 12px}.hc-title{margin:0 0 4px;font-weight:800}.hc-sub{color:var(--muted);margin-bottom:6px}.hc-rating{color:#b45309;font-weight:800}.hc-stars{color:#f59e0b;letter-spacing:1px}.reviews{grid-column:1 / -1}.rev-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width:900px){.rev-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.rev-row{grid-template-columns:1fr}}.rev-list{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width:900px){.rev-list{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.rev-list{grid-template-columns:1fr}}@media (max-width:760px){.svc-card{min-height:140px;padding:10px}}@media (max-width:480px){.svc-card{min-height:120px;padding:10px}}@media (max-width:900px){.promo-large video{height:260px}}@media (max-width:600px){.promo-large video{height:200px}}.rev-card{border:1px solid var(--ring);border-radius:14px;padding:12px;background:var(--card);box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:84px;max-height:160px;overflow:hidden}.rev-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}.rev-avatar{width:36px;height:36px;border-radius:50%;background:var(--chip);display:grid;place-items:center;font-weight:800}.rev-name{font-weight:800}.rev-stars{color:#f59e0b;font-weight:700;letter-spacing:1px}.rev-body{color:var(--muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.home-app-grid{display:grid;grid-template-columns:repeat(2,minmax(360px,1fr));gap:14px}@media (max-width:900px){.home-app-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.home-app-grid{grid-template-columns:1fr}}.home-app-card{display:block;border:1px solid var(--ring);border-radius:14px;overflow:hidden;background:var(--card);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.home-app-card:hover{transform:translateY(-2px);box-shadow:0 14px 40px #0000001f}.home-app-media{position:relative;aspect-ratio:16/9;background:var(--chip);border-bottom:1px solid var(--ring)}.home-app-media img{width:100%;height:100%;object-fit:cover;display:block}.play-ico.lg{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:56px;height:56px}.home-app-info{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:start;padding:10px}.home-app-left{display:flex;flex-direction:column;align-items:center;gap:6px}.home-app-icon{width:64px;height:64px;border-radius:12px;border:1px solid var(--ring);background:var(--chip);display:grid;place-items:center;overflow:hidden;font-weight:800}.home-app-icon img{width:100%;height:100%;object-fit:cover;display:block}.home-app-meta{min-width:0}.home-app-title{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-app-sub{display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:600}.home-app-rating{margin-top:4px;color:var(--muted);font-weight:700}.star-inline{color:#f59e0b}.home-app-type{border:1px solid var(--ring);background:var(--chip);padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px}.rev-list .rev-card{max-height:none}.rev-list .rev-body.full{-webkit-line-clamp:unset;overflow:visible;display:block}.about-proj-icon{width:56px;height:56px;border-radius:12px;border:1px solid var(--ring);background:var(--chip);object-fit:cover;flex-shrink:0}.project-card{padding:12px;border-bottom:1px solid var(--ring)}.project-card:last-child{border-bottom:0}.project-top{display:flex;gap:10px;align-items:center;margin-bottom:6px}.project-head{display:flex;flex-direction:column}.project-title{font-weight:800}.project-range,.project-assoc{font-size:12px}.project-desc{margin:8px 0 10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-skillline{display:flex;gap:8px;align-items:center;margin:6px 0}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--ring);background:var(--chip);font-weight:700;font-size:12px}.project-linkcard{display:flex;gap:10px;align-items:center;border:1px solid var(--ring);background:var(--chip);padding:10px;border-radius:12px}.project-linkthumb{width:56px;height:56px;border-radius:12px;border:1px solid var(--ring);background:linear-gradient(135deg,#0b2240,#0f3143)}.project-linktext{display:flex;flex-direction:column}.project-linktitle{font-weight:700}.project-foot{padding:8px 12px;border-top:1px solid var(--ring);text-align:center;margin-top:10px}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
