margin: 0; padding: 0; box-sizing: border-box; } :root{color-scheme:light dark}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background-color .3s ease,color .3s ease}body.light-mode{--bg: #ffffff;--bg-alt: #f9fafb;--sidebar: #f9fafb;--text: #111827;--text-sec: #6b7280;--text-ter: #9ca3af;--text-ghost: #d1d5db;--border: #e5e7eb;--border-light: #f3f4f6;--card: #ffffff;--card-hover: #f9fafb;--accent: #10b981;--accent-soft: rgba(16,185,129,.08);--accent-text: #059669;--nav-bg: rgba(255,255,255,.88);--shadow: rgba(0,0,0,.04);--orange: #f59e0b;--blue: #3b82f6;--purple: #8b5cf6;--cyan: #06b6d4}body.dark-mode{--bg: #0f1117;--bg-alt: #161821;--sidebar: #12141b;--text: #e5e7eb;--text-sec: #9ca3af;--text-ter: #6b7280;--text-ghost: #374151;--border: #1e2130;--border-light: #1e2130;--card: #161821;--card-hover: #1c1f2a;--accent: #34d399;--accent-soft: rgba(52,211,153,.1);--accent-text: #34d399;--nav-bg: rgba(15,17,23,.88);--shadow: rgba(0,0,0,.25);--orange: #f59e0b;--blue: #3b82f6;--purple: #8b5cf6;--cyan: #06b6d4}body{background-color:var(--bg);color:var(--text)}h1,h2,h3,h4,h5,h6{font-family:Inter,sans-serif;font-weight:700;line-height:1.2}.serif{font-family:Newsreader,serif}.mono{font-family:JetBrains Mono,monospace}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .6s ease-out}.skip-nav{position:absolute;top:-100px;left:16px;background:var(--accent-text);color:#fff;padding:8px 16px;border-radius:4px;z-index:10000;text-decoration:none;font-weight:600}.skip-nav:focus{top:8px}nav{position:fixed;top:0;left:0;right:0;height:64px;background:var(--nav-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:0 24px;z-index:1000;box-shadow:0 2px 8px var(--shadow);box-sizing:border-box}.nav-container{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1400px;height:100%}.nav-left{display:flex;align-items:center;gap:32px}.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);cursor:pointer;transition:opacity .2s}.logo:hover{opacity:.8}.logo-icon{width:32px;height:32px;border-radius:6px;overflow:hidden}.logo-icon img{width:100%;height:100%;object-fit:cover}.logo-text{font-weight:700;font-size:16px;letter-spacing:-.5px}.nav-center{display:flex;align-items:center;gap:24px}.nav-link{color:var(--text-sec);text-decoration:none;font-size:clamp(12px,1.5vw,14px);font-weight:500;cursor:pointer;transition:color .2s;position:relative;min-height:44px;display:flex;align-items:center}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--accent)}.dropdown-wrapper,.dropdown-trigger{position:relative}.dropdown-menu{position:absolute;top:100%;left:0;padding-top:8px;min-width:280px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s;z-index:1001;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 25px var(--shadow);overflow:hidden}.dropdown-menu-inner{background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 25px var(--shadow);overflow:hidden}.dropdown-wrapper:hover .dropdown-menu,.dropdown-trigger:hover .dropdown-menu,.dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{padding:12px 16px;color:var(--text);text-decoration:none;display:block;cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-light)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:var(--card-hover)}.dropdown-item-title{font-weight:600;font-size:14px;color:var(--text)}.dropdown-item-desc{font-size:12px;color:var(--text-ter);margin-top:4px}.nav-right{display:flex;align-items:center;gap:16px}.theme-toggle{width:40px;height:40px;border:1px solid var(--border);border-radius:6px;background:var(--bg-alt);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-sec);transition:all .2s}.theme-toggle:hover{background:var(--card-hover);color:var(--text)}.cta-button{padding:10px 20px;background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s,box-shadow .2s}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #10b9814d}main{margin-top:64px;min-height:calc(100vh - 64px)}.container{max-width:1600px;margin:0 auto;padding:0 clamp(16px,4vw,60px)}.page-content{padding:64px 0}.hero{text-align:center;padding:clamp(80px,12vw,120px) clamp(16px,4vw,40px) clamp(40px,6vw,60px)}.hero-badge{display:inline-block;background:var(--accent-soft);color:var(--accent-text);padding:8px 16px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:24px;border:1px solid rgba(52,211,153,.2)}.hero h1{font-family:Newsreader,serif;font-size:clamp(28px,6vw,56px);font-weight:700;line-height:1.2;margin-bottom:16px;color:var(--text)}.hero p{font-size:clamp(16px,2vw,20px);color:var(--text-sec);margin-bottom:40px;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.hero-buttons{display:flex;gap:16px;justify-content:center;margin-bottom:80px}.btn{padding:12px 28px;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 16px #10b9814d}.btn-secondary{background:var(--bg-alt);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--card-hover)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}.stat{padding:24px}.stat-number{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--accent);margin-bottom:8px}.stat-label{font-size:14px;color:var(--text-sec)}.courses-section{padding:clamp(40px,8vw,60px) clamp(16px,4vw,40px);background:var(--bg-alt)}.section-title{text-align:center;font-size:clamp(24px,4vw,36px);font-weight:700;margin-bottom:60px;color:var(--text)}.section{padding:clamp(40px,6vw,80px) clamp(24px,5vw,60px);max-width:1400px;margin:0 auto}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:clamp(20px,3vw,28px);transition:border-color .2s,box-shadow .2s,transform .2s;display:block}.card:hover{border-color:var(--accent);box-shadow:0 8px 24px var(--shadow);transform:translateY(-2px)}.card-tag{display:inline-block;padding:4px 10px;background:var(--accent-soft);color:var(--accent);border-radius:4px;font-size:11px;font-weight:600}.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,3vw,24px);margin:0 auto}.course-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:clamp(20px,3vw,28px);transition:all .3s;cursor:pointer}.course-card:hover{border-color:var(--accent);box-shadow:0 12px 24px var(--shadow);transform:translateY(-4px)}.course-badge{display:inline-block;padding:6px 12px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:16px}.badge-emerald{background:#10b9811a;color:var(--accent)}.badge-blue{background:#3b82f61a;color:var(--blue)}.badge-orange{background:#f59e0b1a;color:var(--orange)}.course-card h3{font-size:24px;margin-bottom:12px;color:var(--text)}.course-card p{color:var(--text-sec);line-height:1.6;margin-bottom:24px;font-size:14px}.course-meta{display:flex;gap:24px;padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:24px;font-size:13px;color:var(--text-ter)}.course-meta-item{display:flex;align-items:center;gap:6px}.course-button{background:var(--bg-alt);color:var(--text);border:1px solid var(--border);padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:14px}.course-button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.course-button-link{display:inline-block;padding:10px 16px;background:transparent;color:var(--accent-text);border:1px solid var(--accent-text);border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;text-align:center}.course-button-link:hover{background:var(--accent-soft)}.frameworks-section{padding:clamp(40px,8vw,60px) clamp(16px,4vw,40px)}.framework-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,3vw,24px)}.framework-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:clamp(20px,3vw,28px);transition:all .2s}.framework-card:hover{border-color:var(--accent);box-shadow:0 8px 16px var(--shadow)}.framework-name{font-weight:700;font-size:16px;color:var(--text);margin-bottom:8px}.framework-desc{font-size:14px;color:var(--text-sec);line-height:1.5}.community-section{padding:clamp(40px,8vw,60px) clamp(16px,4vw,40px);background:var(--bg-alt);text-align:center}.community-heading{font-family:Newsreader,serif;font-size:36px;margin-bottom:40px}.social-links{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}.social-link{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);text-decoration:none;transition:all .2s;font-weight:500}.social-link:hover{border-color:var(--accent-text);color:var(--accent-text)}.course-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;padding:40px;max-width:1600px;margin:0 auto;transition:grid-template-columns .3s ease,padding .3s ease}.course-sidebar{background:var(--sidebar);border:1px solid var(--border);border-radius:8px;padding:24px;height:fit-content;position:sticky;top:80px;transition:all .3s ease}.sidebar-header{font-weight:700;font-size:16px;margin-bottom:16px;color:var(--text)}.progress-bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:24px}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.sidebar-item{padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:all .2s;min-height:44px;display:flex;align-items:center}.sidebar-item:last-child{border-bottom:none}.sidebar-item:hover{color:var(--accent)}.sidebar-item.active{color:var(--accent);font-weight:600}.sidebar-item-title{font-size:13px;font-weight:500;color:var(--text)}.sidebar-item.active .sidebar-item-title{color:var(--accent)}.sidebar-item-time{font-size:12px;color:var(--text-ter);margin-top:4px}.sidebar-module{border-bottom:1px solid var(--border)}.sidebar-module:last-child{border-bottom:none}.sidebar-module .sidebar-item{border-bottom:none}.sidebar-toc{position:static;top:auto;left:auto;right:auto;height:auto;background:none;backdrop-filter:none;border-bottom:none;justify-content:flex-start;display:flex;flex-direction:column;gap:0;padding:0 0 8px;margin:0;border-left:none;z-index:auto;box-shadow:none;box-sizing:border-box}.sidebar-toc-item{font-size:11px;color:var(--text-ter);text-decoration:none;padding:4px 0 4px 16px;line-height:1.4;transition:color .15s;border-left:2px solid var(--border);margin:0;opacity:.8}.sidebar-toc-item:not(.sidebar-toc-sub)+.sidebar-toc-item:not(.sidebar-toc-sub){margin-top:2px;padding-top:6px;border-top:1px solid var(--border-light)}.sidebar-toc-sub+.sidebar-toc-item:not(.sidebar-toc-sub){margin-top:2px;padding-top:6px;border-top:1px solid var(--border-light)}.sidebar-toc-item:hover{color:var(--accent);opacity:1;border-left-color:var(--accent)}.sidebar-toc-sub{padding-left:28px;font-size:10px;opacity:.6;border-left-color:transparent}.sidebar-phase-group{margin-bottom:4px}.sidebar-phase-group:last-child{margin-bottom:0}.sidebar-phase-label{display:flex;align-items:center;gap:8px;padding:8px 16px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-ter);margin-top:8px}.sidebar-phase-group:first-child .sidebar-phase-label{margin-top:0}.sidebar-phase-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.sidebar-phase-1 .sidebar-phase-dot{background:#3b82f6}.sidebar-phase-1{color:#3b82f6}.sidebar-phase-2 .sidebar-phase-dot{background:#f59e0b}.sidebar-phase-2{color:#f59e0b}.sidebar-phase-3 .sidebar-phase-dot{background:#10b981}.sidebar-phase-3{color:#10b981}.sidebar-phase-group .sidebar-module:last-child{border-bottom:none}.course-main{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:48px;min-width:0;overflow-x:hidden}.sidebar-toggle{display:none}.back-to-top{position:fixed;bottom:32px;right:32px;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--card);color:var(--text-sec);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0000001f;opacity:0;transform:translateY(16px);transition:opacity .3s ease,transform .3s ease,background .2s;pointer-events:none;z-index:100}.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.back-to-top:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.breadcrumb{display:flex;gap:8px;margin-bottom:32px;font-size:13px;color:var(--text-ter)}.breadcrumb-link{color:var(--accent);cursor:pointer;text-decoration:none}.breadcrumb-link:hover{text-decoration:underline}.module-header{margin-bottom:40px}.module-icon{font-size:32px;margin-bottom:16px}.module-title{font-size:32px;font-weight:700;margin-bottom:8px;color:var(--text)}.module-subtitle{font-size:14px;color:var(--text-sec)}.content-preview{background:var(--bg-alt);border:1px solid var(--border);border-radius:8px;padding:24px;margin:32px 0;font-family:Newsreader,serif;font-size:16px;line-height:1.8;color:var(--text)}.section-box{margin:32px 0}.section-box h4{font-size:16px;margin-bottom:16px;color:var(--text)}.checklist{display:grid;grid-template-columns:1fr 1fr;gap:12px}.checklist-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-alt);border-radius:6px;font-size:13px;color:var(--text-sec)}.checklist-icon{color:var(--accent);font-weight:700;flex-shrink:0}.milestone-box{background:var(--accent-soft);border:1px solid var(--accent);border-radius:8px;padding:24px;margin:32px 0;font-size:14px;color:var(--text);line-height:1.6}.milestone-label{font-weight:600;color:var(--accent);margin-bottom:8px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.module-navigation{display:flex;justify-content:space-between;gap:16px;margin-top:40px;padding-top:24px;border-top:1px solid var(--border)}.nav-login-link{background:none;border:none;color:var(--text-sec);font-size:13px;font-weight:500;cursor:pointer;padding:8px 4px;transition:color .2s;font-family:inherit}.nav-login-link:hover{color:var(--text)}.nav-signup-btn{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}.nav-signup-btn:hover{background:var(--accent-text)!important;border-color:var(--accent-text)!important}.nav-button{padding:12px 20px;border:1px solid var(--border);background:var(--bg-alt);color:var(--text);border-radius:6px;cursor:pointer;font-weight:600;font-size:13px;transition:all .2s}.nav-button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.nav-button:disabled{opacity:.5;cursor:not-allowed}.mark-complete-button{padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:13px;transition:all .2s}.mark-complete-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,32px)}.blog-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:clamp(20px,3vw,28px);cursor:pointer;transition:all .2s}.blog-card:hover{border-color:var(--accent);box-shadow:0 8px 16px var(--shadow);transform:translateY(-4px)}.blog-tag{display:inline-block;padding:4px 10px;background:var(--accent-soft);color:var(--accent);border-radius:4px;font-size:11px;font-weight:600;margin-bottom:12px}.blog-card h3{font-size:20px;margin-bottom:12px;color:var(--text)}.blog-subtitle{font-size:13px;color:var(--text-ter);margin-bottom:16px;font-style:italic}.blog-meta{display:flex;gap:16px;font-size:12px;color:var(--text-ter);margin-top:16px}.blog-read-link{color:var(--accent);text-decoration:none;font-weight:600;margin-top:16px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.blog-read-link:hover{gap:10px}.resources-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,3vw,24px)}.resource-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:clamp(20px,3vw,28px);transition:all .2s}.resource-card:hover{border-color:var(--accent);box-shadow:0 8px 16px var(--shadow)}.resource-icon{font-size:24px;margin-bottom:12px}.resource-card h3{font-size:16px;margin-bottom:8px;color:var(--text)}.resource-card p{font-size:13px;color:var(--text-sec);line-height:1.5;margin-bottom:16px}.resource-type{display:inline-block;padding:4px 10px;background:var(--bg-alt);color:var(--text-ter);border-radius:4px;font-size:11px;font-weight:600}.podcast-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,3vw,24px)}.episode-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:clamp(20px,3vw,28px);transition:all .2s}.episode-card:hover{border-color:var(--accent);box-shadow:0 8px 16px var(--shadow)}.episode-number{display:inline-block;width:40px;height:40px;background:var(--accent-soft);color:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:12px}.episode-card h3{font-size:16px;margin-bottom:8px;color:var(--text)}.episode-meta{display:flex;gap:16px;font-size:12px;color:var(--text-ter);margin-bottom:12px}.play-button{width:48px;height:48px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s}.play-button:hover{transform:scale(1.1);box-shadow:0 4px 12px #10b9814d}footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:60px 40px 40px;margin-top:80px}.footer-content{max-width:1600px;margin:0 auto}.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid var(--border)}.footer-column h3{font-size:14px;font-weight:700;margin-bottom:16px;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.footer-column p{font-size:13px;color:var(--text-sec);line-height:1.6;margin-bottom:12px}.footer-link{display:block;font-size:13px;color:var(--text-sec);text-decoration:none;margin-bottom:12px;transition:color .2s;cursor:pointer;background:none;border:none;padding:0}.footer-link:hover{color:var(--accent)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-ter)}.accordion{background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.accordion-item{border-bottom:1px solid var(--border)}.accordion-item:last-child{border-bottom:none}.accordion-header{padding:20px;background:var(--bg-alt);cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--text);min-height:48px}.accordion-header:hover{background:var(--card-hover)}.accordion-icon{color:var(--accent);transition:transform .2s}.accordion-icon.open{transform:rotate(180deg)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.accordion-content.open{max-height:1000px}.accordion-body{padding:20px;color:var(--text-sec);line-height:1.6;font-size:14px}.accordion-body ol{margin-left:20px;margin-top:12px}.accordion-body li{margin-bottom:8px}.library-section{padding:40px 0}.library-part{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:32px;margin-bottom:24px;cursor:pointer;transition:all .2s}.library-part:hover{border-color:var(--accent);box-shadow:0 8px 16px var(--shadow)}.library-part h3{font-size:18px;margin-bottom:8px;color:var(--text)}.library-part p{font-size:14px;color:var(--text-sec);margin-bottom:16px}.library-chapters{display:flex;flex-wrap:wrap;gap:12px}.chapter-tag{display:inline-block;background:var(--accent-soft);color:var(--accent);padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500}.hamburger-btn{display:none;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;cursor:pointer;padding:0;z-index:1001}.hamburger-line{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s ease;position:relative}.hamburger-line:before,.hamburger-line:after{content:"";display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s ease;position:absolute;left:0}.hamburger-line:before{top:-7px}.hamburger-line:after{top:7px}.hamburger-btn.open .hamburger-line{background:transparent}.hamburger-btn.open .hamburger-line:before{top:0;transform:rotate(45deg)}.hamburger-btn.open .hamburger-line:after{top:0;transform:rotate(-45deg)}.hamburger{display:none;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;cursor:pointer;padding:0;z-index:1001;flex-direction:column;gap:5px}.hamburger .hamburger-line{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s ease;transform-origin:center}.hamburger .hamburger-line.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger .hamburger-line.open:nth-child(2){opacity:0}.hamburger .hamburger-line.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-overlay,.mobile-menu-panel{display:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-link{display:flex;align-items:center;padding:16px;font-size:16px;font-weight:500;color:var(--text);border:none;background:none;cursor:pointer;border-bottom:1px solid var(--border);text-align:left;width:100%;min-height:48px;transition:color .2s}.mobile-menu-link:hover,.mobile-menu-link.active{color:var(--accent-text)}.mobile-menu-cta{margin-top:20px;padding:14px 20px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;text-align:center;min-height:48px}@media(min-width:1200px){.framework-grid,.resources-grid,.podcast-grid,.blog-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.course-grid,.stats{grid-template-columns:repeat(2,1fr)}.course-layout{grid-template-columns:250px 1fr}}@media(max-width:768px){.hamburger-btn,.hamburger{display:flex}.nav-center{display:none!important}.nav-right>.nav-button{display:none!important}.nav-right>.nav-login-link{display:none!important}.nav-right>.user-menu-wrapper{display:none!important}.logo-text{display:none}.nav-right{gap:8px}.mobile-menu-overlay{display:block;position:fixed;inset:64px 0 0;background:#0000004d;z-index:9998}.mobile-menu-panel{display:none;position:fixed;inset:64px 0 0;background:var(--bg);z-index:9999;flex-direction:column;padding:20px;overflow-y:auto;animation:slideDown .25s ease}.mobile-menu-panel.open{display:flex}.mobile-menu-panel .nav-link{font-size:16px;padding:12px 0;border-bottom:1px solid var(--border);width:100%}.mobile-menu-panel .dropdown-wrapper{width:100%}.mobile-menu-panel .dropdown-menu.open{position:static;opacity:1;pointer-events:auto;transform:none;box-shadow:none;border:none;padding-left:16px}.mobile-auth-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}nav{padding:0 16px}.container{padding:0 16px}.hero-buttons{flex-direction:column;align-items:center;gap:12px}.hero-buttons .btn,.hero-buttons .btn-secondary{width:100%;max-width:320px;text-align:center;justify-content:center}.stats{grid-template-columns:repeat(2,1fr)}.course-grid,.framework-grid,.blog-grid,.resources-grid,.podcast-grid{grid-template-columns:1fr}.course-layout{grid-template-columns:1fr;padding:12px;gap:0}.course-main{padding:24px 16px;border-radius:0 0 8px 8px;border-top:none}.sidebar-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:var(--sidebar);border:1px solid var(--border);border-radius:8px 8px 0 0;cursor:pointer;font-size:14px;color:var(--text);text-align:left;order:-2}.sidebar-toggle-icon{font-size:16px;color:var(--text-ter)}.sidebar-toggle-label{flex:1;font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-toggle-meta{font-size:11px;color:var(--text-ter);font-family:SF Mono,Fira Code,monospace}.sidebar-toggle-arrow{font-size:14px;color:var(--text-ter);transition:transform .2s}.course-sidebar{position:static;order:-1;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease,border-width .35s ease;padding:0 24px;border-radius:0;border-top:none;border-bottom:none}.course-sidebar.mobile-open{max-height:60vh;overflow-y:auto;padding:16px 24px;border-top:none;border-bottom:1px solid var(--border)}.back-to-top{bottom:20px;right:16px;width:40px;height:40px}.section-header h2,.frameworks-section h2,.community-section h2{font-size:clamp(22px,5vw,28px)}.footer-top{grid-template-columns:1fr;gap:24px}.auth-modal,.download-gate-modal{width:95%;max-width:400px;margin:20px auto;padding:24px 20px}.profile-container{padding:24px 16px}.profile-card{flex-direction:column;text-align:center}.hub-subnav{gap:0;padding:0 8px}.hub-subnav button{font-size:11px;padding:4px 8px;white-space:nowrap}.social-links{flex-wrap:wrap;justify-content:center}.user-dropdown{right:-10px}}@media(max-width:480px){nav{padding:0 12px}.stats{grid-template-columns:1fr 1fr;gap:12px}.stat{padding:16px 8px}.btn,.btn-secondary{padding:12px 20px;font-size:14px}.course-card,.framework-card,.resource-card,.episode-card,.blog-card{padding:20px}.auth-modal{width:calc(100% - 32px);padding:20px 16px}.auth-oauth-btn{padding:10px 16px;font-size:14px}.download-gate-modal{width:calc(100% - 32px);padding:20px 16px}.footer-bottom{font-size:12px;flex-direction:column;gap:8px;text-align:center}}@media(max-width:360px){.stats{grid-template-columns:1fr}}.hub-subnav{position:fixed;top:64px;left:0;right:0;z-index:999;background:#0a0a0ff7;backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 16px;display:flex;align-items:center;gap:2px;height:44px;overflow-x:auto}.hub-subnav::-webkit-scrollbar{display:none}.hub-subnav button{color:var(--text-sec);font-size:12px;padding:5px 11px;border-radius:6px;border:none;background:none;cursor:pointer;white-space:nowrap;transition:all .18s ease;font-weight:500;font-family:inherit}.hub-subnav button:hover{color:var(--text);background:#ffffff0f}.hub-subnav button.active{color:#ff8c42;background:#e85d0424}.auth-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px;width:90%;max-width:420px;position:relative;box-shadow:0 24px 48px #0003}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-sec);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px}.auth-modal-close:hover{color:var(--text);background:var(--bg-alt)}.auth-modal h2{font-size:24px;margin-bottom:8px;color:var(--text)}.auth-modal .auth-subtitle{color:var(--text-sec);font-size:14px;margin-bottom:28px}.auth-oauth-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.auth-oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.auth-oauth-btn:hover{border-color:var(--accent);background:var(--bg-alt)}.auth-oauth-btn svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px;color:var(--text-ter);font-size:12px;text-transform:uppercase;letter-spacing:1px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form-group{margin-bottom:16px}.auth-form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-sec);margin-bottom:6px}.auth-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .2s}.auth-input:focus{outline:2px solid var(--accent);outline-offset:-2px;border-color:var(--accent)}.auth-checkbox-row{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:13px;color:var(--text-sec)}.auth-checkbox-row input[type=checkbox]{accent-color:var(--accent)}.auth-submit-btn{width:100%;padding:12px;background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.auth-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:var(--text-sec)}.auth-toggle a{color:var(--accent);cursor:pointer;text-decoration:none;font-weight:500}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}.user-nav-area{display:flex;align-items:center;gap:10px;position:relative}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#10b981,#34d399);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s;overflow:hidden}.user-avatar:hover{transform:scale(1.05)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-dropdown{position:absolute;top:44px;right:0;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:8px;min-width:180px;box-shadow:0 12px 24px var(--shadow);display:none;z-index:100}.user-dropdown.open{display:block}.user-dropdown-item{display:block;padding:10px 14px;color:var(--text);font-size:13px;border-radius:6px;cursor:pointer;transition:background .15s;border:none;background:none;width:100%;text-align:left;font-family:inherit}.user-dropdown-item:hover{background:var(--bg-alt)}.user-dropdown-item.danger{color:#ef4444}.notes-panel{margin-top:24px;border:1px solid var(--border);border-radius:10px;overflow:hidden}.notes-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--bg-alt);cursor:pointer;font-size:14px;font-weight:600;color:var(--text)}.notes-header:hover{background:var(--card-hover)}.notes-body{padding:16px 20px;display:none}.notes-body.open{display:block}.notes-textarea{width:100%;min-height:120px;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;line-height:1.6;resize:vertical;transition:border-color .2s}.notes-textarea:focus{outline:2px solid var(--accent);outline-offset:-2px;border-color:var(--accent)}.notes-status{display:flex;justify-content:flex-end;margin-top:8px;font-size:12px;color:var(--text-ter)}.notes-login-prompt{padding:20px;text-align:center;color:var(--text-sec);font-size:13px}.notes-login-prompt a{color:var(--accent);cursor:pointer;font-weight:500}.profile-container{max-width:1200px;margin:0 auto;padding:40px clamp(16px,4vw,40px)}.profile-card{display:flex;align-items:center;gap:20px;padding:32px;background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:32px}.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#10b981,#34d399);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:28px;flex-shrink:0;overflow:hidden}.profile-avatar-lg img{width:100%;height:100%;object-fit:cover}.profile-info h2{font-size:22px;margin-bottom:4px;color:var(--text)}.profile-info p{font-size:14px;color:var(--text-sec)}.progress-section{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:32px;margin-bottom:24px}.progress-section h3{font-size:18px;margin-bottom:24px;color:var(--text)}.progress-course-item{margin-bottom:20px}.progress-course-item:last-child{margin-bottom:0}.progress-course-label{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px;color:var(--text)}.progress-course-bar{height:8px;background:var(--bg-alt);border-radius:4px;overflow:hidden}.progress-course-fill{height:100%;border-radius:4px;transition:width .5s ease}.download-gate-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.download-gate-modal{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px;width:90%;max-width:440px;text-align:center;box-shadow:0 24px 48px #0003}.download-gate-modal h3{font-size:20px;margin-bottom:12px;color:var(--text)}.download-gate-modal p{font-size:14px;color:var(--text-sec);margin-bottom:24px;line-height:1.6}.download-gate-benefits{text-align:left;margin-bottom:24px}.download-gate-benefits div{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:var(--text-sec)}.download-gate-benefits span.icon{color:var(--accent);font-size:16px}
