:root{--bg-color:#f8f9fa;--text-color:#2d3748;--text-secondary:#4a5568;--text-muted:#718096;--border-color:#e2e8f0;--hover-bg:#edf2f7;--code-bg:#f7fafc;--code-border:#e2e8f0;--link-color:#1e40af;--link-hover:#1d4ed8;--accent-primary:#1e40af;--accent-secondary:#f97316;--accent-hover:#fb923c;--font-size-xs:12px;--font-size-sm:14px;--font-size-base:17px;--font-size-lg:18px;--font-size-xl:22px;--font-size-2xl:28px;--font-size-3xl:36px;--font-size-4xl:48px;--spacing-xs:8px;--spacing-sm:16px;--spacing-md:24px;--spacing-lg:40px;--spacing-xl:60px;--spacing-2xl:80px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #00000026;--terminal-bg:#0d1117;--terminal-text:#39ff14;--terminal-header:#21262d;--terminal-border:#30363d;--control-close:#ff5f56;--control-minimize:#ffbd2e;--control-maximize:#27ca3f}.dark-mode{--bg-color:#1a202c;--text-color:#e2e8f0;--text-secondary:#cbd5e0;--text-muted:#a0aec0;--border-color:#4a5568;--hover-bg:#2d3748;--code-bg:#2d3748;--code-border:#4a5568;--link-color:#14b8a6;--link-hover:#0d9488;--accent-primary:#14b8a6;--accent-secondary:#fb923c;--accent-hover:#fcd34d}*{-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box;margin:0;padding:0;perspective:1000}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{-webkit-overflow-scrolling:touch;background-color:#f8f9fa;background-color:var(--bg-color);flex:1 1;touch-action:pan-y}code{font-family:JetBrains Mono,Monaco,Menlo,Ubuntu Mono,monospace}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga" 1,"calt" 1;-webkit-overflow-scrolling:touch;background-color:#f8f9fa;background-color:var(--bg-color);color:#2d3748;color:var(--text-color);font-family:Fira Code,Source Code Pro,JetBrains Mono,Monaco,Menlo,Ubuntu Mono,monospace;font-size:17px;font-size:var(--font-size-base);font-weight:400;line-height:1.6;overscroll-behavior-y:contain;scroll-behavior:smooth;text-rendering:optimizeLegibility;transition:background-color .3s ease,color .3s ease}.container{margin:0 auto;max-width:1000px;padding:0 40px;padding:0 var(--spacing-lg)}.header{background:#f8f9fa;background:var(--bg-color);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);contain:layout style;padding:0;position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease,border-color .3s ease;will-change:transform;z-index:100}.header-content{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;max-width:1000px;padding:0 40px;padding:0 var(--spacing-lg)}.logo{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:500;text-decoration:none;transition:color .3s ease}.nav{align-items:center;display:flex;gap:24px;gap:var(--spacing-md)}.nav a{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);font-weight:400;text-decoration:none;text-transform:lowercase;transition:color .2s ease}.nav a:hover{color:#1e40af;color:var(--accent-primary)}.blog-hero{margin-bottom:24px;margin-bottom:var(--spacing-md);padding:24px 0 16px;padding:var(--spacing-md) 0 var(--spacing-sm) 0;text-align:center}.blog-subtitle{color:#2d3748;color:var(--text-color);font-size:28px;font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;line-height:1.2;margin-bottom:16px;margin-bottom:var(--spacing-sm)}.blog-description{color:#4a5568;color:var(--text-secondary);font-size:18px;font-size:var(--font-size-lg);font-weight:400;line-height:1.6;margin:0 auto;max-width:600px}.blog-list{margin:0 auto;max-width:1000px}.blog-item{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);contain:layout style;padding:16px 0;padding:var(--spacing-sm) 0;transition:background-color .2s ease,transform .2s ease;will-change:transform}.blog-item:hover{background-color:#edf2f7;background-color:var(--hover-bg);margin:0 -24px;margin:0 calc(var(--spacing-md)*-1);padding:16px 24px;padding:var(--spacing-sm) var(--spacing-md)}.blog-item:last-child{border-bottom:none}.blog-item-content{display:flex;flex-direction:column}.blog-item-header{align-items:baseline;display:flex;flex-direction:row;gap:16px;gap:var(--spacing-sm)}.blog-item-title{color:#2d3748;color:var(--text-color);flex:1 1;font-size:18px;font-size:var(--font-size-lg);font-weight:600;line-height:1.3;margin:0}.blog-item-link{color:inherit;text-decoration:none}.blog-item-link:hover{color:#1e40af;color:var(--accent-primary)}.blog-item-excerpt{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.5;margin-bottom:8px;margin-bottom:var(--spacing-xs)}.blog-item-date{color:#718096;color:var(--text-muted);flex-shrink:0;font-size:12px;font-size:var(--font-size-xs);font-weight:400;line-height:1.3;white-space:nowrap}.blog-post{margin:0 auto;max-width:650px}.blog-post-image{border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:4px;border-radius:var(--radius-sm);height:300px;margin-bottom:24px;margin-bottom:var(--spacing-md);object-fit:cover;width:100%}.blog-post-content{padding:40px 0 0;padding:var(--spacing-lg) 0 0 0;text-align:left}.blog-post-title{color:#2d3748;color:var(--text-color);font-size:22px;font-size:var(--font-size-xl);font-weight:600;letter-spacing:-.01em;line-height:1.3;margin-bottom:8px;margin-bottom:var(--spacing-xs);text-align:center}.blog-post-date{margin-bottom:24px;margin-bottom:var(--spacing-md);text-align:left}.blog-post-date,.blog-share-button{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);font-weight:400}.blog-share-button{align-items:center;background:#0000;border:none;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;gap:8px;gap:var(--spacing-xs);padding:0;text-decoration:none;text-transform:lowercase;transition:all .2s ease}.blog-share-button:hover{color:#1e40af;color:var(--accent-primary)}.blog-share-button svg{flex-shrink:0}.blog-post-back{align-items:center;display:flex;gap:24px;gap:var(--spacing-md);justify-content:center}.blog-post-body{color:#2d3748;color:var(--text-color);font-size:.95rem;font-weight:400;line-height:1.7;text-align:left}.blog-post-body h2{font-size:22px;font-size:var(--font-size-xl);margin:40px 0 16px;margin:var(--spacing-lg) 0 var(--spacing-sm) 0}.blog-post-body h2,.blog-post-body h3{color:#2d3748;color:var(--text-color);font-weight:600}.blog-post-body h3{font-size:18px;font-size:var(--font-size-lg);margin:24px 0 16px;margin:var(--spacing-md) 0 var(--spacing-sm) 0}.blog-post-body p{color:#2d3748;color:var(--text-color);margin-bottom:16px;margin-bottom:var(--spacing-sm)}.blog-post-body a{border-bottom:1px solid #4a5568;border-bottom:1px solid var(--text-secondary);color:#4a5568;color:var(--text-secondary);text-decoration:none;transition:all .2s ease}.blog-post-body a:hover{border-bottom-color:#1e40af;border-bottom-color:var(--accent-primary);color:#1e40af;color:var(--accent-primary)}.blog-post-body ol,.blog-post-body ul{margin:16px 0;margin:var(--spacing-sm) 0;padding-left:24px;padding-left:var(--spacing-md)}.blog-post-body li{margin-bottom:8px;margin-bottom:var(--spacing-xs)}.blog-post-body pre{border:1px solid #e2e8f0;border:1px solid var(--code-border);line-height:1.5;margin:16px 0;margin:var(--spacing-sm) 0;overflow-x:auto;padding:16px;padding:var(--spacing-sm)}.blog-post-body code,.blog-post-body pre{background:#f7fafc;background:var(--code-bg);border-radius:4px;border-radius:var(--radius-sm);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,JetBrains Mono,Fira Code,monospace;font-size:14px;font-size:var(--font-size-sm)}.blog-post-body code{border:1px solid #e2e8f0;border:1px solid var(--code-border);color:#2d3748;color:var(--text-color);padding:2px 8px;padding:2px var(--spacing-xs)}.blog-post-body pre code{background:none;border:none;color:#2d3748;color:var(--text-color);padding:0}.projects-grid{grid-gap:24px;grid-gap:var(--spacing-md);display:grid;gap:24px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:40px;margin-top:var(--spacing-lg)}.project-card{background:#f8f9fa;background:var(--bg-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-lg);contain:layout style;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;will-change:transform}.project-card:hover{border-color:#1e40af;border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-image{height:200px;overflow:hidden;width:100%}.project-image img{height:100%;object-fit:cover;width:100%}.project-content{padding:24px}.project-title{color:#2d3748;color:var(--text-color);font-size:18px;font-weight:500;margin-bottom:8px}.project-description{color:#4a5568;color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:16px}.project-tech{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{background:#edf2f7;background:var(--hover-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:3px;color:#4a5568;color:var(--text-secondary);font-size:12px;font-weight:400;padding:4px 8px}.about-content{margin:0 auto;max-width:1000px}.solutions-grid{grid-gap:24px;grid-gap:var(--spacing-md);display:grid;gap:24px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:24px;margin-top:var(--spacing-md)}.solution-item{align-items:flex-start;background-color:#f8f9fa;background-color:var(--bg-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-lg);display:flex;gap:16px;gap:var(--spacing-sm);padding:24px;padding:var(--spacing-md);transition:all .3s ease}.solution-item:hover{border-color:#1e40af;border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.solution-icon{align-items:center;background-color:#edf2f7;background-color:var(--hover-bg);border-radius:6px;border-radius:var(--radius-md);display:flex;flex-shrink:0;font-size:22px;font-size:var(--font-size-xl);height:40px;justify-content:center;width:40px}.solution-content{flex:1 1}.solution-content h3{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;line-height:1.3;margin:0 0 8px;margin:0 0 var(--spacing-xs) 0}.solution-content p{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.5;margin:0}.about-hero{align-items:center;display:flex;gap:40px;gap:var(--spacing-lg);margin-bottom:24px;margin-bottom:var(--spacing-md);padding:40px 0;padding:var(--spacing-lg) 0}.about-image{flex-shrink:0}.about-image img{border:2px solid #e0e0e0;border-radius:50%;height:150px;object-fit:cover;width:150px}.about-text{flex:1 1}.about-stats{display:flex;gap:40px;gap:var(--spacing-lg);justify-content:center;margin-top:24px;margin-top:var(--spacing-md)}.stat{text-align:center}.stat-number{color:#2d3748;color:var(--text-color);display:block;font-size:24px;font-weight:600;margin-bottom:4px}.stat-label{color:#718096;color:var(--text-muted);font-size:14px;font-weight:400}.about-sections{grid-gap:40px;display:grid;gap:40px}.about-section{padding:0}.about-section h2{color:#2d3748;color:var(--text-color);font-size:24px;font-weight:600;margin-bottom:16px}.about-section p{color:#4a5568;color:var(--text-secondary);font-size:15px;line-height:1.7;margin-bottom:16px}.skills-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:16px}.skills-showcase{margin-top:40px;margin-top:var(--spacing-lg)}.skills-showcase h3{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;margin-bottom:24px;margin-bottom:var(--spacing-md)}.tech-stack-list{grid-gap:24px;grid-gap:var(--spacing-md);display:grid;gap:24px;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:16px;margin-top:var(--spacing-sm)}.tech-item{background-color:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-md);gap:16px;gap:var(--spacing-sm);padding:16px;padding:var(--spacing-sm);transition:all .3s ease}.tech-icon,.tech-item{align-items:center;display:flex}.tech-icon{flex-shrink:0;height:32px;justify-content:center;width:32px}.tech-icon img{height:100%;object-fit:contain;width:100%}.tech-content{display:flex;flex-direction:column;gap:2px}.tech-item:hover{border-color:#1e40af;border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.tech-name{color:#2d3748;color:var(--text-color);font-size:17px;font-size:var(--font-size-base);font-weight:600}.tools-list{grid-gap:16px;grid-gap:var(--spacing-sm);display:grid;gap:16px;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:16px;margin-top:var(--spacing-sm)}.tool-item{background-color:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:4px;border-radius:var(--radius-sm);gap:8px;gap:var(--spacing-xs);padding:8px;padding:var(--spacing-xs);transition:all .3s ease}.tool-icon,.tool-item{align-items:center;display:flex}.tool-icon{flex-shrink:0;height:24px;justify-content:center;width:24px}.tool-icon img{height:100%;object-fit:contain;width:100%}.tool-content{display:flex;flex-direction:column;gap:2px}.tool-item:hover{border-color:#f97316;border-color:var(--accent-secondary);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.tool-name{color:#2d3748;color:var(--text-color);font-size:14px;font-size:var(--font-size-sm);font-weight:600}.tool-description{color:#718096;color:var(--text-muted);font-size:12px;font-size:var(--font-size-xs);line-height:1.3}.skill-category h3{color:#2d3748;color:var(--text-color);font-size:16px;font-weight:500;margin-bottom:8px}.skill-category ul{list-style:none;padding:0}.skill-category li{color:#4a5568;color:var(--text-secondary);font-size:14px;padding:4px 0}.services-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:16px}.service{padding:0}.service h3{color:#2d3748;color:var(--text-color);font-size:16px;font-weight:500;margin-bottom:8px}.service p{color:#4a5568;color:var(--text-secondary);font-size:14px;line-height:1.6}.contact-section{text-align:left}.contact-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px}.contact-link{background:#1e40af;background:var(--accent-primary);border:1px solid #1e40af;border:1px solid var(--accent-primary);border-radius:6px;color:#fff;font-size:14px;font-weight:500;padding:10px 20px;text-decoration:none;transition:all .2s ease}.contact-link:hover{background:#fb923c;background:var(--accent-hover);border-color:#fb923c;border-color:var(--accent-hover);transform:translateY(-1px)}.footer{background-color:#f8f9fa;background-color:var(--bg-color);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);color:#2d3748;color:var(--text-color);margin-top:auto;padding:16px 0;padding:var(--spacing-sm) 0;text-align:center}.footer-content{display:block;text-align:center}.footer-content p{color:#718096;color:var(--text-muted);font-size:12px;font-size:var(--font-size-xs);margin:0}.footer-social{margin:16px 0;margin:var(--spacing-sm) 0;text-align:center}.footer-social a{color:#2d3748;color:var(--text-color);font-size:14px;font-size:var(--font-size-sm);text-decoration:none;transition:color .2s ease}.footer-social a:hover{color:#1e40af;color:var(--accent-primary)}.footer-social .separator{color:#718096;color:var(--text-muted);margin:0 8px;margin:0 var(--spacing-xs)}.disclaimer{border-top:none;margin-top:8px;margin-top:var(--spacing-xs);padding-top:0;text-align:center}.disclaimer p{color:#718096;color:var(--text-muted);font-size:12px;font-size:var(--font-size-xs);font-style:italic;line-height:1.4;margin:0}.terminal-icon{align-items:center;border-radius:6px;color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.terminal-icon:hover{background-color:#edf2f7;background-color:var(--hover-bg);color:#1e40af;color:var(--accent-primary);transform:scale(1.05)}.terminal-overlay{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.terminal-window{background-color:#0d1117;background-color:var(--terminal-bg);border:1px solid #30363d;border:1px solid var(--terminal-border);border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000026;box-shadow:var(--shadow-lg);contain:layout style;max-height:80vh;max-width:600px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;width:100%;will-change:transform}.terminal-window.maximized{border-radius:0;height:95vh;max-height:95vh;max-width:95vw;width:95vw}.terminal-header{align-items:center;background-color:#21262d;background-color:var(--terminal-header);border-bottom:1px solid #30363d;border-bottom:1px solid var(--terminal-border);display:flex;justify-content:space-between;padding:16px;padding:var(--spacing-sm) var(--spacing-sm)}.terminal-controls{display:flex;gap:8px;gap:var(--spacing-xs)}.terminal-control{border-radius:50%;cursor:pointer;height:12px;transition:all .2s ease;width:12px}.terminal-control:hover{opacity:.8;transform:scale(1.1)}.terminal-control.close{background-color:#ff5f56;background-color:var(--control-close)}.terminal-control.close:hover{background-color:#ff3b30}.terminal-control.minimize{background-color:#ffbd2e;background-color:var(--control-minimize)}.terminal-control.minimize:hover{background-color:#ff9500}.terminal-control.maximize{background-color:#27ca3f;background-color:var(--control-maximize)}.terminal-control.maximize:hover{background-color:#1dbd2e}.terminal-title{color:#f0f6fc;font-family:JetBrains Mono,monospace;font-size:14px;font-size:var(--font-size-sm);font-weight:500}.terminal-body{background-color:#0d1117;background-color:var(--terminal-bg);max-height:400px;overflow-y:auto;padding:16px;padding:var(--spacing-sm)}.terminal-content{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,JetBrains Mono,Fira Code,monospace;font-size:14px;font-size:var(--font-size-sm);line-height:1.5;margin:0;white-space:pre-wrap}.terminal-content,.terminal-cursor{color:#39ff14;color:var(--terminal-text)}.terminal-cursor{animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.terminal-commands{background-color:#21262d;background-color:var(--terminal-header);border-top:1px solid #30363d;border-top:1px solid var(--terminal-border);display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-sm);padding:16px;padding:var(--spacing-sm)}.page-header{margin-bottom:60px;margin-bottom:var(--spacing-xl);padding:60px 0 40px;padding:var(--spacing-xl) 0 var(--spacing-lg) 0;text-align:center}.page-header h1{color:#2d3748;color:var(--text-color);font-size:36px;font-size:var(--font-size-3xl);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:16px;margin-bottom:var(--spacing-sm)}.page-description{color:#4a5568;color:var(--text-secondary);font-size:18px;font-size:var(--font-size-lg);font-weight:400;line-height:1.6;margin:0 auto;max-width:600px}.page-hero{margin-bottom:80px;margin-bottom:var(--spacing-2xl);padding:80px 0 60px;padding:var(--spacing-2xl) 0 var(--spacing-xl) 0;text-align:center}.page-hero-title{color:#2d3748;color:var(--text-color);font-size:48px;font-size:var(--font-size-4xl);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:16px;margin-bottom:var(--spacing-sm)}.page-hero-subtitle{color:#4a5568;color:var(--text-secondary);font-size:18px;font-size:var(--font-size-lg);line-height:1.6;margin:0 auto;max-width:600px}.about-hero-title{color:#2d3748;color:var(--text-color);font-size:28px;font-size:var(--font-size-2xl);font-weight:700;margin-bottom:24px;margin-bottom:var(--spacing-md)}.location-link{border-bottom:1px dotted #0000;border-radius:4px;border-radius:var(--radius-sm);color:#1e40af;color:var(--accent-primary);cursor:pointer;padding:2px 4px;position:relative;text-decoration:none;transition:all .3s ease}.location-link:hover{background-color:#edf2f7;background-color:var(--hover-bg);border-bottom-color:#f97316;border-bottom-color:var(--accent-secondary);color:#f97316;color:var(--accent-secondary);transform:translateY(-1px)}.location-link:after{content:"📍";font-size:.8em;margin-left:4px;opacity:0;transition:opacity .3s ease}.location-link:hover:after{opacity:1}.weather-tooltip{animation:fadeInUp .3s ease-out;pointer-events:none}.weather-tooltip-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f8f9fa;background:var(--bg-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000026;box-shadow:var(--shadow-lg);min-width:200px;padding:24px;padding:var(--spacing-md);position:relative}.weather-tooltip-content:before{border-bottom:8px solid #e2e8f0;border-bottom:8px solid var(--border-color);border-left:8px solid #0000;border-right:8px solid #0000;top:-8px}.weather-tooltip-content:after,.weather-tooltip-content:before{content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.weather-tooltip-content:after{border-bottom:7px solid #f8f9fa;border-bottom:7px solid var(--bg-color);border-left:7px solid #0000;border-right:7px solid #0000;top:-7px}.weather-loading{align-items:center;color:#4a5568;color:var(--text-secondary);display:flex;font-size:14px;font-size:var(--font-size-sm);gap:16px;gap:var(--spacing-sm)}.weather-spinner{animation:spin 1s linear infinite;border:2px solid #e2e8f0;border-top:2px solid #1e40af;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:16px;width:16px}.weather-error{color:#4a5568;color:var(--text-secondary)}.weather-error,.weather-success{align-items:center;display:flex;gap:16px;gap:var(--spacing-sm)}.weather-icon{font-size:22px;font-size:var(--font-size-xl);line-height:1}.weather-info{flex:1 1}.weather-main{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;margin-bottom:2px}.weather-condition{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);margin-bottom:4px}.weather-details{color:#718096;color:var(--text-muted);font-size:12px;font-size:var(--font-size-xs);line-height:1.4}.weather-source{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);margin-top:16px;margin-top:var(--spacing-sm);padding-top:8px;padding-top:var(--spacing-xs);text-align:center}.weather-source small{color:#718096;color:var(--text-muted);font-size:10px;font-style:italic}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.about-hero-subtitle{flex-wrap:wrap;gap:40px;gap:var(--spacing-lg);justify-content:center;margin-bottom:60px;margin-bottom:var(--spacing-xl)}.about-hero-subtitle,.subtitle-item{align-items:center;display:flex;padding:0}.subtitle-item{transition:all .3s ease}.subtitle-item:hover{transform:translateY(-1px)}.subtitle-content{display:flex;flex-direction:column;gap:2px}.subtitle-label{color:#718096;color:var(--text-muted);font-size:12px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.subtitle-value{color:#2d3748;color:var(--text-color);font-size:17px;font-size:var(--font-size-base);font-weight:500;line-height:1.3}.subtitle-separator{background:#e2e8f0;background:var(--border-color);height:30px;opacity:.4;width:1px}.college-link{border-bottom:1px dotted #0000;color:#1e40af;color:var(--accent-primary);text-decoration:none;transition:all .3s ease}.college-link:hover{border-bottom-color:#f97316;border-bottom-color:var(--accent-secondary);color:#f97316;color:var(--accent-secondary);transform:translateY(-1px)}.about-hero-intro{color:#2d3748;color:var(--text-color);font-size:17px;font-size:var(--font-size-base);line-height:1.6;margin:24px auto 0;margin:var(--spacing-md) auto 0 auto;max-width:600px;text-align:center}.blog-post-not-found{padding:80px 0;padding:var(--spacing-2xl) 0;text-align:center}.blog-post-not-found-title{color:#2d3748;color:var(--text-color);font-size:36px;font-size:var(--font-size-3xl);margin-bottom:24px;margin-bottom:var(--spacing-md)}.blog-post-not-found-text{color:#4a5568;color:var(--text-secondary);margin-bottom:40px;margin-bottom:var(--spacing-lg)}.blog-post-back{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);margin-top:40px;margin-top:var(--spacing-lg);padding-top:16px;padding-top:var(--spacing-sm);text-align:center}.blog-post-back-link{align-items:center;color:#4a5568;color:var(--text-secondary);display:inline-flex;font-size:14px;font-size:var(--font-size-sm);font-weight:400;gap:8px;gap:var(--spacing-xs);text-decoration:none;text-transform:lowercase;transition:color .2s ease}.blog-post-back-link:hover{color:#1e40af;color:var(--accent-primary)}.live-soon{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:80px 0;padding:var(--spacing-2xl) 0;text-align:center}.live-soon h1{color:#2d3748;color:var(--text-color);font-size:48px;font-size:var(--font-size-4xl);font-weight:700;letter-spacing:-.02em;margin-bottom:24px;margin-bottom:var(--spacing-md)}.live-soon p{color:#4a5568;color:var(--text-secondary);font-size:18px;font-size:var(--font-size-lg);line-height:1.6;margin:0 auto;max-width:500px}.resources-content{margin:0 auto;max-width:1000px}.resource-category{margin-bottom:40px;margin-bottom:var(--spacing-lg)}.resource-category-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#2d3748;color:var(--text-color);font-size:22px;font-size:var(--font-size-xl);font-weight:600;margin-bottom:16px;margin-bottom:var(--spacing-sm);padding-bottom:8px;padding-bottom:var(--spacing-xs)}.resource-list{grid-gap:8px;grid-gap:var(--spacing-xs);display:grid;gap:8px;gap:var(--spacing-xs)}.resource-item{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);padding:16px 0;padding:var(--spacing-sm) 0;transition:all .2s ease}.resource-item:last-child{border-bottom:none}.resource-item:hover{background-color:#edf2f7;background-color:var(--hover-bg);border-radius:4px;border-radius:var(--radius-sm);padding-left:16px;padding-left:var(--spacing-sm)}.resource-title{font-size:17px;font-size:var(--font-size-base);font-weight:500;margin:0 0 8px;margin:0 0 var(--spacing-xs) 0}.resource-link{color:#1e40af;color:var(--link-color);text-decoration:none;transition:color .2s ease}.resource-link:hover{color:#1d4ed8;color:var(--link-hover);text-decoration:underline}.resource-description{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.4;margin:0}@media (max-width:768px){.resource-list{gap:16px;gap:var(--spacing-sm)}.resource-item{padding:16px;padding:var(--spacing-sm)}.resource-category-title{font-size:22px;font-size:var(--font-size-xl)}}.now-content{margin:0 auto;max-width:800px}.now-section{margin-bottom:40px;margin-bottom:var(--spacing-lg)}.now-section h2{border-bottom:2px solid #1e40af;border-bottom:2px solid var(--accent-primary);color:#2d3748;color:var(--text-color);font-size:22px;font-size:var(--font-size-xl);font-weight:600;margin-bottom:24px;padding-bottom:8px}.now-item{background:#f8f9fa;background:var(--bg-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-lg);margin-bottom:16px;margin-bottom:var(--spacing-sm);padding:24px;padding:var(--spacing-md);transition:all .2s ease}.now-item:hover{border-color:#1e40af;border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.now-item h3{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;margin-bottom:12px}.now-item p{margin-bottom:16px}.now-item p,.now-item ul{color:#4a5568;color:var(--text-secondary);line-height:1.6}.now-item ul{margin-left:20px}.now-item li{margin-bottom:8px}.now-tags{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#edf2f7;background:var(--hover-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;color:#4a5568;color:var(--text-secondary);font-size:12px;font-weight:500;padding:4px 12px}.uses-content{margin:0 auto;max-width:1000px}.uses-category{margin-bottom:60px}.uses-category h2{color:#2d3748;color:var(--text-color);font-size:28px;font-size:var(--font-size-2xl);font-weight:600;margin-bottom:32px;text-align:center}.uses-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:40px}.uses-item{background:#f8f9fa;background:var(--bg-color);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius-lg);padding:24px;padding:var(--spacing-md);transition:all .2s ease}.uses-item:hover{border-color:#1e40af;border-color:var(--accent-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.uses-item h3{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;margin-bottom:12px}.uses-item p{margin-bottom:16px}.uses-item p,.uses-item ul{color:#4a5568;color:var(--text-secondary);line-height:1.6}.uses-item ul{margin-left:20px}.uses-item li{margin-bottom:8px}.uses-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.uses-list{margin:0 auto;max-width:600px}.changelog-content{margin:0 auto;max-width:800px}.changelog-entry{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);margin-bottom:40px;padding-bottom:32px}.changelog-entry:last-child{border-bottom:none}.changelog-date{color:#1e40af;color:var(--accent-primary);font-family:JetBrains Mono,monospace;font-size:14px;font-size:var(--font-size-sm)}.changelog-changes h3,.changelog-date{font-weight:600;margin-bottom:8px;margin-bottom:var(--spacing-xs)}.changelog-changes h3{color:#2d3748;color:var(--text-color);font-size:17px;font-size:var(--font-size-base)}.changelog-list{list-style:none;padding:0}.changelog-list li{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);line-height:1.5;margin-bottom:8px;margin-bottom:var(--spacing-xs);padding-left:16px;padding-left:var(--spacing-sm);position:relative}.changelog-list li:before{color:#1e40af;color:var(--accent-primary);content:"•";font-weight:700;left:0;position:absolute}.changelog-note{background-color:#edf2f7;background-color:var(--hover-bg);border-left:3px solid #1e40af;border-left:3px solid var(--accent-primary);border-radius:4px;border-radius:var(--radius-sm);color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);font-style:italic;margin-top:24px;margin-top:var(--spacing-md);padding:16px;padding:var(--spacing-sm)}.changelog-future{border-top:2px solid #e2e8f0;border-top:2px solid var(--border-color);margin-top:60px;padding-top:40px}.changelog-future h2{color:#2d3748;color:var(--text-color);font-size:18px;font-size:var(--font-size-lg);font-weight:600;margin-bottom:24px;margin-bottom:var(--spacing-md);text-align:center}.mobile-menu-toggle{align-items:center;background:none;border:none;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;display:none;flex-direction:column;gap:4px;height:44px;justify-content:center;padding:16px;padding:var(--spacing-sm);position:relative;transition:background-color .2s ease;width:44px;z-index:200}.mobile-menu-toggle:hover{background-color:#edf2f7;background-color:var(--hover-bg)}.hamburger-line{background-color:#2d3748;background-color:var(--text-color);border-radius:1px;height:2px;transition:all .3s ease;width:20px}.mobile-menu-toggle[aria-expanded=true] .hamburger-line:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle[aria-expanded=true] .hamburger-line:nth-child(2){opacity:0}.mobile-menu-toggle[aria-expanded=true] .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.mobile-menu-overlay{animation:fadeIn .3s ease;background-color:#00000080;bottom:0;left:0;will-change:opacity;z-index:1000}.mobile-menu,.mobile-menu-overlay{contain:layout style;position:fixed;right:0;top:0}.mobile-menu{animation:slideInRight .3s ease;background-color:#f8f9fa;background-color:var(--bg-color);border-left:1px solid #e2e8f0;border-left:1px solid var(--border-color);box-shadow:0 8px 24px #00000026;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:24px;gap:var(--spacing-md);height:100vh;padding:60px 40px;padding:var(--spacing-xl) var(--spacing-lg);width:280px;will-change:transform;z-index:1001}.mobile-menu a{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#2d3748;color:var(--text-color);display:flex;font-size:18px;font-size:var(--font-size-lg);font-weight:500;min-height:44px;padding:16px 0;padding:var(--spacing-sm) 0;text-decoration:none;transition:color .2s ease}.mobile-menu a:hover{color:#1e40af;color:var(--accent-primary)}.mobile-menu a:last-child{border-bottom:none}.mobile-menu-divider{background-color:#e2e8f0;background-color:var(--border-color);height:1px;margin:16px 0;margin:var(--spacing-sm) 0}.mobile-menu-link{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);color:#2d3748;color:var(--text-color);display:flex;font-size:18px;font-size:var(--font-size-lg);font-weight:500;min-height:44px;padding:16px 0;padding:var(--spacing-sm) 0;text-decoration:none;transition:color .2s ease}.mobile-menu-link:hover{color:#1e40af;color:var(--accent-primary)}.mobile-menu-link:last-of-type{border-bottom:none}.mobile-theme-toggle{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);display:flex;justify-content:center;margin-top:16px;margin-top:var(--spacing-sm);padding:16px 0;padding:var(--spacing-sm) 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pull-to-refresh-container{contain:layout style;min-height:100vh;position:relative}.pull-to-refresh-indicator{align-items:center;background-color:#f8f9fa;background-color:var(--bg-color);border-radius:0 0 8px 8px;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px;gap:var(--spacing-xs);left:50%;padding:16px;padding:var(--spacing-sm);position:fixed;top:0;transform:translateX(-50%);transition:all .3s ease;z-index:100}.refresh-icon{color:#1e40af;color:var(--accent-primary);font-size:18px;font-size:var(--font-size-lg);transition:transform .3s ease}.refresh-icon.pulling{transform:rotate(180deg)}.refresh-icon.ready{transform:rotate(1turn)}.refresh-spinner{align-items:center;display:flex;justify-content:center}.spinner{animation:spin 1s linear infinite;border:2px solid #e2e8f0;border-top:2px solid #1e40af;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:20px;width:20px;will-change:transform}.refresh-text{color:#4a5568;color:var(--text-secondary);font-size:14px;font-size:var(--font-size-sm);font-weight:500}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.header-content{padding:0 24px;padding:0 var(--spacing-md)}.desktop-nav{display:none}.mobile-menu-toggle{display:flex}.page-description{font-size:14px;font-size:var(--font-size-sm)}.blog-subtitle{font-size:28px;font-size:var(--font-size-2xl)}.blog-description{font-size:14px;font-size:var(--font-size-sm)}.blog-item-header{align-items:flex-start;flex-direction:column;gap:8px;gap:var(--spacing-xs)}.blog-item-date{margin-bottom:8px;margin-bottom:var(--spacing-xs);margin-top:0}.blog-item:hover{margin:0 -24px;margin:0 calc(var(--spacing-md)*-1);padding:24px;padding:var(--spacing-md) var(--spacing-md)}.blog-post-title{font-size:28px;font-size:var(--font-size-2xl)}.about-hero{flex-direction:column;text-align:center}.about-hero,.about-stats{gap:24px;gap:var(--spacing-md)}.about-stats{justify-content:center}.about-hero-subtitle{flex-direction:column;gap:24px;gap:var(--spacing-md)}.subtitle-separator{display:none}.subtitle-item{justify-content:center}.tech-stack-list{gap:16px;gap:var(--spacing-sm);grid-template-columns:1fr}.tech-item{justify-content:center;text-align:center}.tech-icon{height:28px;width:28px}.tools-list{gap:8px;gap:var(--spacing-xs);grid-template-columns:repeat(2,1fr)}.tool-item{justify-content:center;padding:8px;padding:var(--spacing-xs);text-align:center}.tool-icon{height:20px;width:20px}.tech-content,.tool-content{align-items:center}.tech-name,.tool-name{font-size:14px;font-size:var(--font-size-sm)}.tech-description,.tool-description{font-size:12px;font-size:var(--font-size-xs)}.solutions-grid{gap:16px;gap:var(--spacing-sm);grid-template-columns:1fr}.solution-item{padding:16px;padding:var(--spacing-sm)}.solution-icon{font-size:18px;font-size:var(--font-size-lg);height:32px;width:32px}.solution-content h3{font-size:17px;font-size:var(--font-size-base)}.solution-content p{font-size:12px;font-size:var(--font-size-xs)}.now-section h2,.uses-category h2{font-size:22px;font-size:var(--font-size-xl)}.uses-grid{gap:16px;gap:var(--spacing-sm);grid-template-columns:1fr}.now-item,.uses-item{padding:16px;padding:var(--spacing-sm)}.changelog-date{font-size:14px;font-size:var(--font-size-sm)}.changelog-changes h3{font-size:18px;font-size:var(--font-size-lg)}.footer-content{flex-direction:column;text-align:center}.footer-links{justify-content:center}.blog-item-link,.contact-link,.mobile-menu a,.nav a{align-items:center;display:flex;min-height:44px;padding:16px 24px;padding:var(--spacing-sm) var(--spacing-md)}.page-header h1{font-size:28px;font-size:var(--font-size-2xl);line-height:1.2}.blog-subtitle{font-size:22px;font-size:var(--font-size-xl);line-height:1.3}.blog-description{font-size:17px;font-size:var(--font-size-base)}.container{padding:0 24px;padding:0 var(--spacing-md)}.page-header{padding:40px 0;padding:var(--spacing-lg) 0}.blog-hero{padding:24px 0;padding:var(--spacing-md) 0}.footer,.header{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.footer{padding-bottom:env(safe-area-inset-bottom)}.mobile-menu{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-top:calc(60px + env(safe-area-inset-top));padding-top:calc(var(--spacing-xl) + env(safe-area-inset-top))}.weather-tooltip-content{font-size:14px;font-size:var(--font-size-sm);max-width:90vw;min-width:180px;padding:16px;padding:var(--spacing-sm)}.weather-main{font-size:17px;font-size:var(--font-size-base)}.weather-condition{font-size:12px;font-size:var(--font-size-xs)}.weather-details{font-size:10px;line-height:1.3}.weather-source small{font-size:9px}.weather-icon{font-size:18px;font-size:var(--font-size-lg)}.weather-tooltip{transform:translateX(-50%)}.location-link:active{background-color:#edf2f7;background-color:var(--hover-bg);transform:scale(.98)}.weather-tooltip-content:after,.weather-tooltip-content:before{display:none}.weather-tooltip-content{border-radius:6px;border-radius:var(--radius-md);box-shadow:0 8px 32px #0003}}.theme-toggle{align-items:center;background:none;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;height:44px;justify-content:center;padding:16px;padding:var(--spacing-sm);transition:all .2s ease;width:44px}.theme-toggle:hover{background-color:#edf2f7;background-color:var(--hover-bg);color:#1e40af;color:var(--accent-primary);transform:scale(1.05)}.theme-toggle:focus{outline:2px solid #1e40af;outline:2px solid var(--accent-primary);outline-offset:2px}.theme-toggle-icon{align-items:center;display:flex;justify-content:center;transition:transform .3s ease}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg)}.skip-to-content{background:#1e40af;background:var(--accent-primary);border-radius:4px;color:#fff;font-size:14px;font-size:var(--font-size-sm);left:6px;padding:8px;position:absolute;text-decoration:none;top:-40px;z-index:1000}.skip-to-content:focus{top:6px}
/*# sourceMappingURL=main.83d6a4fb.css.map*/