:root{--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-size-6xl:3.75rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:2.5rem;--spacing-3xl:3rem;--spacing-4xl:4rem;--spacing-5xl:5rem;--spacing-6xl:6rem;--color-logo-dark:hsl(220deg 25% 15%);--color-logo-dark-light:hsl(220deg 25% 15% / 90%);--color-logo-dark-lighter:hsl(220deg 25% 15% / 80%);--color-logo-teal:hsl(180deg 65% 45%);--color-logo-teal-light:hsl(180deg 65% 55%);--color-logo-teal-dark:hsl(180deg 65% 35%);--color-logo-teal-subtle:hsl(180deg 65% 45% / 10%);--color-logo-orange:hsl(25deg 85% 55%);--color-logo-orange-light:hsl(25deg 85% 65%);--color-logo-orange-dark:hsl(25deg 85% 45%);--color-logo-orange-subtle:hsl(25deg 85% 55% / 10%);--color-logo-white:hsl(0deg 0% 98%);--color-logo-white-soft:hsl(0deg 0% 98% / 90%);--color-logo-white-subtle:hsl(0deg 0% 98% / 80%);--color-logo-blue:hsl(210deg 85% 50%);--color-logo-blue-light:hsl(210deg 85% 60%);--color-logo-blue-dark:hsl(210deg 85% 40%);--color-logo-blue-subtle:hsl(210deg 85% 50% / 10%);--color-success:hsl(120deg 60% 50%);--color-warning:hsl(45deg 100% 60%);--color-error:hsl(0deg 70% 60%);--color-info:hsl(200deg 100% 60%);--color-text-primary:var(--color-logo-white);--color-text-secondary:var(--color-logo-white-soft);--color-text-muted:var(--color-logo-white-subtle);--color-text-inverse:var(--color-logo-dark);--color-text-accent:var(--color-logo-teal);--color-bg-primary:var(--color-logo-dark);--color-bg-secondary:var(--color-logo-dark-light);--color-bg-accent:var(--color-logo-teal-subtle);--color-bg-surface:var(--color-logo-white);--color-bg-card:hsl(220deg 25% 18%);--color-border-primary:var(--color-logo-white-subtle);--color-border-secondary:var(--color-logo-teal);--color-border-muted:var(--color-logo-white-soft);--font-family-heading:'Montserrat','Poppins',-apple-system,blinkmacsystemfont,'Segoe UI',sans-serif;--font-family-body:'Lato','Inter',-apple-system,blinkmacsystemfont,'Segoe UI',sans-serif;--font-family-mono:'SF Mono',monaco,'Cascadia Code','Roboto Mono',consolas,'Courier New',monospace;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-tight:1.25;--line-height-snug:1.375;--line-height-normal:1.5;--line-height-relaxed:1.625;--line-height-loose:2;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 hsl(0deg 0% 0% / 5%);--shadow-md:0 4px 6px -1px hsl(0deg 0% 0% / 10%),0 2px 4px -1px hsl(0deg 0% 0% / 6%);--shadow-lg:0 10px 15px -3px hsl(0deg 0% 0% / 10%),0 4px 6px -2px hsl(0deg 0% 0% / 5%);--shadow-xl:0 20px 25px -5px hsl(0deg 0% 0% / 10%),0 10px 10px -5px hsl(0deg 0% 0% / 4%);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px;--transition-fast:150ms ease-in-out;--transition-normal:300ms ease-in-out;--transition-slow:500ms ease-in-out;--focus-ring:0 0 0 3px var(--color-logo-teal-subtle);--focus-ring-offset:2px}*,::after,::before{box-sizing:border-box}html{font-size:16px;line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{margin:0;padding:0;font-family:var(--font-family-body);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary)}h1{font-size:var(--font-size-5xl);font-weight:var(--font-weight-extrabold)}h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold)}h3{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h4{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}h5{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}h6{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium)}p{margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary)}a{color:var(--color-logo-teal);text-decoration:underline;text-decoration-color:transparent;text-underline-offset:0.25rem;transition:all var(--transition-fast)}a:hover{color:var(--color-logo-teal-light);text-decoration-color:currentcolor}a:focus{outline:0;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}[tabindex]:focus,button:focus,input:focus,select:focus,textarea:focus{outline:0;box-shadow:var(--focus-ring)}.skip-nav{position:absolute;top:-100%;left:0;background:var(--color-bg-surface);color:var(--color-text-inverse);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;z-index:var(--z-modal);border-radius:0 0 var(--radius-md) 0}.skip-nav:focus{top:0}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important;scroll-behavior:auto!important}}.container{width:100%;max-width:var(--breakpoint-xl);margin:0 auto;padding:0 var(--spacing-md)}@media (width >= 640px){.container{padding:0 var(--spacing-lg)}}@media (width >= 1024px){.container{padding:0 var(--spacing-xl)}}.page-section{padding:var(--spacing-5xl) 0}.section-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);text-align:center;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.section-subtitle{font-size:var(--font-size-lg);text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl);line-height:var(--line-height-relaxed)}@media print{*{background:0 0!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}a,a:visited{text-decoration:underline}a[href]::after{content:' (' attr(href) ')'}h1,h2,h3{page-break-after:avoid}}.github-project-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-normal);cursor:pointer;position:relative;min-height:280px;display:flex;flex-direction:column}.github-project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-logo-teal)}.github-project-card:focus{outline:0;box-shadow:var(--focus-ring);border-color:var(--color-logo-teal)}.github-project-card.loading{cursor:wait}.github-project-card.error{border-color:var(--color-error);cursor:default}.card-content{display:flex;flex-direction:column;height:100%}.card-header{margin-bottom:var(--spacing-md)}.card-body{flex:1;margin-bottom:var(--spacing-md)}.card-footer{margin-top:auto;display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:var(--spacing-sm)}.repo-info{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.repo-name{font-family:var(--font-family-mono);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-logo-teal);margin:0;line-height:var(--line-height-tight)}.repo-owner{color:var(--color-text-secondary)}.repo-separator{color:var(--color-text-muted)}.repo-title{color:var(--color-logo-teal)}.repo-visibility{font-size:var(--font-size-sm);opacity:.8}.repo-description{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.repo-topics,.technologies{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.tech-tag,.topic-tag{background-color:var(--color-logo-teal-subtle);color:var(--color-logo-teal);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border:1px solid var(--color-logo-teal)}.repo-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-md)}.stat-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.stat-icon{font-size:var(--font-size-base)}.stat-value{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.stat-label{color:var(--color-text-muted)}.repo-meta{display:flex;flex-direction:column;gap:var(--spacing-xs)}.language-info{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.language-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.language-name{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.last-updated{font-size:var(--font-size-xs);color:var(--color-text-muted)}.card-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.view-on-github{color:var(--color-logo-teal);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--spacing-xs)}.external-link-icon{font-size:var(--font-size-xs);opacity:.8}.coming-soon{color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic}.card-loading{display:flex;align-items:center;gap:var(--spacing-md);height:100%;min-height:200px}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border-primary);border-top:3px solid var(--color-logo-teal);border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.loading-skeleton{flex:1}.skeleton-description,.skeleton-stats,.skeleton-title{background:linear-gradient(90deg,var(--color-border-primary) 25%,var(--color-border-muted) 50%,var(--color-border-primary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-title{height:24px;width:70%;margin-bottom:var(--spacing-md)}.skeleton-description{height:16px;width:100%;margin-bottom:var(--spacing-sm)}.skeleton-stats{height:16px;width:50%}@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.card-error{display:flex;align-items:center;gap:var(--spacing-md);height:100%;min-height:200px}.error-icon{font-size:var(--font-size-2xl);flex-shrink:0}.error-content{flex:1}.error-title{color:var(--color-text-primary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.error-message{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-sm)}.error-details{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:var(--font-family-mono)}.fallback-title{color:var(--color-logo-teal);font-size:var(--font-size-xl)}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.status-active{background-color:var(--color-success);color:var(--color-logo-white)}.status-planning{background-color:var(--color-warning);color:var(--color-logo-dark)}.status-development{background-color:var(--color-logo-blue);color:var(--color-logo-white)}@media (width <= 480px){.github-project-card{padding:var(--spacing-md)}.repo-stats{flex-direction:column;gap:var(--spacing-sm)}.card-footer{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}}@media (prefers-reduced-motion:reduce){.loading-spinner,.skeleton-description,.skeleton-stats,.skeleton-title{animation:none}.github-project-card{transition:none}}@media (prefers-contrast:high){.github-project-card{border-width:2px}.tech-tag,.topic-tag{border-width:2px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}main{min-height:calc(100vh - 8rem);padding:var(--spacing-lg) 0}main:focus{outline:0}.site-footer{background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border-primary);margin-top:auto}.site-footer__content{padding:var(--spacing-lg) 0;text-align:center}.footer-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.footer-text a{color:var(--color-logo-teal);text-decoration:none}.footer-text a:hover{text-decoration:underline}.hero-section{background:linear-gradient(135deg,var(--color-bg-primary) 0,var(--color-bg-secondary) 100%);text-align:center;padding:var(--spacing-5xl) 0}.hero-content{max-width:800px;margin:0 auto}.hero-logo{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.hero-logo-image{width:120px;height:120px;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);transition:all var(--transition-normal);animation:float 6s ease-in-out infinite}.hero-logo-image:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 20px 40px var(--color-logo-teal-subtle)}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-logo-text{display:inline-block;font-family:var(--font-family-heading);font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);background:linear-gradient(135deg,var(--color-logo-teal),var(--color-logo-orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 20px var(--color-logo-teal-subtle)}.hero-title{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.hero-tagline{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);line-height:var(--line-height-relaxed)}.hero-tagline strong{color:var(--color-logo-teal);font-weight:var(--font-weight-semibold)}.hero-intro{margin-bottom:var(--spacing-2xl)}.hero-intro p{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.hero-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-xl);font-family:var(--font-family-heading);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-decoration:none;border:2px solid transparent;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;min-height:44px;min-width:44px}.btn:focus{outline:0;box-shadow:var(--focus-ring)}.btn-primary{background-color:var(--color-logo-teal);color:var(--color-logo-white);border-color:var(--color-logo-teal)}.btn-primary:hover{background-color:var(--color-logo-teal-dark);border-color:var(--color-logo-teal-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-logo-orange);color:var(--color-logo-white);border-color:var(--color-logo-orange)}.btn-secondary:hover{background-color:var(--color-logo-orange-dark);border-color:var(--color-logo-orange-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background-color:transparent;color:var(--color-logo-teal);border-color:var(--color-logo-teal)}.btn-outline:hover{background-color:var(--color-logo-teal);color:var(--color-logo-white);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-large{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.project-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-normal)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-logo-teal)}.project-title{color:var(--color-logo-teal);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-lg)}.project-section-title{color:var(--color-logo-orange);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.05em}.project-problem,.project-solution{margin-bottom:var(--spacing-lg)}.project-problem p,.project-solution p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.project-actions{margin-top:var(--spacing-xl)}.project-description{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.project-technologies{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.tech-tag{background-color:var(--color-logo-teal-subtle);color:var(--color-logo-teal);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border:1px solid var(--color-logo-teal)}.project-status{font-size:var(--font-size-sm);color:var(--color-logo-orange);font-weight:var(--font-weight-medium)}.ramblings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.rambling-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-normal)}.rambling-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-logo-teal-subtle)}.rambling-title{color:var(--color-text-primary);font-size:var(--font-size-xl);margin-bottom:var(--spacing-md);line-height:var(--line-height-snug)}.rambling-excerpt{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-md)}.rambling-meta{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.section-actions{text-align:center;margin-top:var(--spacing-xl)}.cta-section{background:linear-gradient(135deg,var(--color-logo-teal-subtle) 0,var(--color-logo-orange-subtle) 100%);text-align:center}.cta-content{max-width:600px;margin:0 auto}.cta-title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.cta-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-xl)}.cta-actions{display:flex;justify-content:center}@media (max-width:768px){.hero-section{padding:var(--spacing-3xl) 0}.hero-logo-image{width:80px;height:80px}.hero-logo-text{font-size:var(--font-size-3xl)}.hero-title{font-size:var(--font-size-3xl)}.hero-tagline{font-size:var(--font-size-lg)}.hero-actions{flex-direction:column;align-items:center}.projects-grid{grid-template-columns:1fr}.ramblings-grid{grid-template-columns:1fr}.cta-title{font-size:var(--font-size-2xl)}}@media (max-width:480px){.project-card,.rambling-card{padding:var(--spacing-md)}.btn{width:100%;max-width:280px}.hero-logo-image{width:60px;height:60px}.hero-logo-text{font-size:var(--font-size-2xl)}}@media (prefers-reduced-motion:reduce){.hero-logo-image{animation:none}.hero-logo-image:hover{transform:scale(1.05)}}.contact-page{max-width:1000px;margin:0 auto}.page-header{text-align:center;margin-bottom:var(--spacing-3xl)}.page-title{font-size:var(--font-size-4xl);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.page-subtitle{font-size:var(--font-size-xl);color:var(--color-text-secondary)}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:start}.contact-form-section h2,.contact-info h2{color:var(--color-logo-blue);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-lg)}.contact-info p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.contact-methods{display:grid;gap:var(--spacing-lg)}.contact-method h3{color:var(--color-text-primary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.contact-link{color:var(--color-logo-blue);text-decoration:none;font-weight:var(--font-weight-medium);display:inline-block;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);min-height:44px;min-width:44px;display:flex;align-items:center;transition:all var(--transition-fast)}.contact-link:hover{background-color:var(--color-logo-blue-subtle)}.contact-link:hover{text-decoration:underline}.contact-form{background-color:var(--color-bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border-primary)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;color:var(--color-text-primary);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm)}.required{color:var(--color-error)}.form-input,.form-textarea{width:100%;padding:var(--spacing-md);border:2px solid var(--color-border-primary);border-radius:var(--radius-md);background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-family-body);font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus{outline:0;border-color:var(--color-logo-blue);box-shadow:var(--focus-ring)}.form-group.has-error .form-input,.form-group.has-error .form-textarea{border-color:var(--color-error)}.form-textarea{resize:vertical;min-height:120px}.form-help{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-sm);line-height:var(--line-height-relaxed)}.form-error{font-size:var(--font-size-sm);color:var(--color-error);margin-top:var(--spacing-sm);min-height:1.2em}.form-actions{margin-top:var(--spacing-xl);text-align:center}.form-note{margin-top:var(--spacing-xl);padding:var(--spacing-md);background-color:var(--color-logo-orange-subtle);border-radius:var(--radius-md);border:1px solid var(--color-logo-orange)}.form-note p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.form-note strong{color:var(--color-logo-orange)}.form-success{background-color:var(--color-success-subtle);border:1px solid var(--color-success);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;margin-bottom:var(--spacing-xl)}.success-icon{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-md)}.success-content h3{color:var(--color-success);margin-bottom:var(--spacing-md)}.success-content p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.form-submit-error{background-color:var(--color-error-subtle);border:1px solid var(--color-error);border-radius:var(--radius-md);padding:var(--spacing-md);color:var(--color-error);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-medium)}@media (max-width:768px){.contact-content{grid-template-columns:1fr;gap:var(--spacing-2xl)}.contact-form{padding:var(--spacing-lg)}}@media (max-width:480px){.contact-form{padding:var(--spacing-md)}}@media (prefers-contrast:high){.form-input,.form-textarea{border-width:3px}.form-input:focus,.form-textarea:focus{border-width:3px}}.projects-page{max-width:1200px;margin:0 auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-3xl)}.project-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-normal)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-logo-teal)}.project-title{color:var(--color-logo-teal);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}.project-description{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.project-status{display:flex;justify-content:flex-end}.status-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.status-active{background-color:var(--color-success);color:var(--color-logo-white)}.status-planning{background-color:var(--color-warning);color:var(--color-logo-dark)}.coming-soon{text-align:center;background-color:var(--color-bg-secondary);padding:var(--spacing-2xl);border-radius:var(--radius-lg);border:1px solid var(--color-border-primary)}.coming-soon h2{color:var(--color-logo-teal);margin-bottom:var(--spacing-lg)}.coming-soon ul{text-align:left;max-width:600px;margin:var(--spacing-lg) auto 0;color:var(--color-text-secondary)}.coming-soon li{margin-bottom:var(--spacing-sm)}.project-links{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-primary)}.project-link{color:var(--color-logo-teal);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.project-link:hover{text-decoration:underline}.projects-empty,.projects-error,.projects-loading{text-align:center;padding:var(--spacing-3xl);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border-primary)}.projects-loading{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border-primary);border-top:4px solid var(--color-logo-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.projects-empty h3,.projects-error .error-icon{color:var(--color-error);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}.projects-empty h3,.projects-error .error-content h3{color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.projects-empty p,.projects-error p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.projects-error a{color:var(--color-logo-blue);text-decoration:none;font-weight:var(--font-weight-medium)}.projects-error a:hover{text-decoration:underline}.ramblings-page{max-width:900px;margin:0 auto}.intro-blurb{background-color:var(--color-bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border-primary);margin-bottom:var(--spacing-3xl)}.intro-blurb p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.posts-coming-soon{text-align:center}.posts-coming-soon h2{color:var(--color-logo-blue);font-size:var(--font-size-3xl);margin-bottom:var(--spacing-lg)}.posts-coming-soon>p{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-2xl)}.upcoming-posts{display:grid;gap:var(--spacing-xl);text-align:left}.post-preview{background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-normal)}.post-preview:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-logo-blue-subtle)}.post-title{color:var(--color-text-primary);font-size:var(--font-size-xl);margin-bottom:var(--spacing-md);line-height:var(--line-height-snug)}.post-excerpt{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.post-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:var(--font-size-sm)}.post-category{background-color:var(--color-logo-blue);color:var(--color-logo-white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-weight:var(--font-weight-medium)}.post-reading-time{color:var(--color-text-muted)}.post-status{background-color:var(--color-logo-orange);color:var(--color-logo-white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-weight:var(--font-weight-medium)}@media (max-width:768px){.post-meta{flex-direction:column;gap:var(--spacing-sm)}.post-category,.post-status{align-self:flex-start}}.about-page{max-width:800px;margin:0 auto}.cta-content{text-align:center;background-color:var(--color-bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border-primary)}.cta-content h2{color:var(--color-logo-blue);margin-bottom:var(--spacing-md)}.cta-content p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.site-header{background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border-primary);position:sticky;top:0;z-index:var(--z-sticky);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.site-header__inner{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 0;min-height:4rem}.site-header__brand{flex-shrink:0}.site-header__logo{display:inline-flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--color-text-primary);font-family:var(--font-family-heading);font-weight:var(--font-weight-extrabold);font-size:var(--font-size-xl);transition:all var(--transition-fast);padding:var(--spacing-sm);border-radius:var(--radius-md)}.site-header__logo:hover{color:var(--color-logo-teal);transform:scale(1.05)}.site-header__logo:focus{outline:0;box-shadow:var(--focus-ring)}.logo-image{width:40px;height:40px;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.site-header__logo:hover .logo-image{transform:rotate(5deg)}.logo-text{background:linear-gradient(135deg,var(--color-logo-teal),var(--color-logo-orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:var(--font-size-xl)}.site-header__nav{flex:1;display:flex;justify-content:center}.nav-list{display:flex;list-style:none;margin:0;padding:0;gap:var(--spacing-lg)}.nav-item{display:flex}.nav-link{display:inline-flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-primary);text-decoration:none;font-family:var(--font-family-heading);font-weight:var(--font-weight-medium);font-size:var(--font-size-base);border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative;min-height:44px;min-width:44px;justify-content:center}.nav-link:hover{color:var(--color-logo-teal);background-color:var(--color-logo-teal-subtle)}.nav-link:focus{outline:0;box-shadow:var(--focus-ring)}.nav-link[aria-current=page]{color:var(--color-logo-teal);background-color:var(--color-logo-teal-subtle)}.nav-link[aria-current=page]::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:80%;height:2px;background-color:var(--color-logo-teal);border-radius:var(--radius-full)}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:0 0;border:none;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);gap:4px}.mobile-menu-toggle:hover{background-color:var(--color-logo-teal-subtle)}.mobile-menu-toggle:focus{outline:0;box-shadow:var(--focus-ring)}.hamburger-line{display:block;width:24px;height:2px;background-color:var(--color-text-primary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.mobile-menu-toggle:hover .hamburger-line{background-color:var(--color-logo-teal)}@media (max-width:768px){.site-header__nav{display:none}.mobile-menu-toggle{display:flex}.nav-list{flex-direction:column;gap:var(--spacing-sm)}.site-header__inner{padding:var(--spacing-sm) 0}}@media (max-width:480px){.site-header__logo{font-size:var(--font-size-lg)}.logo-image{width:32px;height:32px}.logo-text{font-size:var(--font-size-lg)}}@media (prefers-contrast:high){.site-header{border-bottom-width:2px}.nav-link{border:1px solid transparent}.nav-link:focus,.nav-link[aria-current=page]{border-color:currentColor}}@media print{.site-header{position:static;border-bottom:1px solid #000;background:0 0}.mobile-menu-toggle{display:none}.site-header__nav{display:none}}