.header{background-color:#0f172af2;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}@supports (backdrop-filter: blur(1px)){.header{background-color:#0f172acc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}.header-container{max-width:var(--container-max);margin:0 auto;padding:1rem var(--page-padding);display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.375rem;font-weight:700;color:var(--text);text-decoration:none;letter-spacing:-.02em;transition:color var(--transition-fast);padding:.25rem;border-radius:2px}.logo:hover{color:var(--color-primary)}.logo:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.nav-list{display:flex;gap:2.5rem;list-style:none;margin:0;padding:0}.nav-link{color:var(--muted);text-decoration:none;font-weight:500;font-size:.9375rem;padding:.5rem;position:relative;transition:color var(--transition-fast);border-radius:2px}.nav-link:after{content:"";position:absolute;bottom:0;left:.5rem;width:0;height:2px;background-color:var(--color-primary);border-radius:1px;transition:width var(--transition-base)}.nav-link:hover:after,.nav-link.active:after{width:calc(100% - 1rem)}.nav-link:hover,.nav-link.active{color:var(--color-white)}.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}@media (max-width: 768px){.header-container{flex-direction:column;gap:1rem;padding:.875rem var(--page-padding)}.nav-list{gap:1.5rem}.nav-link{font-size:.875rem}}.footer{background-color:var(--surface);color:var(--text);padding:2.5rem var(--page-padding);margin-top:auto;border-top:1px solid var(--border)}.footer-container{max-width:var(--container-max);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.social-links{display:flex;gap:2rem}.social-link{color:var(--muted);text-decoration:none;font-weight:500;font-size:.9375rem;transition:color var(--transition-fast),text-decoration var(--transition-fast);padding:.25rem .5rem;border-radius:2px}.social-link:hover{color:var(--color-primary);text-decoration:underline}.social-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.copyright{color:var(--muted);font-size:.8125rem;margin:0}.continuity-note{color:var(--muted);font-size:.75rem;margin:0;opacity:.7;font-style:italic}.project-card{background-color:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md);transition:transform var(--transition-base),box-shadow var(--transition-base);display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.project-card:hover .project-image img{transform:scale(1.05)}.project-image-link{display:block;cursor:pointer;border-radius:var(--radius-lg)}.project-image-link:hover .project-image img,.project-image-link:hover .image-placeholder{opacity:.85}.project-image-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.project-image{width:100%;height:200px;overflow:hidden;background-color:var(--surface-2);position:relative}.project-image img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:opacity var(--transition-fast),transform var(--transition-base)}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);transition:opacity var(--transition-fast)}.image-placeholder span{font-size:4rem;font-weight:700;color:var(--color-white);opacity:.9}.project-content{padding:1.5rem;display:flex;flex-direction:column;flex:1}.project-title{font-size:1.25rem;font-weight:600;color:var(--text);margin:0 0 .75rem;letter-spacing:-.01em}.project-title-link{color:inherit;text-decoration:none;transition:color var(--transition-fast);display:inline-block;padding:.25rem 0;border-radius:2px}.project-title-link:hover{color:var(--color-primary);text-decoration:underline}.project-title-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.project-header{display:flex;flex-wrap:wrap;align-items:baseline;gap:.75rem;margin-bottom:.75rem}.project-header .project-title{margin-bottom:0}.featured-badge{position:absolute;top:.75rem;left:.75rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background-color:var(--surface-2);padding:.25rem .625rem;border-radius:var(--radius-full);border:1px solid var(--border);white-space:nowrap;z-index:1}.project-description{color:var(--muted);font-size:.9375rem;line-height:1.65;margin:0 0 1.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.key-features{margin:0 0 1.25rem;padding-left:1.25rem;list-style-type:disc}.key-features li{color:var(--muted);font-size:.875rem;line-height:1.6;margin-bottom:.375rem}.key-features li:last-child{margin-bottom:0}.learning-section{margin:0 0 1.25rem;padding-top:.75rem;border-top:1px solid var(--border)}.learning-title{font-size:.8125rem;font-weight:600;color:var(--muted);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.03em}.learning-highlights{margin:0;padding-left:1.25rem;list-style-type:disc}.learning-highlights li{color:var(--muted);font-size:.8125rem;line-height:1.55;margin-bottom:.25rem}.learning-highlights li:last-child{margin-bottom:0}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{background-color:var(--surface-2);color:var(--text);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;border:1px solid var(--border);transition:background-color var(--transition-fast)}.project-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:auto}.project-links{display:flex;flex-wrap:wrap;gap:.75rem}.project-link{padding:.625rem 1.25rem;border-radius:var(--radius-full);text-decoration:none;font-weight:500;font-size:.875rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:inline-block;cursor:pointer}.project-link:hover{transform:translateY(-1px)}.github-link,.server-link{background-color:var(--surface-2);color:var(--text);border:1px solid var(--border)}.github-link:hover,.server-link:hover{background-color:var(--surface);border-color:var(--muted);box-shadow:var(--shadow-sm)}.demo-link{background-color:var(--color-primary);color:var(--bg);border:1px solid var(--color-primary);font-weight:600}.demo-link:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-sm)}.demo-link:focus-visible,.github-link:focus-visible,.server-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.view-details-link{display:inline-block;padding:.625rem 1.25rem;border-radius:var(--radius-full);background-color:var(--surface);color:var(--text);border:1px solid var(--border);font-weight:500;font-size:.875rem;text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);cursor:pointer}.view-details-link:hover{background-color:var(--surface-2);border-color:var(--muted);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.view-details-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}@media (max-width: 480px){.project-content{padding:1.25rem}.project-links{flex-direction:column}.project-link{text-align:center}}.home{min-height:calc(100vh - 200px)}.hero{max-width:720px;margin:0 auto;padding:5rem var(--page-padding) 4rem;text-align:center}.hero-greeting{font-size:1rem;color:var(--color-primary);margin:0 0 .75rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.hero-name{font-size:clamp(2.5rem,6vw,3.5rem);font-weight:700;color:var(--text);margin:0 0 .75rem;letter-spacing:-.03em;line-height:1.1}.hero-title{font-size:clamp(1.125rem,3vw,1.5rem);font-weight:400;color:var(--muted);margin:0 0 2rem}.hero-headline{font-size:1.125rem;font-weight:500;line-height:1.65;color:var(--text);margin:0 0 1rem;max-width:560px;margin-left:auto;margin-right:auto}.hero-description{font-size:1.0625rem;line-height:1.75;color:var(--muted);margin:0 0 2.5rem;max-width:560px;margin-left:auto;margin-right:auto}.hero-statement{font-size:.9375rem;color:var(--muted);font-style:italic;margin:0 0 2.5rem;opacity:.85}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:.875rem 2rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9375rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:inline-block;cursor:pointer}.btn-primary{background-color:var(--color-primary);color:var(--bg);box-shadow:var(--shadow-sm);font-weight:600}.btn-primary:hover{background-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background-color:var(--surface-2);border-color:var(--muted);box-shadow:var(--shadow-md)}.skills-preview{background-color:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem var(--page-padding);text-align:center}.skills-title{font-size:.8125rem;font-weight:600;color:var(--muted);margin:0 0 1.5rem;text-transform:uppercase;letter-spacing:.05em}.skills-list{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;max-width:640px;margin:0 auto;list-style:none;padding:0}.skill-item{background-color:var(--surface-2);color:var(--text);padding:.5rem 1.25rem;border-radius:var(--radius-full);font-weight:500;font-size:.875rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.featured-projects{padding:4rem var(--page-padding);max-width:var(--container-max);margin:0 auto}.featured-title{font-size:.8125rem;font-weight:600;color:var(--muted);text-align:center;margin:0 0 2rem;text-transform:uppercase;letter-spacing:.05em}.featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.featured-cta{text-align:center;margin-top:2.5rem}.more-projects{padding:4rem var(--page-padding);max-width:var(--container-max);margin:0 auto}.more-projects-title{font-size:.8125rem;font-weight:600;color:var(--muted);text-align:center;margin:0 0 2rem;text-transform:uppercase;letter-spacing:.05em}.more-projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}@media (max-width: 768px){.hero{padding:3rem var(--page-padding) 2.5rem}.hero-name{font-size:2.25rem}.hero-title{font-size:1.125rem}.hero-description{font-size:1rem}.featured-projects,.more-projects{padding:3rem var(--page-padding)}}@media (max-width: 480px){.hero-buttons{flex-direction:column;align-items:center}.btn{width:100%;max-width:250px;text-align:center}}.about{min-height:calc(100vh - 200px);background-color:var(--bg)}.about-container{max-width:800px;margin:0 auto;padding:4rem var(--page-padding)}.about .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 2.5rem;text-align:center;letter-spacing:-.02em}.section-title{font-size:1.25rem;font-weight:600;color:var(--text);margin:0 0 1rem;padding-bottom:.625rem;border-bottom:2px solid var(--color-primary);display:inline-block}.about-text{font-size:1rem;line-height:1.75;color:var(--muted);margin:0 0 1rem}.about-text a{color:var(--color-primary);text-decoration:underline;text-decoration-color:var(--accent-soft);text-underline-offset:2px;transition:text-decoration-color var(--transition-fast)}.about-text a:hover{text-decoration-color:var(--color-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem}.skill-category{background-color:var(--bg);padding:1.5rem;border-radius:var(--radius-md);border:1px solid var(--border)}.skill-category h3{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 1rem}.skill-category ul{list-style:none;padding:0;margin:0}.skill-category li{color:var(--muted);position:relative;padding:.375rem 0 .375rem 1.25rem;font-size:.9375rem}.skill-category li:before{content:"▸";color:var(--color-primary);position:absolute;left:0}@media (max-width: 768px){.about-container{padding:3rem var(--page-padding)}.about .page-title{font-size:2rem}.section-title{font-size:1.125rem}.about-text{font-size:.9375rem}.about-section{padding:1.5rem}}.projects{min-height:calc(100vh - 200px);background-color:var(--bg)}.projects-container{max-width:var(--container-max);margin:0 auto;padding:4rem var(--page-padding)}.projects .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 1rem;text-align:center;letter-spacing:-.02em}.projects-description{font-size:1.0625rem;color:var(--muted);text-align:center;max-width:800px;margin-left:auto;margin-right:auto;margin-bottom:2.5rem;line-height:1.65;width:100%}.filter-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2.5rem}.filter-btn{background-color:var(--surface);color:var(--muted);border:1px solid var(--border);padding:.5rem 1.125rem;border-radius:var(--radius-full);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--accent-soft)}.filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--bg);font-weight:600}.filter-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.no-results{text-align:center;color:var(--muted);font-size:1.0625rem;padding:3rem 1rem}@media (max-width: 768px){.projects-container{padding:3rem var(--page-padding)}.projects .page-title{font-size:2rem}.projects-grid{grid-template-columns:1fr}}.project-details{min-height:calc(100vh - 200px);background-color:var(--bg)}.project-details-container{max-width:800px;margin:0 auto;padding:4rem var(--page-padding)}.details-header{margin-bottom:2rem}.details-title-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:1rem}.details-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0;letter-spacing:-.02em}.details-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background-color:var(--surface);padding:.375rem .75rem;border-radius:var(--radius-full);border:1px solid var(--border);white-space:nowrap}.details-image-container{margin-bottom:2rem;background-color:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);display:flex;justify-content:center;align-items:center}.project-image-full{max-width:100%;height:auto;border-radius:var(--radius-lg);display:block}.details-section{margin-bottom:2rem;background-color:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border)}.details-section-title{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-primary);display:inline-block}.details-description{font-size:1rem;line-height:1.75;color:var(--muted);margin:0}.details-list{margin:0;padding-left:1.5rem;list-style-type:disc}.details-list li{color:var(--muted);font-size:.9375rem;line-height:1.7;margin-bottom:.5rem}.details-list li:last-child{margin-bottom:0}.details-tech-stack{display:flex;flex-wrap:wrap;gap:.5rem}.details-tech-tag{background-color:var(--surface-2);color:var(--text);padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;border:1px solid var(--border)}.details-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9375rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:inline-block;cursor:pointer}.btn:hover{transform:translateY(-2px)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.btn-primary{background-color:var(--color-primary);color:var(--bg);border:1px solid var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--surface-2);border-color:var(--muted);box-shadow:var(--shadow-sm)}.details-back{padding-top:1.5rem;border-top:1px solid var(--border)}.back-link{color:var(--color-primary);font-weight:500;font-size:.9375rem;text-decoration:none;transition:color var(--transition-fast),text-decoration var(--transition-fast);display:inline-block;padding:.25rem 0;border-radius:2px}.back-link:hover{color:var(--color-primary-light);text-decoration:underline}.back-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.not-found{text-align:center;padding:4rem 0}.not-found-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:var(--text);margin:0 0 1rem}.not-found-text{color:var(--muted);font-size:1rem;margin:0 0 2rem}@media (max-width: 480px){.project-details-container{padding:2rem var(--page-padding)}.details-section{padding:1.25rem}.details-actions{flex-direction:column}.btn{text-align:center;width:100%}}.contact{min-height:calc(100vh - 200px);background-color:var(--bg)}.contact-container{max-width:560px;margin:0 auto;padding:4rem var(--page-padding);text-align:center}.contact .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 1rem;letter-spacing:-.02em}.contact .page-subtitle{font-size:1.0625rem;color:var(--muted);line-height:1.65;margin:0 0 3rem}.contact-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.contact-card{background-color:var(--surface);padding:1.5rem 2rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.contact-card:hover{box-shadow:var(--shadow-md)}.contact-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.contact-link{font-size:1.0625rem;color:var(--text);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.contact-link:hover{color:var(--color-primary)}.email-cta{margin-top:2rem}.email-button{display:inline-block;background-color:var(--color-primary);color:var(--bg);padding:1rem 2.5rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9375rem;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.email-button:hover{background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.contact-container{padding:3rem var(--page-padding)}.contact .page-title{font-size:2rem}.contact .page-subtitle{font-size:1rem}.contact-card{padding:1.25rem 1.5rem}}.app{display:flex;flex-direction:column;min-height:100vh}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2dd4bf;--color-primary-dark: #14b8a6;--color-primary-light: #5eead4;--accent-soft: rgba(45, 212, 191, .15);--accent-gradient: linear-gradient(135deg, #0d9488 0%, #0891b2 100%);--text: #e2e8f0;--muted: #94a3b8;--color-dark: #e2e8f0;--color-gray: #94a3b8;--color-gray-light: #64748b;--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--border: rgba(148, 163, 184, .15);--color-background: #1e293b;--color-white: #f8fafc;--container-max: 1120px;--page-padding: clamp(1rem, 3vw, 1.5rem);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2), 0 1px 3px rgba(0, 0, 0, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .25), 0 2px 4px -2px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .3), 0 8px 10px -6px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7;color:var(--text);background-color:var(--bg);background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(45,212,191,.04),transparent)}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:600;color:var(--text)}h1{font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.02em}h2{font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.01em}h3{font-size:clamp(1.125rem,2vw,1.375rem)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}a:focus-visible,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft);border-radius:var(--radius-sm)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}::selection{background-color:var(--accent-soft);color:var(--color-primary)}.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}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition:none!important;animation:none!important}html{scroll-behavior:auto!important}.project-card:hover{transform:none!important}}
