@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Montserrat:wght@300;400;500;600;700&display=swap);:root{--primary:#1b4332;--primary-dark:#143728;--primary-light:#1b433214;--accent-mint:#d8f3dc;--accent-mint-dark:#b7e4c7;--accent-sage:#95d5b2;--accent-green-soft:#52b788;--accent-yellow:#f9c74f;--accent-red:#e07a5f;--accent-blue:#457b9d;--bg-light:#fafaf5;--bg-white:#fff;--bg-card:#fff;--bg-card-hover:#f5f5f0;--bg-section:#f0f7f4;--text-primary:#1b1b1b;--text-secondary:#5a6b63;--text-muted:#8a9a92;--heading-primary:#1b4332;--heading-secondary:#1b1b1b;--border-color:#e2e8e5;--border-light:#edf2ef;--gradient-primary:linear-gradient(135deg,#1b4332,#2d6a4f);--gradient-mint:linear-gradient(135deg,#d8f3dc,#b7e4c7);--gradient-soft:linear-gradient(135deg,#f0f7f4,#fafaf5);--shadow-sm:0 1px 3px #0000000a,0 1px 2px #0000000f;--shadow-md:0 4px 12px #0000000f,0 2px 4px #0000000a;--shadow-lg:0 12px 32px #00000014,0 4px 8px #0000000a;--shadow-xl:0 20px 48px #0000001a;--radius-sm:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-pill:9999px;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--spacing-2xl:5rem;--nav-height:4.5rem;--nav-bg:#fafaf5d9;--nav-bg-scrolled:#fffffff2;--nav-border:#e2e8e5;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-heading:"Montserrat",sans-serif;--transition-fast:0.15s ease;--transition-normal:0.25s ease;--transition-slow:0.4s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafaf5;background-color:var(--bg-light);color:#1b1b1b;color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--font-sans);line-height:1.6}h1,h2,h3,h4,h5,h6{color:#1b4332;color:var(--heading-primary);font-family:Montserrat,sans-serif;font-family:var(--font-heading);font-weight:700;line-height:1.2}h1{font-size:clamp(2rem,4vw,3.25rem)}h2{color:#1b1b1b;color:var(--heading-secondary);font-size:clamp(1.5rem,3vw,2.25rem)}h3{color:#1b4332;color:var(--heading-primary);font-size:1.25rem}a{color:#1b4332;color:var(--primary);text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast)}a:hover{color:#52b788;color:var(--accent-green-soft)}p{color:#5a6b63;color:var(--text-secondary);line-height:1.7;margin-bottom:1rem;margin-bottom:var(--spacing-sm)}button{border:none;cursor:pointer;font-weight:500;transition:all .25s ease;transition:all var(--transition-normal)}button,input,select,textarea{font-family:Inter,system-ui,-apple-system,sans-serif;font-family:var(--font-sans)}input,select,textarea{background-color:#fff;background-color:var(--bg-white);border:1px solid #e2e8e5;border:1px solid var(--border-color);color:#1b1b1b;color:var(--text-primary)}#appContainer{min-height:100vh;position:relative}#navBar{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#fafaf5d9;background:var(--nav-bg);border-bottom:1px solid #0000;display:flex;height:4.5rem;height:var(--nav-height);justify-content:space-between;left:0;padding:0 3rem;padding:0 var(--spacing-xl);position:fixed;right:0;top:0;transition:all .25s ease;transition:all var(--transition-normal);z-index:1000}#navBar.scrolled{background:#fffffff2;background:var(--nav-bg-scrolled);border-bottom:1px solid #e2e8e5;border-bottom:1px solid var(--nav-border);box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f;box-shadow:var(--shadow-sm)}.logo-container{align-items:center;border-radius:9999px;border-radius:var(--radius-pill);display:flex;gap:1rem;gap:var(--spacing-sm);padding:.5rem 1rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all .25s ease;transition:all var(--transition-normal)}.logo-container:hover{background:#1b433214;background:var(--primary-light)}.home-icon{font-size:1.25rem}.home-icon,.logo-text{color:#1b4332;color:var(--primary)}.logo-text{font-family:Montserrat,sans-serif;font-family:var(--font-heading);font-size:1.15rem;font-weight:700;letter-spacing:-.02em}.nav-items{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-xs)}.nav-item-container{position:relative}.nav-link{align-items:center;background:#0000;border:1px solid #0000;border-radius:9999px;border-radius:var(--radius-pill);color:#5a6b63;color:var(--text-secondary);display:flex;font-size:.92rem;font-weight:500;gap:.5rem;gap:var(--spacing-xs);padding:.6rem 1.1rem;text-decoration:none;transition:all .25s ease;transition:all var(--transition-normal)}.nav-link:hover{background:#1b433214;background:var(--primary-light);color:#1b4332;color:var(--primary)}.nav-link.active{background:linear-gradient(135deg,#1b4332,#2d6a4f);background:var(--gradient-primary);border-color:#0000;box-shadow:0 4px 12px #0000000f,0 2px 4px #0000000a;box-shadow:var(--shadow-md);color:#fff;color:var(--bg-white)}.nav-button{background:#0000;border:1px solid #0000}.nav-icon{align-items:center;display:flex;font-size:1rem}.nav-text{font-size:.92rem}.active-indicator,.mobile-nav{display:none}.mobile-nav{background:#fff;background:var(--bg-white);border-top:1px solid #e2e8e5;border-top:1px solid var(--border-color);padding:1rem 0;padding:var(--spacing-sm) 0;width:100%}.scrollable-tabs{-ms-overflow-style:none;display:flex;gap:.5rem;overflow-x:auto;padding:.5rem;scrollbar-width:none}.scrollable-tabs::-webkit-scrollbar{display:none}.mobile-nav-link{align-items:center;background:#0000;border:1px solid #0000;border-radius:.75rem;border-radius:var(--radius-md);color:#5a6b63;color:var(--text-secondary);display:flex;font-size:.95rem;gap:.75rem;padding:.75rem 1rem;text-decoration:none;transition:all .25s ease;transition:all var(--transition-normal);white-space:nowrap}.mobile-nav-link:hover{background:#f0f7f4;background:var(--bg-section);color:#1b4332;color:var(--primary)}.mobile-nav-link.active{background:linear-gradient(135deg,#1b4332,#2d6a4f);background:var(--gradient-primary);color:#fff;color:var(--bg-white)}#mainContainer{min-height:100vh;padding-top:4.5rem;padding-top:var(--nav-height)}.page-container{min-height:calc(100vh - 4.5rem);min-height:calc(100vh - var(--nav-height));position:relative}.mobile-menu-button{background:none;border:none;border-radius:.75rem;border-radius:var(--radius-md);color:#1b1b1b;color:var(--text-primary);display:none;font-size:1.25rem;padding:.5rem;padding:var(--spacing-xs);transition:all .25s ease;transition:all var(--transition-normal)}.mobile-menu-button:hover{background:#1b433214;background:var(--primary-light);color:#1b4332;color:var(--primary)}#navBar.menu-open{background:#fff;background:var(--bg-white);border-bottom:1px solid #e2e8e5;border-bottom:1px solid var(--border-color);height:auto}@media (max-width:768px){#navBar{flex-wrap:wrap;padding:1rem;padding:var(--spacing-sm)}.nav-items{display:none}.mobile-menu-button,.mobile-nav{display:block}.mobile-nav{width:100%}.scrollable-tabs{display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-xs);padding:0 1rem;padding:0 var(--spacing-sm)}.mobile-nav-link{align-items:center;background:#0000;border-radius:.75rem;border-radius:var(--radius-md);color:#5a6b63;color:var(--text-secondary);display:flex;font-size:1rem;gap:1rem;gap:var(--spacing-sm);padding:.75rem 1rem;transition:all .25s ease;transition:all var(--transition-normal)}.mobile-nav-link:hover{background:#f0f7f4;background:var(--bg-section);transform:translateX(.5rem);transform:translateX(var(--spacing-xs))}.mobile-nav-link.active{background:linear-gradient(135deg,#1b4332,#2d6a4f);background:var(--gradient-primary);color:#fff;color:var(--bg-white)}}@media (max-width:480px){.logo-text{font-size:1rem}.mobile-nav-link{font-size:.9rem;padding:.5rem 1rem;padding:var(--spacing-xs) var(--spacing-sm)}}.landing-container{align-items:center;background:var(--bg-light);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:var(--spacing-xl);position:relative;width:100%}.gradient-bg{background:radial-gradient(ellipse at center,#d8f3dc80 0,#b7e4c733 40%,#0000 70%);border-radius:50%;filter:blur(60px);height:80%;position:absolute;right:-10%;top:-20%;width:60%;z-index:0}.social-links{display:flex;flex-direction:column;gap:var(--spacing-md);left:var(--spacing-lg);position:fixed;top:50%;transform:translateY(-50%);z-index:10}.social-link{align-items:center;background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);color:var(--text-muted);display:flex;font-size:1.35rem;height:2.75rem;justify-content:center;transition:all var(--transition-normal);width:2.75rem}.social-link:hover{border-color:var(--primary);box-shadow:var(--shadow-md);color:var(--primary);transform:translateY(-2px)}.main-content{align-items:center;display:flex;gap:var(--spacing-2xl);justify-content:space-between;margin:0 auto;max-width:1100px;padding:var(--spacing-xl);position:relative;width:100%;z-index:1}.text-content{flex:1 1;max-width:560px}.greeting{color:var(--text-muted);font-size:1.1rem;font-weight:500;letter-spacing:.02em;margin-bottom:var(--spacing-xs);text-transform:uppercase}.name{color:var(--heading-primary);font-size:clamp(2.25rem,5vw,3.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--spacing-sm)}.role-container{height:2.25rem;margin-bottom:var(--spacing-md);overflow:hidden;position:relative}.role{color:var(--accent-green-soft);font-size:1.35rem;font-weight:600;position:absolute;width:100%}.terminal-box{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-md);display:inline-block;margin-bottom:var(--spacing-md);padding:.75rem 1.25rem}.terminal-box code{background:none;color:var(--primary);font-family:SF Mono,Fira Code,monospace;font-size:.85rem}.description{color:var(--text-secondary);font-size:clamp(.95rem,1.5vw,1.1rem);line-height:1.7;margin-bottom:var(--spacing-lg)}.cta-container{display:flex;gap:var(--spacing-sm)}.cta-container a{text-decoration:none}.cta-button{align-items:center;border:none;border-radius:var(--radius-pill);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;justify-content:center;letter-spacing:.01em;padding:.85rem 1.75rem;transition:all var(--transition-normal)}.cta-button.primary{background:var(--gradient-primary);box-shadow:var(--shadow-md);color:#fff}.cta-button.primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.cta-button.secondary{background:var(--bg-white);border:1.5px solid var(--border-color);color:var(--primary)}.cta-button.secondary:hover{background:var(--primary-light);border-color:var(--primary);transform:translateY(-2px)}.image-container{align-items:center;display:flex;flex:1 1;justify-content:center;max-width:420px;position:relative}.profile-image{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);height:auto;max-width:400px;object-fit:contain;position:relative;width:100%;z-index:2}.image-backdrop{background:var(--gradient-mint);border-radius:var(--radius-xl);height:110%;opacity:.6;position:absolute;transform:rotate(-3deg) scale(.95);width:110%;z-index:1}@media (max-width:1024px){.landing-container,.main-content{padding:var(--spacing-md)}.main-content{flex-direction:column;gap:var(--spacing-lg);text-align:center}.text-content{max-width:100%}.social-links{display:none}.cta-container{justify-content:center}.image-container{max-width:320px}}@media (max-width:768px){.landing-container{min-height:calc(100vh - var(--nav-height));padding:var(--spacing-sm)}.main-content{flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-sm);padding-bottom:calc(var(--spacing-xl)*2);text-align:center}.text-content{order:1}.image-container{margin:0 auto;max-width:260px;order:2;width:100%}.social-links{bottom:var(--spacing-lg);display:flex;flex-direction:row;gap:var(--spacing-sm);justify-content:center;left:0;padding:var(--spacing-sm);position:absolute;right:0;top:auto;transform:none}.social-link{font-size:1.2rem;height:2.5rem;width:2.5rem}.cta-container{flex-wrap:wrap;gap:var(--spacing-sm)}.cta-button{margin:0 auto;max-width:280px;width:100%}.terminal-box{display:none}}@media (max-width:480px){.landing-container,.main-content{padding:var(--spacing-xs)}.main-content{gap:var(--spacing-sm);padding-bottom:calc(var(--spacing-xl)*1.5)}.image-container{max-width:220px}.cta-button{font-size:.9rem;padding:.75rem 1.5rem}}@media (max-width:360px){.name{font-size:1.75rem}.greeting,.role{font-size:1rem}.description{font-size:.875rem}}@media (max-height:600px) and (orientation:landscape){.landing-container{min-height:auto;padding:var(--spacing-xs)}.main-content{flex-direction:row;gap:var(--spacing-md);padding:var(--spacing-sm)}.image-container{max-width:200px}}.about-container{background:var(--bg-light);color:var(--text-primary);font-family:var(--font-sans);line-height:1.7;margin:0 auto;max-width:1100px;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-2xl)}.hero-section{border-bottom:1px solid var(--border-light);padding:var(--spacing-2xl) 0 var(--spacing-xl);text-align:center}.hero-subtitle{font-size:1.3rem;font-weight:400;margin-left:auto;margin-right:auto;max-width:600px}.animated-roles,.hero-subtitle{margin-bottom:var(--spacing-lg)}.animated-roles{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.role-badge{background:var(--accent-mint);border:1px solid var(--accent-mint-dark);border-radius:var(--radius-pill);color:var(--primary);font-size:.88rem;font-weight:600;padding:.5rem 1.15rem;transition:all var(--transition-normal)}.role-badge:hover{background:var(--accent-mint-dark);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.turing-quote{color:var(--text-muted);font-size:.95rem;font-style:italic;margin-top:var(--spacing-lg)}.section-heading{color:var(--heading-primary);font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.stats-section{margin:var(--spacing-2xl) 0}.stats-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stat-card{color:var(--text-primary);font-size:.95rem;font-weight:500;padding:var(--spacing-md);transition:all var(--transition-normal)}.stat-card:hover{border-color:var(--accent-mint-dark);transform:translateY(-4px)}.stack-section{margin:var(--spacing-2xl) 0}.stack-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.tech-item{text-align:center}.logo-wrapper{align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:inline-flex;justify-content:center;padding:1rem;transition:all var(--transition-normal)}.logo-wrapper:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-md);transform:translateY(-4px)}.tech-icon{height:40px;object-fit:contain;width:40px}.tech-label{color:var(--text-secondary);display:block;font-size:.82rem;font-weight:500;margin-top:.5rem}.interests-section{margin:var(--spacing-2xl) 0}.interests-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.interest-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-md);transition:all var(--transition-normal)}.interest-card:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-md);transform:translateY(-4px)}.interest-card h3{color:var(--heading-primary);font-size:1.1rem;margin:0 0 .5rem}.interest-card p{color:var(--text-muted);font-size:.9rem;margin:0}.contact-section{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin:var(--spacing-2xl) 0 var(--spacing-lg);padding:var(--spacing-xl);text-align:center}.contact-section p{color:var(--text-secondary);font-size:1.05rem;margin-bottom:var(--spacing-lg)}.contact-social-links{display:flex;gap:var(--spacing-lg);justify-content:center}.contact-social-links a{align-items:center;background:var(--accent-mint);border:1px solid var(--accent-mint-dark);border-radius:var(--radius-pill);color:var(--primary);display:flex;font-size:2rem;height:3.5rem;justify-content:center;padding:.75rem;transition:all var(--transition-normal);width:3.5rem}.contact-social-links a:hover{background:var(--primary);box-shadow:var(--shadow-md);color:#fff;transform:translateY(-3px)}@media (max-width:768px){.about-container{padding:var(--spacing-sm)}.section-heading{font-size:1.5rem}.stats-grid{grid-template-columns:1fr 1fr}.stack-grid{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}.skills-container{align-items:center;background:var(--bg-light);color:var(--text-primary);display:flex;flex-direction:column;gap:var(--spacing-lg);min-height:100vh;padding:var(--spacing-lg)}.interactive-header{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);max-width:1400px;padding:var(--spacing-xl) var(--spacing-lg);width:100%}.header-content{margin:0 auto;max-width:800px;text-align:center}.header-content h1{color:var(--heading-primary);font-size:2.25rem;font-weight:800;letter-spacing:-.02em;margin-bottom:var(--spacing-sm)}.skills-subtitle{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-bottom:var(--spacing-md);text-align:center}.floating-words{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.floating-word{background:var(--accent-mint);border:1px solid var(--accent-mint-dark);border-radius:var(--radius-pill);color:var(--primary);cursor:default;font-size:.88rem;font-weight:600;padding:.4rem 1rem;transition:all var(--transition-normal)}.floating-word:hover{background:var(--accent-mint-dark);transform:translateY(-2px)}.search-container{margin:0 auto;margin-bottom:var(--spacing-md);max-width:600px;position:relative;width:100%}.search-icon{color:var(--text-muted);font-size:.9rem;left:var(--spacing-sm);position:absolute;top:50%;transform:translateY(-50%)}.search-container input{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);color:var(--text-primary);font-size:.95rem;height:auto;padding:.85rem 1rem .85rem 2.75rem;transition:all var(--transition-normal);width:100%}.search-container input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b43321a;outline:none}.search-container input::placeholder{color:var(--text-muted)}.filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:var(--spacing-md) auto;max-width:900px}.filter-button{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-secondary);cursor:pointer;font-size:.88rem;font-weight:500;min-width:auto;padding:.5rem 1.15rem;transition:all var(--transition-normal)}.filter-button:hover{background:var(--accent-mint);border-color:var(--accent-mint-dark);color:var(--primary)}.filter-button.active{background:var(--gradient-primary);border-color:#0000;box-shadow:var(--shadow-sm);color:#fff}.skills-list{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));width:100%}.skill-item{align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;padding:var(--spacing-md);transition:all var(--transition-normal)}.skill-item:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-md);transform:translateY(-3px)}.skill-icon-container{align-items:center;background:var(--accent-mint);border-radius:var(--radius-md);color:var(--primary);display:flex;flex-shrink:0;font-size:1.5rem;justify-content:center;margin-right:var(--spacing-sm);padding:.7rem}.skill-info h3{color:var(--text-primary);font-size:.95rem;font-weight:600;margin:0}.skill-category{color:var(--text-muted);font-size:.8rem;font-weight:400}@media (max-width:768px){.skills-container{padding:var(--spacing-sm)}.interactive-header{padding:var(--spacing-md)}.header-content h1{font-size:1.75rem}.skills-list{grid-template-columns:1fr}.filter-buttons{gap:.4rem}.filter-button{font-size:.82rem;padding:.4rem .9rem}}.projects-page{background:var(--bg-light);display:flex;flex-direction:column;height:calc(100vh - var(--nav-height));overflow:hidden;padding:1.5vmin 2vw}.projects-header{flex-shrink:0;margin:0 auto;max-width:640px;padding:1.5vmin 0 2vmin;text-align:center}.projects-header h1{color:var(--heading-primary);font-size:clamp(1.5rem,2.8vmin,2.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:.4rem}.projects-tagline{color:var(--text-muted);font-size:clamp(.8rem,1.4vmin,1rem);line-height:1.5;margin:0 auto;max-width:520px}.grid-wrapper{align-items:center;display:flex;flex:1 1;justify-content:center;margin:0 auto;max-width:1200px;min-height:0;position:relative;width:100%}.projects-grid{grid-gap:clamp(.5rem,1vmin,1rem);display:grid;gap:clamp(.5rem,1vmin,1rem);grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);height:100%;max-height:100%;width:100%}.project-tile{background:var(--tile-bg);border:1px solid #0000000a;border-radius:clamp(.75rem,1.5vmin,1.25rem);cursor:pointer;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:clamp(.75rem,1.5vmin,1.5rem);position:relative;transition:box-shadow .3s ease,border-color .3s ease}.project-tile:hover{border-color:#00000014;box-shadow:0 16px 40px #0000001a,0 4px 12px #0000000f}.tile-ppm-wide{grid-column:span 2}.tile-content{display:flex;flex-direction:column;height:100%;justify-content:space-between;min-height:0;position:relative;z-index:2}.tile-header-group{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.tile-badge{background:#e2ff90;border:1px solid #17332d;border-radius:6px;box-shadow:2px 2px 0 0 #17332d;color:#17332d;font-size:.65rem;font-weight:700;letter-spacing:.05em;padding:.3rem .6rem;position:relative;text-transform:uppercase;z-index:3}.tile-hero .tile-badge,.tile-ppm-wide .tile-badge{background:#e2ff90;border-color:#17332d;box-shadow:2px 2px 0 0 #00000080;color:#17332d}.tile-top{align-items:flex-start;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:.5rem}.tile-icon{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;border:1px solid #ffffff80;border-radius:clamp(.4rem,.8vmin,.75rem);box-shadow:0 2px 8px #0000000f;display:flex;font-size:clamp(.9rem,1.8vmin,1.35rem);height:clamp(2rem,3.5vmin,3rem);justify-content:center;width:clamp(2rem,3.5vmin,3rem)}.tile-icon,.tile-year{color:var(--tile-accent)}.tile-year{font-size:clamp(.55rem,1vmin,.75rem);font-weight:600;letter-spacing:.04em;opacity:.5}.tile-body{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:0;overflow:hidden;padding:.25rem 0}.tile-title{color:var(--tile-accent);font-family:var(--font-heading);font-size:clamp(.95rem,2vmin,1.5rem);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin-bottom:clamp(.15rem,.4vmin,.35rem)}.tile-tagline{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--tile-accent);display:-webkit-box;font-size:clamp(.6rem,1.1vmin,.82rem);font-weight:500;line-height:1.35;margin:0;opacity:.55;overflow:hidden}.tile-bottom{align-items:flex-end;display:flex;flex-shrink:0;justify-content:space-between}.tile-tech{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(.5rem,.8vmin,.75rem)}.tile-tech-pill{background:#fff;border:2px solid #17332d;border-radius:6px;box-shadow:2px 3px 0 0 #17332d;color:#17332d;cursor:default;flex-shrink:0;font-family:Inter,sans-serif;font-family:var(--font-heading,"Inter",sans-serif);font-size:clamp(.65rem,1vmin,.75rem);font-weight:600;line-height:1.2;margin-bottom:4px;padding:.35rem .8rem;transition:all .15s ease;white-space:nowrap}.tile-tech-pill:hover{box-shadow:0 0 0 0 #17332d;transform:translateY(3px)}.tile-arrow{align-items:center;background:var(--tile-accent);border-radius:50%;color:var(--tile-bg);display:flex;flex-shrink:0;font-size:clamp(.5rem,.9vmin,.7rem);height:clamp(1.5rem,2.5vmin,2rem);justify-content:center;opacity:0;transform:translateX(-8px);transition:all .3s ease;width:clamp(1.5rem,2.5vmin,2rem)}.project-tile:hover .tile-arrow{opacity:1;transform:translateX(0)}.tile-hero{--tile-accent:#fff}.tile-photo-bg{border-radius:inherit;inset:0;overflow:hidden;position:absolute;z-index:0}.tile-photo-bg img{filter:saturate(.45) brightness(.92);height:100%;object-fit:cover;object-position:center top;opacity:.35;transform:scale(1.05);transition:opacity .4s ease,filter .4s ease,transform .5s ease;width:100%}.tile-hero .tile-photo-bg:after{background:linear-gradient(160deg,#1b433266,#1b433233 40%,#1b43321a);content:"";inset:0;position:absolute;transition:opacity .4s ease;z-index:1}.tile-hero:hover .tile-photo-bg img{filter:saturate(.9) brightness(.9);opacity:.8;transform:scale(1)}.tile-hero:hover .tile-photo-bg:after{background:linear-gradient(160deg,#1b4332bd,#1b433280 50%,#1b433238)}.tile-hero .tile-icon{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff3;border-color:#ffffff40;box-shadow:0 4px 12px #0006;color:#fff}.tile-hero .tile-title{color:#fff;text-shadow:0 2px 4px #000000b3}.tile-hero .tile-tagline{color:#fffffff2;font-weight:500;opacity:1;text-shadow:0 1px 4px #000c}.tile-hero .tile-year{color:#ffffffb3;opacity:1}.tile-hero .tile-arrow{background:#fff;color:var(--primary)}.tile-decoration{background:#ffffff2e;border-radius:50%;bottom:-30%;height:60%;right:-20%;width:60%;z-index:1}.callout,.tile-decoration{pointer-events:none;position:absolute}.callout{align-items:center;display:flex;gap:.4rem;z-index:10}.callout-arrow{height:clamp(22px,3vmin,32px);width:clamp(40px,5vmin,60px)}.callout-label{border-radius:var(--radius-pill);font-family:var(--font-heading);font-size:clamp(.65rem,1.1vmin,.82rem);font-weight:700;letter-spacing:-.01em;padding:.3rem .75rem;white-space:nowrap}.callout-award{color:#92400e}.callout-tile-0{flex-direction:row;left:-.5rem;top:2%;transform:translateX(calc(-100% - .25rem))}.callout-tile-0 .callout-label{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.callout-tile-0 .callout-arrow{transform:rotate(-10deg)}.callout-publication{color:#1b4332}.callout-tile-1{flex-direction:row-reverse;right:-.5rem;top:2%;transform:translateX(calc(100% + .25rem))}.callout-tile-1 .callout-label{background:#e8f5e9;border:1px solid #95d5b2;color:#1b4332}.callout-tile-1 .callout-arrow{transform:scaleX(-1) rotate(10deg)}.callout-research{color:#1b5e20}.callout-tile-5{flex-direction:row-reverse;right:-.5rem;top:50%;transform:translateX(calc(100% + .25rem)) translateY(-50%)}.callout-tile-5 .callout-label{background:#d8f3dc;border:1px solid #95d5b2;color:#1b5e20}.callout-tile-5 .callout-arrow{transform:scaleX(-1) rotate(-5deg)}.callout-mainresearch{color:#60a5fa}.callout-tile-6{bottom:6%;flex-direction:row;left:-.5rem;transform:translateX(calc(-100% - .25rem))}.callout-tile-6 .callout-label{background:#0f172a;border:1px solid #334155;color:#60a5fa}.callout-tile-6 .callout-arrow{transform:rotate(10deg)}@media (max-width:1300px){.callout{display:none}}@media (max-width:900px){.projects-page{height:auto;min-height:calc(100vh - var(--nav-height));overflow:auto;padding:var(--spacing-lg) var(--spacing-sm);padding-bottom:var(--spacing-2xl)}.grid-wrapper{align-items:flex-start}.projects-grid{gap:.85rem;grid-template-columns:repeat(2,1fr);grid-template-rows:auto;height:auto}.project-tile{aspect-ratio:1/.85}.projects-header{padding:var(--spacing-sm) 0 var(--spacing-md)}.tile-ppm-wide{grid-column:span 2}}@media (max-width:600px){.projects-page{padding:var(--spacing-md) var(--spacing-sm);padding-bottom:var(--spacing-xl)}.projects-grid{gap:.75rem;grid-template-columns:1fr}.tile-ppm-wide{grid-column:span 1}.project-tile{aspect-ratio:auto;min-height:170px;padding:1.25rem}.tile-title{font-size:1.2rem}.tile-tagline{font-size:.78rem}.projects-header{padding:var(--spacing-xs) 0 var(--spacing-sm)}.projects-header h1{font-size:1.65rem}.projects-tagline{font-size:.85rem}.tile-arrow{opacity:1;transform:translateX(0)}.tile-icon{font-size:1.1rem;height:2.5rem;width:2.5rem}.tile-tech{gap:.4rem}.tile-tech-pill{box-shadow:0 2px 0 0 #1b4332;font-size:.6rem;padding:.2rem .5rem}}@media (max-width:400px){.project-tile{min-height:155px;padding:1rem}.tile-title{font-size:1.05rem}.tile-tagline{font-size:.7rem}.tile-tech{gap:.35rem}.tile-tech-pill{box-shadow:0 2px 0 0 #1b4332;font-size:.55rem;padding:.18rem .45rem}.tile-icon{font-size:1rem;height:2.25rem;width:2.25rem}}@media (min-height:1000px) and (min-width:901px){.projects-grid{max-height:80vh}}@media (max-height:650px) and (min-width:901px){.projects-header{padding:.5rem 0 .75rem}.projects-header h1{font-size:1.3rem;margin-bottom:.2rem}.projects-tagline{font-size:.75rem}.projects-page{padding:.5rem 2vw}}.project-detail{background:var(--bg-light);margin:0 auto;max-width:820px;min-height:100vh;padding:var(--spacing-lg)}.back-button{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;margin-bottom:var(--spacing-lg);padding:.5rem 0;transition:color .2s ease}.back-button:hover{color:var(--primary)}.detail-hero{background:var(--detail-bg);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);overflow:hidden;padding:2.5rem;position:relative}.detail-hero-decoration{background:#fff3;border-radius:50%;height:100%;pointer-events:none;position:absolute;right:-15%;top:-40%;width:55%}.detail-hero-content{align-items:flex-start;display:flex;gap:var(--spacing-lg);position:relative;z-index:2}.detail-hero-icon{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;border:1px solid #fff6;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000f;color:var(--detail-accent);display:flex;flex-shrink:0;font-size:1.75rem;height:4rem;justify-content:center;width:4rem}.detail-hero-text{flex:1 1}.detail-badge{border-radius:var(--radius-pill);display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.02em;margin-bottom:.75rem;padding:.3rem .8rem}.detail-badge-award{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.detail-badge-research{background:#d8f3dc;border:1px solid #95d5b2;color:#1b5e20}.detail-badge-publication{background:#e8f5e9;border:1px solid #95d5b2;color:#1b4332}.detail-hero-pub{min-height:220px;overflow:hidden;position:relative}.detail-hero-photo{border-radius:inherit;inset:0;overflow:hidden;position:absolute;z-index:0}.detail-hero-photo img{filter:saturate(.4) brightness(.8);height:100%;object-fit:cover;object-position:center 30%;opacity:.35;width:100%}.detail-hero-pub .detail-hero-decoration{background:linear-gradient(160deg,#1b4332cc,#1b433280 50%,#1b433240);border-radius:0;height:100%;inset:0;position:absolute;right:0;top:0;width:100%}.detail-hero-pub .detail-hero-content{position:relative;z-index:2}.detail-hero-pub .detail-hero-icon{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff3;border-color:#ffffff40;color:#fff}.detail-hero-pub h1{color:#fff;text-shadow:0 2px 10px #0000004d}.detail-hero-pub .detail-hero-tagline{color:#ffffffd9;text-shadow:0 1px 4px #0003}.detail-hero-pub .detail-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-color:#ffffff4d;color:#fff}.detail-pub-info{background:var(--bg-white);border:1px solid var(--accent-mint-dark)}.pub-meta-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.pub-meta-item{align-items:flex-start;display:flex;gap:.75rem}.pub-meta-item>svg{color:var(--primary);flex-shrink:0;font-size:1rem;margin-top:.2rem}.pub-meta-item>div{display:flex;flex-direction:column;gap:.15rem}.pub-meta-label{color:var(--text-muted);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.pub-meta-value{color:var(--text-primary);font-size:.92rem;font-weight:500;line-height:1.4}.pub-award{color:var(--primary);font-weight:700}.contributions-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.contribution-card{background:var(--bg-section);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md);transition:all .2s ease}.contribution-card:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.contribution-card h4{color:var(--primary);font-size:.9rem;font-weight:700;margin-bottom:.4rem}.contribution-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.6;margin:0}.detail-hero h1{color:var(--detail-accent);font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:.5rem}.detail-hero-tagline{color:var(--detail-accent);font-size:1.05rem;font-weight:500;margin:0;opacity:.6}.detail-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-meta{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:var(--spacing-md);padding:var(--spacing-md)}.meta-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.88rem;font-weight:500;gap:.5rem}.meta-item svg{color:var(--accent-green-soft);font-size:.85rem}.detail-section{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg)}.detail-section h2{color:var(--heading-primary);font-size:1.1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:var(--spacing-sm)}.detail-description{color:var(--text-secondary);font-size:.95rem;line-height:1.8;margin:0}.detail-impact{background:var(--bg-section);border-color:var(--accent-mint-dark)}.detail-impact p{color:var(--primary);font-size:1rem;font-weight:600;line-height:1.6;margin:0}.detail-tech-grid{display:flex;flex-wrap:wrap;gap:.45rem}.detail-tech-pill{background:var(--accent-mint);border:1px solid var(--accent-mint-dark);border-radius:var(--radius-pill);color:var(--primary);font-size:.82rem;font-weight:600;padding:.4rem .9rem;transition:all .2s ease}.detail-tech-pill:hover{background:var(--accent-mint-dark);transform:translateY(-1px)}.detail-tags{display:flex;flex-wrap:wrap;gap:.4rem}.detail-tag{background:var(--bg-section);border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-secondary);font-size:.8rem;font-weight:500;padding:.35rem .85rem}.detail-cta{padding-top:var(--spacing-sm)}.detail-link-button{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);color:#fff;display:inline-flex;font-size:.95rem;font-weight:600;gap:.6rem;padding:.9rem 2rem;text-decoration:none;transition:all .25s ease}.detail-link-button:hover{box-shadow:var(--shadow-lg);color:#fff;transform:translateY(-2px)}.detail-not-found{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:60vh}.detail-not-found h2{color:var(--text-muted)}.detail-not-found a{color:var(--primary);font-weight:600}.case-study-block{display:flex;flex-direction:column;gap:.75rem}.cs-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.05em;margin-bottom:.25rem;opacity:.7;text-transform:uppercase}.cs-problem{background:#fff5f5;border-left:3px solid #e53e3e;border-radius:0 6px 6px 0;color:#742a2a;padding:.75rem 1rem}.cs-problem .cs-label{color:#c53030}.cs-implementation{background:#ebf8ff;border-left:3px solid #3182ce;border-radius:0 6px 6px 0;color:#2c5282;padding:.75rem 1rem}.cs-implementation .cs-label{color:#2b6cb0}.cs-result{background:#f0fff4;border-left:3px solid #38a169;border-radius:0 6px 6px 0;color:#276749;padding:.75rem 1rem}.cs-result .cs-label{color:#2f855a}.key-stats-container{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:var(--spacing-xl)}.stat-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);justify-content:center;text-align:center;transition:all .3s ease}.stat-card:hover{border-color:var(--detail-accent)}.stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--detail-accent) 0,var(--primary) 100%);-webkit-background-clip:text;color:var(--detail-accent);font-size:2rem;font-weight:800;line-height:1;margin-bottom:.5rem}.stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}@media (max-width:768px){.project-detail{padding:var(--spacing-sm)}.detail-hero{padding:1.5rem}.detail-hero-content{flex-direction:column;gap:var(--spacing-sm)}.detail-hero h1{font-size:1.5rem}.detail-meta{flex-direction:column;gap:var(--spacing-sm)}.detail-section{padding:var(--spacing-md)}.detail-link-button{justify-content:center;width:100%}}.research-page{background:var(--bg-light);min-height:100vh;padding-bottom:6rem}.research-back{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;border:1px solid var(--border-light);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);color:var(--text-secondary);cursor:pointer;display:flex;font-size:.82rem;font-weight:600;gap:.5rem;left:clamp(1rem,3vw,2.5rem);padding:.5rem 1rem;position:fixed;top:calc(var(--nav-height) + 1rem);transition:all .2s ease;z-index:50}.research-back:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-md);color:var(--primary)}.research-hero{align-items:center;background:radial-gradient(ellipse at 20% 50%,#0f172a0a 0,#0000 60%),radial-gradient(ellipse at 80% 30%,#3b82f60a 0,#0000 50%),var(--bg-light);flex-direction:column;min-height:calc(100vh - var(--nav-height));overflow:hidden;padding:4rem 2rem 3rem;position:relative;text-align:center}.hero-badges,.research-hero{display:flex;justify-content:center}.hero-badges{flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}.hero-badge{align-items:center;border-radius:var(--radius-pill);display:inline-flex;font-size:.72rem;font-weight:700;gap:.4rem;letter-spacing:.02em;padding:.35rem .85rem;text-transform:uppercase}.badge-sfsu{background:#e8f5e9;border:1px solid #a5d6a7;color:#1b5e20}.badge-aws{background:#fff3e0;border:1px solid #ffcc02;color:#e65100}.badge-pilot{background:#e3f2fd;border:1px solid #90caf9;color:#1565c0}.hero-title{color:var(--text-primary);font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin-bottom:1.5rem}.hero-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1b4332,#3b82f6);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.7;margin-bottom:2rem;max-width:650px}.hero-subtitle strong{color:var(--text-primary);font-weight:700}.hero-meta{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.85rem;font-weight:500;gap:.5rem;justify-content:center}.hero-divider{color:var(--border-light)}.scroll-indicator{color:var(--text-muted);font-size:1.2rem;margin-top:3rem;opacity:.5}.research-section{margin:0 auto;max-width:900px;padding:4rem 2rem}.section-label{background:var(--accent-mint);border-radius:var(--radius-pill);color:var(--primary);display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.1em;margin-bottom:1rem;padding:.3rem .8rem;text-transform:uppercase}.research-section h2{color:var(--text-primary);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:1rem}.section-lead{color:var(--text-secondary);font-size:clamp(.95rem,1.3vw,1.05rem);line-height:1.75;margin-bottom:2.5rem;max-width:700px}.section-lead strong{color:var(--text-primary);font-weight:700}.problem-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.problem-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1.5rem;transition:all .25s ease}.problem-card:hover{border-color:#fca5a5;box-shadow:0 8px 24px #ef444414;transform:translateY(-3px)}.problem-icon{color:#ef4444;font-size:1.4rem;margin-bottom:.75rem}.problem-card h4{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:.4rem}.problem-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.vision-pillars{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.pillar{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1.5rem;text-align:center;transition:all .25s ease}.pillar:hover{border-color:var(--accent-mint-dark);box-shadow:var(--shadow-md);transform:translateY(-3px)}.pillar-icon{color:var(--primary);font-size:2rem;margin-bottom:.75rem}.pillar h4{color:var(--text-primary);font-size:.95rem;font-weight:700;margin-bottom:.4rem}.pillar p{color:var(--text-secondary);font-size:.82rem;line-height:1.6}.arch-section{max-width:900px}.arch-diagram{display:flex;flex-direction:column;gap:0}.arch-layer{background:var(--bg-white);border:2px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;margin-bottom:0;padding:1.25rem 1.5rem;position:relative;transition:all .25s ease}.arch-layer:hover{border-color:var(--layer-color);box-shadow:0 4px 20px #0000000f}.arch-layer-active{border-color:var(--layer-color);box-shadow:0 4px 24px #00000014}.arch-layer-header{align-items:center;display:flex;gap:.85rem}.arch-layer-num{color:var(--layer-color);font-family:monospace;font-family:var(--font-mono,monospace);font-size:.7rem;font-weight:800;opacity:.5}.arch-layer-icon{color:var(--layer-color);font-size:1.3rem}.arch-layer-title{color:var(--text-primary);flex:1 1;font-size:.95rem;font-weight:700}.arch-chevron{color:var(--text-muted);font-size:.75rem;transition:transform .3s ease}.arch-chevron.rotated{transform:rotate(180deg)}.arch-layer-detail{overflow:hidden}.arch-layer-desc{color:var(--text-secondary);font-size:.85rem;line-height:1.65;margin:1rem 0;padding-left:2.8rem}.arch-nodes{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));padding-bottom:.5rem;padding-left:2.8rem}.arch-node{align-items:center;background:var(--bg-section);border:1px solid var(--border-light);border-radius:var(--radius-md);display:flex;flex-direction:column;padding:1rem .75rem;text-align:center;transition:all .2s ease}.arch-node:hover{border-color:var(--layer-color);box-shadow:0 4px 12px #0000000f;transform:translateY(-2px)}.arch-node-icon{color:var(--layer-color);font-size:1.6rem;margin-bottom:.5rem}.arch-node-label{color:var(--text-primary);font-size:.82rem;font-weight:700}.arch-node-sub{color:var(--text-muted);font-size:.7rem;margin-top:.15rem}.arch-connector{align-items:center;display:flex;flex-direction:column;height:28px;position:relative}.connector-line{background:linear-gradient(to bottom,var(--border-light),var(--accent-mint-dark));flex:1 1;width:2px}.connector-dot{background:var(--accent-mint-dark);border-radius:50%;height:8px;width:8px}.swarm-diagram{align-items:center;display:flex;flex-direction:column;gap:0;margin-bottom:3rem}.swarm-agent{background:var(--bg-white);border:2px solid var(--border-light);border-radius:var(--radius-lg);max-width:320px;padding:1.5rem;position:relative;text-align:center;transition:all .25s ease;width:100%}.swarm-agent:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.swarm-orchestrator{background:linear-gradient(135deg,#fffbeb 0,var(--bg-white) 100%);border-color:#f59e0b}.swarm-ppm{background:linear-gradient(135deg,#ecfdf5 0,var(--bg-white) 100%);border-color:#10b981}.swarm-mcp{background:linear-gradient(135deg,#f5f3ff 0,var(--bg-white) 100%);border-color:#8b5cf6}.swarm-agent-icon{align-items:center;border-radius:50%;display:flex;font-size:1.3rem;height:48px;justify-content:center;margin:0 auto .75rem;width:48px}.swarm-orchestrator .swarm-agent-icon{background:#fef3c7;color:#d97706}.swarm-ppm .swarm-agent-icon{background:#d1fae5;color:#059669}.swarm-mcp .swarm-agent-icon{background:#ede9fe;color:#7c3aed}.swarm-agent h4{color:var(--text-primary);font-size:.95rem;font-weight:700;margin-bottom:.3rem}.swarm-agent p{color:var(--text-secondary);font-size:.8rem;line-height:1.5}.swarm-tag{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-pill);color:var(--text-muted);font-size:.65rem;font-weight:700;letter-spacing:.05em;padding:.2rem .6rem;position:absolute;right:1rem;text-transform:uppercase;top:-.5rem}.swarm-arrows{display:flex;gap:4rem;padding:.75rem 0}.swarm-arrow{align-items:center;color:var(--text-muted);display:flex;flex-direction:column}.swarm-arrow span{font-size:.65rem;font-weight:600;letter-spacing:.05em;margin-bottom:.2rem;text-transform:uppercase}.swarm-arrow:after{background:var(--border-light);content:"";display:block;height:20px;width:2px}.swarm-bottom{display:flex;gap:1.5rem}.tools-heading{margin-bottom:1.5rem;text-align:center}.tools-heading h3{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin-bottom:.3rem}.tools-heading p{color:var(--text-muted);font-size:.85rem}.tools-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.tool-card{align-items:flex-start;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:.6rem;padding:.85rem 1rem;transition:all .2s ease}.tool-card:hover{border-color:var(--accent-mint-dark);transform:translateY(-1px)}.tool-check{color:#10b981;flex-shrink:0;font-size:.85rem;margin-top:.15rem}.tool-card strong{color:var(--text-primary);display:block;font-size:.82rem;margin-bottom:.1rem}.tool-card span{color:var(--text-muted);font-size:.73rem;line-height:1.4}.contrib-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}.contrib-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1.5rem;transition:all .25s ease}.contrib-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-3px)}.contrib-icon{align-items:center;background:var(--accent-mint);border-radius:var(--radius-sm);color:var(--primary);display:flex;font-size:1.1rem;height:42px;justify-content:center;margin-bottom:1rem;width:42px}.contrib-card h4{color:var(--text-primary);font-size:.95rem;font-weight:700;margin-bottom:.4rem}.contrib-card p{color:var(--text-secondary);font-size:.82rem;line-height:1.65}.metrics-section{text-align:center}.metrics-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);display:flex;flex-direction:column;padding:1.5rem 1rem;transition:all .25s ease}.stat-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-number{color:var(--primary);font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:900;letter-spacing:-.03em;line-height:1;margin-bottom:.4rem}.stat-label{color:var(--text-muted);font-size:.75rem;font-weight:500;line-height:1.3;text-align:center}.stack-categories{display:flex;flex-direction:column;gap:1.5rem}.stack-category{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:1.25rem 1.5rem}.stack-category h4{align-items:center;color:var(--text-primary);display:flex;font-size:.85rem;font-weight:700;gap:.5rem;margin-bottom:.75rem}.stack-category h4 svg{color:var(--primary)}.stack-pills{display:flex;flex-wrap:wrap;gap:.5rem}.stack-pill{background:var(--accent-mint);border:1px solid var(--accent-mint-dark);border-radius:var(--radius-pill);color:var(--primary);font-size:.75rem;font-weight:600;padding:.3rem .7rem;transition:all .2s ease}.stack-pill:hover{background:var(--primary);color:#fff}.timeline{padding-left:2rem;position:relative}.timeline:before{background:linear-gradient(to bottom,var(--border-light),var(--primary),var(--border-light));bottom:0;content:"";left:0;position:absolute;top:0;width:2px}.timeline-item{padding-bottom:2.5rem;padding-left:1.5rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--bg-white);border:3px solid var(--border-light);border-radius:50%;height:12px;left:-2.55rem;position:absolute;top:.25rem;transition:all .3s ease;width:12px}.timeline-active .timeline-dot{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 4px #1b433226}.timeline-period{color:var(--primary);display:block;font-size:.72rem;font-weight:700;letter-spacing:.06em;margin-bottom:.3rem;text-transform:uppercase}.timeline-content h4{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:.5rem}.timeline-content ul{display:flex;flex-direction:column;gap:.3rem;list-style:none;padding:0}.timeline-content li{color:var(--text-secondary);font-size:.82rem;line-height:1.5;padding-left:1.2rem;position:relative}.timeline-content li:before{background:var(--accent-mint-dark);border-radius:50%;content:"";height:5px;left:0;position:absolute;top:.55em;width:5px}.cta-section{border-top:1px solid var(--border-light);padding-bottom:4rem;padding-top:3rem;text-align:center}.cta-section h2{margin-bottom:1.5rem}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-btn{align-items:center;border:2px solid #0000;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:700;gap:.6rem;padding:.85rem 1.75rem;text-decoration:none;transition:all .25s ease}.cta-primary{background:var(--primary);border-color:var(--primary);color:#fff}.cta-primary:hover{background:#0000;box-shadow:var(--shadow-md);color:var(--primary);transform:translateY(-2px)}.cta-secondary{background:#0000;border-color:var(--border-light);color:var(--text-primary)}.cta-secondary:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}@media (max-width:768px){.research-hero{min-height:auto;padding:5rem 1.5rem 3rem}.hero-title{font-size:clamp(2rem,8vw,3rem)}.research-section{padding:3rem 1.25rem}.arch-nodes{grid-template-columns:repeat(2,1fr)}.arch-layer-desc,.arch-nodes{padding-left:0}.swarm-bottom{align-items:center;flex-direction:column}.swarm-arrows{gap:2rem}.contrib-grid,.tools-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}.hero-meta{flex-direction:column;gap:.2rem}.hero-divider{display:none}.research-back{left:auto;margin:1rem 1.25rem 0;position:relative;top:auto}}@media (max-width:480px){.arch-nodes,.metrics-grid{grid-template-columns:1fr}.hero-badges{align-items:center;flex-direction:column}}
/*# sourceMappingURL=main.9f496960.css.map*/