:root{--bg-main: #21271b;--bg-surface: #1C1F18;--bg-nav: #273218;--text-primary: #E8E4D9;--text-secondary: #A39E8F;--accent-primary: #8BA888;--accent-secondary: #C58E61;--border-color: #2A2E24;--shadow: 0 10px 30px rgba(0, 0, 0, .5);--glow: 0 0 15px rgba(139, 168, 136, .1);font-family:Inter,system-ui,-apple-system,Avenir,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-main)}[data-theme=light]{--bg-main: #F5F1E8;--bg-surface: #EDEAE0;--bg-nav: #EAE6DA;--text-primary: #2C2A24;--text-secondary: #6B6558;--accent-primary: #5B7A58;--accent-secondary: #A0662F;--border-color: #D4CFBF;--shadow: 0 10px 30px rgba(0, 0, 0, .08);--glow: 0 0 15px rgba(91, 122, 88, .15);color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-main);color:var(--text-primary);font-family:Work Sans,sans-serif;line-height:1.6}#root{width:100%;min-height:100vh}a{font-weight:500;color:var(--accent-primary);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent-secondary)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-surface);color:var(--text-primary);cursor:pointer;transition:all .25s ease}button:hover{border-color:var(--accent-primary)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}h1,h2,h3{font-family:Crimson Pro,serif;color:var(--text-primary)}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--accent-primary);background:var(--bg-main);color:var(--accent-primary);font-size:1.1rem;cursor:pointer;z-index:500;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.back-to-top:hover{background:var(--accent-primary);color:var(--bg-main)}.easter-egg-burst{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9997;background:radial-gradient(ellipse at center,rgba(139,168,136,.18) 0%,transparent 70%);animation:easterBurst 2.5s ease forwards}@keyframes easterBurst{0%{opacity:0;transform:scale(.8)}15%{opacity:1;transform:scale(1.05)}80%{opacity:1}to{opacity:0;transform:scale(1.1)}}.photo-filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.5rem}.filter-btn{padding:.35rem .9rem;border-radius:999px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.8rem;letter-spacing:.04em;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.filter-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-main)}.portfolio{width:100%;height:100vh;display:flex;flex-direction:column;overflow:hidden}.page-wrapper{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-content{animation:pageFadeIn .35s ease forwards}.navbar{z-index:100;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;background:var(--bg-main);flex-shrink:0}.navbar-brand{display:flex;align-items:center;gap:1rem;background:none;border:none;cursor:pointer;padding:0;transition:all .3s ease;outline:none}.navbar-brand:focus{outline:none}.navbar-monogram{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--accent-primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--accent-primary);transition:background .2s ease,color .2s ease}.navbar-brand:hover .navbar-monogram{background:var(--accent-primary);color:var(--bg-main)}.theme-toggle{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;transition:color .2s ease,opacity .2s ease;line-height:1;opacity:.6}.theme-toggle:hover{color:var(--accent-primary);border-color:transparent;opacity:1}.theme-toggle:focus,.theme-toggle:focus-visible{outline:none}.navbar-right{display:flex;align-items:center;gap:.25rem;position:relative;z-index:200}.burger-menu{display:flex;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:.5rem}.burger-menu span{width:25px;height:2px;background-color:var(--text-primary);transition:all .3s ease;display:block}.burger-menu.active span:nth-child(1){transform:rotate(45deg) translate(8px,8px)}.burger-menu.active span:nth-child(2){opacity:0}.burger-menu.active span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.nav-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:var(--bg-main);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding-bottom:3rem;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.nav-menu-socials{position:absolute;bottom:3rem;display:flex;gap:1.5rem;align-items:center}.nav-menu-logo{height:1.8rem;width:1.8rem;opacity:.7;transition:opacity .2s ease,transform .6s cubic-bezier(.65,.05,0,1)}.nav-menu-socials a:hover .nav-menu-logo{opacity:1;transform:rotateY(360deg)}.nav-menu.active{opacity:1;visibility:visible}.nav-menu a{font-family:Crimson Pro,serif;font-size:2.5rem;padding:.5rem 1rem;text-decoration:none;color:var(--text-primary);transition:color .2s ease;text-align:center}.nav-menu a:hover{color:var(--accent-primary)}.hero{min-height:calc(100vh - 5rem);display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6rem;padding:2rem 6rem 4rem;position:relative;overflow:hidden}.hero-text{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;position:relative;z-index:1}.hero-image{position:relative;z-index:1;flex-shrink:0}.hero-profile{width:340px;height:340px;object-fit:cover;object-position:center 15%;border-radius:50%;display:block}.hero-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.profile-image-container{margin-bottom:2rem}.profile-image{width:160px;height:160px;border-radius:50%;object-fit:cover;box-shadow:0 4px 20px #0000004d;opacity:0}.name-title{font-size:clamp(2.5rem,5vw,5rem);font-weight:900;text-transform:uppercase;letter-spacing:.15em;margin:0;line-height:1;color:var(--text-primary);perspective:1000px;position:relative;z-index:1}.name-title span{position:relative;display:inline-block;will-change:transform;transform-style:preserve-3d}.name-line{display:block}.currently{font-size:.8rem;color:var(--text-secondary);font-weight:300;letter-spacing:.06em;position:relative;z-index:1;margin:.5rem 0 0;min-height:1.2em}.subtitle{font-size:1rem;color:var(--text-secondary);margin:1.5rem 0 1rem;font-weight:300;letter-spacing:.08em;border-top:1px solid var(--border-color);padding-top:1.5rem;position:relative;z-index:1;min-height:1.6em}.subtitle strong{font-weight:500;color:var(--text-primary)}.type-cursor{animation:blink .7s step-end infinite;color:var(--accent-primary);margin-left:1px}@keyframes blink{50%{opacity:0}}.social-links{display:flex;gap:2rem;justify-content:center;margin-top:2rem}.social-links a{display:inline-block;transition:transform .3s ease,filter .3s ease}.social-links a:hover{transform:translateY(-4px)}.logo{height:2rem;width:2rem;opacity:0}.logo.github:hover{filter:drop-shadow(0 0 8px rgba(112,145,147,.6))}.logo.instagram:hover{filter:drop-shadow(0 0 8px rgba(190,42,146,.6))}.logo.linkedin:hover{filter:drop-shadow(0 0 8px rgba(97,150,207,.6))}section{padding:4rem 2rem;max-width:1200px;margin:0 auto}.section-title{font-size:2.2rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.5rem;opacity:0;color:var(--text-primary)}.section-content{font-size:1rem;line-height:1.8;color:var(--text-secondary);max-width:600px;margin:0 auto}.about{margin-top:4rem}.work{padding-top:8rem;padding-bottom:8rem;border-top:1px solid var(--border-color)}.projects-container{position:relative}.projects-container:hover .project-item{opacity:.3!important;transition:opacity .3s ease!important}.projects-container:hover .project-item:hover{opacity:1!important}.project-line-track{position:absolute;left:-20px;top:0;bottom:0;width:2px}.project-line{width:100%;height:0;background:linear-gradient(to bottom,var(--accent-primary),var(--accent-secondary))}.projects{margin-top:2rem}.project-item{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem 0;border-bottom:1px solid var(--border-color);gap:2rem;will-change:filter,opacity,transform}.project-item:first-child{border-top:1px solid var(--border-color)}.project-item-left{display:flex;gap:1.5rem;align-items:flex-start;flex:1}.project-num{font-size:.7rem;color:var(--text-secondary);padding-top:.35rem;flex-shrink:0;letter-spacing:.05em}.project-info h3{font-size:1.2rem;color:var(--text-primary);margin:0 0 .5rem;font-weight:700;transition:color .2s ease}.project-item:hover .project-info h3{color:var(--accent-primary)}.project-info p{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0;max-width:480px}.project-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:1rem;flex-shrink:0}.project-tags{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.project-tag{font-size:.7rem;color:var(--text-secondary);border:1px solid var(--border-color);padding:.15rem .6rem;border-radius:20px;letter-spacing:.03em}.project-link{color:var(--accent-primary);text-decoration:none;font-size:.85rem;font-weight:600;transition:color .2s ease,letter-spacing .2s ease}.project-link:hover{color:var(--accent-secondary);letter-spacing:.05em}button.project-link{background:none;border:none;padding:0;border-radius:0;cursor:pointer}@media (max-width: 640px){.project-item{flex-direction:column;gap:1rem}.project-item-right{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:.75rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.contact{text-align:center;padding:5rem 2rem}.email-link{display:inline-block;margin-top:2rem;color:var(--accent-primary);text-decoration:none;font-size:1.1rem;font-weight:600;letter-spacing:.02em;border-bottom:1px solid var(--accent-primary);padding-bottom:2px;transition:color .2s ease,border-color .2s ease,letter-spacing .2s ease}.email-link:hover{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary);letter-spacing:.06em}.footer{text-align:center;padding:4rem 2rem 3rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.9rem}.footer-email{display:inline-block;font-size:1.1rem;font-weight:600;color:var(--text-primary);text-decoration:none;letter-spacing:.04em;margin-bottom:2rem;transition:color .2s ease}.footer-email:hover{color:var(--accent-primary)}.footer-social{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2rem}.footer-social a{display:inline-block;perspective:400px}.footer-logo{height:2.5rem;width:2.5rem;opacity:.8;transition:transform .6s cubic-bezier(.65,.05,0,1),opacity .3s ease}.footer-social a:hover .footer-logo{transform:rotateY(360deg)}.blog-hero{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;margin-top:5rem}.blog-title{font-size:3rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--text-primary);margin-bottom:1rem}.blog-subtitle{font-size:1.2rem;color:var(--text-secondary);font-weight:300;letter-spacing:.05em}.blog-content{padding:0;max-width:none;margin:0}.photo-grid{display:flex;align-items:flex-start;gap:14px;perspective:800px;padding:0 2rem 4rem;max-width:1200px;margin:0 auto}.photo-col{flex:1;display:flex;flex-direction:column;gap:14px}.photo-card{position:relative;overflow:hidden;border-radius:4px;cursor:pointer;background:var(--bg-surface);transition:opacity .3s ease,transform .5s cubic-bezier(.65,.05,0,1),box-shadow .5s ease}.photo-grid:hover .photo-card{opacity:.4}.photo-grid:hover .photo-card:hover{opacity:1;transform:translateY(-8px);box-shadow:0 24px 48px #00000059}.photo-img{width:100%;display:block;object-fit:cover;min-height:180px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;transition:transform .75s cubic-bezier(.65,.05,0,1)}.photo-card:hover .photo-img{transform:scale(1.06)}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(18,20,15,.85) 0%,transparent 60%);clip-path:inset(0 0 100% 0);transition:clip-path .75s cubic-bezier(.65,.05,0,1);display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;gap:.2rem}.photo-card:hover .photo-overlay{clip-path:inset(0 0 0% 0)}.photo-location{color:#e8e4d9;font-size:.9rem;font-weight:600;letter-spacing:.03em;transition:transform .75s cubic-bezier(.65,.05,0,1);transform-origin:left bottom}.photo-year{color:#a39e8f;font-size:.8rem;transition:transform .75s cubic-bezier(.65,.05,0,1);transform-origin:left bottom}.photo-card:hover .photo-location,.photo-card:hover .photo-year{transform:scale(1.08)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0c0e0af2;display:flex;align-items:center;justify-content:center;padding:3.5rem 2rem 2rem}.lightbox-content{position:relative;max-width:min(90vw,1200px);width:100%;display:flex;flex-direction:column;align-items:center}.lightbox-img{max-width:100%;max-height:calc(100vh - 9rem);border-radius:4px;display:block}.lightbox-close{position:fixed;top:1.25rem;right:1.25rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:color .2s ease;line-height:1;z-index:10000}.lightbox-close:hover{color:var(--text-primary)}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:none;border:none;color:#ffffff80;font-size:3rem;cursor:pointer;padding:0 1.25rem;line-height:1;transition:color .2s ease;z-index:10000;-webkit-user-select:none;user-select:none}.lightbox-nav:hover{color:#ffffffe6}.lightbox-prev{left:0}.lightbox-next{right:0}.lightbox-meta{margin-top:1rem;display:flex;gap:1rem;align-items:baseline;align-self:flex-start}.lightbox-location{color:var(--text-primary);font-size:1rem;font-weight:600}.lightbox-year{color:var(--text-secondary);font-size:.85rem}@media (max-width: 768px){.photo-grid{padding:0 1rem 3rem}.photo-overlay{clip-path:inset(0 0 0% 0)}}.about-hero{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;margin-top:5rem}.about-title{font-size:3rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--text-primary)}.about-content{padding:4rem 2rem;max-width:900px;margin:0 auto}.about-container{display:flex;flex-direction:row;align-items:flex-start;gap:3rem}@media (max-width: 768px){.about-container{flex-direction:column;align-items:center}.about-profile-image{width:100%;max-width:320px;height:280px}}.about-image{flex-shrink:0}.about-profile-image{width:280px;height:360px;object-fit:cover;border-radius:4px;box-shadow:0 8px 32px #0006;border:1px solid var(--border-color)}.about-text{flex:1}.about-text h3{font-size:1.5rem;color:var(--text-primary);margin-top:2rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.about-text h4{font-size:1.1rem;color:var(--accent-primary);margin-top:1rem;margin-bottom:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.about-text h3:first-child{margin-top:0}.about-text p{color:var(--text-secondary);line-height:1.8;margin-bottom:1.5rem;font-size:1rem}.about-text ul{list-style:none;padding:0;margin:0 0 2rem}.about-text li{color:var(--text-secondary);padding:.5rem 0 .5rem 1.5rem;position:relative;font-size:1rem;line-height:1.6}.about-text li:before{content:"→";position:absolute;left:0;color:var(--accent-primary);font-weight:700}.about-text blockquote{border-left:2px solid var(--accent-primary);margin:1.5rem 0;padding:.5rem 0 .5rem 1.25rem;color:var(--text-secondary);font-style:italic;line-height:1.8}.about-text blockquote cite{display:block;margin-top:.5rem;font-style:normal;font-size:.85rem;color:var(--accent-primary);letter-spacing:.03em}.footer-social a:hover .footer-logo{opacity:1}.footer-logo.github:hover{filter:drop-shadow(0 0 8px rgba(112,145,147,.6))}.footer-logo.instagram:hover{filter:drop-shadow(0 0 8px rgba(190,42,146,.6))}.footer-logo.linkedin:hover{filter:drop-shadow(0 0 8px rgba(97,150,207,.6))}@media (max-width: 768px){.hero{flex-direction:column;gap:2.5rem;padding:7rem 2rem 3rem;text-align:center}.hero-text{align-items:center}.hero-profile{width:260px;height:260px}.name-title{font-size:clamp(2rem,10vw,3.5rem)}.subtitle{font-size:1rem}.logo{height:1.75rem;width:1.75rem}.section-title{font-size:2rem}section{padding:4rem 1.5rem}}@media (max-width: 480px){.hero{min-height:100dvh;padding:6rem 1.5rem 3rem;gap:2rem}.hero-profile{width:200px;height:200px}.name-title{font-size:clamp(1.4rem,8.5vw,2.5rem);letter-spacing:.03em}.subtitle{font-size:.9rem}.social-links{gap:1.5rem}.logo{height:1.5rem;width:1.5rem}.section-title{font-size:1.5rem}.projects{grid-template-columns:1fr}}.card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;padding:24px;transition:all .3s ease;box-shadow:var(--shadow)}.card:hover{border-color:var(--accent-primary);box-shadow:var(--glow);transform:translateY(-4px)}.tag-category{color:var(--accent-secondary);border:1px solid var(--accent-secondary);background:transparent;padding:4px 12px;font-size:.8rem;border-radius:20px}.cve-hero{min-height:60vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:10rem 2rem 5rem;max-width:900px;margin:0 auto;position:relative}.cve-back-btn{position:absolute;top:6.5rem;left:2rem;background:none;border:none;color:var(--text-secondary);font-size:.85rem;letter-spacing:.04em;cursor:pointer;padding:0;transition:color .2s ease,letter-spacing .2s ease}.cve-back-btn:hover{color:var(--accent-primary);letter-spacing:.08em;border-color:transparent}.cve-hero-meta{display:flex;gap:1.5rem;margin-bottom:1.5rem;opacity:0}.cve-hero-num,.cve-hero-year{font-size:.75rem;color:var(--text-secondary);letter-spacing:.06em;border:1px solid var(--border-color);padding:.2rem .7rem;border-radius:20px}.cve-hero-title{font-size:clamp(2.8rem,6vw,5.5rem);font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--text-primary);line-height:1;margin-bottom:1.5rem;opacity:0}.cve-hero-subtitle{font-size:1.05rem;color:var(--text-secondary);line-height:1.75;max-width:540px;margin-bottom:2.5rem;opacity:0}.cve-hero-links{display:flex;gap:1rem;flex-wrap:wrap;opacity:0}.cve-link-btn{display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.04em;padding:.55rem 1.4rem;border-radius:4px;text-decoration:none;transition:background .2s ease,color .2s ease,border-color .2s ease,letter-spacing .2s ease}.cve-link-btn--primary{background:var(--accent-primary);color:var(--bg-main);border:1px solid var(--accent-primary)}.cve-link-btn--primary:hover{background:transparent;color:var(--accent-primary);letter-spacing:.07em}.cve-link-btn--secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.cve-link-btn--secondary:hover{border-color:var(--accent-secondary);color:var(--accent-secondary)}.cve-link-btn--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.cve-content{max-width:900px;margin:0 auto;padding:0 2rem 8rem;border-top:1px solid var(--border-color)}.cve-section{padding:3.5rem 0;border-bottom:1px solid var(--border-color);opacity:0}.cve-section:last-child{border-bottom:none}.cve-section-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-primary);margin-bottom:1.5rem;font-family:Work Sans,sans-serif}.cve-body-text{font-size:.95rem;color:var(--text-secondary);line-height:1.85;margin-bottom:1.25rem}.cve-body-text:last-child{margin-bottom:0}.cve-body-text code,.cve-feature-list code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85em;color:var(--accent-secondary);background:var(--bg-surface);padding:.1em .4em;border-radius:3px;border:1px solid var(--border-color)}.cve-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.cve-feature-list li{color:var(--text-secondary);font-size:.92rem;line-height:1.7;padding-left:1.5rem;position:relative}.cve-feature-list li:before{content:"→";position:absolute;left:0;color:var(--accent-primary);font-weight:700}.cve-stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.cve-stack-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:4px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .2s ease}.cve-stack-card:hover{border-color:var(--accent-primary)}.cve-stack-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);font-family:Work Sans,sans-serif}.cve-stack-value{font-size:.92rem;color:var(--text-primary);font-weight:600}@media (max-width: 768px){.cve-hero{padding:9rem 1.5rem 4rem}.cve-back-btn{top:5.5rem;left:1.5rem}.cve-hero-title{font-size:clamp(2.2rem,9vw,3.5rem)}.cve-stack-grid{grid-template-columns:1fr}.cve-content{padding:0 1.5rem 6rem}}@media (max-width: 480px){.cve-hero-links{flex-direction:column;align-items:flex-start}.cve-link-btn{width:100%;text-align:center}}
