:root{--bg:#f5f0e8;--surface:#ede7db;--text:#1c1917;--muted:#8c7b6b;--accent:#c96442;--amber:#e8b84b;--border:#d4c9bb;--font-serif:"Playfair Display", Georgia, serif;--font-sans:"DM Sans", sans-serif;--font-mono:"JetBrains Mono", monospace}[data-dark=true]{--bg:#1a1714;--surface:#231f1c;--text:#f0ebe1;--muted:#7a6e65;--accent:#d4714e;--border:#3a342f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.7;transition:background .3s,color .3s;position:relative;overflow-x:hidden}body:before{content:"";opacity:.035;pointer-events:none;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");position:fixed;inset:0}body:after{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle,#71717121 1px,#0000 1px);background-size:24px 24px;position:fixed;inset:0}[data-dark=true] body:after{background-image:radial-gradient(circle,#f0ebe114 1px,#0000 1px)}a{color:inherit;text-decoration:none}ul{list-style:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}.mono-tag{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px}.mono-section-label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:11px;display:inline-block}.label-dashed-line{border-top:1px dashed var(--border);flex:1;margin-top:6px;margin-left:16px}.section-label-wrap{align-items:center;margin-bottom:48px;display:flex}.scroll-progress{background:var(--accent);z-index:1100;transform-origin:0;width:0%;height:2px;transition:width .1s linear;position:fixed;top:0;left:0}.nav-bar{z-index:1000;background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:64px;padding:0 40px;transition:background .3s;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{align-items:center;display:flex}.nav-logo-text{font-family:var(--font-serif);color:var(--text);letter-spacing:-.01em;font-size:18px;font-weight:700}.nav-desktop-links{align-items:center;gap:4px;display:flex}.nav-desktop-link{font-family:var(--font-sans);color:var(--muted);letter-spacing:.01em;cursor:pointer;background:0 0;border:none;padding:6px 12px;font-size:13.5px;font-weight:400;transition:color .18s;position:relative}.nav-desktop-link:after{content:"";background:var(--accent);transform-origin:0;height:1px;transition:transform .18s;position:absolute;bottom:2px;left:12px;right:12px;transform:scaleX(0)}.nav-desktop-link:hover{color:var(--text)}.nav-desktop-link:hover:after{transform:scaleX(1)}.nav-desktop-link.nav-link-active{color:var(--text)}.nav-desktop-link.nav-link-active:after{background:var(--accent);transform:scaleX(1)}.nav-lang-btn{font-family:var(--font-mono);letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);align-items:center;gap:2px;padding:5px 10px;font-size:11px;transition:color .18s,border-color .18s;display:flex}.nav-lang-btn:hover{color:var(--text);border-color:var(--text)}.nav-lang-text{font-weight:500}.nav-icon-btn{color:var(--muted);justify-content:center;align-items:center;padding:6px;transition:color .18s;display:flex}.nav-icon-btn:hover{color:var(--text)}.nav-right{align-items:center;gap:10px;display:flex}.hamburger{cursor:pointer;flex-direction:column;gap:6px;padding:4px;display:flex}.hamburger span{background:var(--text);border-radius:1px;height:2px;margin-left:auto;transition:width .2s ease-in-out,opacity .2s ease-in-out,transform .15s ease-in-out;display:block}.hamburger span:first-child{width:28px}.hamburger span:nth-child(2){width:22px}.hamburger span:nth-child(3){width:16px}.hamburger.open span:first-child{width:28px;transform:translateY(8px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;width:0;transform:translate(10px)scaleX(0)}.hamburger.open span:nth-child(3){width:28px;transform:translateY(-8px)rotate(-45deg)}.menu-btn-container{z-index:1200;align-items:center;height:64px;padding-right:16px;display:none;position:fixed;top:0;right:0}@media (max-width:768px){.menu-btn-container{display:flex}.nav-desktop-links,.nav-lang-btn,.nav-icon-btn{display:none}}.nav-panel{background:var(--bg);border-left:1px solid var(--border);z-index:1100;flex-direction:column;width:min(380px,90vw);height:100vh;padding:72px 48px 48px;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.nav-panel.panel-open{transform:translate(0)}.panel-links{flex-direction:column;flex:1;gap:8px;display:flex}.panel-link{font-family:var(--font-serif);color:var(--text);text-transform:capitalize;letter-spacing:-.01em;text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px dashed #0000;align-items:baseline;gap:16px;width:100%;padding:8px 0;font-size:32px;font-weight:700;transition:color .2s;display:flex}.panel-link:hover,.panel-link.panel-link-active{color:var(--accent);border-bottom-color:var(--accent)}.panel-num{color:var(--muted);font-size:10px}.panel-footer{flex-direction:row;align-items:center;gap:16px;margin-top:32px;display:flex}.panel-icon-btn{color:var(--muted);justify-content:center;align-items:center;padding:6px;transition:color .18s,transform .18s;display:flex}.panel-icon-btn:hover{color:var(--text);transform:translateY(-1px)}.nav-overlay{z-index:1050;background:#0000004d;position:fixed;inset:0}.lang-fade{animation:.25s both lang-fade-in}@keyframes lang-fade-in{0%{opacity:0}to{opacity:1}}.section{padding:100px 0}.section-inner{max-width:1100px;margin:0 auto;padding:0 40px}.hero-section{align-items:center;min-height:100vh;padding-top:64px;display:flex;position:relative;overflow:hidden}.hero-inner{grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;max-width:1100px;margin:0 auto;padding:0 40px;display:grid}.hero-left{flex-direction:column;gap:20px;display:flex}.hero-name{font-family:var(--font-serif);color:var(--text);letter-spacing:-.02em;font-size:clamp(52px,7vw,96px);font-weight:800;line-height:1}.hero-tagline{font-family:var(--font-serif);color:var(--accent);font-size:clamp(18px,2.2vw,26px);font-style:italic;font-weight:400}.hero-sub{font-family:var(--font-sans);color:var(--muted);max-width:420px;font-size:15px;line-height:1.6}.hero-ctas{flex-wrap:wrap;gap:16px;margin-top:8px;display:flex}.cta-dashed{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;border:1.5px dashed var(--accent);color:var(--accent);padding:11px 24px;font-size:12px;transition:background .2s,color .2s;display:inline-block}.cta-dashed:hover{background:var(--accent);color:var(--bg)}.cta-outline{border-color:var(--border);color:var(--muted)}.cta-outline:hover{background:var(--surface);color:var(--text);border-color:var(--text)}.hero-right{justify-content:center;align-items:center;min-height:460px;display:flex;position:relative}.profile-circle-wrap{border:2.5px solid #b0645073;border-radius:50%;width:320px;height:320px;position:relative;overflow:hidden;box-shadow:0 8px 40px #0000001a}.profile-circle-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.float-dot{background:var(--accent);border-radius:50%;position:absolute}.dot-1{opacity:.6;width:8px;height:8px;top:18%;right:8%}.dot-2{opacity:.4;width:5px;height:5px;bottom:28%;left:5%}.float-star{color:var(--muted);opacity:.45;font-size:16px;position:absolute;top:10%;left:12%;transform:rotate(15deg)}.float-dash{font-family:var(--font-mono);color:var(--muted);opacity:.35;letter-spacing:2px;font-size:10px;position:absolute;top:76%;right:6%}.torn-scrap{background:var(--surface);border:1px solid var(--border);position:absolute}.scrap-1{clip-path:polygon(0 0,100% 4%,98% 80%,3% 100%,0% 60%);width:48px;height:28px;top:8%;right:20%;transform:rotate(6deg)}.scrap-2{clip-path:polygon(2% 0,100% 0%,97% 100%,0% 96%);width:34px;height:20px;bottom:14%;right:4%;transform:rotate(-11deg)}.about-section{background:var(--surface)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.about-body{color:var(--text);text-wrap:pretty;margin-bottom:20px;font-size:15.5px;line-height:1.75}.text-mark{background-color:var(--amber);color:var(--text);border-radius:2px;padding:0 3px 1px;font-style:normal;text-decoration:none}[data-dark=true] .text-mark{color:var(--text);background-color:#e8b84b47}.about-collage{flex-direction:column;gap:12px;min-height:280px;display:flex;position:relative}.collage-torn-block{background:var(--bg);border:1px solid var(--border);flex-direction:column;gap:4px;padding:16px 20px;display:flex;position:relative}.collage-torn-block:before{content:"";background:var(--surface);clip-path:polygon(0 0,3% 100%,8% 20%,13% 90%,18% 10%,24% 80%,30% 5%,36% 75%,42% 15%,48% 85%,54% 0,60% 90%,66% 10%,72% 80%,78% 5%,84% 95%,90% 15%,96% 70%,100% 0);height:8px;position:absolute;bottom:-1px;left:0;right:0}.block-1{align-self:flex-start;width:70%;transform:rotate(-1.5deg)}.block-2{align-self:flex-end;width:65%;transform:rotate(1deg)}.block-3{align-self:flex-start;width:60%;transform:rotate(-.5deg)}.collage-mono{font-family:var(--font-serif);color:var(--text);font-size:22px;font-weight:700}.collage-sub{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:10px}.collage-ink-dot{background:var(--accent);opacity:.6;border-radius:50%;width:10px;height:10px;position:absolute;top:40%;left:50%}.collage-dash-group{font-family:var(--font-mono);color:var(--border);letter-spacing:4px;font-size:10px;position:absolute;top:50%;right:10px}.collage-asterisk{color:var(--muted);opacity:.4;font-size:18px;position:absolute}.ast-1{bottom:8px;right:0}.ast-2{font-size:24px;top:8px;right:30%}.timeline{padding-left:48px;position:relative}.timeline-line{background:repeating-linear-gradient(to bottom, var(--border) 0, var(--border) 6px, transparent 6px, transparent 12px);width:2px;position:absolute;top:0;bottom:0;left:8px}.timeline-entry{margin-bottom:52px;position:relative}.timeline-marker{position:absolute;top:6px;left:-44px}.marker-dot{background:var(--accent);border:2px solid var(--bg);width:12px;height:12px;box-shadow:0 0 0 2px var(--accent);border-radius:50%}.exp-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.exp-tag{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;background:var(--surface);border:1px solid var(--border);color:var(--accent);clip-path:polygon(0 0,100% 0,98% 100%,2% 100%);padding:3px 10px;font-size:10px}.exp-year{font-family:var(--font-mono);color:var(--muted);font-size:11px}.exp-company{font-family:var(--font-serif);color:var(--text);margin-bottom:2px;font-size:22px;font-weight:700}.exp-role{color:var(--muted);margin-bottom:12px;font-size:14px}.exp-bullets{flex-direction:column;gap:6px;display:flex}.exp-bullets li{color:var(--text);padding-left:16px;font-size:14.5px;line-height:1.6;position:relative}.exp-bullets li:before{content:"—";color:var(--border);font-size:12px;position:absolute;left:0}.skills-section{background:var(--surface)}.skills-category{margin-bottom:48px}.skills-divider{align-items:center;gap:12px;margin-bottom:24px;display:flex}.torn-divider-label{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);background:var(--bg);border:1px dashed var(--border);clip-path:polygon(0 0,100% 0,97% 100%,3% 100%);padding:4px 14px;font-size:10px}.skills-divider:after{content:"";border-top:1px dashed var(--border);flex:1;height:1px}.skills-grid{grid-template-columns:repeat(6,1fr);gap:16px;display:grid;overflow:visible}.skill-item{background:var(--bg);border:1px solid var(--border);cursor:pointer;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;transition:border-color .2s,transform .15s,background .15s;display:flex;position:relative;overflow:visible}.skill-item:hover{border-color:var(--accent);transform:translateY(-2px)}.skill-item.skill-active{border-color:var(--accent);background:var(--accent);z-index:10;transform:translateY(-2px)}.skill-item.skill-active .skill-icon,.skill-item.skill-active .skill-label{color:var(--bg)}.skill-item.skill-active .skill-icon-img{background-color:var(--bg)}.skill-popover{background:var(--text);width:200px;color:var(--bg);z-index:100;pointer-events:auto;padding:12px 14px;animation:.18s cubic-bezier(.34,1.56,.64,1) both popover-in;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000038}@keyframes popover-in{0%{opacity:0;transform:translate(-50%)translateY(6px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.skill-popover-arrow{background:var(--text);clip-path:polygon(0 0,100% 0,50% 100%);width:12px;height:6px;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}.skill-popover-name{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;font-size:10px}.skill-popover-desc{font-family:var(--font-sans);color:var(--bg);text-wrap:pretty;font-size:12px;line-height:1.6}.skill-icon{font-size:22px;line-height:1;font-family:var(--font-mono);color:var(--text);font-weight:500}.skill-icon-img{background-color:var(--text);width:36px;height:36px;transition:background-color .3s;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.skill-label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:center;font-size:10px}.filter-tabs{flex-wrap:wrap;gap:8px;margin-bottom:40px;display:flex}.filter-stamp{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;border:1.5px solid var(--border);color:var(--muted);cursor:pointer;clip-path:polygon(0 0,100% 0,97% 100%,3% 100%);padding:6px 18px;font-size:10px;transition:all .2s}.filter-stamp.active,.filter-stamp:hover{background:var(--accent);border-color:var(--accent);color:var(--bg)}.projects-grid{grid-template-columns:repeat(2,1fr);gap:32px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:transform .2s;overflow:hidden}.project-card:hover{transform:translateY(-3px)}.project-img-wrap{height:180px;position:relative;overflow:visible}.torn-top{z-index:2;width:100%;height:20px;display:block;position:absolute;bottom:-1px;left:0;right:0}.project-img-inner{background:var(--border);filter:sepia(.25);justify-content:center;align-items:center;height:100%;display:flex;position:relative;overflow:hidden}.project-body{padding:20px 24px 24px}.project-tags{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.proj-tag{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:2px 8px;font-size:9px}.project-title{font-family:var(--font-serif);color:var(--text);margin-bottom:6px;font-size:20px;font-weight:700}.project-desc{color:var(--muted);text-wrap:pretty;margin-bottom:14px;font-size:13.5px;line-height:1.6}.project-link{color:var(--accent);align-items:center;transition:opacity .2s;display:inline-flex}.project-link:hover{opacity:.7}.contact-section{background:var(--surface)}.contact-grid{grid-template-columns:1fr;align-items:start;display:grid}.contact-intro{color:var(--muted);margin-bottom:32px;font-size:15px}.contact-form{flex-direction:column;gap:28px;display:flex}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-size:10px}.form-input{border:none;border-bottom:1.5px solid var(--border);color:var(--text);font-family:var(--font-sans);background:0 0;outline:none;width:100%;padding:10px 0;font-size:15px;transition:border-color .2s}.form-input::placeholder{color:var(--muted);opacity:.6}.form-input:focus{border-bottom-color:var(--accent)}.form-textarea{resize:vertical;min-height:100px}.send-btn{font-family:var(--font-serif);background:var(--accent);color:var(--bg);letter-spacing:.02em;cursor:pointer;text-align:center;border:none;width:100%;margin-top:8px;padding:14px 32px;font-size:16px;font-weight:700;transition:opacity .2s}.send-btn:hover{opacity:.85}.send-btn:disabled{opacity:.55;cursor:default}.form-error{color:var(--accent);margin-top:12px;font-size:13px}.social-row{gap:20px;margin-top:28px;display:flex}.social-icon{color:var(--muted);align-items:center;transition:color .2s;display:flex}.social-icon:hover{color:var(--text)}footer{text-align:center;border-top:1px solid var(--border);padding:32px 40px}.footer-text{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:11px}.pd-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;opacity:1;background:#1c191799;justify-content:center;align-items:flex-end;transition:opacity .28s;display:flex;position:fixed;inset:0}@media screen and (min-width:769px){.pd-backdrop{align-items:center;padding-top:64px}.pd-sheet{max-height:calc(88vh - 64px)}}.pd-backdrop.pd-hidden{opacity:0}.pd-sheet{background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent;border-top-left-radius:2px;border-top-right-radius:2px;width:100%;max-width:800px;max-height:88vh;transition:transform .32s cubic-bezier(.4,0,.2,1);position:relative;overflow-y:auto;transform:translateY(0)}.pd-sheet.pd-sheet-hidden{transform:translateY(60px)}.pd-close{z-index:10;background:var(--bg);border:1px solid var(--border);width:40px;height:40px;color:var(--muted);justify-content:center;align-items:center;transition:color .2s,border-color .2s;display:flex;position:absolute;top:16px;right:16px}.pd-close:hover{color:var(--text);border-color:var(--text)}.pd-hero-img{aspect-ratio:16/10;width:100%;position:relative;overflow:hidden}.pd-torn-bottom{z-index:2;width:100%;height:28px;display:block;position:absolute;bottom:-1px;left:0;right:0}.pd-chip{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 12px;font-size:10px}.pd-chip-year{color:#f0ebe1;background:#1c19178c;border:1px solid #ffffff1f}.pd-thumbs{scrollbar-width:none;border-bottom:1px solid var(--border);gap:8px;padding:16px 28px;display:flex;overflow-x:auto}.pd-thumbs::-webkit-scrollbar{display:none}.pd-thumb{cursor:pointer;background:var(--border);border:2px solid #0000;flex-shrink:0;align-items:flex-end;width:120px;height:72px;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.pd-thumb.pd-thumb-active{border-color:var(--accent)}.pd-content{grid-template-columns:1fr auto;align-items:start;gap:40px;padding:28px 28px 5vh;display:grid}.pd-tags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.pd-title{font-family:var(--font-serif);color:var(--text);letter-spacing:-.01em;margin-bottom:14px;font-size:30px;font-weight:700;line-height:1.15}.pd-desc{color:var(--muted);text-wrap:pretty;max-width:520px;font-size:14.5px;line-height:1.75}.pd-content-right{flex-direction:column;gap:10px;min-width:160px;padding-top:4px;display:flex}.pd-repo-btn{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text);border:1.5px solid var(--text);white-space:nowrap;align-items:center;gap:8px;padding:10px 16px;font-size:11px;transition:background .2s,color .2s;display:inline-flex}.pd-repo-btn:hover{background:var(--text);color:var(--bg)}.pd-deco-line{font-family:var(--font-mono);color:var(--border);letter-spacing:4px;margin-top:8px;font-size:10px}@media (max-width:900px){.skills-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.nav-bar,.section-inner{padding:0 20px}.hero-inner{text-align:left;grid-template-columns:1fr;gap:40px;padding:0 20px}.hero-right{order:-1;min-height:280px}.profile-circle-wrap{width:240px;height:240px}.hero-name{font-size:52px}.about-grid{grid-template-columns:1fr;gap:40px}.about-collage{display:none}.skills-grid{grid-template-columns:repeat(4,1fr)}.projects-grid,.contact-grid{grid-template-columns:1fr}.pd-hero-img{height:auto}.pd-content{grid-template-columns:1fr;gap:24px}.pd-content-right{flex-flow:wrap}.pd-title{font-size:22px}.pd-thumbs{padding:12px 16px}.pd-content{padding:20px 16px 32px}}@media (max-width:480px){.skills-grid{grid-template-columns:repeat(3,1fr)}.hero-name{font-size:44px}}
