:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #293548;--border: #334155;--border-subtle:#1e2d40;--text-1: #f1f5f9;--text-2: #94a3b8;--text-3: #64748b;--accent: #6366f1;--accent-light: #818cf8;--accent-bg: rgba(99, 102, 241, .1);--accent-border: rgba(99, 102, 241, .22);--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--success-border: rgba(16, 185, 129, .22);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .1);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif;--font-mono: ui-monospace, "SF Mono", "Cascadia Code", "Source Code Pro", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5), 0 1px 1px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .4);--transition: .15s ease;--transition-md: .25s ease;font-family:var(--font-sans);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{background:var(--bg);color:var(--text-1);min-height:100vh;scroll-behavior:smooth;overflow-x:hidden}h1{font-size:clamp(1.875rem,4vw,2.5rem);font-weight:800;line-height:1.15;letter-spacing:-.03em;color:var(--text-1)}h2{font-size:clamp(1.125rem,2.5vw,1.375rem);font-weight:700;line-height:1.3;letter-spacing:-.01em;color:var(--text-1)}h3{font-size:1.0625rem;font-weight:600;line-height:1.4;color:var(--text-1)}h4{font-size:.6875rem;font-weight:600;line-height:1.5;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em}p{font-size:.9375rem;line-height:1.75;color:var(--text-2)}a{color:var(--accent-light);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--text-1)}a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-sm)}button{font-family:inherit;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button[disabled]{opacity:.4;cursor:not-allowed}code{font-family:var(--font-mono);font-size:.85em;padding:.15em .45em;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent-light)}hr{border:none;height:1px;background:var(--border-subtle);margin:var(--space-10) 0}.homepage{max-width:1200px;margin:0 auto;padding:var(--space-6) var(--space-4)}@media(min-width:768px){.homepage{padding:var(--space-10) var(--space-6)}}@media(min-width:1024px)and (orientation:landscape){.homepage{padding:var(--space-10) var(--space-8)}.hero{position:fixed;top:var(--space-10);width:290px}.sections{margin-left:calc(290px + var(--space-10))}}@media(min-width:1440px)and (orientation:landscape){.hero{width:330px}.sections{margin-left:calc(330px + var(--space-12))}}.section-label{display:block;font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-light);margin-bottom:var(--space-2)}.section-title{font-size:clamp(1.125rem,2.5vw,1.375rem);font-weight:700;color:var(--text-1);margin-bottom:var(--space-6);line-height:1.3;letter-spacing:-.01em}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.skip-link{position:fixed;top:-100px;left:0;z-index:10000;background:var(--accent);color:#fff;padding:.75rem 1.5rem;text-decoration:none;border-radius:0 0 var(--radius-md) 0;font-weight:600;transition:top var(--transition);opacity:0;pointer-events:none}.skip-link:focus{top:0;opacity:1;pointer-events:auto}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media print{.homepage{display:block}a:after{content:" (" attr(href) ")"}}.hero-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md);margin-bottom:var(--space-8)}@media(min-width:768px){.hero-wrapper{padding:var(--space-8)}}@media(min-width:1024px)and (orientation:landscape){.hero-wrapper{margin-bottom:0}}.header{display:flex;flex-direction:column;gap:var(--space-6)}.hero-header{display:flex;flex-direction:column;gap:var(--space-2)}.greeting{font-size:clamp(1.75rem,5vw,2.5rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--text-1)}.hero-lead{font-size:clamp(.9375rem,2.5vw,1.0625rem);font-weight:500;line-height:1.4;color:var(--accent-light);margin-top:var(--space-1)}.hero-tagline{font-size:.9375rem;color:var(--text-2);line-height:1.7;margin-top:var(--space-3);max-width:420px}.hero-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-4)}.availability-badge,.location-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:.3rem .7rem;border-radius:9999px;font-size:.8125rem;font-weight:500;line-height:1}.availability-badge{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.availability-badge:before{content:"";display:inline-block;width:6px;height:6px;background:var(--success);border-radius:50%}.location-badge{background:var(--surface-2);color:var(--text-3);border:1px solid var(--border)}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);padding:var(--space-4) var(--space-3);background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-1)}.stat-value{font-size:1.125rem;font-weight:700;color:var(--text-1);line-height:1}.stat-label{font-size:.6875rem;color:var(--text-3);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.social-icons{display:flex;flex-wrap:wrap;gap:var(--space-2)}.social-icon-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:.4375rem .875rem;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);text-decoration:none;font-size:.875rem;font-weight:500;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.social-icon-link svg{font-size:1rem;flex-shrink:0}.social-icon-link:hover{background:var(--accent-bg);border-color:var(--accent-border);color:var(--text-1);transform:translateY(-1px)}.social-icon-link:active{transform:translateY(0)}.social-icon-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.articles-container{margin-bottom:var(--space-10)}.articles-container h2{margin-bottom:var(--space-6)}.articles-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3);margin-bottom:var(--space-6)}@media(min-width:640px){.articles-grid{grid-template-columns:repeat(2,1fr)}}.article-card{display:flex;flex-direction:column;gap:var(--space-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);text-decoration:none;box-shadow:var(--shadow-sm);transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.article-card:hover{border-color:var(--accent-border);background:var(--surface-2);box-shadow:var(--shadow-md)}.content-wrapper{display:flex;flex-direction:column;gap:var(--space-2)}.content-wrapper h3{font-size:.9375rem;font-weight:600;line-height:1.45;color:var(--text-1);transition:color var(--transition)}.article-card:hover .content-wrapper h3{color:var(--accent-light)}.content-wrapper h4{font-size:.875rem;font-weight:400;line-height:1.6;color:var(--text-3);text-transform:none;letter-spacing:normal}.articles-footer{display:flex;justify-content:center}.more-articles-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:.5625rem 1.25rem;font-size:.875rem;font-weight:600;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-2);cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.more-articles-button:hover{background:var(--surface);border-color:var(--accent-border);color:var(--accent-light);transform:translateY(-1px)}.more-articles-button:active{transform:translateY(0)}.container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-8);box-shadow:var(--shadow-sm)}@media(min-width:768px){.container{padding:var(--space-8)}}.about-lead{font-size:1.0625rem;font-weight:500;line-height:1.65;color:var(--text-1);margin-bottom:var(--space-5)}.about-content p{font-size:.9375rem;line-height:1.75;color:var(--text-2);margin-bottom:var(--space-4)}.about-content p:last-child{margin-bottom:0}.about-content strong{color:var(--text-1);font-weight:600}.about-content code{font-family:var(--font-mono);font-size:.85em;padding:.15em .45em;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:var(--radius-sm);color:var(--accent-light)}.about-content a{color:var(--accent-light);font-weight:500;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-border);transition:color var(--transition),text-decoration-color var(--transition)}.about-content a:hover{color:var(--text-1);text-decoration-color:var(--text-1)}.section-skills{margin-bottom:var(--space-12)}.skills-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media(min-width:640px){.skills-grid{grid-template-columns:repeat(2,1fr)}}.skill-category{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm)}.category-title{font-size:.9375rem;font-weight:600;color:var(--text-1);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.skills-list{display:flex;flex-direction:column;gap:var(--space-3)}.skill-item{display:flex;flex-direction:column;gap:var(--space-1)}.skill-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2)}.skill-name{font-size:.9375rem;font-weight:500;color:var(--text-1)}.skill-years{font-size:.8125rem;color:var(--text-3)}.skill-proficiency{font-size:.6875rem;font-weight:600;padding:.2rem .55rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border:1px solid transparent;flex-shrink:0}.proficiency-expert{color:var(--success);background:var(--success-bg);border-color:var(--success-border)}.proficiency-advanced{color:var(--accent-light);background:var(--accent-bg);border-color:var(--accent-border)}.proficiency-intermediate{color:var(--text-3);background:var(--surface-2);border-color:var(--border)}.section-experiences{margin-bottom:var(--space-12)}.experiences-list{display:flex;flex-direction:column;gap:var(--space-4)}.experience-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:border-color var(--transition),box-shadow var(--transition)}.experience-card:hover{border-color:var(--border-subtle);box-shadow:var(--shadow-md)}.experience-header{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle)}@media(min-width:768px){.experience-header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.experience-title-group{flex:1;min-width:0}.experience-role{font-size:1.0625rem;font-weight:600;color:var(--text-1);margin:0 0 var(--space-1) 0;line-height:1.3}.experience-company{display:flex;align-items:center;gap:var(--space-2);font-size:.9375rem;font-weight:500;color:var(--text-2);margin:0}.experience-company svg{font-size:.8125rem;color:var(--text-3);flex-shrink:0}.experience-meta{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;flex-shrink:0}.experience-date,.experience-location{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-3)}.experience-date svg,.experience-location svg{font-size:.75rem;flex-shrink:0}.experience-type{display:inline-flex;align-items:center;font-size:.75rem;font-weight:600;color:var(--accent-light);background:var(--accent-bg);border:1px solid var(--accent-border);padding:.2rem .5rem;border-radius:9999px;letter-spacing:.02em}.experience-section{margin-bottom:var(--space-5)}.experience-section:last-child{margin-bottom:0}.experience-section h4{font-size:.6875rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin:0 0 var(--space-3) 0}.experience-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.experience-section ul li{font-size:.9375rem;color:var(--text-2);line-height:1.65;padding-left:1.125rem;position:relative}.experience-section ul li:before{content:"–";position:absolute;left:0;color:var(--text-3)}.achievements-list li:before{content:"✓";color:var(--success);font-weight:700}.experience-technologies{margin-bottom:var(--space-4)}.experience-technologies h4{font-size:.6875rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin:0 0 var(--space-3) 0}.experience-technologies .tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-2)}.experience-technologies .tech-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--text-2);transition:color var(--transition),background var(--transition)}.experience-technologies .tech-badge:hover{color:var(--text-1);background:var(--border)}.experience-highlights{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-subtle)}.highlight-text{font-size:.9375rem;color:var(--text-3);font-style:italic;line-height:1.7;margin:0;padding-left:var(--space-4);border-left:2px solid var(--accent)}.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.75rem 1.125rem;box-shadow:var(--shadow-lg);animation:toast-in .2s ease forwards}.toast-message{color:var(--text-1);font-size:.9375rem;font-weight:500;display:block}@keyframes toast-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@media(prefers-reduced-motion:reduce){.toast{animation:none}}@media(max-width:480px){.toast{bottom:1rem;right:1rem;left:1rem}}.section-contact{margin-bottom:var(--space-12);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-6);box-shadow:var(--shadow-sm);text-align:center}@media(min-width:640px){.section-contact{padding:var(--space-12) var(--space-10)}}.contact-content{max-width:540px;margin:0 auto}.section-title{font-size:clamp(1.25rem,3vw,1.625rem);font-weight:700;color:var(--text-1);margin-bottom:var(--space-3);line-height:1.25;letter-spacing:-.02em}.contact-description{font-size:.9375rem;color:var(--text-2);line-height:1.75;margin-bottom:var(--space-8)}.contact-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-8)}@media(min-width:480px){.contact-actions{flex-direction:row;justify-content:center}}.btn-large{padding:.6875rem 1.5rem;font-size:.9375rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);text-decoration:none;border-radius:var(--radius-md);transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition);cursor:pointer;font-family:inherit}.btn-primary.btn-large{background:var(--accent);border:1px solid var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary.btn-large:hover{background:var(--accent-light);border-color:var(--accent-light);transform:translateY(-1px)}.btn-primary.btn-large:active{transform:translateY(0)}.btn-secondary.btn-large{background:transparent;border:1px solid var(--border);color:var(--text-2)}.btn-secondary.btn-large:hover{background:var(--surface-2);border-color:var(--text-3);color:var(--text-1);transform:translateY(-1px)}.btn-secondary.btn-large:active{transform:translateY(0)}.contact-links{padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.contact-links-label{font-size:.8125rem;color:var(--text-3);margin-bottom:var(--space-4)}.social-links{display:flex;justify-content:center;gap:var(--space-3);flex-wrap:wrap}.social-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-2);text-decoration:none;padding:.4375rem .875rem;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);font-size:.875rem;font-weight:500;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.social-link:hover{background:var(--accent-bg);border-color:var(--accent-border);color:var(--text-1);transform:translateY(-1px)}.social-link:active{transform:translateY(0)}.social-link svg{font-size:1rem;flex-shrink:0}.social-link span{font-size:.875rem}.portfolio-container{margin-bottom:var(--space-10)}.portfolio-container h2{margin-bottom:var(--space-6)}.portfolio-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}@media(min-width:640px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}.portfolio-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:border-color var(--transition),box-shadow var(--transition)}.portfolio-card:hover{border-color:var(--border-subtle);box-shadow:var(--shadow-md)}.portfolio-image{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg)}.portfolio-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-md);display:block}.portfolio-card:hover .portfolio-image img{transform:scale(1.04)}.featured-badge{position:absolute;top:var(--space-3);right:var(--space-3);background:var(--accent);color:#fff;padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;box-shadow:var(--shadow-sm);z-index:1}.portfolio-content{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);flex:1}.portfolio-title{font-size:1.0625rem;font-weight:600;color:var(--text-1);margin:0;line-height:1.35}.portfolio-subtitle{font-size:.875rem;color:var(--text-3);margin:0;line-height:1.5}.tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tech-badge{display:inline-flex;align-items:center;padding:.2rem .55rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--text-2)}.portfolio-description{font-size:.9375rem;color:var(--text-2);line-height:1.7;margin:0}.achievements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.achievements-list li{font-size:.875rem;color:var(--text-2);line-height:1.6;padding-left:1.125rem;position:relative}.achievements-list li:before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:700}.portfolio-links{display:flex;gap:var(--space-2);margin-top:auto;padding-top:var(--space-3)}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.5rem 1rem;font-size:.875rem;font-weight:600;text-decoration:none;border-radius:var(--radius-md);transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition);flex:1;cursor:pointer;font-family:inherit}.btn-primary{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-2)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--text-3);color:var(--text-1);transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}.btn-primary svg,.btn-secondary svg{font-size:.875rem}@media(max-width:480px){.portfolio-links{flex-direction:column}}
