:root{--color-bg-primary:#0a0a0f;--color-bg-secondary:#0f0f16;--color-bg-tertiary:#16161f;--color-bg-card:#12121a;--color-bg-elevated:#1a1a24;--color-bg-hover:#1e1e2a;--color-border-subtle:hsla(0,0%,100%,.06);--color-border-default:hsla(0,0%,100%,.1);--color-border-emphasis:hsla(0,0%,100%,.15);--color-border-active:rgba(99,102,241,.5);--color-text-primary:#f8fafc;--color-text-secondary:#cbd5e1;--color-text-tertiary:#64748b;--color-text-muted:#475569;--color-accent:#6366f1;--color-accent-hover:#818cf8;--color-accent-dim:rgba(99,102,241,.15);--color-accent-glow:rgba(99,102,241,.2);--color-success:#10b981;--color-success-dim:rgba(16,185,129,.15);--color-warning:#f59e0b;--color-warning-dim:rgba(245,158,11,.15);--color-error:#ef4444;--color-error-dim:rgba(239,68,68,.15);--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow-md:0 4px 6px rgba(0,0,0,.4);--shadow-lg:0 10px 20px rgba(0,0,0,.4);--shadow-xl:0 20px 30px rgba(0,0,0,.5);--shadow-glow:0 0 40px var(--color-accent-glow);--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-sans);line-height:1.6;min-height:100vh}::selection{background:var(--color-accent);color:#fff}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-default);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-emphasis)}*{scrollbar-width:thin;scrollbar-color:var(--color-border-default) var(--color-bg-secondary)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.25;color:var(--color-text-primary)}h1{font-size:2.5rem;letter-spacing:-.02em}h2{font-size:2rem;letter-spacing:-.01em}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin:0;color:var(--color-text-secondary);line-height:1.7}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}.font-mono,code,pre{font-family:var(--font-mono)}.container{width:100%;max-width:80rem;margin:0 auto;padding:0 var(--space-lg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card,.sr-only{overflow:hidden}.card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);transition:all var(--transition-base);position:relative}.card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,hsla(0,0%,100%,.02),transparent 50%);pointer-events:none}.card:hover{border-color:var(--color-border-default);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-hover{cursor:pointer}.card-hover:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow)}.card-header-accent{position:relative}.card-header-accent:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent);opacity:0;transition:opacity var(--transition-fast)}.card-header-accent:hover:after{opacity:1}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:500;border-radius:var(--radius-full);background:var(--color-bg-elevated);color:var(--color-text-secondary)}.badge-accent{background:var(--color-accent-dim);color:var(--color-accent)}.badge-success{background:var(--color-success-dim);color:var(--color-success)}.badge-warning{background:var(--color-warning-dim);color:var(--color-warning)}.badge-error{background:var(--color-error-dim);color:var(--color-error)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-border-emphasis)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-card);color:var(--color-text-primary)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:1rem}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:.8125rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeIn{animation:fadeIn var(--transition-slow) ease-out}.animate-slideUp{animation:slideUp var(--transition-slow) ease-out}.animate-slideIn{animation:slideIn var(--transition-slow) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-shimmer{animation:shimmer 2s linear infinite;background:linear-gradient(to right,transparent 25%,var(--color-border-default) 50%,transparent 75%);background-size:200% 100%}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.section{padding:var(--space-4xl) 0}.section-header{margin-bottom:var(--space-3xl)}.section-title{font-size:1.875rem;font-weight:700;margin-bottom:var(--space-sm)}.section-subtitle{font-size:1.125rem;color:var(--color-text-tertiary);max-width:48rem}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.section{padding:var(--space-3xl) 0}.section-header{margin-bottom:var(--space-2xl)}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,10,15,.8);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle);transition:all var(--transition-base)}.navbar.scrolled{background:rgba(10,10,15,.95);box-shadow:var(--shadow-md)}.navbar-content{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:80rem;margin:0 auto;padding:0 var(--space-lg)}.navbar-logo{font-weight:700;font-size:1.25rem;color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-fast)}.navbar-logo:hover{color:var(--color-accent)}.navbar-links{display:flex;align-items:center;gap:var(--space-lg)}.navbar-link{position:relative;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;text-decoration:none;padding:var(--space-sm) 0;transition:color var(--transition-fast)}.navbar-link:hover{color:var(--color-text-primary)}.navbar-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--transition-base)}.navbar-link:hover:after{width:100%}.navbar-link.active{color:var(--color-accent)}.navbar-link.active:after{width:100%}.navbar-dropdown{position:relative}.navbar-dropdown-trigger{display:flex;align-items:center;gap:var(--space-xs);background:none;border:none;cursor:pointer;padding:var(--space-sm) 0;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;transition:color var(--transition-fast)}.navbar-dropdown-trigger:hover{color:var(--color-text-primary)}.navbar-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:180px;background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-sm);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100;margin-top:var(--space-sm)}.navbar-dropdown:hover .navbar-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.navbar-dropdown-item{display:block;padding:var(--space-sm) var(--space-md);color:var(--color-text-secondary);font-size:.875rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.navbar-dropdown-item:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.navbar-mobile-menu{display:none;background:transparent;border:none;cursor:pointer;padding:var(--space-sm);color:var(--color-text-secondary);transition:color var(--transition-fast)}.navbar-mobile-menu:hover{color:var(--color-text-primary)}.navbar-mobile-menu svg{display:block}.mobile-menu{display:none}@media (max-width:768px){.navbar-links{display:none}.navbar-mobile-menu{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;padding:var(--space-sm)}.navbar-mobile-menu svg{width:24px;height:24px}.mobile-menu{display:block;background:rgba(10,10,15,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle);overflow:hidden;transition:all var(--transition-base)}.mobile-menu-content{padding:var(--space-md) 0}.mobile-menu-links{display:flex;flex-direction:column;gap:var(--space-xs);padding:0 var(--space-md)}.mobile-menu-link{display:flex;align-items:center;min-height:48px;padding:var(--space-md) var(--space-lg);color:var(--color-text-secondary);font-size:1rem;font-weight:500;text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-menu-link.active,.mobile-menu-link:hover{color:var(--color-text-primary);background:var(--color-bg-elevated)}.mobile-menu-cta{display:block;margin:var(--space-md) var(--space-md) var(--space-sm);padding:0 var(--space-md)}.mobile-menu-cta .btn{width:100%;justify-content:center;padding:var(--space-md) var(--space-lg);font-size:1rem;min-height:48px}.mobile-menu{max-height:0;opacity:0;padding:0}.mobile-menu.open{max-height:500px;opacity:1;padding:0}.mobile-menu-content{padding:var(--space-md) var(--space-lg);padding-bottom:var(--space-xl)}}.hero{min-height:100vh;display:flex;align-items:center;padding:calc(64px + var(--space-3xl)) 0 var(--space-4xl);position:relative;overflow:hidden}.hero-bg-effect{position:absolute;inset:0;z-index:-1;overflow:hidden}.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(99,102,241,.03) 1px,transparent 0),linear-gradient(90deg,rgba(99,102,241,.03) 1px,transparent 0);background-size:60px 60px}.hero-bg-pattern{position:absolute;top:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse at 30% 20%,rgba(99,102,241,.08) 0,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(16,185,129,.05) 0,transparent 40%)}.hero-content{max-width:80rem;margin:0 auto;padding:0 var(--space-lg);position:relative;z-index:1}.hero-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--space-3xl);align-items:center}.hero-image-container{position:relative;display:flex;justify-content:center}.hero-image-wrapper{position:relative;width:240px;height:240px;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-xl);z-index:2}.hero-image{object-fit:cover}.hero-image-accent{position:absolute;inset:-8px;border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--color-accent) 0,var(--color-success) 100%);opacity:.2;z-index:-1;filter:blur(20px)}.hero-text{display:flex;flex-direction:column;gap:var(--space-md)}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--color-success-dim);color:var(--color-success);font-size:.8125rem;font-weight:500;width:fit-content}.hero-badge,.hero-badge-dot{border-radius:var(--radius-full)}.hero-badge-dot{width:8px;height:8px;background:var(--color-success);animation:pulse 2s ease-in-out infinite}.hero-title{font-size:2.75rem;font-weight:700;line-height:1.15;color:var(--color-text-primary);margin:0}.hero-title-accent{background:linear-gradient(135deg,var(--color-accent) 0,var(--color-success) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.7;margin:0;max-width:36rem}.hero-description-sub{font-size:1rem;color:var(--color-text-tertiary);line-height:1.6;margin:0;max-width:36rem}.hero-text-highlight{color:var(--color-text-primary);font-weight:500}.hero-actions,.hero-highlights{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.hero-highlights{flex-wrap:wrap}.hero-highlight-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);font-size:.875rem;color:var(--color-text-secondary)}@media (max-width:1024px){.hero-layout{grid-template-columns:1fr;text-align:center;gap:var(--space-xl)}.hero-image-container{order:-1}.hero-image-wrapper{width:180px;height:180px}.hero-description,.hero-description-sub{max-width:none}.hero-badge{margin:0 auto}.hero-actions,.hero-highlights{justify-content:center}}@media (max-width:768px){.hero{padding:calc(64px + var(--space-xl)) 0 var(--space-2xl);min-height:auto;display:flex;flex-direction:column;justify-content:center}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.hero-actions{flex-direction:column;gap:var(--space-sm)}.hero-actions .btn{width:100%;justify-content:center;min-height:44px}.hero-highlights{flex-direction:column;align-items:center}.hero-highlight-item{width:100%;justify-content:center}}@media (max-width:480px){.hero{padding:calc(60px + var(--space-lg)) 0 var(--space-xl)}.hero-title{font-size:1.75rem;line-height:1.2}.hero-description{font-size:.9375rem}.hero-image-wrapper{width:140px;height:140px}.hero-badge{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}}.content-section{padding:var(--space-2xl) 0;border-top:1px solid var(--color-border-subtle)}@media (max-width:640px){.content-section{padding:var(--space-xl) 0}}.content-section:first-child{border-top:none}.content-section:last-child{border-bottom:1px solid var(--color-border-subtle)}.section-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);background:var(--color-accent-dim);color:var(--color-accent);margin-bottom:var(--space-md)}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.blog-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column}.blog-card:hover{border-color:var(--color-border-default);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.blog-card-image{position:relative;width:100%;height:180px;overflow:hidden;flex-shrink:0}.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.blog-card:hover .blog-card-image img{transform:scale(1.05)}.blog-card-overlay{position:absolute;inset:0;background:rgba(10,10,15,.6);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity var(--transition-base)}.blog-card:hover .blog-card-overlay{opacity:1}.blog-card-content{padding:var(--space-lg);flex:1;display:flex;flex-direction:column}.blog-card-categories{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.blog-category{padding:var(--space-xs) var(--space-sm);background:var(--color-accent-dim);color:var(--color-accent);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.blog-card-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-sm) 0;line-height:1.4;-webkit-line-clamp:2}.blog-card-excerpt,.blog-card-title{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.blog-card-excerpt{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--space-md) 0;flex:1;-webkit-line-clamp:3}.blog-card-meta{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);margin-top:auto}.blog-card-date{color:var(--color-text-tertiary)}.blog-card-date,.blog-card-read{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem}.blog-card-read{color:var(--color-accent);font-weight:500}.blog-view-all{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-bg-card);border:1px dashed var(--color-border-default);border-radius:var(--radius-xl);color:var(--color-text-secondary);font-size:.9375rem;transition:all var(--transition-base)}.blog-view-all:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-dim)}.blog-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--color-text-tertiary)}.loading-spinner{width:24px;height:24px;border:2px solid var(--color-border-default);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}.blog-error{text-align:center;padding:var(--space-3xl);color:var(--color-error)}@media (max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}.blog-view-all{grid-column:1/-1}}@media (max-width:640px){.blog-grid{grid-template-columns:1fr}.blog-card-image{height:160px}}.project-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-lg);transition:all var(--transition-base);display:flex;flex-direction:column}.project-card:hover{border-color:var(--color-border-default);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-card-header-row{justify-content:space-between;margin-bottom:var(--space-md)}.project-card-header-left,.project-card-header-row{display:flex;align-items:flex-start;gap:var(--space-md)}.project-card-icon{color:var(--color-text-tertiary);flex-shrink:0;margin-top:2px}.project-card-title-wrapper{display:flex;flex-direction:column;gap:var(--space-xs)}.project-card-title{font-size:1.0625rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.project-card-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.75rem;color:var(--color-text-tertiary);transition:color var(--transition-fast)}.project-card-link:hover{color:var(--color-accent)}.project-card-actions{display:flex;align-items:center;gap:var(--space-sm)}.project-card-external{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-tertiary);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);transition:all var(--transition-fast)}.project-card-external:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-dim)}.project-card-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--space-md) 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.project-readme{margin-bottom:var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden}.project-readme-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border-subtle);font-size:.75rem;font-weight:500;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.project-readme-content{padding:var(--space-md);max-height:200px;overflow:hidden;transition:max-height var(--transition-slow)}.project-readme-content.expanded{max-height:800px;overflow-y:auto}.readme-h1,.readme-h2,.readme-h3{font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin:var(--space-md) 0 var(--space-sm) 0;line-height:1.3}.readme-h1{font-size:1rem}.readme-h2{font-size:.9375rem}.readme-h3{font-size:.875rem}.readme-p{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.6;margin:var(--space-sm) 0}.readme-p:first-child{margin-top:0}.readme-p:last-child{margin-bottom:0}.readme-inline-code{font-size:.8125rem;padding:.125rem .375rem;border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-accent)}.readme-code-block,.readme-inline-code{font-family:var(--font-mono);background:var(--color-bg-card)}.readme-code-block{font-size:.75rem;display:block;padding:var(--space-md);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);overflow-x:auto;margin:var(--space-sm) 0}.readme-pre{margin:0;padding:0;background:transparent}.readme-ol,.readme-ul{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.6;margin:var(--space-sm) 0;padding-left:var(--space-lg)}.readme-li{margin:var(--space-xs) 0}.readme-blockquote{font-size:.8125rem;color:var(--color-text-tertiary);border-left:3px solid var(--color-accent);margin:var(--space-sm) 0;padding:var(--space-sm) var(--space-md);background:var(--color-bg-card)}.readme-strong{font-weight:600;color:var(--color-text-primary)}.readme-em{font-style:italic}.readme-table-wrapper{overflow-x:auto;margin:var(--space-sm) 0}.readme-content a{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--color-accent);text-decoration:none;font-size:.8125rem}.readme-content a:hover{text-decoration:underline}.readme-content a svg{flex-shrink:0}.readme-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-sm);background:var(--color-bg-tertiary);border:none;border-top:1px solid var(--color-border-subtle);color:var(--color-accent);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.readme-toggle:hover{background:var(--color-accent-dim)}.project-readme-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-md);font-size:.8125rem;color:var(--color-text-tertiary)}.loading-spinner-small{width:16px;height:16px;border:2px solid var(--color-border-default);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}.project-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}.project-language{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-text-secondary)}.project-language-dot{width:10px;height:10px;border-radius:50%}.project-stats{gap:var(--space-md)}.project-stat,.project-stats{display:flex;align-items:center}.project-stat{gap:var(--space-xs);font-size:.8125rem;color:var(--color-text-tertiary)}.project-stat svg{opacity:.7}.project-topics{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-md)}.project-topic{padding:var(--space-xs) var(--space-sm);background:var(--color-bg-elevated);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:.75rem;border:1px solid var(--color-border-subtle);transition:all var(--transition-fast)}.project-topic:hover{background:var(--color-accent-dim);color:var(--color-accent);border-color:var(--color-accent)}.project-card-footer{display:flex;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);margin-top:auto;flex-wrap:wrap}.project-card-footer,.project-readme-link{align-items:center;font-size:.75rem;color:var(--color-text-tertiary)}.project-readme-link{display:inline-flex;gap:var(--space-xs);margin-left:auto;transition:color var(--transition-fast)}.project-readme-link:hover{color:var(--color-accent)}.input,.select,.textarea{width:100%;padding:var(--space-sm) var(--space-md);font-size:.875rem;color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.input::placeholder,.textarea::placeholder{color:var(--color-text-tertiary)}.textarea{min-height:100px;resize:vertical}.label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.form-group{margin-bottom:var(--space-md)}.footer{padding:var(--space-2xl) 0;border-top:1px solid var(--color-border-subtle);margin-top:var(--space-3xl)}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md)}.footer-copyright{color:var(--color-text-tertiary);font-size:.875rem}.footer-links{display:flex;gap:var(--space-md)}.footer-link{color:var(--color-text-tertiary);transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-text-primary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.section-divider{height:1px;background:var(--color-border-subtle);margin:0;border:none}.line-clamp-1{-webkit-line-clamp:1}.line-clamp-1,.line-clamp-2{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.kpi-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.2;margin-bottom:var(--space-xs)}.kpi-improvement{font-size:.8125rem;font-weight:500;color:var(--color-success);line-height:1.3}.problem-lead-in{font-weight:600;color:var(--color-text-primary)}.problem-description{line-height:1.7}.architecture-section{padding:var(--space-xl) 0}.architecture-header{text-align:center;margin-bottom:var(--space-2xl)}.architecture-diagram-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-2xl)}.architecture-diagram-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);text-align:center;margin:0 0 var(--space-xl) 0}.architecture-loop{position:relative;width:100%;max-width:320px;margin:0 auto;height:260px}.loop-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:var(--color-bg-card);border:2px solid var(--color-accent);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;box-shadow:var(--shadow-glow)}.loop-center-label{font-size:.6875rem;font-weight:600;color:var(--color-accent);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.loop-svg{transform:translate(-50%,-50%);width:260px;height:260px;pointer-events:none;z-index:0}.loop-node,.loop-svg{position:absolute;top:50%;left:50%}.loop-node{flex-direction:column;text-align:center;z-index:1;transition:transform .3s ease}.loop-node,.loop-node-icon{display:flex;align-items:center}.loop-node-icon{width:44px;height:44px;border-radius:50%;background:var(--color-bg-elevated);border:2px solid var(--node-color,var(--color-accent));justify-content:center;color:var(--node-color,var(--color-accent));margin-bottom:var(--space-sm)}.loop-node-content{display:flex;flex-direction:column;align-items:center}.loop-node-label{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.loop-node-desc{font-size:.6875rem;color:var(--color-text-tertiary);max-width:90px;line-height:1.4}.loop-legend{display:flex;justify-content:center;gap:var(--space-xl);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle)}.loop-legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:.75rem;color:var(--color-text-secondary)}.loop-legend-arrow{color:var(--color-accent);font-weight:700}.loop-legend-human{color:var(--color-success);font-size:.875rem}.architecture-principles{margin-bottom:var(--space-2xl)}.architecture-principles-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-lg) 0}.architecture-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.architecture-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;flex-direction:column;transition:all var(--transition-base)}.architecture-card:hover{border-color:var(--color-border-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.architecture-card-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-accent-dim);color:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-sm)}.architecture-card-title{font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.architecture-card-desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.tech-stack-banner{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.tech-stack-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);white-space:nowrap}.tech-stack-items{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-sm)}.tech-stack-item{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);background:var(--color-bg-card);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.tech-stack-separator{color:var(--color-text-muted);font-size:.6875rem}@media (max-width:768px){.architecture-grid{grid-template-columns:1fr}.architecture-loop{height:auto;max-width:none;display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) 0}.loop-center{order:0;margin-bottom:var(--space-lg)}.loop-center,.loop-node{position:relative;top:auto;left:auto;transform:none}.loop-node{flex-direction:row;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-sm);width:100%;max-width:100%;text-align:left}.loop-node-icon{width:36px;height:36px;margin-bottom:0;flex-shrink:0}.loop-node-icon svg{width:18px;height:18px}.loop-node-content{align-items:flex-start}.loop-node-label{font-size:.8125rem;margin-bottom:0}.loop-node-desc{font-size:.6875rem;max-width:none;text-align:left}.loop-svg{display:none}.tech-stack-banner{align-items:flex-start}.loop-legend,.tech-stack-banner{flex-direction:column;gap:var(--space-sm)}.loop-legend{align-items:center;margin-top:var(--space-md);padding-top:var(--space-sm)}}.philosophy-section{padding:var(--space-xl) 0}.philosophy-header{text-align:center;margin-bottom:var(--space-2xl)}.philosophy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-2xl)}.principle-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-lg);display:flex;flex-direction:column;transition:all var(--transition-base)}.principle-card:hover{border-color:var(--color-border-default);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.principle-card-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.principle-icon{width:44px;height:44px;border-radius:var(--radius-lg);border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.principle-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.principle-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7;margin:0 0 var(--space-md) 0;flex:1}.principle-example{padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle)}.principle-example-label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-xs)}.principle-example-text{font-size:.8125rem;color:var(--color-text-tertiary);line-height:1.6;margin:0}.philosophy-cta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xl);padding:var(--space-xl);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl)}.philosophy-cta-content{flex:1}.philosophy-cta-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-xs) 0}.philosophy-cta-text{font-size:.9375rem;color:var(--color-text-secondary);margin:0}@media (max-width:1024px){.philosophy-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.philosophy-grid{grid-template-columns:1fr}.philosophy-cta{flex-direction:column;gap:var(--space-lg)}.philosophy-cta,.philosophy-cta-content{text-align:center}}.ecosystem-section{padding:var(--space-xl) 0}.ecosystem-header{text-align:center;margin-bottom:var(--space-2xl)}.ecosystem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.system-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:0;display:flex;flex-direction:column;transition:all var(--transition-base);position:relative;overflow:hidden}.system-card:hover{border-color:var(--color-border-default);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.system-card-header{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);padding-bottom:var(--space-md)}.system-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.system-title-row{display:flex;flex-direction:column;gap:var(--space-xs)}.system-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.system-subtitle{font-size:.8125rem;color:var(--color-text-tertiary);margin:0;font-weight:500}.system-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7;margin:0;padding:0 var(--space-lg);margin-bottom:var(--space-lg)}.system-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:var(--space-md) var(--space-lg);margin:0 var(--space-lg);margin-bottom:var(--space-lg);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle)}.system-metric{text-align:center;padding:var(--space-sm);position:relative}.system-metric:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:60%;background:var(--color-border-subtle)}.system-metric-value{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.system-metric-label{font-size:.6875rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.system-card-footer{padding:var(--space-md) var(--space-lg);padding-top:0;margin-top:auto}.system-cta{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:.875rem;font-weight:500;color:var(--color-accent);text-decoration:none;transition:gap var(--transition-fast)}.system-cta:hover{gap:var(--space-md)}.ecosystem-cta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xl);padding:var(--space-xl);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);margin-top:var(--space-2xl)}.ecosystem-cta-content{flex:1}.ecosystem-cta-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-xs) 0}.ecosystem-cta-text{font-size:.9375rem;color:var(--color-text-secondary);margin:0}@media (max-width:1024px){.ecosystem-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.ecosystem-grid{grid-template-columns:1fr}.ecosystem-cta{flex-direction:column;gap:var(--space-lg)}.ecosystem-cta,.ecosystem-cta-content{text-align:center}.system-metrics{grid-template-columns:1fr;gap:var(--space-sm)}.system-metric:not(:last-child):after{display:none}.system-metric{border-bottom:1px solid var(--color-border-subtle)}.system-metric:last-child{border-bottom:none}}.youtube-section{padding:var(--space-xl) 0}.youtube-header{margin-bottom:var(--space-xl);gap:var(--space-md)}.youtube-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:red;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.youtube-title{margin:0 0 var(--space-xs) 0}.youtube-subtitle{color:var(--color-text-tertiary);margin:0}.youtube-channel-link{display:inline-flex;gap:var(--space-sm);font-size:.8125rem;font-weight:500}.youtube-channel-link:hover{border-color:red;color:red;background:rgba(255,0,0,.1)}.youtube-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-md)}.youtube-tab{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-tertiary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.youtube-tab:hover{background:var(--color-bg-elevated);color:var(--color-text-secondary)}.youtube-tab.active{background:var(--color-accent-dim);color:var(--color-accent)}.youtube-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.youtube-grid,.youtube-playlists{margin-bottom:var(--space-xl)}.youtube-section{display:flex;flex-direction:column;gap:var(--space-lg)}.youtube-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);flex-wrap:wrap}.youtube-title-row{display:flex;align-items:center;gap:var(--space-md)}.youtube-icon-wrapper{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,red,#c00);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.youtube-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3}.youtube-subtitle{margin:var(--space-xs) 0 0}.youtube-channel-link,.youtube-subtitle{font-size:.875rem;color:var(--color-text-secondary)}.youtube-channel-link{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-fast)}.youtube-channel-link:hover{color:var(--color-text-primary);border-color:var(--color-border-default)}.youtube-playlist-card{display:flex;align-items:stretch;gap:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;transition:all var(--transition-base)}.youtube-playlist-card:hover{border-color:var(--color-border-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.youtube-playlist-thumbnail{position:relative;width:200px;min-height:140px;background:linear-gradient(135deg,#1a1a2e,#16213e);flex-direction:column;flex-shrink:0;overflow:hidden}.youtube-playlist-overlay,.youtube-playlist-thumbnail{display:flex;align-items:center;justify-content:center}.youtube-playlist-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);transition:background var(--transition-base)}.youtube-playlist-card:hover .youtube-playlist-overlay{background:rgba(255,0,0,.2)}.youtube-play-button-large{width:56px;height:56px;border-radius:50%;background:red;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform var(--transition-base);box-shadow:0 4px 12px rgba(255,0,0,.3)}.youtube-playlist-card:hover .youtube-play-button-large{transform:scale(1.1)}.youtube-playlist-count{position:absolute;bottom:var(--space-sm);left:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:rgba(0,0,0,.8);border-radius:var(--radius-md);color:#fff;font-size:.75rem;font-weight:500}.youtube-playlist-info{flex:1;display:flex;flex-direction:column;justify-content:center;padding:var(--space-md) var(--space-md) var(--space-md) 0}.youtube-playlist-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-xs)}.youtube-playlist-desc{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--space-sm);line-height:1.5}.youtube-playlist-cta{display:flex;align-items:center;gap:var(--space-xs);color:red;font-size:.875rem;font-weight:500}.youtube-view-all{padding:var(--space-md);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);font-size:.875rem;transition:all var(--transition-fast)}.youtube-view-all:hover{color:var(--color-text-primary);border-color:var(--color-border-default)}@media (max-width:768px){.youtube-playlist-card{flex-direction:column}.youtube-playlist-thumbnail{width:100%;min-height:180px}.youtube-playlist-info{padding:var(--space-md)}.youtube-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.youtube-channel-link{width:100%;justify-content:center}}@media (max-width:640px){.youtube-playlist-thumbnail{min-height:160px}.youtube-play-button-large{width:48px;height:48px}.youtube-play-button-large svg{width:24px;height:24px}.youtube-title{font-size:1.125rem}.youtube-playlist-title{font-size:.9375rem}.youtube-playlist-desc{font-size:.8125rem}}.video-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;transition:all var(--transition-base);text-decoration:none}.video-card:hover{border-color:var(--color-border-default);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.video-card-thumbnail{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;flex-shrink:0}.video-card-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.video-card:hover .video-card-thumbnail img{transform:scale(1.05)}.video-card-overlay{position:absolute;inset:0;background:rgba(10,10,15,.5);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity var(--transition-base)}.video-card:hover .video-card-overlay{opacity:1}.video-card-duration{position:absolute;bottom:var(--space-sm);right:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:rgba(0,0,0,.8);border-radius:var(--radius-sm);color:#fff;font-size:.75rem;font-weight:500}.video-card-content{padding:var(--space-md);flex:1;display:flex;flex-direction:column}.video-card-title{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-md) 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.video-card-meta{display:flex;align-items:center;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);flex-wrap:wrap}.video-card-date,.video-card-views{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--color-text-tertiary)}.video-card-date svg,.video-card-views svg{opacity:.7}.youtube-view-all-card{background:var(--color-bg-card);border:1px dashed var(--color-border-default);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all var(--transition-base);min-height:200px}.youtube-view-all-card:hover{border-color:red;background:rgba(255,0,0,.05)}.youtube-view-all-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:.9375rem;font-weight:500}.youtube-view-all-content svg{color:red}.youtube-view-all{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-bg-card);border:1px dashed var(--color-border-default);border-radius:var(--radius-xl);color:var(--color-text-secondary);font-size:.9375rem;text-decoration:none;transition:all var(--transition-base)}.youtube-view-all:hover{border-color:red;color:red;background:rgba(255,0,0,.05)}.youtube-view-all svg{flex-shrink:0}.system-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);background:var(--color-success-dim);color:var(--color-success);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.youtube-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--color-text-tertiary)}.youtube-error{text-align:center;padding:var(--space-3xl);color:var(--color-error)}@media (max-width:1024px){.youtube-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.youtube-header{flex-direction:column;align-items:flex-start}.youtube-title-row{width:100%}.youtube-channel-link{width:100%;justify-content:center}.youtube-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--space-sm)}.youtube-tab{white-space:nowrap}.youtube-grid{grid-template-columns:1fr}.youtube-view-all{flex-direction:column;gap:var(--space-sm)}.youtube-view-all-card{min-height:120px}}.gh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media (max-width:1024px){.gh-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}}@media (max-width:640px){.gh-grid{grid-template-columns:1fr;gap:var(--space-md)}.gh-card{padding:var(--space-md);min-height:auto}.gh-card-header{gap:var(--space-sm);margin-bottom:var(--space-xs)}.gh-card-icon{width:28px;height:28px}.gh-card-title{font-size:.875rem}.gh-card-description{font-size:.8125rem;-webkit-line-clamp:3}.gh-card-meta{gap:var(--space-sm);padding-top:var(--space-sm)}.gh-card-date,.gh-card-lang,.gh-card-stat{font-size:.75rem}}.gh-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;transition:all var(--transition-base);text-decoration:none;position:relative;min-height:160px}.gh-card:hover{border-color:var(--color-border-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.gh-card-link-overlay{position:absolute;inset:0;z-index:1}.gh-card-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-sm)}.gh-card-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0}.gh-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);flex:1;min-width:0}.gh-card-title{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gh-card-link{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--color-text-tertiary);transition:all var(--transition-fast);flex-shrink:0}.gh-card-link:hover{color:var(--color-accent);background:var(--color-accent-dim)}.gh-card-description{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.5;margin:0 0 var(--space-md) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gh-card-meta{gap:var(--space-md);margin-top:auto;padding-top:var(--space-md);border-top:1px solid var(--color-border-subtle);flex-wrap:wrap}.gh-card-lang,.gh-card-meta{display:flex;align-items:center}.gh-card-lang{gap:var(--space-xs);font-size:.75rem;color:var(--color-text-secondary);font-weight:500}.gh-card-lang-dot{width:8px;height:8px;border-radius:50%}.gh-card-stats{gap:var(--space-md)}.gh-card-stat,.gh-card-stats{display:flex;align-items:center}.gh-card-stat{gap:var(--space-xs);font-size:.75rem;color:var(--color-text-tertiary)}.gh-card-stat svg{opacity:.7}.gh-card-date{font-size:.75rem;color:var(--color-text-tertiary);margin-left:auto}.gh-card-topics{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.gh-card-topic{padding:2px var(--space-sm);background:var(--color-bg-elevated);border-radius:var(--radius-sm);font-size:.6875rem;color:var(--color-text-muted)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media (max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.projects-grid{grid-template-columns:1fr}}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/999e639cd9d85971-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/9af6411484c7e20a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e6b5cfd5a74e1cae-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/6aacc40b7795b725-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/67110d8fe39c5e84-s.woff2) format("woff2");unicode-range:u+2000-2001,u+2004-2008,u+200a,u+23b8-23bd,u+2500-259f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/046b90749014f852-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/3703c28dcda155b1-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/999e639cd9d85971-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/9af6411484c7e20a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e6b5cfd5a74e1cae-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/6aacc40b7795b725-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/67110d8fe39c5e84-s.woff2) format("woff2");unicode-range:u+2000-2001,u+2004-2008,u+200a,u+23b8-23bd,u+2500-259f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/046b90749014f852-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/3703c28dcda155b1-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/999e639cd9d85971-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/9af6411484c7e20a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e6b5cfd5a74e1cae-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/6aacc40b7795b725-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/67110d8fe39c5e84-s.woff2) format("woff2");unicode-range:u+2000-2001,u+2004-2008,u+200a,u+23b8-23bd,u+2500-259f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/046b90749014f852-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/3703c28dcda155b1-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/999e639cd9d85971-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/9af6411484c7e20a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/e6b5cfd5a74e1cae-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/6aacc40b7795b725-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/67110d8fe39c5e84-s.woff2) format("woff2");unicode-range:u+2000-2001,u+2004-2008,u+200a,u+23b8-23bd,u+2500-259f}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/046b90749014f852-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Fira_Code_fa9dfa;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/3703c28dcda155b1-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Fira_Code_Fallback_fa9dfa;src:local("Arial");ascent-override:73.56%;descent-override:23.92%;line-gap-override:0.00%;size-adjust:134.59%}.__className_fa9dfa{font-family:__Fira_Code_fa9dfa,__Fira_Code_Fallback_fa9dfa;font-style:normal}.__variable_fa9dfa{--font-fira-code:"__Fira_Code_fa9dfa","__Fira_Code_Fallback_fa9dfa"}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Space_Grotesk_49a339;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Space_Grotesk_Fallback_49a339;src:local("Arial");ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.00%;size-adjust:109.69%}.__className_49a339{font-family:__Space_Grotesk_49a339,__Space_Grotesk_Fallback_49a339;font-style:normal}.__variable_49a339{--font-space-grotesk:"__Space_Grotesk_49a339","__Space_Grotesk_Fallback_49a339"}