*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #08080C;--color-bg-secondary: #0C0C12;--color-surface: #101016;--color-surface-hover: #16161E;--color-border: #1C1C26;--color-border-subtle: rgba(255, 255, 255, .04);--color-accent: #94A3B8;--color-accent-warm: #F59E0B;--color-accent-muted: #64748B;--color-accent-glow: rgba(148, 163, 184, .08);--color-text: #E2E8F0;--color-text-secondary: #94A3B8;--color-text-muted: #64748B;--font-display: "Instrument Serif", Georgia, serif;--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--space-4xl: 96px;--space-5xl: 128px;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 6px;--radius-xl: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease-out;--container-max: 1100px;--container-padding: 24px}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:15px;line-height:1.7;color:var(--color-text);background-color:var(--color-bg);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:400;line-height:1.15;letter-spacing:-.01em}h1{font-size:clamp(2.75rem,6vw,4.5rem);font-style:italic}h2{font-size:clamp(1.75rem,3.5vw,2.5rem)}h3{font-size:clamp(1.15rem,2vw,1.35rem);font-family:var(--font-sans);font-weight:500}p{color:var(--color-text-secondary)}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}code,.mono{font-family:var(--font-mono);font-size:.85em}.accent-text{color:var(--color-accent-warm)}.muted-text{color:var(--color-text-muted)}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding)}.section{padding:var(--space-5xl) 0;position:relative}.section--dark{background:var(--color-bg)}.section--alt{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.section-divider{height:1px;background:linear-gradient(90deg,transparent 0%,var(--color-border) 30%,var(--color-border) 70%,transparent 100%);margin:0 auto;max-width:var(--container-max)}.section-header{margin-bottom:var(--space-3xl)}.section-header h2{margin-bottom:var(--space-sm)}.section-header p{color:var(--color-text-muted);font-size:.95rem}.section-label{display:inline-block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-md)}.divider{height:1px;background:var(--color-border);margin:var(--space-xl) 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-mono);font-size:.8rem;font-weight:500;letter-spacing:.02em;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:transparent;color:var(--color-text)}.btn:hover{border-color:var(--color-accent);color:var(--color-text);background:var(--color-surface)}.btn-primary{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.btn-primary:hover{background:var(--color-accent-warm);border-color:var(--color-accent-warm);color:var(--color-bg)}.tag{display:inline-flex;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:500;font-family:var(--font-mono);letter-spacing:.02em;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.tag--accent{border-color:var(--color-accent-muted);color:var(--color-accent)}.terminal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.8rem;overflow:hidden}.terminal__header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.terminal__dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.terminal__dot--red{background:#ef4444}.terminal__dot--yellow{background:#f59e0b}.terminal__dot--green{background:#22c55e}.terminal__title{font-size:.7rem;color:var(--color-text-muted);margin-left:auto}.terminal__body{padding:var(--space-md);line-height:1.8}.terminal__prompt{color:var(--color-accent-warm)}.terminal__command{color:var(--color-text)}.terminal__output{color:var(--color-text-muted)}.link-arrow{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);transition:all var(--transition-fast)}.link-arrow:hover{color:var(--color-accent-warm);gap:var(--space-sm)}::selection{background:var(--color-accent-warm);color:var(--color-bg)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:1px solid var(--color-accent-warm);outline-offset:2px}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.navbar{position:fixed;top:var(--space-md);left:50%;transform:translate(-50%);width:calc(100% - (var(--container-padding) * 2));max-width:var(--container-max);z-index:100;padding:var(--space-sm) var(--space-lg);background:#08080cd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.navbar--scrolled{background:#08080cf2}.navbar__container{display:flex;align-items:center;justify-content:space-between}.navbar__logo{display:flex;align-items:center;gap:var(--space-xs);font-size:.85rem;color:var(--color-text);letter-spacing:-.01em}.navbar__logo-symbol{color:var(--color-accent-warm)}.navbar__logo:hover{color:var(--color-text)}.navbar__links{display:flex;align-items:center;gap:var(--space-xl)}.navbar__link{font-size:.8rem;color:var(--color-text-muted);transition:color var(--transition-fast);letter-spacing:.01em}.navbar__link:hover{color:var(--color-text)}.navbar__actions{display:flex;align-items:center;gap:var(--space-md)}.navbar__mobile-toggle{display:none;background:none;border:none;color:var(--color-text);cursor:pointer;padding:var(--space-xs)}.navbar__mobile-menu{display:none;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border);margin-top:var(--space-sm)}.navbar__mobile-link{font-size:.9rem;color:var(--color-text-muted);padding:var(--space-sm) 0}.navbar__mobile-link:hover{color:var(--color-text)}@media(max-width:768px){.navbar{top:var(--space-sm);width:calc(100% - (var(--space-md) * 2))}.navbar__links,.navbar__actions .btn{display:none}.navbar__mobile-toggle,.navbar__mobile-menu--open{display:flex}}.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-5xl) 0;background:var(--color-bg)}.hero__bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;mask-image:linear-gradient(to bottom,black 0%,transparent 70%);-webkit-mask-image:linear-gradient(to bottom,black 0%,transparent 70%);pointer-events:none}.hero__content{position:relative;z-index:1;flex:1;display:flex;align-items:center}.hero__main{display:grid;grid-template-columns:1fr 400px;gap:var(--space-3xl);align-items:center;width:100%}.hero__text{max-width:540px}.hero__greeting{font-size:1.5rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.hero__title{margin-bottom:var(--space-lg)}.hero__subtitle{font-size:1.05rem;line-height:1.75;margin-bottom:var(--space-xl);max-width:460px}.hero__actions{display:flex;align-items:center;gap:var(--space-xl)}.hero__terminal,.hero__terminal .terminal{width:100%}.hero__divider{padding:var(--space-3xl) 0}.hero__divider-line{height:1px;background:linear-gradient(90deg,transparent 0%,var(--color-border) 20%,var(--color-accent-warm) 50%,var(--color-border) 80%,transparent 100%)}@media(max-width:900px){.hero__main{grid-template-columns:1fr;gap:var(--space-2xl)}.hero__terminal{order:-1}.hero__text,.hero__subtitle{max-width:100%}}@media(max-width:600px){.hero{padding-top:120px}.hero__actions{flex-direction:column;align-items:flex-start;gap:var(--space-md)}}.project-featured{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2xl);margin-bottom:var(--space-xl)}.project-featured__content{display:flex;flex-direction:column}.project-featured__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-md)}.project-featured__header h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400}.project-featured__links a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.project-featured__links a:hover{color:var(--color-text);border-color:var(--color-accent)}.project-featured__content p{font-size:.95rem;line-height:1.7;margin-bottom:var(--space-lg);flex-grow:1}.project-featured__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.project-featured__code{width:100%}.project-featured__code .terminal__body{padding:var(--space-md);overflow-x:auto}.project-featured__code pre{margin:0;font-size:.72rem;line-height:1.6;color:var(--color-text-secondary)}.project-featured__code code{font-family:var(--font-mono)}.projects-list{display:flex;flex-direction:column}.projects-list .section-label{margin-bottom:var(--space-lg)}.project-row{display:grid;grid-template-columns:1fr auto auto;gap:var(--space-xl);align-items:center;padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.project-row:hover{background:var(--color-surface);margin:0 calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md)}.project-row__info{min-width:0}.project-row__title{font-size:1rem;margin-bottom:var(--space-xs)}.project-row__description{font-size:.85rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-row__tags{display:flex;gap:var(--space-xs);flex-shrink:0}.project-row__links{flex-shrink:0}@media(max-width:900px){.project-featured{grid-template-columns:1fr}.project-featured__code{order:-1}}@media(max-width:700px){.project-row{grid-template-columns:1fr;gap:var(--space-sm);align-items:flex-start}.project-row__description{white-space:normal}.project-row__tags{flex-wrap:wrap}}.skills-primary{margin-bottom:var(--space-2xl)}.skills-intro{font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary);max-width:700px;margin-bottom:var(--space-xl)}.skills-intro strong{color:var(--color-text);font-weight:500}.skills-intro em{color:var(--color-accent-warm);font-style:normal}.skills-primary__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.skill-primary{display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:center}.skill-primary__name{font-family:var(--font-display);font-size:1.25rem;color:var(--color-text)}.skill-primary__years{font-size:.75rem}.skills-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-2xl);margin-bottom:var(--space-3xl)}.skill-category__title{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-md);font-weight:500}.skill-category__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.skills-philosophy{padding-top:var(--space-2xl);border-top:1px solid var(--color-border)}.skills-philosophy blockquote{max-width:600px}.skills-philosophy p{font-family:var(--font-display);font-size:1.35rem;font-style:italic;line-height:1.5;color:var(--color-text-muted)}@media(max-width:768px){.skills-primary__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.skills-primary__grid{grid-template-columns:1fr}}.blog-list{display:flex;flex-direction:column}.blog-item{display:grid;grid-template-columns:200px 1fr auto;gap:var(--space-xl);align-items:flex-start;padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border);transition:all var(--transition-fast)}.blog-item:hover{background:var(--color-surface);margin:0 calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md)}.blog-item__meta{display:flex;flex-direction:column;gap:var(--space-sm)}.blog-item__meta time{font-size:.75rem}.blog-item__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.blog-item__content h3{font-family:var(--font-display);font-size:1.25rem;margin-bottom:var(--space-xs);transition:color var(--transition-fast)}.blog-item:hover .blog-item__content h3{color:var(--color-accent-warm)}.blog-item__content p{font-size:.9rem;color:var(--color-text-muted);line-height:1.6}.blog-item__link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0;margin-top:var(--space-xs)}.blog-item:hover .blog-item__link{color:var(--color-text);border-color:var(--color-accent)}.blog-footer{padding-top:var(--space-xl)}@media(max-width:700px){.blog-item{grid-template-columns:1fr auto;gap:var(--space-md)}.blog-item__meta{order:1;grid-column:1 / -1;flex-direction:row;align-items:center;gap:var(--space-md)}.blog-item__content{order:2}.blog-item__link{order:3;align-self:flex-start}}.photography__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.photo-card{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--color-surface);border-radius:var(--radius-sm)}.photo-card:nth-child(2),.photo-card:nth-child(5){aspect-ratio:3/4}.photo-card img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow),filter var(--transition-base);filter:grayscale(20%)}.photo-card:hover img{transform:scale(1.03);filter:grayscale(0%)}.photo-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-md);opacity:0;transition:opacity var(--transition-base)}.photo-card:hover .photo-card__overlay{opacity:1}.photo-card__location{font-size:.8rem;color:var(--color-text);margin-bottom:var(--space-xs)}.photo-card__exif{display:flex;gap:var(--space-md);font-size:.65rem;color:var(--color-text-muted)}.lightbox{position:fixed;inset:0;z-index:200;background:#08080cf7;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox__close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:none;border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;padding:var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.lightbox__close:hover{border-color:var(--color-accent)}.lightbox__content{max-width:900px;width:100%}.lightbox__content img{width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius-sm)}.lightbox__info{display:flex;align-items:flex-start;justify-content:space-between;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.lightbox__meta{display:flex;flex-direction:column;gap:var(--space-xs)}.lightbox__location{font-size:1rem;color:var(--color-text)}.lightbox__desc{font-size:.85rem}.lightbox__exif{display:flex;gap:var(--space-lg);font-size:.75rem;color:var(--color-text-muted)}@media(max-width:768px){.photography__grid{grid-template-columns:repeat(2,1fr)}.photo-card__overlay{opacity:1}}@media(max-width:480px){.photography__grid{grid-template-columns:1fr}.photo-card{aspect-ratio:16/10}.photo-card:nth-child(2),.photo-card:nth-child(5){aspect-ratio:16/10}}.footer{padding:var(--space-5xl) 0 var(--space-xl)}.footer__cta{max-width:600px;margin-bottom:var(--space-3xl)}.footer__cta h2{margin-bottom:var(--space-md)}.footer__cta p{font-size:1rem;line-height:1.7;margin-bottom:var(--space-xl)}.footer__bottom{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.footer__brand{display:flex;flex-direction:column;gap:var(--space-xs)}.footer__logo{font-size:.9rem}.footer__tagline{font-size:.75rem}.footer__socials{display:flex;align-items:center;gap:var(--space-sm)}.footer__socials a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.footer__socials a:hover{color:var(--color-text);border-color:var(--color-accent)}.footer__scroll-top{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.footer__scroll-top:hover{color:var(--color-text);border-color:var(--color-accent)}.footer__copyright{padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.footer__copyright p{font-size:.7rem}@media(max-width:600px){.footer__bottom{flex-direction:column;gap:var(--space-lg);align-items:flex-start}.footer__scroll-top{display:none}}.app{min-height:100vh;display:flex;flex-direction:column}.app main{flex:1}html{scroll-padding-top:100px}
