@import url(https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=JetBrains+Mono:wght@400;500;600&display=swap);@import url(https://api.fontshare.com/v2/css?f[]=clash-display@600,700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap);@import url(https://api.fontshare.com/v2/css?f[]=clash-display@400,500,600,700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Fira+Code:wght@400;500&display=swap);:root{--nav-h:72px}.navbar{backdrop-filter:blur(28px) saturate(190%);-webkit-backdrop-filter:blur(28px) saturate(190%);height:72px;height:var(--nav-h,72px);left:0;position:fixed;top:0;transition:background .3s ease,box-shadow .3s ease,border-bottom-color .3s ease;width:100%;z-index:1000}body:not([data-theme=light]) .navbar{background:#07091ef0;border-bottom:1px solid #8278ff2e}body[data-theme=light] .navbar{background:#f5f6fff2;border-bottom:1px solid #6d5dfc24}body:not([data-theme=light]) .navbar.scrolled{background:#07091efa;box-shadow:0 4px 28px #00000085}body[data-theme=light] .navbar.scrolled{background:#f8f9fffc;box-shadow:0 4px 20px #635dc81a}.navbar-container{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1280px;padding:0 24px;width:100%}.logo{align-items:center;display:inline-flex;flex-shrink:0;text-decoration:none}.logo-image{cursor:pointer;display:block;height:44px;object-fit:contain;transition:transform .25s ease,filter .25s ease;width:auto}.logo:hover .logo-image{transform:translateY(-1px) scale(1.03)}.nav-links{gap:34px;list-style:none;margin:0;padding:0}.nav-links,.nav-links li{align-items:center;display:flex}.nav-links a{font-size:15px;font-weight:700;letter-spacing:-.01em;padding:10px 0;position:relative;text-decoration:none;transition:color .25s ease}body:not([data-theme=light]) .nav-links a{color:#c8d2ebd1}body:not([data-theme=light]) .nav-links a.active-link,body:not([data-theme=light]) .nav-links a:hover{color:#fff}body[data-theme=light] .nav-links a{color:#4b5675}body[data-theme=light] .nav-links a.active-link,body[data-theme=light] .nav-links a:hover{color:#07162f}.nav-links a:after{background:linear-gradient(90deg,#7c3aed,#2563eb,#00a6ff);border-radius:999px;bottom:3px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .28s ease;width:0}.nav-links a.active-link:after,.nav-links a:hover:after{width:100%}.nav-actions{align-items:center;display:flex;gap:14px}.theme-toggle{align-items:center;border-radius:14px;cursor:pointer;display:inline-flex;font-size:17px;height:42px;justify-content:center;line-height:1;transition:transform .24s ease,background .24s ease,border-color .24s ease,box-shadow .24s ease;width:42px}body:not([data-theme=light]) .theme-toggle{background:#ffffff12;border:1px solid #8c82ff61;color:#fff}body[data-theme=light] .theme-toggle{background:#6d5dfc12;border:1px solid #6d5dfc38;color:#07162f}.theme-toggle:hover{background:#7c6ef726;border-color:#7c6ef780;box-shadow:0 0 0 3px #7c6ef71f;transform:translateY(-2px)}.theme-toggle:active{transform:scale(.96)}.login-link{font-size:14px;font-weight:700;padding:10px 6px;text-decoration:none;transition:color .25s ease,transform .25s ease}body:not([data-theme=light]) .login-link{color:#c8d2ebd9}body:not([data-theme=light]) .login-link:hover{color:#fff;transform:translateY(-1px)}body[data-theme=light] .login-link{color:#4b5675}body[data-theme=light] .login-link:hover{color:#07162f;transform:translateY(-1px)}.btn-signup{align-items:center;background:linear-gradient(130deg,#7c3aed,#2563eb 52%,#00a6ff);border:none;border-radius:14px;box-shadow:0 8px 24px #6d5dfc6b,inset 0 1px 0 #ffffff2e;color:#fff!important;display:inline-flex;font-size:14px;font-weight:800;justify-content:center;letter-spacing:-.01em;min-height:42px;padding:11px 22px;text-decoration:none;transition:transform .24s ease,box-shadow .24s ease,filter .24s ease}.btn-signup:hover{box-shadow:0 16px 38px #7c6ef78a,inset 0 1px 0 #ffffff38;filter:brightness(1.08);transform:translateY(-3px)}.btn-signup:active{transform:scale(.97)}.hamburger{align-items:center;border-radius:14px;cursor:pointer;display:none;flex-direction:column;gap:5px;height:44px;justify-content:center;transition:background .25s ease,border-color .25s ease,transform .25s ease;width:44px;z-index:1002}body:not([data-theme=light]) .hamburger{background:#ffffff12;border:1px solid #8c82ff52;color:#fff}body[data-theme=light] .hamburger{background:#6d5dfc0f;border:1px solid #6d5dfc33;color:#07162f}.hamburger:hover{background:#7c6ef724;border-color:#7c6ef773;transform:translateY(-2px)}.hamburger span{background:currentColor;border-radius:999px;height:2px;transition:transform .28s ease,opacity .22s ease;width:22px}.hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-drawer{backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border-left:1px solid #8278ff2e;height:100vh;max-width:86%;position:fixed;right:-100%;top:0;transition:right .34s ease;width:320px;z-index:1001}body:not([data-theme=light]) .mobile-drawer{background:#090c26f7;box-shadow:-18px 0 55px #00000080}body[data-theme=light] .mobile-drawer{background:#f5f6fffa;box-shadow:-18px 0 55px #6366f12e}.mobile-drawer.active{right:0}.drawer-inner{height:100%;padding:104px 24px 28px}.drawer-inner,.mobile-links{display:flex;flex-direction:column}.mobile-links{gap:12px;list-style:none;margin:0;padding:0}.mobile-links li{width:100%}.mobile-links a{align-items:center;border-radius:14px;display:flex;font-size:17px;font-weight:800;letter-spacing:-.01em;padding:14px;text-decoration:none;transition:color .22s ease,background .22s ease,transform .22s ease;width:100%}body:not([data-theme=light]) .mobile-links a{color:#c8d2ebd9}body:not([data-theme=light]) .mobile-links a.active-link,body:not([data-theme=light]) .mobile-links a:hover{background:#7c6ef724;color:#fff;transform:translateX(4px)}body[data-theme=light] .mobile-links a{color:#4b5675}body[data-theme=light] .mobile-links a.active-link,body[data-theme=light] .mobile-links a:hover{background:#6d5dfc14;color:#07162f;transform:translateX(4px)}.drawer-actions{display:flex;flex-direction:column;gap:14px;margin-top:34px}.drawer-actions a,.drawer-actions button{border-radius:14px;cursor:pointer;font-size:15px;font-weight:800;min-height:46px;padding:13px 16px;text-align:center;text-decoration:none;transition:transform .22s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease;width:100%}.drawer-login{border:1px solid #8278ff47}body:not([data-theme=light]) .drawer-login{background:#ffffff0f;color:#c8d2ebe6}body[data-theme=light] .drawer-login{background:#6d5dfc0f;border-color:#6d5dfc33;color:#4b5675}.drawer-login:hover{background:#7c6ef71a;border-color:#7c6ef780;transform:translateY(-2px)}.drawer-actions button,.drawer-signup{background:linear-gradient(130deg,#7c3aed,#2563eb 52%,#00a6ff);border:none;box-shadow:0 8px 24px #6d5dfc61;color:#fff!important}.drawer-actions button:hover,.drawer-signup:hover{box-shadow:0 16px 36px #7c6ef780;transform:translateY(-2px)}.drawer-backdrop{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);inset:0;position:fixed;z-index:1000}body:not([data-theme=light]) .drawer-backdrop{background:#02061799}body[data-theme=light] .drawer-backdrop{background:#0f172a42}.user-box{align-items:center;border:1px solid #8278ff38;border-radius:999px;box-shadow:0 2px 8px #00000014;display:flex;gap:10px;padding:6px 8px 6px 6px;transition:border-color .25s ease,transform .25s ease}body:not([data-theme=light]) .user-box{background:#ffffff0f}body[data-theme=light] .user-box{background:#6d5dfc0f}.user-box:hover{border-color:#7c6ef766;transform:translateY(-2px)}.user-avatar{border:2px solid #7c6ef759;border-radius:999px;flex-shrink:0;height:36px;object-fit:cover;width:36px}.user-name{font-size:14px;font-weight:700;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body:not([data-theme=light]) .user-name{color:#fff}body[data-theme=light] .user-name{color:#07162f}.logout-btn{background:linear-gradient(130deg,#7c3aed,#2563eb);border:none;border-radius:999px;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:8px 12px;transition:transform .22s ease,box-shadow .22s ease}.logout-btn:hover{box-shadow:0 8px 20px #6d5dfc5c;transform:translateY(-1px)}@media (max-width:1024px){.navbar-container{padding:0 22px}.nav-links{gap:26px}}@media (max-width:900px){.nav-actions,.nav-links{display:none}.hamburger{display:inline-flex}}@media (max-width:600px){.navbar-container{padding:0 18px}.logo-image{height:39px}.mobile-drawer{width:292px}.drawer-inner{padding:96px 20px 26px}.mobile-links a{font-size:16px;padding:13px}}@media (max-width:420px){.navbar-container{padding:0 16px}.logo-image{height:36px}.hamburger{height:42px;width:42px}.mobile-drawer{width:280px}}@media (prefers-reduced-motion:reduce){.drawer-backdrop,.mobile-drawer,.navbar,.navbar *{animation:none!important;transition:none!important}}.footer{background:#030410fa;border-top:1px solid hsla(0,0%,100%,.065);color:#e2e8f0;font-family:DM Sans,sans-serif;font-family:var(--font-body,"DM Sans",sans-serif);overflow:hidden;position:relative;z-index:2}.footer:before{background:radial-gradient(ellipse 55% 45% at 8% 85%,#7c6ef717 0,#0000 65%),radial-gradient(ellipse 50% 40% at 92% 15%,#22d3ee0f 0,#0000 65%)}.footer:after,.footer:before{content:"";inset:0;pointer-events:none;position:absolute}.footer:after{background-image:linear-gradient(#7c6ef708 1px,#0000 0),linear-gradient(90deg,#7c6ef708 1px,#0000 0);background-size:48px 48px;mask-image:linear-gradient(180deg,#0000,#0006 20%,#0006 80%,#0000);-webkit-mask-image:linear-gradient(180deg,#0000,#0006 20%,#0006 80%,#0000)}[data-theme=light] .footer{background:#d4d8f8fa;border-top-color:#6366f12e;color:#1a1744}[data-theme=light] .footer:before{background:radial-gradient(ellipse 55% 45% at 8% 85%,#6366f112 0,#0000 65%),radial-gradient(ellipse 50% 40% at 92% 15%,#22d3ee0d 0,#0000 65%)}.footer-accent{background:linear-gradient(90deg,#0000,#7c6ef7 25%,#a78bfa 50%,#22d3ee 75%,#0000);height:1px;opacity:.7;position:relative;z-index:1}.footer-inner{grid-gap:72px;align-items:start;display:grid;gap:72px;grid-template-columns:280px 1fr 300px;margin:0 auto;max-width:1300px;padding:80px 64px 64px;position:relative;z-index:1}.footer-brand{display:flex;flex-direction:column;gap:18px}.footer-logo{align-items:center;display:inline-flex;text-decoration:none;width:fit-content}.footer-logo img{display:block;height:38px;opacity:.96;transition:opacity .2s ease,transform .28s cubic-bezier(.34,1.56,.64,1),filter .25s ease;width:auto}.footer-logo:hover img{opacity:1;transform:scale(1.04)}.brand-tagline{color:#7a8ba8;font-size:13.5px;line-height:1.68;max-width:245px}[data-theme=light] .brand-tagline{color:#3730a3}.social-row{flex-wrap:wrap;gap:8px;margin-top:4px}.social-btn,.social-row{align-items:center;display:flex}.social-btn{background:#ffffff0a;border:1px solid #ffffff17;border-radius:11px;color:#5a6a80;font-size:14px;font-weight:800;height:38px;justify-content:center;text-decoration:none;transition:color .2s ease,background .2s ease,border-color .2s ease,transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;width:38px}.social-btn:hover{background:#7c6ef72e;border-color:#7c6ef761;box-shadow:0 8px 20px #7c6ef740;color:#eceef8;transform:translateY(-4px)}[data-theme=light] .social-btn{background:#6366f117;border-color:#6366f12e;color:#6366f1}[data-theme=light] .social-btn:hover{background:#7c6ef729;border-color:#7c6ef759;box-shadow:0 8px 20px #6366f133;color:#4f46e5}.footer-links-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(3,1fr)}.footer-col{min-width:0}.col-title{color:#d0d8f0;font-family:Clash Display,sans-serif;font-family:var(--font-display,"Clash Display",sans-serif);font-size:12px;font-weight:800;letter-spacing:.1em;margin-bottom:18px;text-transform:uppercase}[data-theme=light] .col-title{color:#1a1744}.footer-col ul{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.footer-link{align-items:center;color:#5a6a80;display:inline-flex;font-size:13.5px;gap:6px;position:relative;text-decoration:none;transition:color .2s ease,transform .2s ease}.footer-link:before{background:#7c6ef7;border-radius:50%;content:"";flex-shrink:0;height:5px;opacity:0;transform:scale(.4);transition:opacity .2s ease,transform .2s ease;width:5px}.footer-link:hover{color:#c8d0e8;transform:translateX(5px)}.footer-link:hover:before{opacity:1;transform:scale(1)}[data-theme=light] .footer-link{color:#3730a3}[data-theme=light] .footer-link:hover{color:#1a1744}.newsletter{display:flex;flex-direction:column;gap:14px}.newsletter-sub{color:#5a6a80;font-size:13.5px;line-height:1.65;max-width:290px}[data-theme=light] .newsletter-sub{color:#3730a3}.newsletter-form{display:flex;flex-direction:column;gap:9px;margin-top:2px}.input-wrap{align-items:stretch;background:#ffffff0a;border:1px solid #ffffff17;border-radius:12px;overflow:hidden;transition:border-color .22s ease,box-shadow .22s ease,background .22s ease}.input-wrap:focus-within{border-color:#7c6ef780;box-shadow:0 0 0 3px #7c6ef724}.input-wrap.error{border-color:#ef44448c;box-shadow:0 0 0 3px #ef44441c}[data-theme=light] .input-wrap{background:#c3c8f88c;border-color:#6366f138}[data-theme=light] .input-wrap:focus-within{border-color:#7c6ef785;box-shadow:0 0 0 3px #7c6ef721}.input-wrap input{border:none;color:#eceef8;flex:1 1;font-family:DM Sans,sans-serif;font-family:var(--font-body,"DM Sans",sans-serif);font-size:13.5px;min-width:0;outline:none;padding:12px 15px}.input-wrap input::placeholder{color:#4a5568}[data-theme=light] .input-wrap input{color:#1a1744}[data-theme=light] .input-wrap input::placeholder{color:#6366f1}.input-wrap input:disabled{cursor:not-allowed;opacity:.5}.input-wrap button{align-items:center;background:linear-gradient(135deg,#7c6ef7,#6366f1);border:none;color:#f1f5f9;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:800;justify-content:center;min-width:50px;padding:0 18px;transition:opacity .2s ease,transform .15s ease,box-shadow .2s ease,filter .2s ease}.input-wrap button:hover:not(:disabled){box-shadow:inset 0 0 0 999px #ffffff14;filter:brightness(1.05);opacity:.92}.input-wrap button:active:not(:disabled){transform:scale(.95)}.input-wrap button:disabled{cursor:not-allowed;opacity:.45}.form-msg{font-size:12px;font-weight:700;margin:0;padding:0 2px}.form-msg--success{color:#34d399}.form-msg--error{color:#f87171}.trust-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.trust-badge{background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;color:#475569;font-size:11px;font-weight:600;padding:4px 12px;white-space:nowrap}[data-theme=light] .trust-badge{background:#6366f117;border-color:#6366f12e;color:#5b5ff6}.footer-bottom{align-items:center;border-top:1px solid hsla(0,0%,100%,.055);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin:0 auto;max-width:1300px;padding:22px 64px 30px;position:relative;z-index:1}[data-theme=light] .footer-bottom{border-top-color:#6366f124}.copyright{color:#3d4a5c;font-size:13px;margin:0}[data-theme=light] .copyright{color:#3730a3}.legal-links{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.legal-links a{color:#3d4a5c;font-size:13px;text-decoration:none;transition:color .2s ease,transform .2s ease}.legal-links a:hover{color:#7c6ef7;transform:translateY(-1px)}.legal-links span{color:#2a3445;font-size:13px}[data-theme=light] .legal-links a{color:#3730a3}[data-theme=light] .legal-links a:hover{color:#7c6ef7}[data-theme=light] .legal-links span{color:#6366f1}@media (max-width:1100px){.footer-inner{gap:52px;grid-template-columns:240px 1fr 268px;padding:64px 40px 52px}.footer-bottom{padding:22px 40px 30px}}@media (max-width:900px){.footer-inner{gap:44px;grid-template-columns:1fr 1fr}.footer-brand{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:28px;grid-column:1/-1}.brand-tagline{max-width:320px}.footer-links-grid{grid-column:1/2;grid-template-columns:1fr}.newsletter{grid-column:2/3}}@media (max-width:640px){.footer-inner{gap:38px;grid-template-columns:1fr;padding:52px 24px 44px}.footer-brand{flex-direction:column;gap:16px}.footer-links-grid{gap:24px;grid-column:auto;grid-template-columns:repeat(2,1fr)}.footer-links-grid>:last-child{grid-column:1/-1}.newsletter{grid-column:auto}.newsletter-sub{max-width:100%}.footer-bottom{align-items:flex-start;flex-direction:column;gap:8px;padding:22px 24px 28px}}@media (max-width:400px){.footer-inner{padding:46px 18px 38px}.footer-links-grid{grid-template-columns:1fr}.footer-bottom{padding:20px 18px 26px}.input-wrap input{padding:11px 12px}.input-wrap button{min-width:46px;padding:0 14px}}.home{--hbg:#fff;--hbg-2:#f4f8ff;--htext:#07162f;--htext-2:#475f79;--htext-3:#64748b;--hcard:#ffffffeb;--hcard-2:#ffffffb8;--hborder:#0f172a1a;--hshadow:0 24px 70px #0f172a1a;--hshadow-soft:0 12px 36px #0f172a12;--hshadow-hover:0 28px 80px #0f172a24;--primary:#6d5dfc;--primary-2:#2563eb;--cyan:#00a6ff;--green:#14b86a;--yellow:#f5b915;--hero-bg:radial-gradient(ellipse at -4% 8%,#6d5dfc33,#0000 36%),radial-gradient(ellipse at 92% 50%,#00a6ff40,#0000 38%),radial-gradient(ellipse at 48% 44%,#14b8a61f,#0000 34%),linear-gradient(180deg,#fff,#f4f8ff)}[data-theme=dark] .home{--hbg:#070b16;--hbg-2:#090e1c;--htext:#f0f4fc;--htext-2:#c0cfe4;--htext-3:#8da0b8;--hcard:#0d1428d1;--hcard-2:#0d14288c;--hborder:#8ca0be29;--hshadow:0 28px 90px #0000007a;--hshadow-soft:0 14px 42px #00000052;--hshadow-hover:0 32px 90px #0000008f;--hero-bg:radial-gradient(ellipse at -4% 10%,#6d5dfc5c,#0000 38%),radial-gradient(ellipse at 88% 50%,#00beff40,#0000 38%),radial-gradient(ellipse at 46% 42%,#14b8a61f,#0000 34%),linear-gradient(180deg,#080d1c,#070b18)}.home *,.home :after,.home :before{box-sizing:border-box}.home{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--hbg);color:var(--htext);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;overflow-x:hidden;width:100%}.home a{color:inherit;text-decoration:none}.home-section-inner,.home-shell{margin:0 auto;max-width:1440px;padding:0 48px;width:100%}.home-section{background:var(--hbg);padding:112px 24px;position:relative}.home .gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(130deg,#7c3aed,#2563eb 48%,#00a6ff);-webkit-background-clip:text;background-clip:text;display:inline-block;white-space:nowrap}.home .hero-badge,.home .hero-badge-dot,.home .hero-badge-icon{display:none!important}.home .section-label-wrap{display:flex;justify-content:center;margin-bottom:18px}.home .section-label{align-items:center;background:#6d5dfc17;border:1px solid #6d5dfc3d;border-radius:999px;color:#6d5dfc;display:inline-flex;font-size:11px;font-weight:700;justify-content:center;letter-spacing:.12em;padding:7px 18px;text-transform:uppercase}[data-theme=dark] .home .section-label{background:#6d5dfc29;border-color:#b3a4ff3d;color:#b3a4ff}.home .section-head{margin:0 auto 60px;max-width:720px;text-align:center}.home .section-head h2{color:var(--htext);font-size:clamp(30px,3.8vw,48px);font-weight:800;letter-spacing:-.04em;line-height:1.1;margin:0 0 16px}.home .section-head p{color:var(--htext-2);font-size:16px;font-weight:400;line-height:1.78;margin:0 auto;max-width:580px}.home-hero{align-items:center;background:var(--hero-bg);border-bottom:1px solid var(--hborder);display:flex;isolation:isolate;overflow-x:clip;overflow-y:visible;padding:132px 0 80px;padding:calc(var(--site-nav-height, 72px) + 60px) 0 80px;position:relative}.home .hero-grid-glow{background-image:radial-gradient(circle,#6d5dfc6b 1px,#0000 1.5px);background-position:16px 18px;background-size:22px 22px;inset:0;-webkit-mask-image:linear-gradient(90deg,#000,#0000 25%);mask-image:linear-gradient(90deg,#000,#0000 25%);opacity:.44;pointer-events:none;position:absolute;z-index:-3}.home .hero-orb{border-radius:999px;filter:blur(82px);pointer-events:none;position:absolute;z-index:-2}.home .hero-orb-1{background:#6d5dfc52;height:410px;left:-80px;top:-90px;width:410px}.home .hero-orb-2{background:#00a6ff33;bottom:-8%;height:520px;right:-6%;width:520px}.home .hero-orb-3{background:#14b86a1f;bottom:0;height:340px;left:38%;width:340px}.home-hero .home-shell{max-width:100%;padding:0 24px}.home .hero-line,.home .hero-line-bottom{display:block}.home .hero-skill-word-wrap{display:inline}.home .hero-visual{align-items:center;display:flex;justify-content:center;min-width:0;position:relative;width:100%;z-index:2}.home .hero-visual-glow{background:radial-gradient(circle at 20% 20%,#7c3aed38,#0000 48%),radial-gradient(circle at 80% 80%,#00d4ff33,#0000 48%);border-radius:40px;filter:blur(42px);inset:-10% -5%;position:absolute;z-index:-1}.home .hv-panel{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:var(--hcard);border:1px solid var(--hborder);border-radius:24px;box-shadow:var(--hshadow);display:flex;flex-direction:column;gap:16px;max-width:480px;padding:22px;width:100%}.home .hv-badge{align-items:center;align-self:flex-start;background:#14b86a1a;border:1px solid #14b86a47;border-radius:999px;color:#14b86a;display:inline-flex;font-size:11px;font-weight:700;gap:7px;letter-spacing:.06em;padding:5px 13px;text-transform:uppercase}.home .hv-badge-dot{animation:hvPulse 1.6s ease-in-out infinite;background:#14b86a;border-radius:50%;height:7px;width:7px}@keyframes hvPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.home .hv-header{justify-content:space-between}.home .hv-header,.home .hv-header-left{align-items:center;display:flex;gap:12px}.home .hv-avatar{background:#6d5dfc24;border-radius:12px;display:grid;flex-shrink:0;font-size:20px;height:40px;place-items:center;width:40px}.home .hv-title{color:var(--htext);font-size:14px;font-weight:700;line-height:1.2}.home .hv-subtitle{color:var(--htext-3);font-size:11px;margin-top:2px}.home .hv-ring-wrap{flex-shrink:0;position:relative}.home .hv-ring,.home .hv-ring-wrap{height:52px;width:52px}.home .hv-ring-pct{align-items:center;color:var(--htext);display:flex;font-size:12px;font-weight:800;inset:0;justify-content:center;letter-spacing:-.03em;position:absolute}.home .hv-stats-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.home .hv-mini-stat{align-items:center;background:var(--hcard-2);border:1px solid var(--hborder);border-radius:14px;display:flex;gap:8px;padding:10px;transition:border-color .2s ease,transform .2s ease}.home .hv-mini-stat:hover{border-color:#6d5dfc47;transform:translateY(-2px)}.home .hv-mini-icon{border-radius:8px;display:grid;flex-shrink:0;font-size:14px;height:28px;place-items:center;width:28px}.home .hv-mini-val{color:var(--htext);font-size:12px;font-weight:800;letter-spacing:-.02em;line-height:1}.home .hv-mini-label{color:var(--htext-3);font-size:9px;font-weight:600;letter-spacing:.04em;margin-top:3px;text-transform:uppercase}.home .hv-skills{display:flex;flex-direction:column;gap:8px}.home .hv-section-title{color:var(--htext-3);font-size:11px;font-weight:700;letter-spacing:.1em;margin-bottom:2px;text-transform:uppercase}.home .hv-skill-row{align-items:center;border:1px solid #0000;border-radius:10px;cursor:default;display:flex;gap:8px;padding:6px 8px;transition:border-color .2s ease,background .2s ease}.home .hv-skill-active{background:var(--hcard-2);border-color:var(--hborder)}.home .hv-skill-icon{flex-shrink:0;font-size:14px;text-align:center;width:20px}.home .hv-skill-label{color:var(--htext-2);flex-shrink:0;font-size:12px;font-weight:600;width:56px}.home .hv-bar-track{background:var(--hborder);border-radius:999px;flex:1 1;height:5px;overflow:hidden}.home .hv-bar-fill{border-radius:999px;height:100%;transition:width 1.1s cubic-bezier(.16,1,.3,1);width:0}.home .hv-skill-pct{flex-shrink:0;font-size:11px;font-weight:800;text-align:right;width:30px}.home .hv-code-block{background:#0d1117;border:1px solid var(--hborder);border-radius:14px;overflow:hidden}[data-theme=dark] .home .hv-code-block{background:#060a12;border-color:#ffffff12}.home .hv-code-dots{align-items:center;border-bottom:1px solid #ffffff12;display:flex;gap:6px;padding:9px 14px}.home .hv-code-dots span{border-radius:50%;display:block;height:10px;width:10px}.home .hv-code-lines{display:flex;flex-direction:column;font-family:JetBrains Mono,Fira Code,Cascadia Code,Courier New,monospace;font-size:11.5px;gap:4px;line-height:1.6;min-height:112px;padding:10px 14px}.home .hv-code-line{align-items:baseline;display:flex;gap:12px}.home .hv-line-num{color:#fff3;flex-shrink:0;font-size:10px;text-align:right;-webkit-user-select:none;user-select:none;width:12px}.home .hv-cursor{animation:hvBlink .9s step-end infinite;color:#60a5fa;display:inline-block;font-weight:100}@keyframes hvBlink{0%,to{opacity:1}50%{opacity:0}}.home .hero-skill-word{-webkit-text-fill-color:#0000;background:linear-gradient(130deg,#7c3aed,#2563eb 48%,#00a6ff);-webkit-background-clip:text;background-clip:text;display:inline}.home .hero-sub{color:var(--htext-2);font-size:17px;font-weight:400;line-height:1.76}.home .hero-actions{align-items:center;display:flex;flex-wrap:wrap;margin-left:0;padding-left:0}.home .btn-ghost,.home .btn-primary,.home .btn-secondary{align-items:center;border:1px solid #0000;border-radius:15px;cursor:pointer;display:inline-flex;font-size:15px;font-weight:700;gap:10px;justify-content:center;line-height:1;min-height:54px;padding:0 30px;text-decoration:none;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease,background .24s ease,opacity .24s ease;white-space:nowrap}.home .btn-primary{background:linear-gradient(130deg,#7c3aed,#2563eb 48%,#00a6ff);box-shadow:0 14px 36px #2563eb47;color:#fff}.home .btn-primary:hover{box-shadow:0 22px 52px #2563eb61;transform:translateY(-3px)}.home .btn-secondary{background:#fff9;border-color:var(--hborder);box-shadow:0 8px 24px #0f172a0f;color:var(--htext)}[data-theme=dark] .home .btn-secondary{background:#0f172a75;border-color:#94a3b838}.home .btn-secondary:hover{border-color:#6d5dfc66;box-shadow:var(--hshadow-soft);transform:translateY(-3px)}.home .btn-ghost{background:#6d5dfc14;border-color:#6d5dfc2e;color:#5b5ff6;font-size:14px;min-height:46px;padding:0 22px}[data-theme=dark] .home .btn-ghost{background:#6d5dfc1f;border-color:#6d5dfc3d;color:#a89dff}.home .btn-ghost:hover{background:#6d5dfc24;box-shadow:0 8px 22px #6d5dfc24;transform:translateY(-2px)}.home .hero-stats{align-items:stretch;display:flex;gap:0;margin-top:40px}.home .hero-stats-card{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffbd;border:1px solid var(--hborder);border-radius:20px;box-shadow:var(--hshadow-soft);display:flex;padding:18px 20px;width:min(100%,560px)}[data-theme=dark] .home .hero-stats-card{background:#0d14288a}.home .hero-stat{align-items:center;display:flex;flex:1 1;gap:11px;min-width:0;padding:0 14px;position:relative}.home .hero-stat:not(:last-child):after{background:var(--hborder);content:"";height:80%;position:absolute;right:0;top:10%;width:1px}.home .hero-stat-icon{background:#6d5dfc1f;border-radius:12px;display:grid;flex-shrink:0;font-size:18px;height:40px;place-items:center;width:40px}.home .hero-stat:nth-child(2) .hero-stat-icon{background:#14b86a1f}.home .hero-stat:nth-child(3) .hero-stat-icon{background:#f5b91524}.home .hero-stat-copy{display:block;min-width:0}.home .hero-stat strong{color:var(--htext);display:block;font-size:22px;font-weight:800;letter-spacing:-.04em;line-height:1}.home .hero-stat strong span{font-size:17px}.home .hero-stat p{color:var(--htext-2);font-size:12px;font-weight:600;margin:6px 0 0}.home .trust-strip{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:#ffffffd1;border-bottom:1px solid var(--hborder);border-top:1px solid var(--hborder);overflow:hidden;padding:18px 0;position:relative;z-index:5}[data-theme=dark] .home .trust-strip{background:#070b16e0}.home .trust-strip:after,.home .trust-strip:before{bottom:0;content:"";pointer-events:none;position:absolute;top:0;width:100px;z-index:2}.home .trust-strip:before{background:linear-gradient(90deg,var(--hbg),#0000);left:0}.home .trust-strip:after{background:linear-gradient(270deg,var(--hbg),#0000);right:0}.home .trust-strip-track{align-items:center;animation:marquee 34s linear infinite;display:flex;gap:12px;width:max-content;will-change:transform}.home .trust-strip:hover .trust-strip-track{animation-play-state:paused}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.home .trust-chip{align-items:center;background:var(--hcard);border:1px solid var(--hborder);border-radius:999px;box-shadow:0 4px 16px #0f172a0a;color:var(--htext);display:inline-flex;font-size:13px;font-weight:700;gap:8px;min-height:40px;padding:0 18px;transition:box-shadow .2s ease,border-color .2s ease;white-space:nowrap}.home .trust-chip:hover{border-color:#6d5dfc4d;box-shadow:0 6px 20px #6d5dfc1a}.home .trust-chip img{display:block;flex-shrink:0;height:20px;object-fit:contain;width:20px}.home .course-card,.home .feature-card,.home .final-cta-inner,.home .outcome-card,.home .path-step{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:var(--hcard);border:1px solid var(--hborder);box-shadow:var(--hshadow-soft)}.home .features-section{background:radial-gradient(ellipse at 8% 0,#6d5dfc12,#0000 32%),var(--hbg)}.home .features-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr))}.home .feature-card{border-radius:22px;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:34px 30px;position:relative;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.home .feature-card:before{background:radial-gradient(circle at 14% 8%,color-mix(in srgb,#6366f1 14%,#0000),#0000 38%);background:radial-gradient(circle at 14% 8%,color-mix(in srgb,var(--feature-accent,#6366f1) 14%,#0000),#0000 38%);content:"";inset:0;opacity:.6;pointer-events:none;position:absolute;transition:opacity .3s ease}.home .feature-card:hover{border-color:color-mix(in srgb,var(--feature-accent,#6366f1) 32%,var(--hborder));box-shadow:var(--hshadow-hover);transform:translateY(-8px)}.home .feature-card:hover:before{opacity:.9}.home .feature-icon-wrap{background:color-mix(in srgb,#6366f1 13%,#0000);background:color-mix(in srgb,var(--feature-accent,#6366f1) 13%,#0000);border-radius:16px;display:grid;height:52px;margin-bottom:22px;place-items:center;position:relative;transition:transform .28s ease;width:52px;z-index:1}.home .feature-card:hover .feature-icon-wrap{transform:scale(1.1) rotate(-4deg)}.home .feature-icon{font-size:24px;line-height:1}.home .feature-card h3{color:var(--htext);font-size:18px;font-weight:700;letter-spacing:-.02em;margin:0 0 12px;position:relative;z-index:1}.home .feature-card p{color:var(--htext-2);font-size:14px;font-weight:400;line-height:1.78;margin:0;position:relative;z-index:1}.home .feature-accent-line{border-radius:999px;height:3px;margin-top:24px;position:relative;transition:width .3s ease;width:40px;z-index:1}.home .feature-card:hover .feature-accent-line{width:64px}.home .courses-section{background:radial-gradient(ellipse at 92% 8%,#00a6ff0f,#0000 32%),var(--hbg)}.home .courses-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-auto-rows:1fr;grid-template-columns:repeat(3,minmax(0,1fr))}.home .course-card{border-radius:22px;cursor:pointer;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.home .course-card:hover{border-color:#2563eb52;box-shadow:var(--hshadow-hover)}.home .course-card:focus-visible{outline:3px solid #6d5dfc99;outline-offset:3px}.home .course-media{background:radial-gradient(circle at 50% 12%,#6d5dfc1f,#0000 44%),#0f172a08;flex-shrink:0;height:240px;overflow:hidden;position:relative}[data-theme=dark] .home .course-media{background:radial-gradient(circle at 50% 12%,#6d5dfc33,#0000 44%),#ffffff08}.home .course-media img{display:block;height:100%;object-fit:cover;object-position:center top;transition:transform .46s ease;width:100%}.home .course-card:hover .course-media img{transform:scale(1.07)}.home .course-tag{border-radius:999px;box-shadow:0 8px 22px #00000038;color:#fff;font-size:10px;font-weight:800;left:12px;letter-spacing:.08em;padding:5px 12px;position:absolute;text-transform:uppercase;top:12px;z-index:2}.home .course-media-overlay{background:linear-gradient(0deg,#00000047,#0000 56%);inset:0;pointer-events:none;position:absolute}.home .course-content{display:flex;flex:1 1;flex-direction:column;padding:22px}.home .course-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.home .course-level{align-items:center;background:#6d5dfc1a;border-radius:999px;color:#6d5dfc;display:inline-flex;font-size:10px;font-weight:800;letter-spacing:.09em;padding:4px 11px;text-transform:uppercase}[data-theme=dark] .home .course-level{background:#6d5dfc2e;color:#b3a4ff}.home .course-icon{font-size:20px;line-height:1}.home .course-content h3{color:var(--htext);font-size:18px;font-weight:700;letter-spacing:-.028em;margin:0 0 10px}.home .course-content p{color:var(--htext-2);flex:1 1;font-size:14px;font-weight:400;line-height:1.68;margin:0 0 14px}.home .course-topics{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}.home .topic-chip{align-items:center;background:#94a3b812;border:1px solid var(--hborder);border-radius:999px;color:var(--htext-3);display:inline-flex;font-size:11px;font-weight:600;padding:3px 10px;transition:border-color .2s ease,background .2s ease}.home .course-card:hover .topic-chip{background:#6d5dfc0f;border-color:#6d5dfc38}.home .course-cta{align-items:center;background:linear-gradient(130deg,#7c3aed,#2563eb 56%,#00a6ff);border:none;border-radius:13px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;justify-content:space-between;margin-top:auto;min-height:44px;padding:0 16px;transition:transform .22s ease,box-shadow .22s ease,opacity .22s ease;width:100%}.home .course-cta:hover{box-shadow:0 12px 28px #2563eb42;transform:translateY(-2px)}.home .courses-cta{display:flex;justify-content:center;margin-top:44px}.home .outcomes-section{background:radial-gradient(ellipse at 50% 100%,#6d5dfc0d,#0000 32%),var(--hbg)}.home .outcomes-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr))}.home .outcome-card{border-radius:22px;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:30px;position:relative;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.home .outcome-card:before{background:radial-gradient(circle at 90% 92%,color-mix(in srgb,#6153e0 10%,#0000),#0000 42%);background:radial-gradient(circle at 90% 92%,color-mix(in srgb,var(--outcome-accent,#6153e0) 10%,#0000),#0000 42%);content:"";inset:0;opacity:.4;pointer-events:none;position:absolute;transition:opacity .3s ease}.home .outcome-card:hover{border-color:color-mix(in srgb,var(--outcome-accent,#6153e0) 30%,var(--hborder));box-shadow:var(--hshadow-hover);transform:translateY(-8px)}.home .outcome-card:hover:before{opacity:1}.home .outcome-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.home .outcome-icon{background:#6d5dfc1a;border-radius:14px;display:grid;flex-shrink:0;font-size:22px;height:48px;place-items:center;transition:transform .28s ease;width:48px}.home .outcome-card:hover .outcome-icon{transform:scale(1.12) rotate(-4deg)}.home .outcome-tag{align-items:center;background:#6d5dfc17;border:1px solid #6d5dfc2e;border-radius:999px;color:#6d5dfc;display:inline-flex;font-size:10px;font-weight:800;letter-spacing:.08em;padding:4px 12px;text-transform:uppercase}[data-theme=dark] .home .outcome-tag{background:#6d5dfc29;border-color:#b3a4ff38;color:#b3a4ff}.home .outcome-card h3{color:var(--htext);font-size:18px;font-weight:700;letter-spacing:-.025em;margin:0 0 10px}.home .outcome-card p{color:var(--htext-2);font-size:14px;font-weight:400;line-height:1.75;margin:0}.home .path-section{background:radial-gradient(ellipse at 50% 0,#6d5dfc0f,#0000 30%),var(--hbg)}.home .path-grid{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr))}.home .path-step{align-items:flex-start;border-radius:22px;display:flex;gap:18px;padding:30px 24px;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.home .path-step:hover{border-color:#2563eb47;box-shadow:var(--hshadow-hover);transform:translateY(-7px)}.home .path-number{-webkit-text-fill-color:#0000;background:linear-gradient(130deg,#7c3aed,#2563eb 56%,#00a6ff);-webkit-background-clip:text;background-clip:text;flex:0 0 auto;font-size:30px;font-weight:800;letter-spacing:-.055em;line-height:1}.home .path-body{flex:1 1;min-width:0}.home .path-body h3{color:var(--htext);font-size:16px;font-weight:700;letter-spacing:-.02em;margin:2px 0 10px}.home .path-body p{color:var(--htext-2);font-size:14px;font-weight:400;line-height:1.72;margin:0}.home .final-cta{background:var(--hbg);overflow:hidden;padding:112px 48px 128px;position:relative;text-align:center}.home .final-cta-inner{background:var(--hcard);border:1px solid var(--hborder);border-radius:32px;box-shadow:var(--hshadow);isolation:isolate;margin:0 auto;max-width:1200px;overflow:hidden;padding:80px 90px;position:relative;width:100%}.home .final-cta-orb{border-radius:999px;filter:blur(72px);pointer-events:none;position:absolute;z-index:-1}.home .final-cta-orb-1{background:#6d5dfc38;height:300px;left:-80px;top:-80px;width:300px}.home .final-cta-orb-2{background:#00a6ff2e;bottom:-90px;height:320px;right:-90px;width:320px}.home .final-cta-content{align-items:center;display:flex;flex-direction:column;position:relative;z-index:2}.home .cta-label{margin-bottom:22px}.home .final-cta h2{color:var(--htext);font-size:clamp(32px,3.8vw,48px);font-weight:800;letter-spacing:-.045em;line-height:1.12;margin:0 auto 18px;max-width:580px}.home .final-cta p{color:var(--htext-2);font-size:16px;font-weight:400;line-height:1.78;margin:0 auto 36px;max-width:500px}.home .cta-actions{align-items:center;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}@media (max-width:1024px){.home-section{padding:90px 24px}.home .courses-grid,.home .features-grid,.home .outcomes-grid,.home .path-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home .hero-headline{font-size:clamp(40px,8vw,62px);max-width:100%}.home .hero-line-bottom{max-width:100%;white-space:normal}}@media (max-width:768px){.home-section-inner,.home-shell{padding:0 18px}.home-hero{min-height:auto;padding:76px 0 50px}.home .hero-layout{gap:28px}.home .hero-headline{font-size:clamp(34px,11vw,52px)}.home .hero-line-bottom{white-space:normal}.home .hero-sub{font-size:15px;line-height:1.72}.home .hero-actions{gap:12px}.home .btn-primary,.home .btn-secondary{max-width:320px;width:100%}.home .hero-stats-card{align-items:stretch;flex-direction:column;gap:0;padding:18px 20px;width:100%}.home .hero-stat{padding:12px 0}.home .hero-stat:not(:last-child):after{bottom:0;height:1px;left:0;right:auto;top:auto;width:100%}.home .courses-grid,.home .features-grid,.home .outcomes-grid,.home .path-grid{grid-template-columns:1fr}.home .section-head{margin-bottom:44px}.home-section{padding:78px 20px}.home .final-cta{padding:112px 0 128px}.home .final-cta-inner{border-radius:26px;padding:42px 18px}.home .hv-panel{gap:12px;padding:16px}.home .hv-stats-row{gap:6px}.home .hv-mini-stat{gap:6px;padding:8px 7px}.home .hv-mini-val{font-size:11px}.home .hv-mini-label{font-size:8px}.home .hv-mini-icon{font-size:12px;height:24px;width:24px}.home .hv-code-lines{font-size:10px;min-height:90px;padding:8px 10px}.home .hv-skill-label{font-size:11px;width:44px}.home .hv-skill-pct{font-size:10px;width:26px}}@media (max-width:480px){.home .cta-actions,.home .hero-actions{align-items:center;flex-direction:column;width:100%}.home .cta-actions .btn-primary,.home .cta-actions .btn-secondary{justify-content:center;max-width:300px;width:100%}.home .trust-chip{font-size:12px;min-height:36px;padding:0 14px}.home .trust-chip img{height:18px;width:18px}.home .course-content,.home .feature-card,.home .outcome-card,.home .path-step{padding:24px 20px}.home .course-media{height:200px}.home .final-cta-inner{padding:42px 14px}}@media (prefers-reduced-motion:reduce){.home .skill-enter,.home .skill-exit,.home .trust-strip-track{animation:none}}.home{--site-nav-height:72px}.home-hero .home-shell{margin:0 auto;max-width:1440px;padding:0 48px;width:100%}.home .hero-layout{grid-gap:clamp(40px,5vw,80px);align-items:center;display:grid;gap:clamp(40px,5vw,80px);grid-template-columns:minmax(0,1fr) minmax(440px,.88fr);position:relative;width:100%;z-index:2}.home .hero-content{max-width:640px;min-width:0;overflow:visible;text-align:left}.home .hero-headline{color:var(--htext);font-size:clamp(38px,3.8vw,64px);font-weight:800;letter-spacing:-.06em;line-height:1.07;margin:0;max-width:640px}.home .hero-line-bottom{white-space:normal}.home .hero-sub{font-size:clamp(15px,1.15vw,18px);line-height:1.74;margin:24px 0 32px;max-width:580px}.home .hero-actions{gap:16px}@media (max-width:1280px){.home-hero .home-shell{padding:0 32px}.home .hero-layout{gap:36px;grid-template-columns:1fr 1fr}.home .hero-headline{font-size:clamp(34px,3.5vw,54px)}.home .hv-panel{max-width:460px}}@media (max-width:1180px){.home-hero .home-shell{padding:0 24px}.home .hero-layout{gap:44px;grid-template-columns:1fr;text-align:center}.home .hero-content{margin:0 auto;max-width:780px}.home .hero-headline,.home .hero-sub{margin-left:auto;margin-right:auto}.home .hero-actions,.home .hero-stats{justify-content:center}.home .hero-stats-card{margin:40px auto 0}.home .hero-visual{justify-content:center;width:100%}.home .hv-panel{margin:0 auto;max-width:540px}.home .hero-line-bottom{display:block;white-space:normal}.home .hero-skill-word-wrap{min-width:0}}@media (max-width:768px){.home{--site-nav-height:64px}.home-hero{padding:calc(var(--site-nav-height) + 36px) 0 56px}.home-hero .home-shell{padding:0 18px}.home .hero-headline{font-size:clamp(34px,10vw,52px)}.home .hero-sub{font-size:15px;margin:20px auto 28px}.home .btn-ghost,.home .btn-primary,.home .btn-secondary{font-size:15px;min-height:52px;padding:0 24px}.home .hero-stats-card{align-items:stretch;flex-direction:column;gap:0;margin-top:36px;padding:18px 20px;width:100%}.home .hero-stat{padding:12px 0}.home .hero-stat:not(:last-child):after{bottom:0;height:1px;left:0;right:auto;top:auto;width:100%}.home .hv-panel{border-radius:22px;gap:14px;max-width:100%;padding:18px}.home .hv-title{font-size:15px}.home .hv-subtitle{font-size:12px}.home .hv-avatar{font-size:20px;height:40px;width:40px}.home .hv-ring,.home .hv-ring-wrap{height:52px;width:52px}.home .hv-mini-stat{gap:7px;min-height:auto;padding:9px 10px}.home .hv-mini-icon{font-size:13px;height:26px;width:26px}.home .hv-mini-val{font-size:12px}.home .hv-mini-label{font-size:9px}.home .hv-section-title{font-size:11px;margin-bottom:6px}.home .hv-skill-label{font-size:12px;width:50px}.home .hv-skill-pct{font-size:11px;width:28px}.home .hv-code-lines{font-size:11px;min-height:96px;padding:10px 13px}}.home .hero-line-bottom{align-items:baseline;display:flex;flex-wrap:nowrap;gap:.18em;white-space:nowrap}.home .hero-skill-word-wrap{align-items:baseline;display:inline-grid;line-height:1;min-width:10.8ch;vertical-align:initial}.home .hero-skill-word{display:inline-block;grid-area:1/1;white-space:nowrap;width:max-content;will-change:opacity,transform}.home .skill-enter{animation:homeSkillIn .28s cubic-bezier(.16,1,.3,1) forwards}.home .skill-exit{animation:homeSkillOut .2s ease forwards}@keyframes homeSkillIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes homeSkillOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@media (max-width:1180px){.home .hero-line-bottom{display:block;white-space:normal}.home .hero-skill-word-wrap{min-width:0}}.about-page{--ap-violet:#6c63ff;--ap-violet-2:#8b5cf6;--ap-cyan:#22d3ee;--ap-green:#34d399;--ap-amber:#fbbf24;--ap-pink:#f472b6;--ap-sky:#38bdf8;--ap-font-body:"Plus Jakarta Sans",sans-serif;--ap-font-display:"Syne",sans-serif;--ap-ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ap-ease-out:cubic-bezier(0.22,1,0.36,1);--ap-bg:#060918;--ap-bg-soft:hsla(0,0%,100%,.035);--ap-bg-soft-2:#ffffff0f;--ap-border:#ffffff14;--ap-border-strong:#ffffff24;--ap-text:#eef2ff;--ap-sub:#a8b3cb;--ap-muted:#77839d;--ap-shadow:0 16px 44px #00000047;--ap-shadow-strong:0 28px 76px #00000075;--ap-card-bg:linear-gradient(180deg,#10142cfa,rgba(10,13,31,.995));--ap-grid-color:rgba(124,110,247,.055);--ap-glass:linear-gradient(180deg,#ffffff0d,hsla(0,0%,100%,.025))}[data-theme=light] .about-page{--ap-bg:#f5f7ff;--ap-bg-soft:#ffffffd1;--ap-bg-soft-2:#fffffff5;--ap-border:#6366f11f;--ap-border-strong:#6366f138;--ap-text:#171b3c;--ap-sub:#5c6585;--ap-muted:#6366f1;--ap-shadow:0 16px 40px #6366f11a;--ap-shadow-strong:0 26px 60px #6366f129;--ap-card-bg:linear-gradient(180deg,hsla(0,0%,100%,.985),#f6f8fffc);--ap-grid-color:#6366f112;--ap-glass:linear-gradient(180deg,#ffffffeb,#f8fafffa)}.about-page,.about-page *,.about-page :after,.about-page :before{box-sizing:border-box}.about-page{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(ellipse 82% 56% at 12% -4%,#6c63ff24 0,#0000 58%),radial-gradient(ellipse 60% 42% at 90% 108%,#22d3ee14 0,#0000 56%),radial-gradient(circle at 50% 42%,#6c63ff0d 0,#0000 30%),var(--ap-bg);color:var(--ap-text);font-family:var(--ap-font-body);min-height:100vh;overflow-x:hidden;position:relative}.about-page,.about-page *{cursor:default}.about-page .award-card,.about-page .btn-ghost,.about-page .btn-primary,.about-page .cert-card,.about-page .edu-card,.about-page .hero-chip,.about-page .mv-item,.about-page .profile-contact-item a,.about-page .project-card,.about-page .soft-skill-row,.about-page .stat-card,.about-page .tool-chip,.about-page a,.about-page button{cursor:pointer}.about-page .cursor-glow{display:none!important}.about-page .sec-inner{margin:0 auto;max-width:1320px;padding:0 64px;position:relative;z-index:2}.about-page .reveal{opacity:1;transform:none;transition:opacity .75s var(--ap-ease-out),transform .75s var(--ap-ease-out);transition-delay:0s;transition-delay:var(--delay,0s)}.about-page.js-reveal .reveal,.js-reveal .about-page .reveal{opacity:0;transform:translateY(30px)}.about-page.js-reveal .reveal.active,.js-reveal .about-page .reveal.active{opacity:1;transform:translateY(0)}.about-page .hero-eyebrow,.about-page .mission-eyebrow,.about-page .section-label{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#7c6ef71a;border:1px solid #7c6ef738;border-radius:999px;color:var(--ap-violet);display:inline-flex;font-size:11px;font-weight:800;gap:8px;letter-spacing:.12em;padding:6px 16px;text-transform:uppercase}.about-page .section-label.center{display:flex;justify-content:center;margin-left:auto;margin-right:auto;width:fit-content}.about-page .eyebrow-dot,.about-page .label-dot{animation:apDotPulse 2.2s ease-in-out infinite;background:var(--ap-violet);border-radius:50%;box-shadow:0 0 10px var(--ap-violet);flex-shrink:0;height:6px;width:6px}@keyframes apDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(1.7)}}.about-page .mission-heading,.about-page .section-heading{color:var(--ap-text);font-family:var(--ap-font-display);font-size:clamp(1.95rem,3vw,3rem);letter-spacing:-.04em;line-height:1.06;margin:14px 0 0}.about-page .section-heading.center{text-align:center}.about-page .name-gradient,.about-page .text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(95deg,var(--ap-violet) 0,#a78bfa 45%,var(--ap-cyan) 100%);-webkit-background-clip:text;background-clip:text}.about-page .about-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:24px;box-shadow:var(--ap-shadow);overflow:hidden;padding:30px;position:relative;transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease}.about-page .about-card:before{background:linear-gradient(180deg,#ffffff0f,#0000 32%);content:"";inset:0;opacity:.8;pointer-events:none;position:absolute}.about-page .about-card:hover{border-color:var(--ap-border-strong);box-shadow:var(--ap-shadow-strong);transform:translateY(-4px)}.about-page .about-card-title,.about-page .edu-label{color:var(--ap-text);font-family:var(--ap-font-display);font-size:1.2rem;font-weight:700;letter-spacing:-.025em;margin:0 0 22px;position:relative;z-index:1}.about-page .about-copy{color:var(--ap-sub);font-size:14.8px;line-height:1.82;margin:0 0 16px;position:relative;z-index:1}.about-page .about-copy strong{color:var(--ap-text);font-weight:700}.about-page .about-copy-last{margin-bottom:0}.about-page .about-card-gap{margin-top:24px}.about-page .tools-card{margin-top:28px}.about-page .btn-ghost,.about-page .btn-primary{align-items:center;border-radius:14px;display:inline-flex;font-size:14.5px;font-weight:700;gap:8px;justify-content:center;letter-spacing:-.01em;min-height:50px;padding:13px 26px;text-decoration:none;transition:transform .24s var(--ap-ease-spring),box-shadow .24s ease,background .24s ease,border-color .24s ease,opacity .2s ease}.about-page .btn-primary{background:linear-gradient(135deg,var(--ap-violet),var(--ap-violet-2));border:none;box-shadow:0 12px 28px #7c6ef74d,inset 0 1px 0 #ffffff2e;color:#f8fafc}.about-page .btn-primary:hover{box-shadow:0 16px 36px #7c6ef76b,inset 0 1px 0 #ffffff38;transform:translateY(-3px)}.about-page .btn-ghost{background:var(--ap-bg-soft);border:1px solid var(--ap-border-strong);color:var(--ap-text)}.about-page .btn-ghost:hover{background:var(--ap-bg-soft-2);border-color:var(--ap-border-strong);transform:translateY(-2px)}.about-page .about-hero{border-bottom:1px solid var(--ap-border);overflow:hidden;padding:92px 64px 72px;position:relative;z-index:2}.about-page .hero-grid{background-image:linear-gradient(var(--ap-grid-color) 1px,#0000 1px),linear-gradient(90deg,var(--ap-grid-color) 1px,#0000 1px);background-size:58px 58px;inset:0;mask-image:radial-gradient(ellipse 90% 70% at 50% 40%,#000 50%,#0000 100%);-webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 40%,#000 50%,#0000 100%);pointer-events:none;position:absolute}.about-page .about-hero:before{background:linear-gradient(90deg,#0000,#7c6ef7 30%,#22d3ee 70%,#0000);content:"";height:1px;left:0;opacity:.55;position:absolute;right:0;top:0}.about-page .hero-inner{grid-gap:68px;align-items:center;display:grid;gap:68px;grid-template-columns:1.15fr .85fr;margin:0 auto;max-width:1320px;position:relative;z-index:2}.about-page .hero-title{color:var(--ap-text);font-family:var(--ap-font-display);font-size:clamp(2.7rem,5vw,4.5rem);letter-spacing:-.045em;line-height:1.02;margin:18px 0 12px}.about-page .hero-subtitle{color:var(--ap-sub);font-family:var(--ap-font-display);font-size:clamp(1.3rem,2.2vw,1.9rem);letter-spacing:-.025em;line-height:1.22;margin:0 0 20px}.about-page .hero-desc{color:var(--ap-sub);font-size:15.5px;line-height:1.82;margin-bottom:28px;max-width:650px}.about-page .hero-highlights{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:24px;max-width:720px}.about-page .hero-highlight-card{background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:18px;box-shadow:var(--ap-shadow);padding:16px 18px;transition:border-color .22s ease,transform .22s ease,box-shadow .22s ease}.about-page .hero-highlight-card:hover{border-color:var(--ap-border-strong);box-shadow:var(--ap-shadow-strong);transform:translateY(-3px)}.about-page .highlight-label{color:var(--ap-muted);display:block;font-size:10.5px;font-weight:800;letter-spacing:.1em;margin-bottom:6px;text-transform:uppercase}.about-page .highlight-value{color:var(--ap-text);display:block;font-size:14px;font-weight:700;line-height:1.5}.about-page .hero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}.about-page .hero-chip{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:12.5px;font-weight:700;gap:6px;padding:8px 14px;transition:transform .22s var(--ap-ease-spring),box-shadow .2s ease,border-color .2s ease}.about-page .hero-chip:hover{transform:translateY(-2px)}.about-page .chip-v{background:#7c6ef721;border-color:#7c6ef742;color:#c4b5fd}[data-theme=light] .about-page .chip-v{background:#5b5ff61a;border-color:#5b5ff638;color:#5b5ff6}.about-page .hero-actions{display:flex;flex-wrap:wrap;gap:14px}.about-page .hero-right{display:flex;justify-content:center}.about-page .profile-card{background:var(--ap-card-bg);border:1px solid var(--ap-border-strong);border-radius:30px;box-shadow:var(--ap-shadow-strong);max-width:410px;overflow:hidden;padding:36px 28px 28px;position:relative;text-align:center;width:100%}.about-page .profile-ring{background:linear-gradient(135deg,#38bdf8,#34d399 50%,#6366f1);inset:0;opacity:.92;pointer-events:none;position:absolute;z-index:0}.about-page .profile-card:after{background:var(--ap-card-bg);border-radius:28px;content:"";inset:2px;position:absolute;z-index:1}.about-page .profile-avatar,.about-page .profile-contact-list,.about-page .profile-name,.about-page .profile-role,.about-page .profile-stats-row,.about-page .profile-sub,.about-page .profile-tags{position:relative;z-index:2}.about-page .profile-avatar{align-items:center;background:linear-gradient(135deg,var(--ap-violet),var(--ap-cyan));border-radius:50%;box-shadow:0 0 0 4px #ffffff0f,0 14px 36px #7c6ef752;display:flex;height:100px;justify-content:center;margin:0 auto 18px;width:100px}.about-page .avatar-initials{color:#fff;font-family:var(--ap-font-display);font-size:32px;font-weight:700}.about-page .profile-name{color:#eef2ff;font-family:var(--ap-font-display);font-size:1.55rem;font-weight:700;letter-spacing:-.03em;margin:0 0 6px}[data-theme=light] .about-page .profile-name{color:#17173b}.about-page .profile-role{color:#f472b6;font-size:13px;font-weight:700;margin:0 0 6px}.about-page .profile-sub{color:#97a6c4;font-size:12.5px;line-height:1.6;margin:0 0 22px}[data-theme=light] .about-page .profile-sub{color:#6366f1}.about-page .profile-stats-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:18px}.about-page .pstat{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:14px;padding:13px 8px}[data-theme=light] .about-page .pstat{background:#6366f114;border-color:#6366f129}.about-page .pstat-val{color:#60a5fa;display:block;font-family:var(--ap-font-display);font-size:1.2rem;font-weight:700}[data-theme=light] .about-page .pstat-val{color:#4f46e5}.about-page .pstat-lbl{color:#7d8aa4;display:block;font-size:10px;font-weight:800;letter-spacing:.06em;margin-top:5px;text-transform:uppercase}[data-theme=light] .about-page .pstat-lbl{color:#6366f1}.about-page .profile-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:18px}.about-page .ptag{border-radius:999px;font-size:10.5px;font-weight:800;letter-spacing:.04em;padding:5px 11px}.about-page .ptag-excel{background:#34d3991f;border:1px solid #34d39938;color:#86efac}.about-page .ptag-powerbi{background:#f472b61f;border:1px solid #f472b638;color:#f9a8d4}.about-page .ptag-sql{background:#38bdf81f;border:1px solid #38bdf838;color:#7dd3fc}.about-page .ptag-python{background:#fbbf241f;border:1px solid #fbbf2438;color:#fde047}.about-page .profile-contact-list{border-top:1px solid #ffffff14;display:flex;flex-direction:column;gap:12px;padding-top:16px}[data-theme=light] .about-page .profile-contact-list{border-top-color:#6366f129}.about-page .profile-contact-item{display:flex;flex-direction:column;gap:4px}.about-page .profile-contact-label{color:var(--ap-muted);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.about-page .profile-contact-item a{color:#a9b7d3;font-size:13px;font-weight:600;text-decoration:none;transition:color .2s ease}.about-page .profile-contact-item a:hover{color:#eef2ff}[data-theme=light] .about-page .profile-contact-item a{color:#6366f1}[data-theme=light] .about-page .profile-contact-item a:hover{color:#4f46e5}.about-page .about-me-section,.about-page .awards-section,.about-page .exp-section,.about-page .mission-section,.about-page .projects-section,.about-page .stats-section{padding:72px 0;position:relative;z-index:2}.about-page .stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}.about-page .stat-card{background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:24px;box-shadow:var(--ap-shadow);overflow:hidden;padding:30px 22px;position:relative;text-align:center;transition:transform .28s var(--ap-ease-spring),border-color .25s ease,box-shadow .25s ease}.about-page .stat-card:hover{border-color:#7c6ef757;box-shadow:var(--ap-shadow-strong);transform:translateY(-8px)}.about-page .stat-glow{background:radial-gradient(ellipse at top,#7c6ef721,#0000 68%);inset:0;pointer-events:none;position:absolute}.about-page .stat-icon{font-size:30px;margin-bottom:12px}.about-page .stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--ap-violet),var(--ap-cyan));-webkit-background-clip:text;background-clip:text;font-family:var(--ap-font-display);font-size:2.7rem;line-height:1}.about-page .stat-label{color:var(--ap-text);font-size:14px;font-weight:700;letter-spacing:-.01em;margin-top:10px}.about-page .stat-sub{color:var(--ap-muted);display:block;font-size:11.5px;margin-top:4px}.about-page .about-me-grid{grid-gap:34px;align-items:start;display:grid;gap:34px;grid-template-columns:1fr 1fr}.about-page .skill-bar-item+.skill-bar-item{margin-top:18px}.about-page .skill-bar-header{display:flex;gap:14px;justify-content:space-between;margin-bottom:8px}.about-page .skill-bar-name{color:var(--ap-text);font-size:13.5px;font-weight:700}.about-page .skill-bar-pct{color:var(--ap-muted);font-size:12px;font-weight:700}.about-page .skill-bar-track{background:#ffffff12;border-radius:999px;height:7px;overflow:hidden}[data-theme=light] .about-page .skill-bar-track{background:#6366f11f}.about-page .skill-bar-fill{border-radius:999px;height:100%;transition:width 1.1s var(--ap-ease-out)}.about-page .soft-skills-grid{display:flex;flex-direction:column;gap:8px}.about-page .soft-skill-row{align-items:center;background:hsla(0,0%,100%,.025);border:1px solid var(--ap-border);border-radius:13px;display:flex;gap:10px;padding:11px 14px;transition:transform .22s var(--ap-ease-spring),border-color .2s ease,background .2s ease}.about-page .soft-skill-row:hover{background:#7c6ef70d;border-color:#7c6ef74d;transform:translateX(5px)}[data-theme=light] .about-page .soft-skill-row{background:#6366f10a}.about-page .ss-dot{background:var(--ap-violet);border-radius:50%;box-shadow:0 0 6px var(--ap-violet);flex-shrink:0;height:7px;width:7px}.about-page .ss-name{color:var(--ap-text);font-size:13px;font-weight:600}.about-page .tools-grid{display:flex;flex-wrap:wrap;gap:9px}.about-page .tool-chip{background:#ffffff0a;border:1px solid var(--ap-border-strong);border-radius:999px;color:var(--ap-sub);font-size:12px;font-weight:700;padding:7px 13px;transition:transform .22s var(--ap-ease-spring),border-color .2s ease,background .2s ease,color .2s ease}.about-page .tool-chip:hover{background:#7c6ef71f;border-color:#7c6ef74d;color:var(--ap-text);transform:translateY(-2px)}[data-theme=light] .about-page .tool-chip{background:#6366f112;border-color:#6366f12e}.about-page .exp-section{background:hsla(0,0%,100%,.012);border-bottom:1px solid var(--ap-border);border-top:1px solid var(--ap-border)}[data-theme=light] .about-page .exp-section{background:rgba(99,102,241,.025)}.about-page .exp-list{display:flex;flex-direction:column;gap:22px;margin-top:30px}.about-page .exp-card{background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:24px;box-shadow:var(--ap-shadow);display:grid;grid-template-columns:220px 1fr;overflow:hidden;transition:transform .26s var(--ap-ease-spring),box-shadow .26s ease,border-color .26s ease}.about-page .exp-card:hover{border-color:#7c6ef74d;box-shadow:var(--ap-shadow-strong);transform:translateX(8px)}.about-page .exp-card-left{background:hsla(0,0%,100%,.025);border-right:1px solid var(--ap-border);display:flex;flex-direction:column;gap:10px;padding:26px 22px}[data-theme=light] .about-page .exp-card-left{background:#6366f10a}.about-page .exp-tag{border-radius:999px;display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.07em;padding:4px 11px;text-transform:uppercase;width:fit-content}.about-page .exp-tag-emerald{background:#34d3991f;border:1px solid #34d39938;color:#34d399}.about-page .exp-tag-violet{background:#7c6ef71f;border:1px solid #7c6ef738;color:#c4b5fd}.about-page .exp-tag-sky{background:#38bdf81f;border:1px solid #38bdf838;color:#7dd3fc}[data-theme=light] .about-page .exp-tag-emerald{color:#059669}[data-theme=light] .about-page .exp-tag-violet{color:#5b5ff6}[data-theme=light] .about-page .exp-tag-sky{color:#0284c7}.about-page .exp-location,.about-page .exp-period{color:var(--ap-muted);font-size:12.5px;font-weight:600}.about-page .exp-card-body{padding:26px 30px}.about-page .exp-header{margin-bottom:4px}.about-page .exp-role{color:var(--ap-text);font-family:var(--ap-font-display);font-size:1.24rem;font-weight:700;letter-spacing:-.025em;margin:0 0 5px}.about-page .exp-company{color:var(--ap-violet);font-size:13px;font-weight:700}.about-page .exp-points{display:flex;flex-direction:column;gap:10px;list-style:none;margin:16px 0 0;padding:0}.about-page .exp-point{align-items:flex-start;color:var(--ap-sub);display:flex;font-size:13.5px;gap:10px;line-height:1.72}.about-page .point-dot{border-radius:50%;flex-shrink:0;height:6px;margin-top:8px;width:6px}.about-page .point-dot-emerald{background:#34d399;box-shadow:0 0 6px #34d39980}.about-page .point-dot-violet{background:#7c6ef7;box-shadow:0 0 6px #7c6ef780}.about-page .point-dot-sky{background:#38bdf8;box-shadow:0 0 6px #38bdf880}.about-page .projects-grid{grid-gap:22px;display:grid;gap:22px;grid-template-columns:repeat(2,1fr);margin-top:30px}.about-page .project-card{background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:24px;box-shadow:var(--ap-shadow);overflow:hidden;padding:30px;position:relative;transition:transform .28s var(--ap-ease-spring),box-shadow .28s ease,border-color .28s ease}.about-page .project-card:hover{border-color:#7c6ef757;box-shadow:var(--ap-shadow-strong);transform:translateY(-8px)}.about-page .project-card:before{background:linear-gradient(90deg,#0000,#ffffff0f,#0000);content:"";height:100%;left:-80%;pointer-events:none;position:absolute;top:0;transform:skewX(-18deg);transition:left .55s var(--ap-ease-out);width:50%}.about-page .project-card:hover:before{left:130%}.about-page .proj-accent{border-radius:3px 3px 0 0;height:3px;inset:0 0 auto 0;position:absolute}.about-page .proj-accent-emerald{background:linear-gradient(90deg,var(--ap-green),#0000)}.about-page .proj-accent-sky{background:linear-gradient(90deg,var(--ap-sky),#0000)}.about-page .proj-accent-violet{background:linear-gradient(90deg,var(--ap-violet),#0000)}.about-page .proj-accent-amber{background:linear-gradient(90deg,var(--ap-amber),#0000)}.about-page .proj-org{color:var(--ap-muted);font-size:11px;font-weight:800;letter-spacing:.09em;margin-bottom:10px;text-transform:uppercase}.about-page .proj-title{color:var(--ap-text);font-family:var(--ap-font-display);font-size:1.12rem;letter-spacing:-.025em;line-height:1.28;margin:0 0 10px}.about-page .proj-desc{color:var(--ap-sub);font-size:13.5px;line-height:1.72;margin:0 0 16px}.about-page .proj-tags{display:flex;flex-wrap:wrap;gap:8px}.about-page .proj-tag{border-radius:999px;font-size:10.5px;font-weight:800;letter-spacing:.06em;padding:5px 10px;text-transform:uppercase}.about-page .proj-tag-emerald{background:#34d3991f;border:1px solid #34d39938;color:#34d399}.about-page .proj-tag-sky{background:#38bdf81f;border:1px solid #38bdf838;color:#7dd3fc}.about-page .proj-tag-violet{background:#7c6ef71f;border:1px solid #7c6ef738;color:#c4b5fd}.about-page .proj-tag-amber{background:#fbbf241f;border:1px solid #fbbf2438;color:#fbbf24}[data-theme=light] .about-page .proj-tag-emerald{color:#059669}[data-theme=light] .about-page .proj-tag-sky{color:#0284c7}[data-theme=light] .about-page .proj-tag-violet{color:#5b5ff6}[data-theme=light] .about-page .proj-tag-amber{color:#b45309}.about-page .awards-section{background:hsla(0,0%,100%,.012);border-bottom:1px solid var(--ap-border);border-top:1px solid var(--ap-border)}[data-theme=light] .about-page .awards-section{background:rgba(99,102,241,.025)}.about-page .awards-certs-grid{grid-gap:54px;display:grid;gap:54px;grid-template-columns:1fr 1fr}.about-page .awards-list,.about-page .certs-list,.about-page .edu-list{display:flex;flex-direction:column;gap:13px}.about-page .award-card,.about-page .cert-card,.about-page .edu-card{background:var(--ap-glass);border:1px solid var(--ap-border);border-radius:18px;box-shadow:var(--ap-shadow);transition:transform .24s var(--ap-ease-spring),border-color .22s ease,box-shadow .22s ease}.about-page .award-card:hover,.about-page .cert-card:hover,.about-page .edu-card:hover{border-color:#7c6ef74d;box-shadow:var(--ap-shadow-strong);transform:translateX(5px)}.about-page .award-card{align-items:flex-start;display:flex;gap:14px;padding:18px 20px}.about-page .award-icon{flex-shrink:0;font-size:22px;margin-top:2px}.about-page .award-header{display:flex;gap:10px;justify-content:space-between;margin-bottom:4px}.about-page .award-title{color:var(--ap-text);font-family:var(--ap-font-display);font-size:14px;font-weight:700;margin:0}.about-page .award-year{background:#fbbf241f;border:1px solid #fbbf2438;border-radius:999px;color:#fbbf24;font-size:11px;font-weight:700;padding:3px 9px;white-space:nowrap}[data-theme=light] .about-page .award-year{color:#b45309}.about-page .award-org{color:var(--ap-violet);font-size:12px;font-weight:700;margin:0 0 4px}.about-page .award-desc{color:var(--ap-muted);font-size:12.5px;line-height:1.6;margin:0}.about-page .cert-card{align-items:center;display:flex;gap:12px;padding:14px 18px}.about-page .cert-icon{align-items:center;background:#7c6ef71f;border:1px solid #7c6ef738;border-radius:11px;color:var(--ap-violet);display:flex;flex-shrink:0;font-weight:800;height:36px;justify-content:center;width:36px}.about-page .cert-text{color:var(--ap-text);font-size:13px;font-weight:600;line-height:1.6}.about-page .edu-label{font-size:1rem;margin:30px 0 14px}.about-page .edu-card{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:58px 1fr;padding:16px}.about-page .edu-year{color:var(--ap-sky);font-size:12px;padding-top:2px;text-align:center}.about-page .edu-degree,.about-page .edu-year{font-family:var(--ap-font-display);font-weight:700}.about-page .edu-degree{color:var(--ap-text);font-size:14px;margin:0 0 4px}.about-page .edu-inst{color:var(--ap-sub);font-size:12.5px;font-weight:600;margin:0 0 2px}.about-page .edu-uni{color:var(--ap-muted);font-size:11.5px;margin:0 0 8px}.about-page .edu-score{background:#34d3991f;border:1px solid #34d39938;border-radius:999px;color:#34d399;display:inline-block;font-size:11px;font-weight:700;padding:3px 10px}[data-theme=light] .about-page .edu-score{color:#059669}.about-page .mission-card{background:linear-gradient(135deg,#7c6ef721,#22d3ee12);border:1px solid #7c6ef73d;border-radius:30px;box-shadow:var(--ap-shadow-strong);overflow:hidden;padding:64px;position:relative}[data-theme=light] .about-page .mission-card{background:linear-gradient(135deg,#6366f11a,#22d3ee0f);border-color:#6366f142}.about-page .mission-glow{background:radial-gradient(ellipse at center,#7c6ef71f,#0000 68%);inset:0;pointer-events:none;position:absolute}.about-page .mission-card:before{background-image:linear-gradient(#7c6ef70d 1px,#0000 0),linear-gradient(90deg,#7c6ef70d 1px,#0000 0);background-size:44px 44px;content:"";inset:0;mask-image:radial-gradient(ellipse at center,#000 40%,#0000 100%);-webkit-mask-image:radial-gradient(ellipse at center,#000 40%,#0000 100%);pointer-events:none;position:absolute}.about-page .mission-inner{position:relative;z-index:2}.about-page .mission-para{color:var(--ap-sub);font-size:15.5px;line-height:1.82;margin:18px 0 32px;max-width:780px}.about-page .mission-values{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:32px}.about-page .mv-item{align-items:center;background:var(--ap-bg-soft);border:1px solid var(--ap-border-strong);border-radius:14px;display:inline-flex;gap:10px;min-height:50px;padding:12px 18px;transition:transform .24s var(--ap-ease-spring),border-color .2s ease}.about-page .mv-item:hover{border-color:#7c6ef761;transform:translateY(-3px)}.about-page .mv-icon{font-size:18px}.about-page .mv-label{color:var(--ap-text);font-size:13.5px;font-weight:700}.about-page .mission-actions{display:flex;flex-wrap:wrap;gap:14px}@media (max-width:1200px){.about-page .hero-inner{gap:44px}.about-page .awards-certs-grid{gap:36px}}@media (max-width:1024px){.about-page .about-hero{padding:72px 40px 64px}.about-page .sec-inner{padding:0 40px}.about-page .about-me-grid,.about-page .awards-certs-grid,.about-page .hero-inner{grid-template-columns:1fr}.about-page .stats-grid{grid-template-columns:repeat(2,1fr)}.about-page .projects-grid{grid-template-columns:1fr}.about-page .mission-card{padding:44px}.about-page .hero-right{justify-content:flex-start}}@media (max-width:768px){.about-page .about-hero{padding:54px 24px 56px}.about-page .sec-inner{padding:0 24px}.about-page .stats-grid{gap:14px;grid-template-columns:1fr 1fr}.about-page .exp-card,.about-page .hero-highlights{grid-template-columns:1fr}.about-page .exp-card-left{border-bottom:1px solid var(--ap-border);border-right:none}.about-page .mission-card{padding:32px 24px}.about-page .hero-title{font-size:2.4rem}.about-page .hero-actions,.about-page .mission-actions{align-items:stretch;flex-direction:column}.about-page .btn-ghost,.about-page .btn-primary{width:100%}}@media (max-width:540px){.about-page .stats-grid{grid-template-columns:1fr}.about-page .profile-card{max-width:100%;padding:28px 18px 20px}.about-page .profile-card:after{border-radius:24px}.about-page .hero-title{font-size:2rem}.about-page .hero-subtitle{font-size:1.15rem}.about-page .mission-values{gap:10px}.about-page .mv-item{width:100%}.about-page .about-card,.about-page .project-card{padding:22px 18px}.about-page .award-card,.about-page .cert-card,.about-page .edu-card{padding-left:14px;padding-right:14px}}.tutorials-page{--hbg:#fff;--hbg-2:#f4f8ff;--htext:#07162f;--htext-2:#475f79;--htext-3:#64748b;--hcard:#ffffffeb;--hcard-2:#ffffffb8;--hborder:#0f172a1a;--hshadow:0 24px 70px #0f172a1a;--hshadow-soft:0 12px 36px #0f172a12;--hshadow-hover:0 28px 80px #0f172a24;--primary:#6d5dfc;--cyan:#00a6ff;--green:#14b86a;--yellow:#f5b915}[data-theme=dark] .tutorials-page{--hbg:#070b16;--hbg-2:#090e1c;--htext:#f0f4fc;--htext-2:#c0cfe4;--htext-3:#8da0b8;--hcard:#0d1428d1;--hcard-2:#0d14288c;--hborder:#8ca0be29;--hshadow:0 28px 90px #0000007a;--hshadow-soft:0 14px 42px #00000052;--hshadow-hover:0 32px 90px #0000008f}.tutorials-page *,.tutorials-page :after,.tutorials-page :before{box-sizing:border-box}.tutorials-page{-webkit-font-smoothing:antialiased;background:var(--hbg);color:var(--htext);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;overflow-x:hidden;width:100%}.tgrad{-webkit-text-fill-color:#0000;background:linear-gradient(130deg,#7c3aed,#2563eb 48%,#00a6ff);-webkit-background-clip:text;background-clip:text;display:inline}.reveal{opacity:0;transform:translateY(28px);transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}.reveal.active{opacity:1;transform:translateY(0)}.tutorials-hero{background:radial-gradient(ellipse at -4% 8%,#6d5dfc33,#0000 36%),radial-gradient(ellipse at 92% 50%,#00a6ff38,#0000 38%),radial-gradient(ellipse at 48% 44%,#14b8a61a,#0000 34%),var(--hbg);border-bottom:1px solid var(--hborder);isolation:isolate;overflow:hidden;padding:100px 24px 80px;position:relative;text-align:center}.tutorials-hero:before{background-image:radial-gradient(circle,#6d5dfc61 1px,#0000 1.5px);background-position:16px 18px;background-size:22px 22px;content:"";inset:0;-webkit-mask-image:linear-gradient(180deg,#000,#0000 70%);mask-image:linear-gradient(180deg,#000,#0000 70%);opacity:.36;pointer-events:none;position:absolute;z-index:-1}.hero-premium-shell{align-items:center;display:flex;flex-direction:column;gap:40px;margin:0 auto;max-width:860px;position:relative;z-index:2}.hero-glow{border-radius:999px;filter:blur(80px);pointer-events:none;position:absolute;z-index:-1}.hero-glow-left{background:#6d5dfc47;height:380px;left:-120px;top:-100px;width:380px}.hero-glow-right{background:#00a6ff33;height:420px;right:-140px;top:-60px;width:420px}.hero-content{align-items:center;display:flex;flex-direction:column;gap:20px}.tut-hero-title{color:var(--htext);font-size:clamp(32px,5vw,58px);font-weight:850;letter-spacing:-.05em;line-height:1.08;margin:0}.hero-line{display:block}.hero-line-main{color:var(--htext)}.hero-line-accent{margin-top:4px}.tut-hero-sub{color:var(--htext-2);font-size:17px;font-weight:430;line-height:1.76;margin:0;max-width:620px;text-align:center}.hero-stats-card{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffbd;border:1px solid var(--hborder);border-radius:22px;box-shadow:var(--hshadow-soft);max-width:680px;padding:20px 28px;width:100%}[data-theme=dark] .hero-stats-card{background:#0d14288f}.tut-stats-row{flex-wrap:nowrap;gap:0;justify-content:space-around}.tut-stat,.tut-stats-row{align-items:center;display:flex}.tut-stat{flex:1 1;flex-direction:column;gap:5px}.tut-stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(130deg,#7c3aed,#2563eb 48%,#00a6ff);-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:850;letter-spacing:-.04em;line-height:1}.tut-stat-label{color:var(--htext-2);font-size:12px;font-weight:650;letter-spacing:.01em;text-align:center}.tut-stat-divider{background:var(--hborder);flex-shrink:0;height:40px;width:1px}.filters-wrap{padding:36px 24px 0}.filters-wrap,.premium-filter-bar{display:flex;justify-content:center}.premium-filter-bar{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#fff9;border:1px solid var(--hborder);border-radius:18px;box-shadow:var(--hshadow-soft);flex-wrap:wrap;gap:8px;padding:6px}[data-theme=dark] .premium-filter-bar{background:#0d142880}.filter-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:12px;color:var(--htext-2);cursor:pointer;display:inline-flex;font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-size:14px;font-weight:700;padding:9px 20px;transition:color .22s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease;white-space:nowrap}.filter-btn:hover{background:#6d5dfc14;border-color:#6d5dfc2e;color:var(--htext)}.filter-btn.active-filter{background:linear-gradient(130deg,#7c3aed,#2563eb 52%,#00a6ff);border-color:#0000;box-shadow:0 6px 20px #6d5dfc52;color:#fff}.tutorials-grid-section{margin:0 auto;max-width:1340px;padding:40px 24px 80px}.tut-grid{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr))}.grid-empty{color:var(--htext-2);font-size:16px;font-weight:500;grid-column:1/-1;padding:64px 0;text-align:center}.tutorial-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:var(--hcard);border:1px solid var(--hborder);border-radius:22px;box-shadow:var(--hshadow-soft);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.tutorial-card.is-live{cursor:pointer}.tutorial-card.is-live:hover{border-color:#6d5dfc47;box-shadow:var(--hshadow-hover);transform:translateY(-8px)}.tutorial-card.is-soon{cursor:default;opacity:.72}.tutorial-card:focus-visible{outline:3px solid #6d5dfc99;outline-offset:3px}.tutorial-card-media{background:radial-gradient(circle at 50% 12%,#6d5dfc24,#0000 44%),#0f172a08;flex-shrink:0;height:220px;overflow:hidden;position:relative}[data-theme=dark] .tutorial-card-media{background:radial-gradient(circle at 50% 12%,#6d5dfc38,#0000 44%),#ffffff08}.tutorial-card-image{display:block;height:100%;object-fit:cover;object-position:center top;transition:transform .46s ease;width:100%}.tutorial-card.is-live:hover .tutorial-card-image{transform:scale(1.06)}.tutorial-card-media-overlay{background:linear-gradient(0deg,#00000042,#0000 56%);inset:0;pointer-events:none;position:absolute}.tutorial-card-topbar{align-items:center;display:flex;justify-content:space-between;left:12px;position:absolute;right:12px;top:12px;z-index:3}.tutorial-category{align-items:center;border-radius:999px;box-shadow:0 4px 14px #00000038;color:#fff;display:inline-flex;font-size:10px;font-weight:800;letter-spacing:.08em;padding:5px 13px;text-transform:uppercase}.cat-excel{background:#217346}.cat-sql{background:#0078d4}.cat-python{background:#3572a5}.cat-powerbi{background:#f2c811;color:#1a1a1a}.cat-statistics{background:#e05c2c}.cat-numpy{background:#4dabcf}.cat-pandas{background:#130754}.cat-matplotlib{background:#11557c}.cat-seaborn{background:#4c72b0}.tutorial-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:10px;font-weight:800;letter-spacing:.07em;padding:4px 11px;text-transform:uppercase}.badge-live{background:#14b86a2e;border:1px solid #14b86a4d;color:#14b86a}.badge-soon{background:#f5b91529;border:1px solid #f5b91547;color:#d4a017}.tutorial-soon-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#070b1685;display:flex;inset:0;justify-content:center;position:absolute;z-index:2}.tutorial-soon-overlay span{background:#f5b9152e;border:1px solid #f5b9154d;border-radius:999px;color:#f5b915;font-size:12px;font-weight:800;letter-spacing:.08em;padding:8px 20px;text-transform:uppercase}.tutorial-card-body{display:flex;flex:1 1;flex-direction:column;padding:22px}.tutorial-card-content{display:flex;flex:1 1;flex-direction:column}.tutorial-level{align-items:center;background:#6d5dfc1a;border-radius:999px;color:var(--primary);display:inline-flex;font-size:10px;font-weight:800;letter-spacing:.09em;margin:0 0 6px;padding:3px 11px;text-transform:uppercase;width:fit-content}[data-theme=dark] .tutorial-level{background:#6d5dfc2e;color:#b3a4ff}.tutorial-title{color:var(--htext);font-size:18px;font-weight:750;letter-spacing:-.028em;line-height:1.3;margin:8px 0 10px}.tutorial-desc{color:var(--htext-2);flex:1 1;font-size:14px;font-weight:420;line-height:1.7;margin:0 0 14px}.tutorial-topics{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}.tutorial-topic-pill{align-items:center;background:#94a3b812;border:1px solid var(--hborder);border-radius:999px;color:var(--htext-3);display:inline-flex;font-size:11px;font-weight:650;padding:3px 10px;transition:border-color .2s ease,background .2s ease}.tutorial-card.is-live:hover .tutorial-topic-pill{background:#6d5dfc0f;border-color:#6d5dfc38}.tutorial-card-footer{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-top:auto;padding-top:4px}.tutorial-btn{align-items:center;background:linear-gradient(130deg,#7c3aed,#2563eb 52%,#00a6ff);border:none;border-radius:13px;box-shadow:0 6px 18px #2563eb3d;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-size:14px;font-weight:700;gap:8px;min-height:42px;padding:0 18px;transition:transform .22s ease,box-shadow .22s ease;white-space:nowrap}.tutorial-btn:hover{box-shadow:0 12px 28px #2563eb52;transform:translateY(-2px)}.tutorial-btn-disabled{background:#94a3b824!important;border:1px solid var(--hborder)!important;box-shadow:none!important;color:var(--htext-3)!important;cursor:not-allowed}.tutorial-status{align-items:center;display:inline-flex;font-size:12px;font-weight:650;gap:6px;white-space:nowrap}.status-live{color:#14b86a}.status-soon{color:var(--htext-3)}.status-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.status-live .status-dot{animation:dotPulse 1.8s ease-in-out infinite;background:#14b86a}.status-soon .status-dot{background:var(--htext-3)}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.tut-cta{padding:0 24px 100px}.tut-cta-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:var(--hcard);border:1px solid var(--hborder);border-radius:28px;box-shadow:var(--hshadow-soft);margin:0 auto;max-width:860px;overflow:hidden;padding:64px 60px;position:relative;text-align:center}.tut-cta-card:after,.tut-cta-card:before{border-radius:999px;content:"";filter:blur(72px);pointer-events:none;position:absolute;z-index:0}.tut-cta-card:before{background:#6d5dfc33;height:260px;left:-60px;top:-80px;width:260px}.tut-cta-card:after{background:#00a6ff29;bottom:-80px;height:260px;right:-60px;width:260px}.tut-cta-heading{color:var(--htext);font-size:clamp(22px,3.2vw,36px);font-weight:800;letter-spacing:-.04em;line-height:1.2;margin:0 0 16px;position:relative;z-index:1}.tut-cta-sub{color:var(--htext-2);font-size:15px;font-weight:430;line-height:1.76;margin:0 auto;max-width:560px;position:relative;z-index:1}@media (max-width:1024px){.tut-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.tutorials-hero{padding:80px 18px 60px}.tut-hero-title{font-size:clamp(28px,9vw,44px)}.tut-hero-sub{font-size:15px}.tut-stats-row{gap:0}.tut-stat-value{font-size:22px}.hero-stats-card{padding:16px 18px}.tutorials-grid-section{padding:32px 18px 64px}.tut-grid{grid-template-columns:1fr}.tut-cta{padding:0 18px 72px}.tut-cta-card{padding:44px 28px}.filters-wrap{padding:32px 18px 0}}@media (max-width:480px){.tut-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;justify-items:center}.tut-stat-divider{display:none}.tutorial-card-media{height:190px}.tut-cta-card{padding:36px 20px}.premium-filter-bar{gap:6px;padding:5px}.filter-btn{font-size:13px;padding:8px 14px}}@media (prefers-reduced-motion:reduce){.filter-btn,.reveal,.status-dot,.tutorial-btn,.tutorial-card,.tutorial-card-image{animation:none!important;transition:none!important}}:root{--auth-bg:#f4f7fb;--auth-card:#fff;--auth-left:linear-gradient(135deg,#111827,#1e3a8a 55%,#2563eb);--auth-text:#111827;--auth-muted:#6b7280;--auth-border:#e5e7eb;--auth-input:#f9fafb;--auth-primary:#2563eb;--auth-primary-dark:#1d4ed8;--auth-shadow:0 24px 70px #0f172a29}[data-theme=dark]{--auth-bg:#050816;--auth-card:#0b1020;--auth-left:linear-gradient(135deg,#0f172a,#1e1b4b 55%,#312e81);--auth-text:#f8fafc;--auth-muted:#94a3b8;--auth-border:#94a3b82e;--auth-input:hsla(0,0%,100%,.045);--auth-primary:#6366f1;--auth-primary-dark:#4f46e5;--auth-shadow:0 24px 70px #0000006b}*{box-sizing:border-box}.auth-page{align-items:center;background:radial-gradient(circle at top left,#2563eb24,#0000 34%),radial-gradient(circle at bottom right,#6366f11f,#0000 30%),#f4f7fb;background:radial-gradient(circle at top left,#2563eb24,#0000 34%),radial-gradient(circle at bottom right,#6366f11f,#0000 30%),var(--auth-bg);display:flex;font-family:Inter,sans-serif;justify-content:center;min-height:100vh;padding:92px 18px 28px;width:100%}.auth-container{background:#fff;background:var(--auth-card);border:1px solid #e5e7eb;border:1px solid var(--auth-border);border-radius:28px;box-shadow:0 24px 70px #0f172a29;box-shadow:var(--auth-shadow);display:grid;grid-template-columns:.95fr 1.05fr;max-width:920px;min-height:540px;overflow:hidden;width:100%}.auth-panel-left{background:linear-gradient(135deg,#111827,#1e3a8a 55%,#2563eb);background:var(--auth-left);color:#fff;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;padding:42px 38px;position:relative}.auth-panel-left:before{background:#ffffff1a;border-radius:50%;content:"";height:260px;position:absolute;right:-90px;top:-80px;width:260px}.auth-panel-left:after{background:#ffffff14;border-radius:50%;bottom:-60px;content:"";height:180px;left:-70px;position:absolute;width:180px}.auth-logo{display:inline-flex;position:relative;text-decoration:none;width:fit-content;z-index:1}.auth-logo-image{height:38px;object-fit:contain;width:auto}.auth-panel-content{max-width:330px;position:relative;z-index:1}.auth-panel-headline{color:#fff;font-size:clamp(2rem,3vw,3.1rem);font-weight:800;letter-spacing:-.05em;line-height:1.02;margin:0 0 18px}.auth-panel-sub{color:#ffffffc7;font-size:15px;line-height:1.8;margin:0}.auth-panel-right{align-items:center;background:#fff;background:var(--auth-card);display:flex;justify-content:center;padding:54px 46px}.auth-form-wrap{max-width:390px;width:100%}.auth-form-header{margin-bottom:22px}.auth-form-title{color:#111827;color:var(--auth-text);font-size:2rem;font-weight:800;letter-spacing:-.04em;line-height:1.1;margin:0 0 8px}.auth-form-sub{color:#6b7280;color:var(--auth-muted);font-size:14px;line-height:1.6;margin:0}.auth-switch-link{color:#2563eb;color:var(--auth-primary);font-weight:700;text-decoration:none}.auth-switch-link:hover{text-decoration:underline}.auth-google-btn{align-items:center;background:#fff;background:var(--auth-card);border:1px solid #e5e7eb;border:1px solid var(--auth-border);border-radius:14px;color:#111827;color:var(--auth-text);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin-bottom:4px;min-height:48px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background .2s ease;width:100%}.auth-google-btn:hover{background:#f9fafb;background:var(--auth-input);border-color:#2563eb;border-color:var(--auth-primary);box-shadow:0 0 0 3px #2563eb1a;transform:translateY(-1px)}.auth-google-btn:active{transform:translateY(0)}.google-icon{flex-shrink:0;height:20px;width:20px}.auth-divider{align-items:center;display:flex;gap:12px;margin:16px 0}.auth-divider:after,.auth-divider:before{background:#e5e7eb;background:var(--auth-border);content:"";flex:1 1;height:1px}.auth-divider span{color:#6b7280;color:var(--auth-muted);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.auth-form{gap:18px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-label{color:#111827;color:var(--auth-text);font-size:13px;font-weight:700}.input-wrap{align-items:center;background:#f9fafb;background:var(--auth-input);border:1px solid #e5e7eb;border:1px solid var(--auth-border);border-radius:14px;display:flex;gap:8px;min-height:48px;padding:0 14px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.input-wrap:focus-within{border-color:#2563eb;border-color:var(--auth-primary);box-shadow:0 0 0 4px #2563eb21;transform:translateY(-1px)}.input-wrap input{background:#0000;border:0;color:#111827;color:var(--auth-text);font-family:inherit;font-size:14px;outline:0;width:100%}.input-wrap input::placeholder,.pass-toggle{color:#6b7280;color:var(--auth-muted)}.pass-toggle{background:#0000;border:0;border-radius:10px;cursor:pointer;font-size:15px;height:34px;min-width:38px;transition:background .2s ease,color .2s ease}.pass-toggle:hover{background:#6366f11a;color:#2563eb;color:var(--auth-primary)}.auth-submit-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--auth-primary),var(--auth-primary-dark));border:0;border-radius:14px;box-shadow:0 14px 28px #2563eb47;color:#fff;cursor:pointer;font-size:15px;font-weight:800;letter-spacing:-.01em;min-height:50px;transition:transform .22s ease,box-shadow .22s ease,filter .22s ease}.auth-submit-btn:hover{box-shadow:0 18px 38px #2563eb57;filter:brightness(1.03);transform:translateY(-2px)}.auth-submit-btn:active{transform:translateY(0)}.auth-panel-right p{color:#6b7280;color:var(--auth-muted)}@media (max-width:860px){.auth-container{grid-template-columns:1fr;max-width:460px;min-height:auto}.auth-panel-left{display:none}.auth-panel-right{padding:38px 26px}}@media (max-width:480px){.auth-page{padding:86px 12px 22px}.auth-container{border-radius:22px}.auth-panel-right{padding:30px 18px}.auth-form-title{font-size:1.75rem}.input-wrap{min-height:46px}}:root{--green:#3ecb82;--green-dark:#27ae6a;--green-light:#3ecb8224;--green-pale:#3ecb8212;--green-glow:0 0 20px #3ecb8247;--sidebar-w:272px;--ads-w:210px;--bg:#05061a;--bg2:hsla(0,0%,100%,.032);--surface:hsla(0,0%,100%,.038);--surface-3:#ffffff1a;--text:#eceef8;--text-muted:#5a6a80;--border:hsla(0,0%,100%,.075);--border-accent:#3ecb8259;--shadow:0 4px 16px #0006;--shadow-md:0 12px 36px #0000008c;--font:"DM Sans",-apple-system,sans-serif;--font-display:"Clash Display","DM Sans",sans-serif;--mono:"JetBrains Mono","Courier New",monospace;--sidebar-bg:#060716fa;--v:#7c6ef7}[data-theme=light]{--green:#16a34a;--green-dark:#15803d;--green-light:#16a34a1f;--green-pale:#16a34a0f;--green-glow:0 0 20px #16a34a33;--bg:#eef0fc;--bg2:#d2d6fabf;--surface:#d2d6faa6;--surface-2:#c3c8f8d9;--surface-3:#b4bcf5f2;--text:#1a1744;--text-sub:#3730a3;--text-muted:#6366f1;--border:#6366f124;--border-2:#6366f13d;--border-accent:#16a34a59;--shadow:0 2px 10px #6366f11f;--shadow-md:0 8px 28px #6366f129;--sidebar-bg:#e0e3fcfa}body{color:#eceef8}.tutorial-page,body{background:#05061a;font-family:DM Sans,-apple-system,sans-serif}.tutorial-page{background:var(--bg);display:flex;font-family:var(--font);min-height:100vh}.tutorial-sidebar{background:#060716fa;background:var(--sidebar-bg);border-right:1px solid hsla(0,0%,100%,.075);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;position:sticky;top:0;transition:background .3s ease;width:272px;width:var(--sidebar-w);z-index:50}.tutorial-sidebar::-webkit-scrollbar{width:4px}.tutorial-sidebar::-webkit-scrollbar-track{background:#0000}.tutorial-sidebar::-webkit-scrollbar-thumb{background:#3ecb824d;border-radius:4px}[data-theme=light] .tutorial-sidebar::-webkit-scrollbar-thumb{background:#6366f140}.sidebar-head{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#3ecb8212;background:var(--green-pale);border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);padding:18px 16px 14px;position:sticky;top:0;z-index:5}.sidebar-brand{align-items:center;display:flex;gap:12px;margin-bottom:12px}.sb-icon{filter:drop-shadow(0 2px 8px rgba(62,203,130,.4));flex-shrink:0;font-size:30px}.sb-title{color:#eceef8;color:var(--text);font-family:Clash Display,DM Sans,sans-serif;font-family:var(--font-display);font-size:14.5px;font-weight:700;letter-spacing:-.02em;line-height:1.2}.sb-prog{color:#5a6a80;color:var(--text-muted);font-size:11px;font-weight:500;margin-top:2px}.sb-progress-bar{background:hsla(0,0%,100%,.075);background:var(--border);border-radius:999px;height:5px;overflow:hidden}.sb-progress-fill{background:linear-gradient(90deg,#3ecb82,#22d3ee);background:linear-gradient(90deg,var(--green),#22d3ee);border-radius:999px;box-shadow:0 0 8px #3ecb8280;height:100%;transition:width .5s cubic-bezier(.22,1,.36,1);transition:width .5s var(--ease-out)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:6px 0 24px}.topic-btn{font-family:DM Sans,-apple-system,sans-serif;gap:9px;padding:10px 16px;transition:background .16s,border-color .16s}.topic-btn.topic-active{background:#3ecb8224;background:var(--green-light);border-left-color:#3ecb82;border-left-color:var(--green)}.topic-icon{flex-shrink:0;font-size:15px}.topic-text{color:#eceef8;color:var(--text);flex:1 1;font-size:12.5px;font-weight:600;letter-spacing:-.01em;line-height:1.35;min-width:0}.topic-btn.topic-active .topic-text{color:#3ecb82;color:var(--green)}[data-theme=light] .topic-btn.topic-active .topic-text{color:#27ae6a;color:var(--green-dark)}.topic-arrow{color:#5a6a80;color:var(--text-muted);flex-shrink:0;font-size:14px;line-height:1;transition:transform .22s cubic-bezier(.22,1,.36,1);transition:transform .22s var(--ease-out)}.arrow-open{transform:rotate(90deg)}.subtopic-list{border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);padding:2px 0 6px}.subtopic-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font);gap:9px;padding:7px 16px 7px 30px;text-align:left;transition:background .14s,border-color .14s;width:100%}.subtopic-btn:hover{background:#ffffff12;background:var(--surface-2)}.subtopic-btn.sub-active{background:#3ecb8224;background:var(--green-light);border-left-color:#3ecb82;border-left-color:var(--green)}.subtopic-btn.sub-active .sub-dot{background:#3ecb82;background:var(--green);box-shadow:0 0 6px #3ecb8299}.sub-text{color:#94a3b8;color:var(--text-sub);flex:1 1;font-size:12px;letter-spacing:-.01em;line-height:1.35;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subtopic-btn.sub-active .sub-text{color:#3ecb82;color:var(--green);font-weight:600}[data-theme=light] .subtopic-btn.sub-active .sub-text{color:#27ae6a;color:var(--green-dark)}.subtopic-btn.sub-quiz .sub-text{color:#a78bfa}[data-theme=light] .subtopic-btn.sub-quiz .sub-text{color:#5b5ff6}.subtopic-btn.sub-quiz.sub-active .sub-text{color:#7c6ef7}.sub-dur{color:#5a6a80}.tutorial-main{flex:1 1;max-height:100vh;min-width:0;overflow-y:auto;scroll-behavior:smooth}.tutorial-main::-webkit-scrollbar{width:5px}.tutorial-main::-webkit-scrollbar-track{background:#0000}.tutorial-main::-webkit-scrollbar-thumb{background:#3ecb8240;border-radius:999px}.breadcrumb{align-items:center;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);background:#05061abf;border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);color:#5a6a80;color:var(--text-muted);display:flex;font-size:12.5px;gap:6px;padding:12px 32px;position:sticky;top:0;z-index:10}[data-theme=light] .breadcrumb{background:#e0e3fce0;border-bottom-color:hsla(0,0%,100%,.075);border-bottom-color:var(--border)}.bc-sep{color:#5a6a80;color:var(--text-muted);opacity:.5}.bc-active{color:#eceef8;color:var(--text);font-weight:600}.breadcrumb span:not(.bc-sep):not(.bc-active){color:#3ecb82;color:var(--green);cursor:pointer;transition:opacity .2s}.breadcrumb span:not(.bc-sep):not(.bc-active):hover{opacity:.75}.content-article{max-width:860px;padding:32px 36px 52px}.article-header{align-items:flex-start;border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px}.article-topic-icon{filter:drop-shadow(0 4px 12px rgba(62,203,130,.35));flex-shrink:0;font-size:36px;margin-top:2px}.article-header h1{color:#eceef8;color:var(--text);font-family:Clash Display,DM Sans,sans-serif;font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-.035em;line-height:1.22;margin-bottom:10px}.article-meta{align-items:center;color:#5a6a80;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:12px;gap:12px}.article-meta span{align-items:center;background:#ffffff12;background:var(--surface-2);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:999px;display:inline-flex;font-weight:500;gap:4px;padding:3px 10px}.final-badge{background:#fbbf2426!important;border-color:#fbbf244d!important;color:#fbbf24!important;font-weight:700!important}[data-theme=light] .final-badge{background:#fbbf242e!important;border-color:#fbbf2459!important;color:#b45309!important}.article-intro{background:#3ecb8212;background:var(--green-pale);border-left:3px solid #3ecb82;border-left:3px solid var(--green);border-radius:0 10px 10px 0;border-radius:0 var(--radius) var(--radius) 0;color:#94a3b8;color:var(--text-sub);font-size:14.5px;line-height:1.82;margin-bottom:22px;padding:16px 20px}.tip-banner{align-items:flex-start;background:#fbbf2412;border:1px solid #fbbf2438;border-radius:10px;border-radius:var(--radius);color:#fbbf24;display:flex;font-size:13.5px;gap:12px;line-height:1.65;margin-bottom:22px;padding:14px 18px}[data-theme=light] .tip-banner{background:#fbbf241a;border-color:#fbbf244d;color:#b45309}.tip-icon{flex-shrink:0;font-size:18px;margin-top:1px}.article-img-wrap{border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 12px 36px #0000008c;box-shadow:var(--shadow-md);margin-bottom:26px;overflow:hidden}.article-img{display:block;height:240px;object-fit:cover;transition:transform .4s cubic-bezier(.22,1,.36,1);transition:transform .4s var(--ease-out);width:100%}.article-img:hover{transform:scale(1.02)}.blocks{display:flex;flex-direction:column;gap:22px}.block-label{color:#eceef8;color:var(--text);font-size:13.5px;font-weight:700;letter-spacing:-.01em;margin-bottom:12px}.block-points ul{display:flex;flex-direction:column;gap:8px;list-style:none}.block-points li{align-items:flex-start;background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:8px;color:#94a3b8;color:var(--text-sub);display:flex;font-size:13.5px;gap:10px;line-height:1.65;padding:10px 14px;transition:border-color .2s,background .2s}.block-points li:hover{background:#3ecb8212;background:var(--green-pale);border-color:#3ecb8259;border-color:var(--border-accent)}.chk{color:#3ecb82;color:var(--green);flex-shrink:0;font-size:14px;font-weight:800}.block-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(175px,1fr))}.b-card{background:hsla(0,0%,100%,.038);border:1px solid hsla(0,0%,100%,.075);border-radius:16px;border-radius:var(--radius-lg);cursor:default;padding:18px 16px;transition:box-shadow .25s,transform .25s cubic-bezier(.34,1.56,.64,1),border-color .25s;transition:box-shadow .25s,transform .25s var(--ease-spring),border-color .25s}.b-card:hover{border-color:#3ecb82;border-color:var(--green);box-shadow:0 6px 24px #3ecb8233;transform:translateY(-4px)}.b-card-emoji{filter:drop-shadow(0 2px 6px rgba(0,0,0,.2));font-size:26px;margin-bottom:10px}.b-card h4{color:#eceef8;font-size:13px;letter-spacing:-.01em;margin-bottom:6px}.b-card p{color:#5a6a80}.block-ftable{display:flex;flex-direction:column;gap:8px}.ft-row{align-items:center;background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;gap:14px;padding:12px 16px;transition:border-color .2s,transform .2s cubic-bezier(.34,1.56,.64,1);transition:border-color .2s,transform .2s var(--ease-spring)}.ft-row:hover{border-color:#3ecb8259;border-color:var(--border-accent);transform:translateX(4px)}.ft-tag{border-radius:6px;color:#fff;flex-shrink:0;font-family:JetBrains Mono,Courier New,monospace;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.02em;min-width:88px;padding:5px 12px;text-align:center;white-space:nowrap}.ft-info{display:flex;flex-direction:column;gap:2px}.ft-info strong{color:#eceef8;color:var(--text);font-size:13px;font-weight:700}.ft-info span{color:#5a6a80;color:var(--text-muted);font-size:12px;line-height:1.5}.block-steps ol{counter-reset:step;display:flex;flex-direction:column;gap:8px;list-style:none}.block-steps li{align-items:flex-start;background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:8px;color:#94a3b8;color:var(--text-sub);display:flex;font-size:13.5px;gap:12px;line-height:1.65;padding:10px 14px;transition:border-color .2s,background .2s}.block-steps li:hover{background:#3ecb8212;background:var(--green-pale);border-color:#3ecb8259;border-color:var(--border-accent)}.step-num{align-items:center;background:#3ecb82;background:var(--green);border-radius:50%;box-shadow:0 0 10px #3ecb8266;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:800;height:24px;justify-content:center;width:24px}.block-shortcuts{display:flex;flex-direction:column;gap:8px}.shortcut-row{align-items:flex-start;background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:8px;display:flex;gap:14px;padding:10px 14px;transition:border-color .2s,background .2s}.shortcut-row:hover{background:#3ecb8212;background:var(--green-pale);border-color:#3ecb8259;border-color:var(--border-accent)}kbd{background:#ffffff12;border:1px solid #ffffff21;border:1px solid var(--border-2);border-radius:6px;box-shadow:0 2px 0 #00000040;color:#eceef8;color:var(--text);flex-shrink:0;font-family:JetBrains Mono,Courier New,monospace;font-family:var(--mono);font-size:11.5px;font-weight:600;letter-spacing:.3px;padding:4px 12px;white-space:nowrap}[data-theme=light] kbd{background:#1a1744;border-color:#0000;box-shadow:0 2px 0 #0003;color:#eceef8}.shortcut-row span{color:#94a3b8;color:var(--text-sub);font-size:13px;line-height:1.65}.block-twocol{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.tcol-card{background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);padding:18px 16px;transition:border-color .25s,transform .25s cubic-bezier(.34,1.56,.64,1);transition:border-color .25s,transform .25s var(--ease-spring)}.tcol-card:hover{border-color:#3ecb82;border-color:var(--green);transform:translateY(-3px)}.tcol-icon{display:block;font-size:22px;margin-bottom:10px}.tcol-card h4{color:#eceef8;color:var(--text);font-size:13.5px;font-weight:700;letter-spacing:-.01em;margin-bottom:7px}.tcol-card p{color:#5a6a80;color:var(--text-muted);font-size:12.5px;line-height:1.7}.block-etable{border-radius:10px;border-radius:var(--radius);overflow-x:auto}.block-etable table{border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-collapse:collapse;border-radius:10px;border-radius:var(--radius);font-size:13px;overflow:hidden;width:100%}.block-etable th{background:#3ecb8226;border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);color:#eceef8;color:var(--text);font-size:12px;font-weight:700;letter-spacing:-.01em;padding:10px 16px;text-align:left}[data-theme=light] .block-etable th{background:#3ecb8224;background:var(--green-light);color:#27ae6a;color:var(--green-dark)}.block-etable td{border-top:1px solid hsla(0,0%,100%,.075);border-top:1px solid var(--border);color:#94a3b8;color:var(--text-sub);padding:9px 16px}.block-etable tr:nth-child(2n) td{background:hsla(0,0%,100%,.038);background:var(--surface)}.block-etable tr:hover td{background:#3ecb8212;background:var(--green-pale);transition:background .15s}.block-summary{display:flex;flex-direction:column;gap:10px}.summary-item{align-items:center;background:#3ecb8212;background:var(--green-pale);border:1px solid #3ecb822e;border-radius:10px;color:#eceef8;color:var(--text);display:flex;font-size:13.5px;font-weight:500;gap:13px;line-height:1.55;padding:12px 18px;transition:border-color .2s,transform .2s cubic-bezier(.34,1.56,.64,1);transition:border-color .2s,transform .2s var(--ease-spring)}.summary-item:hover{border-color:#3ecb82;border-color:var(--green);transform:translateX(4px)}[data-theme=light] .summary-item{color:#27ae6a;color:var(--green-dark)}.sum-dot{background:#3ecb82;background:var(--green);border-radius:50%;box-shadow:0 0 8px #3ecb8280;flex-shrink:0;height:9px;width:9px}.quiz-wrap{background:hsla(0,0%,100%,.038);background:var(--surface);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.quiz-top{align-items:center;background:linear-gradient(135deg,#3ecb8226,#22d3ee14);border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 22px}[data-theme=light] .quiz-top{background:#3ecb8224;background:var(--green-light)}.quiz-label{color:#eceef8;color:var(--text);font-family:Clash Display,DM Sans,sans-serif;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:-.02em}.quiz-count{background:#ffffff1a;background:var(--surface-3);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:999px;color:#5a6a80;color:var(--text-muted);font-size:12px;font-weight:600;padding:4px 12px}.quiz-list{display:flex;flex-direction:column;gap:22px;padding:20px 22px}.quiz-q{display:flex;gap:14px}.quiz-q-num{align-items:center;background:#ffffff12;background:var(--surface-2);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:8px;color:#5a6a80;color:var(--text-muted);display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:30px;justify-content:center;margin-top:1px;width:30px}[data-theme=light] .quiz-q-num{background:#6366f11a}.quiz-q-body{flex:1 1}.quiz-q-text{color:#eceef8;color:var(--text);font-size:14px;font-weight:600;letter-spacing:-.01em;line-height:1.55;margin-bottom:12px}.quiz-opts{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.quiz-opt{align-items:center;background:hsla(0,0%,100%,.038);background:var(--surface);border:1.5px solid hsla(0,0%,100%,.075);border:1.5px solid var(--border);border-radius:9px;color:#eceef8;color:var(--text);cursor:pointer;display:flex;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font);font-size:12.5px;gap:9px;padding:9px 13px;text-align:left;transition:all .16s;width:100%}.quiz-opt:hover{background:#3ecb8212;background:var(--green-pale);border-color:#3ecb82;border-color:var(--green)}.quiz-opt.opt-sel{background:#7c6ef71a;border-color:#7c6ef7;border-color:var(--v)}.quiz-opt.opt-correct{background:#3ecb8224;background:var(--green-light);border-color:#3ecb82;border-color:var(--green)}.quiz-opt.opt-wrong{background:#ef444417;border-color:#ef4444}[data-theme=light] .quiz-opt{background:#d2d6fa99;border-color:hsla(0,0%,100%,.075);border-color:var(--border)}[data-theme=light] .quiz-opt:hover{background:#3ecb8212;background:var(--green-pale);border-color:#3ecb82;border-color:var(--green)}[data-theme=light] .quiz-opt.opt-sel{background:#6366f11a;border-color:#7c6ef7;border-color:var(--v)}[data-theme=light] .quiz-opt.opt-correct{background:#3ecb8224;background:var(--green-light);border-color:#3ecb82;border-color:var(--green)}[data-theme=light] .quiz-opt.opt-wrong{background:#ef444414;border-color:#ef4444}.opt-letter{align-items:center;background:#ffffff12;background:var(--surface-2);border-radius:6px;color:#5a6a80;color:var(--text-muted);display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;transition:background .15s,color .15s;width:22px}[data-theme=light] .opt-letter{background:#6366f11f;color:#7c6ef7;color:var(--v)}.quiz-opt.opt-sel .opt-letter{background:#7c6ef7;background:var(--v);color:#fff}.quiz-opt.opt-correct .opt-letter{background:#3ecb82;background:var(--green);color:#fff}.quiz-opt.opt-wrong .opt-letter{background:#ef4444;color:#fff}.opt-text{flex:1 1;line-height:1.4}.opt-mark{flex-shrink:0;font-size:14px;font-weight:800;margin-left:auto}.opt-correct .opt-mark{color:#3ecb82;color:var(--green)}.opt-wrong .opt-mark{color:#ef4444}.quiz-actions{border-top:1px solid hsla(0,0%,100%,.075);border-top:1px solid var(--border);display:flex;justify-content:center;padding:18px 22px 22px}.quiz-submit{background:linear-gradient(135deg,#3ecb82,#27ae6a);background:linear-gradient(135deg,var(--green),var(--green-dark));border:none;border-radius:10px;box-shadow:0 6px 20px #3ecb8261;color:#fff;cursor:pointer;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font);font-size:14px;font-weight:700;letter-spacing:-.01em;padding:12px 32px;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease,opacity .2s;transition:transform .22s var(--ease-spring),box-shadow .22s ease,opacity .2s}.quiz-submit:hover:not(:disabled){box-shadow:0 12px 30px #3ecb8280;transform:translateY(-3px)}.quiz-submit:active:not(:disabled){transform:scale(.97)}.quiz-submit:disabled{background:#ffffff21;background:var(--border-2);box-shadow:none;cursor:not-allowed;opacity:.7}[data-theme=light] .quiz-submit:disabled{background:#6366f12e}.quiz-result-panel{align-items:center;display:flex;flex-direction:column;gap:16px;padding:8px 0;width:100%}.result-badge{align-items:center;border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:14px;padding:20px 32px}.rb-great{background:#3ecb8224;background:var(--green-light);border-color:#3ecb8240}.rb-ok{background:#fbbf241a;border-color:#fbbf2438}.rb-low{background:#ef444417;border-color:#ef44442e}[data-theme=light] .rb-great{background:#16a34a1a}[data-theme=light] .rb-ok{background:#fbbf241f}[data-theme=light] .rb-low{background:#ef444414}.rb-medal,.rb-score{font-size:38px}.rb-score{color:#eceef8;color:var(--text);font-family:Clash Display,DM Sans,sans-serif;font-family:var(--font-display);font-weight:700;letter-spacing:-.04em}.rb-pct{color:#5a6a80;color:var(--text-muted);font-size:22px;font-weight:600}.result-msg{color:#eceef8;color:var(--text);font-size:14.5px;font-weight:600;line-height:1.5;text-align:center}.final-band{color:#5a6a80;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:12px;gap:8px;justify-content:center}.fb-item{background:#ffffff12;background:var(--surface-2);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);border-radius:999px;color:#eceef8;color:var(--text);font-size:12px;font-weight:600;padding:5px 13px}.quiz-retry{background:#0000;border:2px solid #3ecb82;border:2px solid var(--green);border-radius:10px;color:#3ecb82;color:var(--green);cursor:pointer;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font);font-size:13.5px;font-weight:700;padding:9px 26px;transition:background .2s,color .2s,transform .22s cubic-bezier(.34,1.56,.64,1);transition:background .2s,color .2s,transform .22s var(--ease-spring)}.quiz-retry:hover{background:#3ecb82;background:var(--green);color:#fff;transform:translateY(-2px)}.article-nav{align-items:center;border-top:1px solid hsla(0,0%,100%,.075);border-top:1px solid var(--border);display:flex;gap:12px;justify-content:space-between;margin-top:36px;padding-top:22px}.nav-btn{align-items:center;background:linear-gradient(135deg,#3ecb82,#27ae6a);background:linear-gradient(135deg,var(--green),var(--green-dark));border:none;border-radius:10px;box-shadow:0 4px 16px #3ecb8252;color:#fff;cursor:pointer;display:inline-flex;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font);font-size:13.5px;font-weight:700;gap:7px;letter-spacing:-.01em;padding:11px 22px;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease;transition:transform .22s var(--ease-spring),box-shadow .22s ease}.nav-btn:hover:not(:disabled){box-shadow:0 8px 24px #3ecb8270;transform:translateY(-3px)}.nav-btn:active:not(:disabled){transform:scale(.97)}.nav-btn:disabled{box-shadow:none;cursor:not-allowed}.nav-btn:disabled,.nav-prog{background:#ffffff12;background:var(--surface-2);border:1px solid hsla(0,0%,100%,.075);border:1px solid var(--border);color:#5a6a80;color:var(--text-muted)}.nav-prog{border-radius:999px;font-size:12.5px;font-weight:600;padding:6px 14px;white-space:nowrap}.tutorial-ads{border-left:1px solid hsla(0,0%,100%,.075);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:18px;padding:18px 14px;width:210px;width:var(--ads-w)}.ad-box{position:relative}.ad-label{color:#5a6a80;color:var(--text-muted);display:block;font-size:10px;font-weight:600;letter-spacing:.06em;margin-bottom:6px;text-align:center;text-transform:uppercase}.ad-placeholder{background:hsla(0,0%,100%,.038);background:var(--surface);border:1.5px dashed #ffffff21;border:1.5px dashed var(--border-2);border-radius:10px;border-radius:var(--radius);transition:border-color .2s}.ad-placeholder:hover{border-color:#3ecb824d}.ad-inner{align-items:center;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:190px;padding:22px 10px}.ad-icon{font-size:26px;opacity:.25}.ad-inner p{font-size:13.5px;font-weight:700;opacity:.7;text-align:center}.ad-inner p,.ad-size{color:#5a6a80;color:var(--text-muted)}.ad-size{font-size:10px;opacity:.5}.ad-leaderboard{min-height:320px}.ad-sticky{position:sticky;top:56px}.sidebar-mobile-toggle{align-items:center;background:linear-gradient(135deg,#3ecb82,#27ae6a);background:linear-gradient(135deg,var(--green),var(--green-dark));border:none;border-radius:14px;bottom:24px;box-shadow:0 8px 24px #3ecb8273;color:#fff;cursor:pointer;display:none;font-size:22px;height:52px;justify-content:center;position:fixed;right:24px;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s;transition:transform .22s var(--ease-spring),box-shadow .22s;width:52px;z-index:200}.sidebar-mobile-toggle:hover{box-shadow:0 12px 32px #3ecb828c;transform:scale(1.08)}@media (max-width:1150px){.tutorial-ads{display:none}}@media (max-width:900px){:root{--sidebar-w:240px}}@media (max-width:768px){.tutorial-page{flex-direction:column}.tutorial-sidebar{border-bottom:1px solid hsla(0,0%,100%,.075);border-bottom:1px solid var(--border);border-right:none;height:auto;max-height:280px;position:relative;width:100%}.sidebar-head{position:relative}.tutorial-main{max-height:none}.content-article{padding:20px 20px 40px}.article-header{flex-direction:column;gap:10px}.article-topic-icon{font-size:28px}.article-header h1{font-size:20px}.block-twocol{grid-template-columns:1fr}.block-cards{grid-template-columns:1fr 1fr}.quiz-opts{grid-template-columns:1fr}.breadcrumb{padding:10px 20px}.sidebar-mobile-toggle{display:flex}}@media (max-width:480px){.block-cards{grid-template-columns:1fr}.article-intro{font-size:13.5px}.content-article{padding:16px 16px 36px}.article-header h1{font-size:18px}.result-badge{padding:14px 20px}.rb-score{font-size:30px}}:root{--blue:#3b82f6;--blue-dark:#2563eb;--blue-glow:#3b82f659;--blue-bg:#3b82f61a;--blue-border:#3b82f640;--sidebar-w:262px;--bg:#06071a;--bg2:hsla(0,0%,100%,.035);--bg3:#ffffff0f;--surface:#ffffff0a;--surface-2:#ffffff12;--sidebar-bg:#08091cfa;--text:#e8eaf6;--text-sub:#94a3b8;--border:#ffffff14;--border-2:#ffffff21;--code-bg:#0d1117;--code-surface:#161b22;--code-text:#e6edf3;--code-kw:#79c0ff;--code-str:#a5f3a0;--code-cmt:#8b949e;--code-fn:#ffa657;--code-num:#f47067;--radius-lg:16px;--shadow:0 2px 12px #0006;--shadow-md:0 8px 32px #0000008c;--shadow-glow:0 0 30px #3b82f633;--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ease-out:cubic-bezier(0.22,1,0.36,1);--font-display:"Clash Display",sans-serif;--mono:"JetBrains Mono","Fira Code","Courier New",monospace}[data-theme=light]{--blue-bg:#3b82f612;--blue-border:#3b82f633;--bg:#f0f4ff;--bg2:#ffffffe6;--bg3:#fff;--surface:#fff;--surface-2:#f8faff;--sidebar-bg:#fff;--text:#0f172a;--text-muted:#64748b;--text-sub:#475569;--border:#00000012;--border-2:#0000001f;--code-bg:#1a1f2e;--code-surface:#252d3f;--code-text:#e6edf3;--shadow:0 2px 8px #00000012;--shadow-md:0 8px 24px #0000001a;--shadow-glow:0 0 30px #3b82f61a}body{-webkit-font-smoothing:antialiased;background:#06071a;color:#e8eaf6;transition:background .35s ease,color .35s ease}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#3b82f68c}[data-theme=light] ::-webkit-scrollbar-thumb{background:#cbd5e0}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sql-page{background:#06071a;background:var(--bg);display:flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);min-height:100vh;position:relative}.sql-page:before{background:radial-gradient(ellipse 70% 50% at 10% 10%,#3b82f61a 0,#0000 55%),radial-gradient(ellipse 55% 45% at 88% 75%,#6366f112 0,#0000 50%),radial-gradient(ellipse 40% 35% at 50% 50%,#22d3ee0a 0,#0000 50%);content:"";inset:0;pointer-events:none;position:fixed;z-index:0}[data-theme=light] .sql-page:before{background:radial-gradient(ellipse 60% 40% at 10% 10%,#3b82f60f 0,#0000 55%),radial-gradient(ellipse 50% 40% at 88% 75%,#6366f10a 0,#0000 50%)}.sql-page:after{background-image:radial-gradient(circle,#3b82f61f 1px,#0000 0);background-size:32px 32px;content:"";inset:0;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 20%,#0000 100%);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 20%,#0000 100%);opacity:.4;pointer-events:none;position:fixed;z-index:0}[data-theme=light] .sql-page:after{background-image:radial-gradient(circle,#3b82f614 1px,#0000 0);opacity:.3}.sql-page>*{position:relative;z-index:1}.sql-sidebar{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#08091cfa;background:var(--sidebar-bg);border-right:1px solid #ffffff14;border-right:1px solid var(--border);box-shadow:2px 0 24px #00000040;display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;position:sticky;top:0;width:262px;width:var(--sidebar-w);z-index:50}[data-theme=light] .sql-sidebar{box-shadow:2px 0 16px #00000012}.sql-sidebar::-webkit-scrollbar{width:3px}.sql-sidebar::-webkit-scrollbar-thumb{background:#3b82f640}.sb-head{background:#3b82f60f;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;padding:16px 16px 14px;position:relative}.sb-head:before{background:linear-gradient(90deg,#3b82f6,#6366f1cc,#0000);background:linear-gradient(90deg,var(--blue),#6366f1cc,#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}[data-theme=light] .sb-head{background:#3b82f60d}.sb-brand{align-items:center;display:flex;gap:10px;margin-bottom:12px}.sb-logo{filter:drop-shadow(0 0 8px rgba(59,130,246,.5));font-size:26px}.sb-name{color:#e8eaf6;color:var(--text);font-family:Clash Display,sans-serif;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:-.01em}.sb-prog-text{color:#64748b;color:var(--text-muted);font-size:11px;font-weight:500;margin-top:2px}.sb-bar{background:#3b82f61f;border:1px solid #3b82f640;border:1px solid var(--blue-border);border-radius:999px;height:5px;overflow:hidden}[data-theme=light] .sb-bar{background:#dbeafe;border-color:#0000}.sb-bar-fill{background:linear-gradient(90deg,#3b82f6,#6366f1);background:linear-gradient(90deg,var(--blue),#6366f1);border-radius:999px;box-shadow:0 0 10px #3b82f699;height:100%;transition:width .5s cubic-bezier(.22,1,.36,1);transition:width .5s var(--ease-out)}.sb-nav{flex:1 1;overflow-y:auto;padding:6px 0 24px}.topic-group{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border)}.topic-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);gap:8px;padding:9px 14px;text-align:left;transition:background .15s,border-color .15s;width:100%}.topic-btn:hover{background:#ffffff12;background:var(--surface-2)}.topic-btn.topic-active{background:#3b82f61a;background:var(--blue-bg);border-left-color:#3b82f6;border-left-color:var(--blue)}.t-icon{flex-shrink:0;font-size:14px}.t-label{color:#e8eaf6;color:var(--text);flex:1 1;font-size:12.5px;font-weight:600;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topic-btn.topic-active .t-label{color:#3b82f6;color:var(--blue)}.t-arrow{color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:15px;transition:transform .25s cubic-bezier(.22,1,.36,1);transition:transform .25s var(--ease-out)}.t-arrow.open{transform:rotate(90deg)}.sub-list{padding:2px 0 6px}.sub-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);gap:8px;padding:6px 14px 6px 26px;text-align:left;transition:background .12s,border-color .12s;width:100%}.sub-btn:hover{background:#ffffff12;background:var(--surface-2)}.sub-btn.sub-active{background:#3b82f61a;background:var(--blue-bg);border-left-color:#3b82f6;border-left-color:var(--blue)}.sub-dot{background:#ffffff21;background:var(--border-2);border-radius:50%;flex-shrink:0;height:6px;transition:background .2s,box-shadow .2s;width:6px}.dot-active{background:#3b82f6;background:var(--blue);box-shadow:0 0 6px #3b82f699}.sub-label{color:#94a3b8;color:var(--text-sub);flex:1 1;font-size:12px;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sub-btn.sub-active .sub-label{color:#3b82f6;color:var(--blue);font-weight:600}.sub-dur{color:#64748b;color:var(--text-muted);flex-shrink:0;font-size:10px;font-weight:500}.sql-main{background:#0000;flex:1 1;max-height:100vh;min-width:0;overflow-y:auto}.sql-breadcrumb{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff0a;background:var(--surface);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-muted);display:flex;font-size:12.5px;gap:7px;padding:12px 28px;position:sticky;top:0;z-index:10}[data-theme=light] .sql-breadcrumb{background:#fffffff2}.bc-arr{color:#ffffff21;color:var(--border-2);font-weight:700}.bc-cur{color:#e8eaf6;color:var(--text);font-weight:600}.sql-breadcrumb span:not(.bc-arr):not(.bc-cur){color:#3b82f6;color:var(--blue);cursor:pointer;font-weight:500}.sql-breadcrumb span:not(.bc-arr):not(.bc-cur):hover{text-decoration:underline}.sql-article{max-width:860px;padding:28px 32px 52px}.art-header{align-items:flex-start;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);display:flex;gap:16px;margin-bottom:20px;padding-bottom:20px}.art-topic-icon{filter:drop-shadow(0 0 10px rgba(59,130,246,.4));flex-shrink:0;font-size:32px;margin-top:3px}.art-header h1{color:#e8eaf6;color:var(--text);font-family:Clash Display,sans-serif;font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-bottom:10px}.art-meta{align-items:center;color:#64748b;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:12.5px;gap:10px}.art-topic-tag{background:#3b82f61a;background:var(--blue-bg);border:1px solid #3b82f640;border:1px solid var(--blue-border);border-radius:999px;color:#3b82f6;color:var(--blue);font-size:11px;font-weight:600;padding:3px 10px}.art-intro{background:#3b82f612;border-left:3px solid #3b82f6;border-left:3px solid var(--blue);border-radius:0 10px 10px 0;border-radius:0 var(--radius) var(--radius) 0;box-shadow:inset 0 0 0 1px #3b82f614;margin-bottom:22px;padding:14px 18px}[data-theme=light] .art-intro{background:#f0f7ff;box-shadow:none}.art-intro p{color:#94a3b8;color:var(--text-sub);font-size:14.5px;font-weight:500;line-height:1.8}[data-theme=light] .art-intro p{color:#1e3a5f}.art-top-tip{align-items:flex-start;background:#fbbf2412;border:1px solid #fbbf2440;border-radius:10px;border-radius:var(--radius);color:#fcd34d;display:flex;font-size:13.5px;gap:10px;line-height:1.7;margin-bottom:22px;padding:12px 16px}[data-theme=light] .art-top-tip{background:#fffbeb;border-color:#fcd34d;color:#78350f}.tip-bulb{font-size:16px;margin-top:2px}.art-nav{align-items:center;border-top:1px solid #ffffff14;border-top:1px solid var(--border);display:flex;gap:12px;justify-content:space-between;margin-top:36px;padding-top:20px}.nav-next,.nav-prev{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--blue),var(--blue-dark));border:none;border-radius:9px;box-shadow:0 4px 14px #3b82f666;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);font-size:13px;font-weight:700;gap:6px;padding:10px 22px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;transition:transform .2s var(--ease-spring),box-shadow .2s ease}.nav-next:hover:not(:disabled),.nav-prev:hover:not(:disabled){box-shadow:0 8px 22px #3b82f68c;transform:translateY(-2px)}.nav-next:active:not(:disabled),.nav-prev:active:not(:disabled){transform:scale(.97)}.nav-next:disabled,.nav-prev:disabled{background:#ffffff14;background:var(--border);box-shadow:none;color:#64748b;color:var(--text-muted);cursor:not-allowed}[data-theme=light] .nav-next:disabled,[data-theme=light] .nav-prev:disabled{background:#e2e8f0;color:#a0aec0}.nav-count{color:#64748b;color:var(--text-muted);font-size:12.5px;font-weight:600}.sql-blocks{display:flex;flex-direction:column;gap:22px}.b-label{align-items:center;color:#e8eaf6;display:flex;gap:6px;margin-bottom:10px}.b-points ul{gap:8px}.b-points li{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;color:#94a3b8;color:var(--text-sub);gap:10px;padding:10px 14px;transition:border-color .2s,background .2s}.b-points li:hover{background:#3b82f61a;background:var(--blue-bg);border-color:#3b82f640;border-color:var(--blue-border)}.b-chk{color:#3b82f6;color:var(--blue);flex-shrink:0;font-size:14px;margin-top:1px}.b-card-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(165px,1fr))}.b-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;overflow:hidden;position:relative;transition:border-color .2s,transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;transition:border-color .2s,transform .25s var(--ease-spring),box-shadow .2s}.b-card:before{background:linear-gradient(90deg,#3b82f6,#0000);background:linear-gradient(90deg,var(--blue),#0000);content:"";height:2px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s}.b-card:hover{border-color:#3b82f640;border-color:var(--blue-border);box-shadow:0 8px 24px #3b82f626;transform:translateY(-3px)}.b-card:hover:before{opacity:1}.b-card-emoji{margin-bottom:9px}.b-card h4{color:#e8eaf6}.b-card p{line-height:1.6}.b-code-wrap{border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000008c;box-shadow:var(--shadow-md);overflow:hidden}.b-code-header{background:#161b22;background:var(--code-surface);border-bottom:1px solid #ffffff0d;padding:9px 14px}.b-code-dot{border-radius:50%;height:11px;width:11px}.b-code-dot:first-child{background:#ff5f57;box-shadow:0 0 4px #ff5f5780}.b-code-dot:nth-child(2){background:#febc2e;box-shadow:0 0 4px #febc2e80}.b-code-dot:nth-child(3){background:#28c840;box-shadow:0 0 4px #28c84080}.b-code-lang{font-size:10.5px;font-weight:600;letter-spacing:1.5px}.b-code,.b-code-lang{font-family:JetBrains Mono,Fira Code,Courier New,monospace}.b-code{background:#0d1117;color:#e6edf3;font-size:13.5px;padding:18px 20px;tab-size:2}.b-code::-webkit-scrollbar-track{background:#0d1117;background:var(--code-bg)}.b-code::-webkit-scrollbar-thumb{background:#3b82f64d}.b-code .kw{color:#79c0ff;color:var(--code-kw);font-weight:600}.b-code .str{color:#a5f3a0;color:var(--code-str)}.b-code .cmt{color:#8b949e;color:var(--code-cmt);font-style:italic}.b-code .fn{color:#ffa657;color:var(--code-fn)}.b-code .num{color:#f47067;color:var(--code-num)}.b-twocol{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.b-tcol{background:#ffffff0a;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);overflow:hidden;padding:18px;position:relative;transition:border-color .2s,transform .2s cubic-bezier(.34,1.56,.64,1);transition:border-color .2s,transform .2s var(--ease-spring)}.b-tcol:before{background:linear-gradient(90deg,#3b82f6,#0000);background:linear-gradient(90deg,var(--blue),#0000);bottom:0;content:"";height:2px;left:0;opacity:0;position:absolute;right:0;transition:opacity .2s}.b-tcol:hover{border-color:#3b82f640;border-color:var(--blue-border);transform:translateY(-2px)}.b-tcol:hover:before{opacity:1}.b-tcol-icon{display:block;font-size:22px;margin-bottom:10px}.b-tcol h4{color:#e8eaf6;color:var(--text);font-size:13px;font-weight:700;margin-bottom:7px}.b-tcol p{color:#64748b;color:var(--text-muted);font-size:12.5px;line-height:1.7;white-space:pre-line}.b-table-wrap{border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 2px 12px #0006;box-shadow:var(--shadow)}.b-table{border:1px solid #ffffff14;border-radius:16px;border-radius:var(--radius-lg)}.b-table th{background:#3b82f626;border-bottom:1px solid #ffffff21;border-bottom:1px solid var(--border-2);color:#e8eaf6;color:var(--text);font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-weight:700;letter-spacing:.4px;padding:10px 16px}[data-theme=light] .b-table th{background:#1e2330;border-bottom-color:#ffffff1a;color:#e2e8f0}.b-table td{border-top:1px solid #ffffff14;color:#94a3b8;color:var(--text-sub);font-size:13px;padding:9px 16px;transition:background .15s}.b-table tr:nth-child(2n) td{background:#ffffff0a;background:var(--surface)}.b-table tr:hover td{background:#3b82f61a;background:var(--blue-bg);color:#e8eaf6;color:var(--text)}.b-steps li{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;color:#94a3b8;color:var(--text-sub);gap:12px;padding:10px 14px;transition:border-color .2s,background .2s}.b-steps li:hover{background:#3b82f61a;background:var(--blue-bg);border-color:#3b82f640;border-color:var(--blue-border)}.b-step-num{align-items:center;background:linear-gradient(135deg,#3b82f6,#6366f1);background:linear-gradient(135deg,var(--blue),#6366f1);border-radius:50%;box-shadow:0 2px 8px #3b82f666;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:24px;justify-content:center;width:24px}.b-tip{background:#fbbf2412;border:1px solid #fbbf2440;border-radius:10px;color:#fcd34d;line-height:1.7;padding:13px 16px}[data-theme=light] .b-tip{background:#fffbeb;border-color:#fcd34d;color:#78350f}.b-tip-icon{flex-shrink:0;font-size:16px;margin-top:2px}.b-hierarchy{background:#0d1117;background:var(--code-bg);border:1px solid #ffffff21;border:1px solid var(--border-2);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000008c;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:5px;padding:18px 20px}.b-hier-item{color:#e6edf3;color:var(--code-text);font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-family:var(--mono);font-size:13.5px;line-height:1.65;white-space:pre}.sql-ads{display:flex;flex-direction:column;flex-shrink:0;gap:16px;padding:16px 10px;position:relative;width:196px;width:var(--ads-w);z-index:1}.ad-lbl{color:#64748b;color:var(--text-muted);display:block;font-size:10px;font-weight:600;letter-spacing:.6px;margin-bottom:5px;text-align:center;text-transform:uppercase}.ad-box{align-items:center;background:#ffffff0a;background:var(--surface);border:1.5px dashed #ffffff21;border:1.5px dashed var(--border-2);border-radius:10px;display:flex;flex-direction:column;gap:6px;justify-content:center;min-height:180px;padding:20px 10px;transition:border-color .2s,background .2s}.ad-box:hover{background:#3b82f61a;background:var(--blue-bg);border-color:#3b82f640;border-color:var(--blue-border)}.ad-icon{font-size:22px;opacity:.35}.ad-box p{color:#64748b;color:var(--text-muted);font-size:13px;font-weight:700}.ad-sz{color:#ffffff21;color:var(--border-2);font-size:10px}.ad-tall{min-height:300px}.ad-sticky-unit{position:sticky;top:56px}@media (max-width:1200px){.sql-ads{display:none}}@media (max-width:700px){.sql-page{flex-direction:column}.sql-page:after{display:none}.sql-sidebar{box-shadow:0 4px 16px #0003;height:auto;max-height:240px;position:relative;width:100%!important}.sql-main{max-height:none}.sql-article{padding:16px 16px 36px}.art-header{flex-direction:column;gap:8px}.art-topic-icon{font-size:26px}.art-header h1{font-size:19px}.b-twocol{grid-template-columns:1fr}.b-card-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.b-card-grid{grid-template-columns:1fr}.b-code{font-size:12.5px}.sql-article{padding:14px 12px 32px}}.b-code .sql-kw{color:#79c0ff;font-weight:700}.b-code .sql-str{color:#a5f3a0}.b-code .sql-num{color:#f47067}.b-code .sql-cmt{color:#8b949e;font-style:italic}.b-copy-btn{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;color:#64748b;cursor:pointer;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.02em;margin-left:8px;padding:3px 10px;transition:color .18s,background .18s,border-color .18s;white-space:nowrap}.b-copy-btn:hover{background:#3b82f626;border-color:#3b82f64d;color:#e2e8f0}.b-copy-btn.copied{background:#4ade801a;border-color:#4ade804d;color:#4ade80}[data-theme=light] .b-copy-btn{background:#0000000d;border-color:#0000001a;color:#64748b}[data-theme=light] .b-copy-btn:hover{background:#3b82f614;border-color:#3b82f640;color:#0f172a}:root{--yellow:#f7c948;--yellow-dark:#d4a017;--yellow-light:#fefce8;--yellow-pale:#fffdf0;--blue-py:#3776ab;--blue-py-lt:#e8f0fa;--sidebar-w:264px;--ads-w:196px;--bg:#f5f7fa;--surface:#fff;--text:#1a202c;--text-muted:#64748b;--code-bg:#1e2433;--code-text:#e2e8f0;--code-keyword:#f7c948;--code-string:#86efac;--code-comment:#64748b;--radius:8px;--shadow:0 1px 3px #00000012;--font:"Inter",-apple-system,sans-serif;--mono:"Fira Code","Courier New",monospace}body{color:#1a202c;color:var(--text)}.py-page,body{background:#f5f7fa;background:var(--bg);font-family:Inter,-apple-system,sans-serif;font-family:var(--font)}.py-page{display:flex;min-height:100vh}.py-sidebar{background:#fff;background:var(--surface);border-right:1px solid #e2e8f0;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;position:sticky;top:0;width:264px;width:var(--sidebar-w);z-index:50}.py-sidebar::-webkit-scrollbar{width:4px}.py-sidebar::-webkit-scrollbar-track{background:#0000}.py-sidebar::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}.py-sb-head{background:#fffdf0;background:var(--yellow-pale);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 16px 12px}.py-sb-brand{align-items:center;display:flex;gap:10px;margin-bottom:12px}.py-sb-logo{font-size:28px}.py-sb-title{color:#1a202c;color:var(--text);font-size:13.5px;font-weight:700}.py-sb-sub{color:#64748b;color:var(--text-muted);font-size:11px;margin-top:1px}.py-progress-bar{background:#fde68a;border-radius:5px;height:5px;margin-bottom:5px;overflow:hidden}.py-progress-fill{background:linear-gradient(90deg,#f7c948,#3776ab);background:linear-gradient(90deg,var(--yellow),var(--blue-py));border-radius:5px;height:100%;transition:width .4s ease}.py-progress-label{color:#92400e;font-size:10.5px;font-weight:600}.py-sb-nav{flex:1 1;overflow-y:auto;padding:6px 0 24px}.py-topic-group{border-bottom:1px solid #f1f5f9}.py-topic-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);gap:8px;padding:9px 14px;text-align:left;transition:background .15s,border-color .15s;width:100%}.py-topic-btn:hover{background:#fafaf7}.py-topic-btn.py-topic-active{background:#fefce8;background:var(--yellow-light);border-left-color:#d4a017;border-left-color:var(--yellow-dark)}.py-t-icon{flex-shrink:0;font-size:14px}.py-t-label{color:#1a202c;color:var(--text);flex:1 1;font-size:12.5px;font-weight:600;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.py-topic-btn.py-topic-active .py-t-label{color:#92400e}.py-t-arrow{color:#a0aec0;flex-shrink:0;font-size:15px;transition:transform .2s}.py-t-arrow.open{transform:rotate(90deg)}.py-sub-list{padding:2px 0 6px}.py-sub-btn{align-items:center;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);gap:8px;padding:6px 14px 6px 26px;text-align:left;transition:background .12s;width:100%}.py-sub-btn:hover{background:#fafaf7}.py-sub-btn.py-sub-active{background:#fefce8;background:var(--yellow-light);border-left-color:#f7c948;border-left-color:var(--yellow)}.py-sub-dot{background:#e2e8f0;border-radius:50%;flex-shrink:0;height:6px;width:6px}.py-sub-dot.dot-on{background:#d4a017;background:var(--yellow-dark)}.py-sub-label{color:#4a5568;flex:1 1;font-size:12px;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.py-sub-btn.py-sub-active .py-sub-label{color:#92400e;font-weight:600}.py-sub-dur{color:#a0aec0;flex-shrink:0;font-size:10px}.py-main{flex:1 1;max-height:100vh;min-width:0;overflow-y:auto}.py-breadcrumb{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-muted);display:flex;font-size:12px;gap:6px;padding:11px 28px;position:sticky;top:0;z-index:10}.py-bc-sep{color:#e2e8f0}.py-bc-cur{color:#1a202c;color:var(--text);font-weight:500}.py-breadcrumb span:not(.py-bc-sep):not(.py-bc-cur){color:#3776ab;color:var(--blue-py);cursor:pointer}.py-article{max-width:840px;padding:26px 28px 44px}.py-art-header{align-items:flex-start;border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border);display:flex;gap:14px;margin-bottom:18px;padding-bottom:18px}.py-art-icon{flex-shrink:0;font-size:32px;margin-top:2px}.py-art-header h1{color:#1a202c;color:var(--text);font-size:21px;font-weight:700;line-height:1.3;margin-bottom:8px}.py-art-meta{color:#64748b;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:12px;gap:10px}.py-art-tag{background:#fefce8;background:var(--yellow-light);border:1px solid #fde68a;border-radius:20px;color:#92400e;font-size:11px;font-weight:600;padding:2px 10px}.py-intro{background:#e8f0fa;background:var(--blue-py-lt);border-left:4px solid #3776ab;border-left:4px solid var(--blue-py);border-radius:0 8px 8px 0;border-radius:0 var(--radius) var(--radius) 0;margin-bottom:22px;padding:14px 18px}.py-intro p{color:#1e3a5f;font-size:14.5px;line-height:1.8}.py-art-nav{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:36px;padding-top:20px}.py-nav-btn{border:none;border-radius:8px;cursor:pointer;font-family:Inter,-apple-system,sans-serif;font-family:var(--font);font-size:13px;font-weight:700;padding:10px 22px;transition:all .18s}.py-nav-prev{background:#f1f5f9;color:#64748b;color:var(--text-muted)}.py-nav-prev:hover:not(:disabled){background:#e2e8f0;color:#1a202c;color:var(--text)}.py-nav-next{background:#3776ab;background:var(--blue-py);box-shadow:0 2px 8px #3776ab4d;color:#fff}.py-nav-next:hover:not(:disabled){background:#2c5f8a;transform:translateY(-1px)}.py-nav-btn:disabled{background:#e2e8f0;box-shadow:none;color:#a0aec0;cursor:not-allowed;transform:none}.py-nav-count{color:#64748b;color:var(--text-muted);font-size:12.5px;font-weight:500}.py-blocks{display:flex;flex-direction:column;gap:20px}.b-label{color:#1a202c;color:var(--text);font-size:13px;font-weight:600;margin-bottom:9px}.b-points ul{display:flex;flex-direction:column;gap:7px;list-style:none}.b-points li{align-items:flex-start;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:7px;color:#2d3748;display:flex;font-size:13.5px;gap:9px;line-height:1.65;padding:8px 12px;transition:border-color .15s}.b-points li:hover{border-color:#f7c948;border-color:var(--yellow)}.b-arrow{color:#3776ab;color:var(--blue-py);flex-shrink:0;font-size:13px;margin-top:1px}.b-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.b-card{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);padding:16px 14px;transition:border-color .2s,transform .2s,box-shadow .2s}.b-card:hover{border-color:#d4a017;border-color:var(--yellow-dark);box-shadow:0 4px 16px #f7c94826;transform:translateY(-2px)}.b-card-emoji{display:block;font-size:24px;margin-bottom:8px}.b-card h4{color:#1a202c;color:var(--text);font-size:12.5px;font-weight:700;margin-bottom:5px}.b-card p{color:#64748b;color:var(--text-muted);font-size:12px;line-height:1.65}.b-code-header{align-items:center;background:#161b27;border-radius:8px 8px 0 0;border-radius:var(--radius) var(--radius) 0 0;display:flex;gap:6px;padding:8px 14px}.dot{border-radius:50%;height:10px;width:10px}.d1{background:#ef4444}.d2{background:#f59e0b}.d3{background:#22c55e}.b-code-lang{color:#64748b;font-size:10px;letter-spacing:1px;margin-left:auto;text-transform:uppercase}.b-code,.b-code-lang{font-family:Fira Code,Courier New,monospace;font-family:var(--mono)}.b-code{background:#1e2433;background:var(--code-bg);border-radius:0 0 8px 8px;border-radius:0 0 var(--radius) var(--radius);color:#e2e8f0;color:var(--code-text);font-size:13px;line-height:1.75;overflow-x:auto;padding:16px 18px;white-space:pre}.b-code::-webkit-scrollbar{height:4px}.b-code::-webkit-scrollbar-track{background:#161b27}.b-code::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.b-table-wrap{overflow-x:auto}.b-table{border:1px solid #e2e8f0;border:1px solid var(--border);border-collapse:collapse;border-radius:8px;border-radius:var(--radius);font-size:13px;overflow:hidden;width:100%}.b-table th{background:#1e2433;color:#e2e8f0;font-family:Fira Code,Courier New,monospace;font-family:var(--mono);font-size:12px;font-weight:600;padding:9px 14px;text-align:left}.b-table td{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);color:#2d3748;padding:8px 14px}.b-table tr:nth-child(2n) td{background:#fafbfc}.b-table tr:hover td{background:#fffdf0;background:var(--yellow-pale)}.b-steps ol{display:flex;flex-direction:column;gap:8px;list-style:none}.b-steps li{align-items:flex-start;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:7px;color:#2d3748;display:flex;font-size:13.5px;gap:11px;line-height:1.65;padding:9px 12px}.step-n{align-items:center;background:#3776ab;background:var(--blue-py);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:22px}.b-tip{align-items:flex-start;background:#fffdf0;background:var(--yellow-pale);border:1px solid #fde68a;border-radius:8px;border-radius:var(--radius);color:#78350f;display:flex;font-size:13.5px;gap:10px;line-height:1.75;padding:12px 16px}.tip-bulb{flex-shrink:0;font-size:17px;margin-top:1px}.py-ads{display:flex;flex-direction:column;flex-shrink:0;gap:16px;padding:16px 10px;width:196px;width:var(--ads-w)}.py-ad-label{color:#a0aec0;display:block;font-size:10px;letter-spacing:.5px;margin-bottom:5px;text-align:center;text-transform:uppercase}.py-ad-box{align-items:center;background:#fafbfc;border:2px dashed #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:6px;justify-content:center;min-height:180px;padding:20px 10px;transition:border-color .2s}.py-ad-box:hover{border-color:#f7c948;border-color:var(--yellow)}.py-ad-icon{font-size:22px;opacity:.35}.py-ad-box p{color:#b0bec5;font-size:14px;font-weight:700}.py-ad-size{color:#cbd5e0;font-size:10px}.py-ad-tall{min-height:300px}.py-ad-sticky{position:sticky;top:50px}@media (max-width:1200px){.py-ads{display:none}}@media (max-width:860px){:root{--sidebar-w:220px}}@media (max-width:700px){.py-page{flex-direction:column}.py-sidebar{height:auto;max-height:250px;position:relative;width:100%!important}.py-main{max-height:none}.py-article{padding:16px 14px 32px}.py-art-header{flex-direction:column;gap:8px}.py-art-icon{font-size:24px}.py-art-header h1{font-size:18px}.b-cards{grid-template-columns:1fr 1fr}.b-code{font-size:12px}}@media (max-width:480px){.b-cards{grid-template-columns:1fr}.py-art-meta{gap:6px}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--primary-dark:#4338ca;--secondary:#06b6d4;--bg-light:#fff;--bg-dark:#0f172a;--text-light:#0f172a;--text-dark:#f8fafc;--border:#e2e8f0;--radius:10px;--transition:all 0.3s ease}body{background:#fff;background:var(--bg-light);color:#0f172a;color:var(--text-light);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:.3px;line-height:1.6;transition:all .3s ease;transition:var(--transition)}body.dark{background:#0f172a;background:var(--bg-dark);color:#f8fafc;color:var(--text-dark)}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer;font-family:inherit;outline:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#4f46e5;background:var(--primary);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#4338ca;background:var(--primary-dark)}.container{margin:auto;max-width:1200px;padding:0 20px}.flex{align-items:center;display:flex}.grid{grid-gap:20px;display:grid;gap:20px}.shadow{box-shadow:0 10px 25px #0000000d}.card{background:#fff;border-radius:10px;border-radius:var(--radius);padding:20px;transition:all .3s ease;transition:var(--transition)}body.dark .card{background:#1e293b}.hover-lift:hover{transform:translateY(-5px)}h1,h2,h3,h4{font-weight:600}*{transition:all .3s ease;transition:var(--transition)}
/*# sourceMappingURL=main.d8a1d113.css.map*/