:root{--bg:#1a1f24;--bg-elevated:#212a31;--bg-card:#2e3944;--text:#d3d9d4;--text-muted:#748d92;--accent:#124e66;--accent-dim:#124e6626;--accent-light:#124e6640;--border:#748d92;--font-heading:"Syne",sans-serif;--font-body:"DM Sans",system-ui,sans-serif;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius:8px;--radius-lg:12px;--transition:.2s ease}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:1rem;line-height:1.6}[id]{scroll-margin-top:72px}a{color:var(--accent);transition:color var(--transition);text-decoration:none}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:820px;padding:0 var(--space-lg);margin:0 auto}.container-wide{max-width:1100px}.section{padding:var(--space-3xl)0}.section-title{margin:0 0 var(--space-xl);color:var(--text);letter-spacing:-.02em;font-size:clamp(1.5rem,4vw,1.75rem)}.accent{color:var(--accent)}.page{min-height:100vh}.projects-hero{padding:calc(80px + var(--space-2xl))0 var(--space-2xl);background:radial-gradient(900px 500px at 30% 10%,#124e6640,transparent 60%),radial-gradient(700px 450px at 80% 30%,#748d922e,transparent 55%),var(--bg);border-bottom:1px solid #748d9240}.projects-kicker{margin:0 0 var(--space-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem}.projects-title{margin:0 0 var(--space-md);letter-spacing:-.03em;font-size:clamp(2.2rem,6vw,3rem)}.projects-subtitle{margin:0 0 var(--space-lg);color:#b8c5c9;max-width:70ch}.projects-backlink{margin-top:var(--space-sm);color:var(--text-muted);font-weight:600;display:inline-flex}.projects-backlink:hover{color:var(--text)}.projects-grid{gap:var(--space-2xl);grid-template-columns:repeat(12,1fr);display:grid}.project-card{gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #748d9259;grid-column:1/-1;grid-template-columns:1fr 360px;grid-template-areas:"header image""body body";display:grid;box-shadow:0 2px 12px #0003}.project-header{grid-area:header}.project-meta{gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.project-year-tag{color:#7dd9f0f2;background:#124e662e;border:1px solid #2a7a8f59;border-radius:999px;align-items:center;padding:6px 10px;font-size:.8rem;font-weight:700;display:inline-flex}.project-title{margin:0 0 var(--space-sm);font-family:var(--font-heading);letter-spacing:-.02em;color:#2a7a8f;font-size:1.35rem;font-weight:800}.project-subtitle{margin:0 0 var(--space-md);color:#b8c5c9;line-height:1.7}.project-image-wrap{border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid #748d9259;grid-area:image;align-self:start;position:relative;overflow:hidden;box-shadow:0 8px 24px #00000040}.project-image-wrap:not(.project-image-wrap--empty){max-height:280px}.project-image-wrap:not(.project-image-wrap--empty):not(.project-image-wrap--carousel){height:clamp(200px,28vw,280px)}.project-image-wrap--carousel .carousel{max-width:none;padding:0}.project-image-wrap--carousel .carousel-track,.project-image-wrap--carousel .carousel-slide{border-radius:var(--radius-lg)}.project-image-wrap--carousel .carousel-slide{height:clamp(200px,28vw,280px)}.project-image{object-fit:cover;width:100%;height:100%;display:block}.project-image-wrap--empty{justify-content:center;align-items:center;min-height:240px;display:flex}.project-image-placeholder{padding:var(--space-lg);text-align:center;color:var(--text-muted);border-radius:var(--radius-lg);width:calc(100% - (2*var(--space-lg)));margin:var(--space-lg);border:2px dashed #748d9273}.project-body{grid-area:body}.project-sections{gap:var(--space-md);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.project-section{padding:var(--space-md);border-radius:var(--radius-lg);background:#212a318c;border:1px solid #748d9240}.project-section-title{margin:0 0 var(--space-sm);letter-spacing:.02em;text-transform:uppercase;color:var(--text);font-size:.85rem}.project-bullets{padding-left:var(--space-lg);color:#b8c5c9;margin:0;font-size:.92rem;line-height:1.7}.project-bullets li{margin-bottom:var(--space-sm)}.project-bullets li:last-child{margin-bottom:0}.classes-hero{padding:calc(80px + var(--space-2xl))0 var(--space-2xl);background:radial-gradient(900px 500px at 30% 10%,#124e6640,transparent 60%),radial-gradient(700px 450px at 80% 30%,#748d922e,transparent 55%),var(--bg);border-bottom:1px solid #748d9240}.classes-kicker{margin:0 0 var(--space-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem}.classes-title{margin:0 0 var(--space-md);letter-spacing:-.03em;font-size:clamp(2.2rem,6vw,3rem)}.classes-subtitle{margin:0 0 var(--space-xl);color:#b8c5c9;max-width:60ch}.classes-stats{gap:var(--space-md);width:100%;max-width:820px;margin:0 0 var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.classes-stat-card{padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #2a7a8f59;box-shadow:0 2px 12px #0003}.classes-stat-label{color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.85rem;font-weight:600;display:block}.classes-stat-value{font-family:var(--font-heading);letter-spacing:-.02em;color:#2a7a8f;font-size:1.8rem;font-weight:800;display:block}.classes-backlink{margin-top:var(--space-lg);color:var(--text-muted);font-weight:600;display:inline-flex}.classes-backlink:hover{color:var(--text)}.term-progress{width:100%;max-width:820px}.term-progress-track{background:#748d9240;border:1px solid #748d9240;border-radius:999px;height:10px;position:relative}.term-progress-fill{background:linear-gradient(90deg,var(--accent),#2a7a8fe6);border-radius:999px;height:100%;position:absolute;inset:0 auto 0 0;box-shadow:0 6px 16px #124e6659}.term-progress-dots{pointer-events:none;grid-template-columns:repeat(8,1fr);margin:0;padding:0;list-style:none;display:grid;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.term-progress-dot-wrap{flex-direction:column;align-items:center;gap:6px;display:flex}.term-progress-dot{background:var(--bg);border:2px solid #d3d9d459;border-radius:50%;width:14px;height:14px;box-shadow:0 0 0 4px #1a1f24e6}.term-progress-dot--done{background:#2a7a8fcc;border-color:#2a7a8fe6}.term-progress-dot--current{background:var(--accent);border-color:#57c0dd;box-shadow:0 0 0 4px #1a1f24e6,0 0 0 8px #124e6640}.term-progress-dot--todo{background:var(--bg-elevated);border-color:#d3d9d438}.term-progress-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:.75rem}.timeline-terms:before{background:#748d928c}.term-marker{background:#748d9266}.term-marker--completed{background:#2a7a8fe6}.term-marker--current{width:14px;height:14px;box-shadow:0 0 0 4px var(--bg),0 0 0 8px #124e6633;background:#57c0dd;left:-6px}.term-marker--upcoming{background:#748d9259}.term-card{border-color:#748d9259}.term-meta{justify-content:space-between;align-items:center;display:flex}.term-status{color:var(--text-muted);background:#748d921f;border:1px solid #748d9259;border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:700}.term-status--completed{color:#2a7a8ff2;background:#124e6626;border-color:#2a7a8f59}.term-status--current{color:#7dd9f0;background:#124e6640;border-color:#57c0dd59}.term-course-list{padding-left:var(--space-lg);margin:0}.term-course-list li{margin-bottom:var(--space-sm)}.term-course-list li:last-child{margin-bottom:0}.site-header{z-index:100;padding:var(--space-md)0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color var(--transition),background var(--transition);background:#1a1f24d9;border-bottom:1px solid #0000;position:fixed;top:0;left:0;right:0}.site-header.scrolled{border-bottom-color:var(--border)}.nav{max-width:1100px;padding:0 var(--space-lg);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.nav-logo{font-family:var(--font-heading);color:var(--text);letter-spacing:-.03em;font-size:1.25rem;font-weight:800}.nav-logo:hover{color:var(--accent)}.nav-toggle{padding:var(--space-sm);cursor:pointer;color:var(--text);background:0 0;border:none;flex-direction:column;gap:5px;display:none}.nav-toggle span{background:currentColor;border-radius:1px;width:22px;height:2px}.nav-links{align-items:center;gap:var(--space-xl);margin:0;padding:0;list-style:none;display:flex}.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);color:var(--accent)!important}.nav-cta:hover{background:var(--accent-light);color:var(--accent)!important}.hero{min-height:100vh;padding:calc(80px + var(--space-3xl))var(--space-lg)var(--space-3xl);align-items:center;display:flex;position:relative;overflow:hidden}.hero-bg{background:var(--bg);pointer-events:none;position:absolute;inset:0}.hero-container{gap:var(--space-3xl);grid-template-columns:1fr 1.2fr;align-items:center;width:100%;max-width:1400px;margin:0 auto;display:grid;position:relative}.hero-content{z-index:1;position:relative}.hero-image-area{z-index:1;justify-content:center;align-items:center;min-height:700px;display:flex;position:relative}.hero-image-placeholder{aspect-ratio:4/3;justify-content:center;align-items:center;gap:var(--space-lg);width:100%;max-width:650px;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);flex-direction:column;display:flex}.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;color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.5}.hero-image-hint span{opacity:.7;font-size:.8rem}.hero-image-wrapper{aspect-ratio:9/10;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:500px;transition:transform var(--transition),box-shadow var(--transition);position:relative;overflow:hidden;box-shadow:0 4px 20px #124e6633}.hero-image-wrapper:hover{transform:translateY(-4px);box-shadow:0 8px 30px #124e664d}.hero-image-wrapper img,.hero-image-wrapper .hero-image{object-fit:cover;width:100%;height:100%;transition:transform var(--transition);display:block}.hero-image-wrapper:hover img,.hero-image-wrapper:hover .hero-image{transform:scale(1.05)}.hero-image-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);width:100%;max-width:500px;display:grid}.hero-image-grid img{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);width:100%;transition:transform var(--transition),box-shadow var(--transition);box-shadow:0 4px 20px #124e6633}.hero-image-grid img:hover{z-index:1;position:relative;transform:translateY(-4px)scale(1.02);box-shadow:0 8px 30px #124e664d}.hero-label{color:var(--text-muted);margin:0 0 var(--space-md);text-transform:uppercase;letter-spacing:.1em;font-size:.9rem}.hero-title{margin:0 0 var(--space-lg);letter-spacing:-.04em;color:var(--text);font-size:clamp(2.4rem,10vw,5rem);font-weight:800}.hero-tagline{color:var(--text-muted);margin:0 0 var(--space-xl);max-width:520px;font-size:1.15rem}.hero-actions{gap:var(--space-md);flex-wrap:wrap;display:flex}.btn{padding:var(--space-md)var(--space-xl);font-family:var(--font-body);border-radius:var(--radius);transition:background var(--transition),color var(--transition),transform var(--transition);justify-content:center;align-items:center;font-size:.95rem;font-weight:600;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--accent);color:var(--text);border:none}.btn-primary:hover{color:var(--bg);background:#748d92}.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{bottom:var(--space-xl);align-items:center;gap:var(--space-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;flex-direction:column;font-size:.75rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.scroll-line{background:linear-gradient(to bottom,var(--text-muted),transparent);border-radius:1px;width:1px;height:40px;animation:2s ease-in-out infinite scroll-pulse}@keyframes scroll-pulse{0%,to{opacity:.5;transform:scaleY(.8)}50%{opacity:1;transform:scaleY(1)}}.about-grid{gap:var(--space-2xl);display:grid}.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{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.highlight-card{padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #2a7a8f66;box-shadow:0 2px 8px #0003}.highlight-value{font-family:var(--font-heading);color:#2a7a8f;margin-bottom:var(--space-xs);font-size:1.5rem;font-weight:700;display:block}.highlight-label{color:#b8c5c9;font-size:.85rem;font-weight:500}.apps-grid{gap:var(--space-2xl);display:grid}.app-card{gap:var(--space-2xl);padding:var(--space-xl);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #748d9259;grid-template-columns:1fr 1fr;align-items:center;display:grid;overflow:visible;box-shadow:0 2px 12px #0003}.app-card-content{max-width:400px}.app-name{font-family:var(--font-heading);color:#2a7a8f;margin:0 0 var(--space-md);font-size:1.5rem;font-weight:700}.app-description{margin:0 0 var(--space-lg);color:#b8c5c9;font-size:.95rem;line-height:1.7}.app-links{gap:var(--space-md);flex-wrap:wrap;display:flex}.app-link{padding:var(--space-sm)var(--space-md);border-radius:var(--radius);transition:background var(--transition),color var(--transition),transform var(--transition);align-items:center;font-size:.9rem;font-weight:600;display:inline-flex}.app-link:hover{transform:translateY(-1px)}.app-link-store{background:var(--accent);color:var(--text)}.app-link-store:hover{color:var(--text);background:#2a7a8f}.app-link-website{color:#2a7a8f;background:0 0;border:1px solid #2a7a8f}.app-link-website:hover{color:#3fa5c4;background:#2a7a8f26;border-color:#3fa5c4}.app-card-carousel{padding:var(--space-md);justify-content:center;align-items:center;display:flex;overflow:visible}.carousel{width:100%;max-width:280px;padding:var(--space-md);touch-action:pan-y;margin:0 auto;position:relative}.carousel-track{background:0 0;border:none;border-radius:40px;width:100%;position:relative;overflow:visible;box-shadow:0 20px 60px #0006,0 8px 24px #124e664d,0 0 0 1px #748d921a}.carousel-slide{background:var(--bg-elevated);border-radius:40px;position:relative;overflow:hidden}.carousel--phone .carousel-slide{aspect-ratio:9/19}.carousel--media .carousel-slide{aspect-ratio:16/9}.project-image-wrap--carousel .carousel--media .carousel-slide{aspect-ratio:auto}.carousel-image{object-fit:contain;width:100%;height:100%;display:block}.carousel-btn{border:1px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--text);cursor:pointer;transition:background var(--transition),color var(--transition);z-index:2;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.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{justify-content:center;gap:var(--space-sm);margin-top:var(--space-md);display:flex}.carousel-dot{background:var(--border);cursor:pointer;width:8px;height:8px;transition:background var(--transition);border:none;border-radius:50%}.carousel-dot:hover,.carousel-dot.active{background:var(--accent)}.carousel-empty .carousel-placeholder{aspect-ratio:9/19;justify-content:center;align-items: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);text-align:center;flex-direction:column;font-size:.9rem;display:flex}.carousel-placeholder-icon{opacity:.7;font-size:2rem}.carousel-placeholder code{background:var(--bg-card);border-radius:var(--radius);padding:2px 6px;font-size:.8rem}.timeline{position:relative}.timeline:before{content:"";background:var(--border);border-radius:1px;width:2px;position:absolute;top:0;bottom:0;left:0}.timeline-item{padding-left:var(--space-2xl);padding-bottom:var(--space-2xl);position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{background:var(--accent);width:12px;height:12px;box-shadow:0 0 0 4px var(--bg);border-radius:50%;position:absolute;top:.4em;left:-5px}.timeline-content{padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #748d924d;box-shadow:0 2px 8px #0003}.timeline-meta{align-items:baseline;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.timeline-role{font-family:var(--font-heading);color:var(--text);font-weight:600}.timeline-company{color:#2a7a8f;font-size:.95rem;font-weight:500}.timeline-company-link{color:#2a7a8f;transition:color var(--transition);align-items:center;gap:4px;font-weight:500;text-decoration:none;display:inline-flex}.timeline-company-link:after{content:"↗";opacity:.7;transition:opacity var(--transition);font-size:.85em}.timeline-company-link:hover{color:#3fa5c4}.timeline-company-link:hover:after{opacity:1}.timeline-date{color:#8fa5aa;margin-left:auto;font-size:.85rem;font-weight:500}.timeline-content p,.timeline-content ul{color:#b8c5c9;margin:0;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{gap:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.skill-group h3{margin:0 0 var(--space-md);color:var(--text);font-size:1rem;font-weight:600}.skill-group ul{margin:0;padding:0;list-style:none}.skill-group li{padding:var(--space-xs)0;color:#b8c5c9;border-bottom:1px solid #748d924d;font-size:.95rem}.skill-group li:last-child{border-bottom:none}.education-cards{gap:var(--space-lg);display:grid}.edu-card{padding:var(--space-xl);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #748d9259;box-shadow:0 2px 8px #0003}.edu-card-primary{background:var(--bg-card);border-color:#2a7a8f80}.edu-degree{font-family:var(--font-heading);color:var(--text);margin-bottom:var(--space-xs);font-size:1.1rem;font-weight:600;display:block}.edu-school{color:#2a7a8f;margin-bottom:var(--space-xs);font-size:.95rem;font-weight:500;display:block}.edu-date{color:#8fa5aa;margin-bottom:var(--space-md);font-size:.85rem;font-weight:500;display:block}.edu-details{padding-left:var(--space-lg);color:#b8c5c9;margin:0;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{gap:var(--space-md);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.contact-link{align-items:center;gap:var(--space-sm);color:var(--text);font-size:1.05rem;display:inline-flex}.contact-link:hover{color:var(--accent)}.contact-icon{color:var(--accent);font-size:1.1rem}.site-footer{padding:var(--space-xl)0;border-top:1px solid var(--border)}.site-footer p{color:var(--text-muted);text-align:center;margin:0;font-size:.9rem}@media (min-width:1025px){.about-grid{grid-template-columns:1.35fr 1fr;align-items:start}.education-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:1024px){.nav-toggle{display:flex}.nav-links{padding:var(--space-lg);background:var(--bg-elevated);border-bottom:1px solid var(--border);gap:var(--space-md);opacity:0;visibility:hidden;transition:transform var(--transition),opacity var(--transition),visibility var(--transition);-webkit-overflow-scrolling:touch;flex-direction:column;max-height:calc(100vh - 56px);position:fixed;top:56px;left:0;right:0;overflow:auto;transform:translateY(-100%)}.nav-links.open{opacity:1;visibility:visible;transform:translateY(0)}.hero-container{gap:var(--space-2xl);grid-template-columns:1fr}.hero-image-area{order:-1;min-height:360px}.project-card{grid-template-columns:1fr;grid-template-areas:"header""image""body"}.project-header,.project-body,.project-image-wrap{grid-column:1/-1}.app-card{gap:var(--space-lg);grid-template-columns:1fr}.app-card-carousel{order:-1}}@media (max-width:640px){.container{padding:0 var(--space-md)}.section{padding:var(--space-2xl)0}.classes-hero,.projects-hero{padding-top:calc(72px + var(--space-2xl))}.project-image-wrap--empty{min-height:200px}.project-sections{grid-template-columns:1fr}.classes-stats{grid-template-columns:1fr;max-width:100%}.term-progress-dots{grid-template-columns:repeat(8,1fr)}.term-progress-label{font-size:.7rem}.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{width:14px;height:14px;left:0}.timeline-meta{flex-direction:column;gap:0}.timeline-date{margin-left:0}.carousel{max-width:220px;padding:var(--space-sm)}.carousel-btn-prev{left:4px}.carousel-btn-next{right:4px}}
