:root{--bg:#1a1f24;--bg-elevated:#212a31;--bg-card:#2e3944;--text:#d3d9d4;--text-muted:#748d92;--accent:#124e66;--accent-dim:rgba(18,78,102,.15);--accent-light:rgba(18,78,102,.25);--border:#748d92;--font-heading:"Syne",sans-serif;--font-body:"DM Sans",system-ui,sans-serif;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius:8px;--radius-lg:12px;--transition:0.2s ease}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:#748d92}h1,h2,h3{font-family:var(--font-heading);font-weight:700;line-height:1.2}img{max-width:100%;height:auto}.container{width:100%;max-width:720px;margin:0 auto;padding:0 var(--space-lg)}.container-wide{max-width:960px}.section{padding:var(--space-3xl) 0}.section-title{font-size:clamp(1.5rem,4vw,1.75rem);margin:0 0 var(--space-xl);color:var(--text);letter-spacing:-.02em}.accent{color:var(--accent)}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--space-md) 0;background:rgba(26,31,36,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color var(--transition),background var(--transition)}.site-header.scrolled{border-bottom-color:var(--border)}.nav{max-width:960px;margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-heading);font-weight:800;font-size:1.25rem;color:var(--text);letter-spacing:-.03em}.nav-logo:hover{color:var(--accent)}.nav-toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-sm);background:none;border:none;cursor:pointer;color:var(--text)}.nav-toggle span{width:22px;height:2px;background:currentColor;border-radius:1px}.nav-links{display:flex;align-items:center;gap:var(--space-xl);list-style:none;margin:0;padding:0}.nav-links a{color:var(--text-muted);font-size:.9rem;font-weight:500}.nav-links a:hover{color:var(--text)}.nav-cta{padding:var(--space-sm) var(--space-md);background:var(--accent-dim);border-radius:var(--radius)}.nav-cta,.nav-cta:hover{color:var(--accent)!important}.nav-cta:hover{background:var(--accent-light)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:calc(80px + var(--space-3xl)) var(--space-lg) var(--space-3xl);overflow:hidden}.hero-bg{position:absolute;inset:0;background:var(--bg);pointer-events:none}.hero-container{position:relative;width:100%;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;grid-gap:var(--space-3xl);gap:var(--space-3xl);align-items:center}.hero-content,.hero-image-area{position:relative;z-index:1}.hero-image-area{min-height:700px}.hero-image-area,.hero-image-placeholder{display:flex;align-items:center;justify-content:center}.hero-image-placeholder{width:100%;max-width:650px;aspect-ratio:4/3;flex-direction:column;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-card);border:2px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);transition:border-color var(--transition),background var(--transition)}.hero-image-placeholder:hover{border-color:var(--accent-dim);background:var(--bg-elevated)}.hero-image-icon{opacity:.5;color:var(--text-muted)}.hero-image-hint{text-align:center;font-size:.9rem;line-height:1.5;margin:0;color:var(--text-muted)}.hero-image-hint span{font-size:.8rem;opacity:.7}.hero-image-wrapper{width:100%;max-width:500px;aspect-ratio:9/10;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);box-shadow:0 4px 20px rgba(18,78,102,.2);transition:transform var(--transition),box-shadow var(--transition)}.hero-image-wrapper:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(18,78,102,.3)}.hero-image-wrapper .hero-image,.hero-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--transition)}.hero-image-wrapper:hover .hero-image,.hero-image-wrapper:hover img{transform:scale(1.05)}.hero-image-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md);width:100%;max-width:500px}.hero-image-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:0 4px 20px rgba(18,78,102,.2);transition:transform var(--transition),box-shadow var(--transition)}.hero-image-grid img:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 30px rgba(18,78,102,.3);z-index:1;position:relative}.hero-label{font-size:.9rem;color:var(--text-muted);margin:0 0 var(--space-md);text-transform:uppercase;letter-spacing:.1em}.hero-title{font-size:clamp(3rem,10vw,5rem);font-weight:800;margin:0 0 var(--space-lg);letter-spacing:-.04em;color:var(--text)}.hero-tagline{font-size:1.15rem;color:var(--text-muted);margin:0 0 var(--space-xl);max-width:520px}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);font-family:var(--font-body);font-size:.95rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition),color var(--transition),transform var(--transition)}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--accent);color:var(--text);border:none}.btn-primary:hover{background:#748d92;color:var(--bg)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--text-muted);color:var(--text)}.hero-scroll{position:absolute;bottom:var(--space-xl);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--text-muted),transparent);border-radius:1px;animation:scroll-pulse 2s ease-in-out infinite}@keyframes scroll-pulse{0%,to{opacity:.5;transform:scaleY(.8)}50%{opacity:1;transform:scaleY(1)}}.about-grid{display:grid;grid-gap:var(--space-2xl);gap:var(--space-2xl)}.about-text p{margin:0 0 var(--space-lg);color:#b8c5c9;font-size:1rem;line-height:1.7}.about-text p:last-child{margin-bottom:0}.about-text p strong{color:#2a7a8f;font-weight:600}.about-highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}.highlight-card{padding:var(--space-lg);background:var(--bg-card);border:1px solid rgba(42,122,143,.4);border-radius:var(--radius-lg);box-shadow:0 2px 8px rgba(0,0,0,.2)}.highlight-value{display:block;font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:#2a7a8f;margin-bottom:var(--space-xs)}.highlight-label{font-size:.85rem;color:#b8c5c9;font-weight:500}.apps-grid{grid-gap:var(--space-2xl)}.app-card,.apps-grid{display:grid;gap:var(--space-2xl)}.app-card{grid-template-columns:1fr 1fr;grid-gap:var(--space-2xl);align-items:center;padding:var(--space-xl);background:var(--bg-card);border:1px solid rgba(116,141,146,.35);border-radius:var(--radius-lg);overflow:visible;box-shadow:0 2px 12px rgba(0,0,0,.2)}.app-card-content{max-width:400px}.app-name{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:#2a7a8f;margin:0 0 var(--space-md)}.app-description{margin:0 0 var(--space-lg);color:#b8c5c9;font-size:.95rem;line-height:1.7}.app-links{display:flex;flex-wrap:wrap;gap:var(--space-md)}.app-link{display:inline-flex;align-items:center;padding:var(--space-sm) var(--space-md);font-size:.9rem;font-weight:600;border-radius:var(--radius);transition:background var(--transition),color var(--transition),transform var(--transition)}.app-link:hover{transform:translateY(-1px)}.app-link-store{background:var(--accent);color:var(--text)}.app-link-store:hover{background:#2a7a8f;color:var(--text)}.app-link-website{background:transparent;color:#2a7a8f;border:1px solid #2a7a8f}.app-link-website:hover{background:rgba(42,122,143,.15);color:#3fa5c4;border-color:#3fa5c4}.app-card-carousel{display:flex;justify-content:center;align-items:center;padding:var(--space-md);overflow:visible}.carousel{max-width:280px;margin:0 auto;padding:var(--space-md)}.carousel,.carousel-track{position:relative;width:100%}.carousel-track{border-radius:40px;overflow:visible;background:transparent;border:none;box-shadow:0 20px 60px rgba(0,0,0,.4),0 8px 24px rgba(18,78,102,.3),0 0 0 1px rgba(116,141,146,.1)}.carousel-slide{position:relative;border-radius:40px;overflow:hidden;background:var(--bg-elevated)}.carousel-image{width:100%;height:100%;object-fit:contain;display:block}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition);z-index:2}.carousel-btn:hover{background:var(--accent);color:var(--text);border-color:var(--accent)}.carousel-btn-prev{left:-12px}.carousel-btn-next{right:-12px}.carousel-dots{display:flex;justify-content:center;gap:var(--space-sm);margin-top:var(--space-md)}.carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;transition:background var(--transition)}.carousel-dot.active,.carousel-dot:hover{background:var(--accent)}.carousel-empty .carousel-placeholder{aspect-ratio:9/19;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-elevated);border:2px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:.9rem;text-align:center}.carousel-placeholder-icon{font-size:2rem;opacity:.7}.carousel-placeholder code{font-size:.8rem;padding:2px 6px;background:var(--bg-card);border-radius:var(--radius)}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--border);border-radius:1px}.timeline-item{position:relative;padding-left:var(--space-2xl);padding-bottom:var(--space-2xl)}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-5px;top:.4em;width:12px;height:12px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 4px var(--bg)}.timeline-content{padding:var(--space-lg);background:var(--bg-card);border:1px solid rgba(116,141,146,.3);border-radius:var(--radius-lg);box-shadow:0 2px 8px rgba(0,0,0,.2)}.timeline-meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-sm);margin-bottom:var(--space-md)}.timeline-role{font-family:var(--font-heading);font-weight:600;color:var(--text)}.timeline-company{color:#2a7a8f;font-size:.95rem;font-weight:500}.timeline-company-link{color:#2a7a8f;text-decoration:none;transition:color var(--transition);display:inline-flex;align-items:center;gap:4px;font-weight:500}.timeline-company-link:after{content:"↗";font-size:.85em;opacity:.7;transition:opacity var(--transition)}.timeline-company-link:hover{color:#3fa5c4}.timeline-company-link:hover:after{opacity:1}.timeline-date{margin-left:auto;font-size:.85rem;color:#8fa5aa;font-weight:500}.timeline-content p,.timeline-content ul{margin:0;color:#b8c5c9;font-size:.95rem;line-height:1.7}.timeline-content ul{padding-left:var(--space-lg)}.timeline-content li{margin-bottom:var(--space-sm)}.timeline-content li:last-child{margin-bottom:0}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--space-xl);gap:var(--space-xl)}.skill-group h3{font-size:1rem;margin:0 0 var(--space-md);color:var(--text);font-weight:600}.skill-group ul{list-style:none;margin:0;padding:0}.skill-group li{padding:var(--space-xs) 0;color:#b8c5c9;font-size:.95rem;border-bottom:1px solid rgba(116,141,146,.3)}.skill-group li:last-child{border-bottom:none}.education-cards{display:grid;grid-gap:var(--space-lg);gap:var(--space-lg)}.edu-card{padding:var(--space-xl);background:var(--bg-card);border:1px solid rgba(116,141,146,.35);border-radius:var(--radius-lg);box-shadow:0 2px 8px rgba(0,0,0,.2)}.edu-card-primary{border-color:rgba(42,122,143,.5);background:var(--bg-card)}.edu-degree{font-family:var(--font-heading);font-weight:600;font-size:1.1rem;color:var(--text)}.edu-degree,.edu-school{display:block;margin-bottom:var(--space-xs)}.edu-school{color:#2a7a8f;font-size:.95rem;font-weight:500}.edu-date{display:block;font-size:.85rem;color:#8fa5aa;margin-bottom:var(--space-md);font-weight:500}.edu-details{margin:0;padding-left:var(--space-lg);color:#b8c5c9;font-size:.95rem;line-height:1.7}.edu-details li{margin-bottom:var(--space-sm)}.contact-intro{color:var(--text-muted);margin:0 0 var(--space-xl);max-width:480px}.contact-links{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.contact-link{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:1.05rem;color:var(--text)}.contact-icon,.contact-link:hover{color:var(--accent)}.contact-icon{font-size:1.1rem}.site-footer{padding:var(--space-xl) 0;border-top:1px solid var(--border)}.site-footer p{margin:0;font-size:.9rem;color:var(--text-muted);text-align:center}@media (max-width:640px){.nav-toggle{display:flex}.nav-links{position:fixed;top:56px;left:0;right:0;flex-direction:column;padding:var(--space-lg);background:var(--bg-elevated);border-bottom:1px solid var(--border);gap:var(--space-md);transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform var(--transition),opacity var(--transition),visibility var(--transition)}.nav-links.open{transform:translateY(0);opacity:1;visibility:visible}.hero-container{grid-template-columns:1fr;gap:var(--space-2xl)}.hero-image-area{min-height:300px;order:-1}.hero-image-placeholder{max-width:100%}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.timeline:before{left:6px}.timeline-item{padding-left:var(--space-xl)}.timeline-marker{left:0;width:14px;height:14px}.timeline-meta{flex-direction:column;gap:0}.timeline-date{margin-left:0}.app-card{grid-template-columns:1fr;gap:var(--space-lg)}.app-card-carousel{order:-1}.carousel{max-width:220px;padding:var(--space-sm)}.carousel-btn-prev{left:4px}.carousel-btn-next{right:4px}}