:root{--green:#1c3a2a;--green-mid:#2d5a3d;--gold:#c9a84c;--gold-light:#e8c97a;--beige:#f5f0e8;--beige-dark:#e8e0d0;--dark:#111;--gray:#6b7280;--white:#fff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--beige);color:var(--dark);cursor:none;font-family:Satoshi,sans-serif;overflow-x:hidden}.cursor{background:var(--gold);pointer-events:none;z-index:9999;border-radius:50%;width:9px;height:9px;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}.cursor-ring{border:1.5px solid var(--gold);pointer-events:none;z-index:9998;opacity:.55;border-radius:50%;width:34px;height:34px;transition:all .18s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}nav{z-index:100;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f5f0e8ed;border-bottom:1px solid #c9a84c2e;justify-content:space-between;align-items:center;padding:1.2rem 3rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{color:var(--green);letter-spacing:.04em;font-family:Fraunces,serif;font-size:1.5rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:2rem;list-style:none;display:flex}.nav-links a{letter-spacing:.15em;text-transform:uppercase;color:var(--green);font-size:.75rem;font-weight:500;text-decoration:none;transition:color .2s;position:relative}.nav-links a:after{content:"";background:var(--gold);width:0;height:1px;transition:width .3s;position:absolute;bottom:-3px;left:0}.nav-links a:hover{color:var(--gold)}.nav-links a:hover:after{width:100%}.lang-switch{border:1px solid #1c3a2a40;gap:0;display:flex;overflow:hidden}.lang-btn{letter-spacing:.1em;cursor:pointer;color:var(--green);background:0 0;border:none;padding:.38rem .8rem;font-family:Satoshi,sans-serif;font-size:.72rem;font-weight:500;transition:all .2s}.lang-btn.active{background:var(--green);color:var(--beige)}.lang-btn:hover:not(.active){background:#1c3a2a12}#hero{grid-template-columns:1fr 1fr;min-height:100vh;display:grid;position:relative;overflow:hidden}.hero-left{background:var(--green);flex-direction:column;justify-content:center;padding:8rem 4.5rem 5rem 5rem;display:flex;position:relative}.hero-left:after{content:"";background:var(--green);clip-path:polygon(0 0,0 100%,100% 100%);z-index:2;width:110px;position:absolute;top:0;bottom:0;right:-55px}.hero-tag{letter-spacing:.28em;text-transform:uppercase;color:var(--gold);opacity:0;margin-bottom:1.6rem;font-size:.7rem;animation:.8s .2s forwards fadeUp}.hero-title{color:var(--beige);opacity:0;margin-bottom:2.2rem;font-family:Fraunces,serif;font-size:clamp(3.8rem,6.5vw,7rem);font-weight:300;line-height:.92;animation:.9s .4s forwards fadeUp}.hero-title em{color:var(--gold);font-style:italic}.hero-desc{color:#f5f0e899;opacity:0;max-width:340px;margin-bottom:2.5rem;font-size:.88rem;line-height:1.75;animation:.9s .6s forwards fadeUp}.hero-btns{opacity:0;flex-wrap:wrap;gap:1rem;animation:.9s .8s forwards fadeUp;display:flex}.btn-primary{background:var(--gold);color:var(--green);letter-spacing:.13em;text-transform:uppercase;cursor:pointer;border:none;padding:.85rem 2rem;font-family:Satoshi,sans-serif;font-size:.75rem;font-weight:500;text-decoration:none;transition:all .3s}.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px)}.btn-outline{color:var(--beige);letter-spacing:.13em;text-transform:uppercase;border:1px solid #f5f0e84d;padding:.85rem 2rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:all .3s}.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}.hero-badge{opacity:0;width:105px;height:105px;animation:1s 1.2s forwards fadeIn;position:absolute;bottom:3.5rem;left:4.5rem}.hero-badge svg{width:100%;height:100%;animation:18s linear infinite spin}.hero-badge-dot{color:var(--gold);justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:absolute;inset:0}.hero-right{z-index:1;flex-direction:column;justify-content:center;align-items:center;padding:8rem 4rem 5rem 6rem;display:flex;position:relative}.hero-photo-wrap{opacity:0;width:290px;height:360px;animation:1s .6s forwards fadeIn;position:relative}.hero-photo-wrap:before{content:"";border:2px solid var(--gold);opacity:.35;z-index:0;width:100%;height:100%;position:absolute;top:-14px;right:-14px}.hero-photo-stage{z-index:1;width:100%;height:100%;position:relative;overflow:hidden}.hero-photo{object-fit:cover;object-position:center top;filter:grayscale(10%)contrast(1.05)}.hero-layer-person{z-index:2;clip-path:polygon(0 0,100% 0,100% 61%,0 59%)}.hero-layer-laptop{z-index:3;clip-path:polygon(0 59%,100% 61%,100% 100%,0 100%);opacity:0;animation:1s cubic-bezier(.22,1,.36,1) 1.5s forwards laptopSlideIn}@keyframes laptopSlideIn{0%{opacity:0;transform:translate(-24px,60px)}to{opacity:1;transform:translate(0)}}@media (prefers-reduced-motion:reduce){.hero-layer-laptop{opacity:1;animation:none;transform:none}}.hero-stats{opacity:0;gap:3rem;margin-top:2.5rem;animation:.9s 1s forwards fadeUp;display:flex}.stat-num{color:var(--green);font-family:Fraunces,serif;font-size:2.8rem;font-weight:600;line-height:1}.stat-label{letter-spacing:.13em;text-transform:uppercase;color:var(--gray);margin-top:.3rem;font-size:.7rem}#cv-download{background:var(--green);padding:4rem 5rem}.cv-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;max-width:900px;margin:0 auto;display:flex}.cv-text-block .cv-label{letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;font-size:.72rem}.cv-text-block h3{color:var(--beige);font-family:Fraunces,serif;font-size:2.2rem;font-weight:300;line-height:1.1}.cv-text-block h3 em{color:var(--gold);font-style:italic}.cv-text-block p{color:#f5f0e88c;margin-top:.6rem;font-size:.85rem}.cv-buttons{flex-wrap:wrap;gap:1rem;display:flex}.cv-btn{color:var(--beige);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #c9a84c59;align-items:center;gap:.7rem;padding:.9rem 1.8rem;font-family:Satoshi,sans-serif;font-size:.77rem;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.cv-btn:hover{background:var(--gold);color:var(--green);border-color:var(--gold);transform:translateY(-2px)}.cv-btn-icon{border:1px solid #c9a84c66;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;display:flex}#about{grid-template-columns:1fr 1fr;min-height:80vh;display:grid}.about-left{background:var(--green);flex-direction:column;justify-content:center;padding:7rem 5rem;display:flex}.about-right{flex-direction:column;justify-content:center;padding:7rem 5rem;display:flex}.section-num{letter-spacing:.22em;color:var(--gold);margin-bottom:1.4rem;font-family:Fraunces,serif;font-size:.82rem}.section-title-dark{color:var(--beige);font-family:Fraunces,serif;font-size:clamp(3rem,5vw,5rem);font-weight:300;line-height:1}.section-title-dark em{color:var(--gold);font-style:italic}.section-title-light{color:var(--green);font-family:Fraunces,serif;font-size:clamp(2.5rem,4vw,4rem);font-weight:300;line-height:1}.section-title-light em{color:var(--gold);font-style:italic}.about-quote{color:#f5f0e88c;border-left:2px solid var(--gold);margin-top:2.8rem;padding-left:1.5rem;font-family:Fraunces,serif;font-size:1.3rem;font-style:italic;line-height:1.65}.about-text{color:#333;margin-bottom:1.5rem;font-size:.92rem;line-height:1.9}.about-tags{flex-wrap:wrap;gap:.6rem;margin-top:2rem;display:flex}.tag{border:1px solid var(--beige-dark);letter-spacing:.1em;text-transform:uppercase;color:var(--green);padding:.4rem 1rem;font-size:.7rem;transition:all .25s}.tag:hover{background:var(--green);color:var(--beige);border-color:var(--green)}#skills{background:var(--beige-dark);padding:7rem 5rem}.skills-header{text-align:center;margin-bottom:4rem}.skills-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1140px;margin:0 auto;display:grid}.skill-card{background:linear-gradient(160deg, var(--beige) 0%, #fbf8f2 100%);border:1px solid #1c3a2a12;border-radius:14px;padding:1.9rem 1.6rem 1.7rem;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s;position:relative;overflow:hidden}.skill-card:before{content:"";background:linear-gradient(90deg, var(--gold), var(--gold-light));transform-origin:0;height:2px;transition:transform .45s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.skill-card:hover{border-color:#c9a84c66;transform:translateY(-6px);box-shadow:0 18px 48px #1c3a2a24}.skill-card:hover:before{transform:scaleX(1)}.skill-card-top{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.skill-icon{width:46px;height:46px;color:var(--gold);background:#c9a84c1a;border:1px solid #c9a84c40;border-radius:12px;justify-content:center;align-items:center;transition:background .35s,color .35s,transform .35s;display:inline-flex}.skill-icon svg{width:22px;height:22px}.skill-card:hover .skill-icon{background:var(--gold);color:#fff;transform:rotate(-6deg)}.skill-index{color:#1c3a2a2e;font-family:Fraunces,serif;font-size:1.7rem;font-style:italic;line-height:1}.skill-card-title{letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-size:.67rem;font-weight:500}.skill-list{list-style:none}.skill-item{color:#3a3a3a;border-bottom:1px solid #1c3a2a12;justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem 0;font-size:.82rem;display:flex}.skill-item span:first-child{padding-left:.95rem;position:relative}.skill-item span:first-child:before{content:"";background:var(--gold);opacity:.55;border-radius:1px;width:5px;height:5px;margin-top:-2.5px;position:absolute;top:50%;left:0;transform:rotate(45deg)}.skill-item:last-child{border-bottom:none;padding-bottom:0}.skill-level{flex-shrink:0;gap:3px;display:inline-flex}.skill-level i{background:#1c3a2a2e;border-radius:50%;width:5px;height:5px}.skill-level i.on{background:var(--gold)}#experience{background:var(--green);padding:7rem 5rem}.exp-header{margin-bottom:4rem}.timeline{max-width:900px;position:relative}.tl-item{opacity:0;padding-bottom:4rem;padding-left:3rem;transition:opacity .65s,transform .65s;position:relative;transform:translate(-24px)}.tl-item.visible{opacity:1;transform:translate(0)}.tl-item:last-child{padding-bottom:0}.tl-item:after{content:"";background:linear-gradient(var(--gold), #c9a84c1f);transform-origin:top;z-index:0;width:1px;transition:transform .7s .15s;position:absolute;top:.4rem;bottom:0;left:0;transform:scaleY(0)}.tl-item.visible:after{transform:scaleY(1)}.tl-item:last-child:after{display:none}.tl-item:before{content:"";background:var(--gold);border:2px solid var(--green);z-index:1;border-radius:50%;width:11px;height:11px;transition:transform .55s cubic-bezier(.34,1.56,.64,1) .1s,box-shadow .35s;position:absolute;top:.4rem;left:-5px;transform:scale(0)}.tl-item.visible:before{transform:scale(1)}.tl-item:first-child.visible:before{animation:2.6s ease-in-out 1.1s infinite dotPulse}@keyframes dotPulse{0%,to{box-shadow:0 0 #c9a84c80}50%{box-shadow:0 0 0 7px #c9a84c00}}.tl-period,.tl-title,.tl-company,.tl-bullets li{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(10px)}.tl-item.visible .tl-period,.tl-item.visible .tl-title,.tl-item.visible .tl-company,.tl-item.visible .tl-bullets li{opacity:1;transform:none}.tl-item.visible .tl-period{transition-delay:.18s}.tl-item.visible .tl-title{transition-delay:.28s}.tl-item.visible .tl-company{transition-delay:.36s}.tl-item.visible .tl-bullets li:first-child{transition-delay:.46s}.tl-item.visible .tl-bullets li:nth-child(2){transition-delay:.54s}.tl-item.visible .tl-bullets li:nth-child(3){transition-delay:.62s}.tl-item.visible .tl-bullets li:nth-child(4){transition-delay:.7s}.tl-item.visible .tl-bullets li:nth-child(5){transition-delay:.78s}.tl-period{letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;font-size:.7rem}.tl-title{color:var(--beige);margin-bottom:.25rem;font-family:Fraunces,serif;font-size:1.85rem;font-weight:400;transition:opacity .5s,transform .5s,color .3s}.tl-company{color:#f5f0e880;letter-spacing:.04em;margin-bottom:1.2rem;font-size:.83rem}.tl-bullets{list-style:none}.tl-bullets li{color:#f5f0e8b3;padding:.3rem 0 .3rem 1.2rem;font-size:.83rem;line-height:1.65;position:relative}.tl-bullets li:before{content:"—";color:var(--gold);opacity:.7;position:absolute;left:0}.tl-item:hover:before{transform:scale(1.3);box-shadow:0 0 0 5px #c9a84c29}.tl-item:hover .tl-title{color:var(--gold)}@media (prefers-reduced-motion:reduce){.tl-item,.tl-item.visible,.tl-item:after,.tl-item.visible:after,.tl-item:before,.tl-item.visible:before,.tl-period,.tl-title,.tl-company,.tl-bullets li{opacity:1;transition:none;animation:none;transform:none}}#projects{padding:7rem 5rem}.projects-header{margin-bottom:3.5rem}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.4rem;display:grid}.proj-card{border:1px solid var(--beige-dark);background:var(--beige);opacity:0;border-radius:16px;flex-direction:column;transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s,border-color .5s;display:flex;position:relative;overflow:hidden;transform:translateY(28px)scale(.985)}.proj-card.visible{opacity:1;transform:translateY(0)scale(1)}.proj-card:hover{border-color:#c9a84c8c;transform:translateY(-10px);box-shadow:0 30px 70px #1c3a2a2e}.proj-title{color:var(--green);width:fit-content;margin-bottom:.6rem;font-family:Fraunces,serif;font-size:1.45rem;font-weight:500;line-height:1.1;position:relative}.proj-title:after{content:"";background:linear-gradient(90deg, var(--gold), var(--gold-light));width:0;height:2px;transition:width .45s cubic-bezier(.22,1,.36,1);position:absolute;bottom:-3px;left:0}.proj-card:hover .proj-title:after{width:100%}.proj-desc{color:var(--gray);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:1.2rem;font-size:.81rem;line-height:1.7;display:-webkit-box;overflow:hidden}.proj-tags{flex-wrap:wrap;gap:.4rem;display:flex}.proj-tag{letter-spacing:.1em;text-transform:uppercase;color:var(--green-mid);background:#2d5a3d14;border-radius:999px;padding:.2rem .7rem;font-size:.66rem;transition:background .3s,color .3s}.proj-card:hover .proj-tag{color:var(--green);background:#c9a84c29}.proj-link{letter-spacing:.1em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.4rem;margin-top:.9rem;font-size:.72rem;text-decoration:none;transition:gap .25s;display:inline-flex}.proj-link:hover{gap:.7rem}.proj-body{flex-direction:column;flex:1;padding:1.7rem 1.8rem 2rem;display:flex}.proj-index{letter-spacing:.2em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.55rem;margin-bottom:.7rem;font-size:.6rem;font-weight:600;display:inline-flex}.proj-index i{background:var(--gold);opacity:.55;width:16px;height:1px}.proj-body .proj-tags{margin-top:auto;padding-top:1.1rem}.proj-media{background:radial-gradient(120% 80% at 50% 0%, #c9a84c24, transparent 60%), linear-gradient(160deg, var(--green) 0%, var(--green-mid) 100%);border-bottom:1px solid var(--beige-dark);justify-content:center;align-items:flex-end;height:270px;display:flex;position:relative;overflow:hidden}.proj-badge{z-index:3;letter-spacing:.12em;text-transform:uppercase;color:var(--green);background:var(--gold-light);border-radius:999px;padding:.28rem .6rem;font-size:.6rem;font-weight:500;position:absolute;top:.9rem;right:.9rem}.proj-media.is-clickable{width:100%;font:inherit;text-align:inherit;cursor:pointer;border:none;padding:0}.proj-media.is-clickable:focus-visible{outline:2px solid var(--gold);outline-offset:-3px}.proj-count{z-index:4;letter-spacing:.08em;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;background:#0006;border-radius:999px;padding:.22rem .5rem;font-size:.58rem;transition:opacity .3s;position:absolute;top:.9rem;right:.9rem}.proj-card:hover .proj-count{opacity:1}.proj-ghost{z-index:4;text-shadow:0 1px 8px #0d120f40;color:#f5f0e852;letter-spacing:-.02em;pointer-events:none;font-family:Fraunces,serif;font-size:4.4rem;font-style:italic;font-weight:300;line-height:1;transition:transform .6s cubic-bezier(.22,1,.36,1),color .5s;position:absolute;top:.7rem;left:1.2rem}.proj-card:hover .proj-ghost{color:var(--gold-light);transform:translateY(-3px)}.proj-media:after{content:"";z-index:5;pointer-events:none;background:linear-gradient(115deg,#0000 32%,#ffffff21 48%,#0000 62%);transition:transform .85s;position:absolute;inset:0;transform:translate(-130%)}.proj-card:hover .proj-media:after{transform:translate(130%)}.proj-open{z-index:6;background:var(--gold);color:var(--green);letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;opacity:0;border-radius:999px;align-items:center;gap:.5rem;padding:.5rem 1.05rem;font-size:.6rem;font-weight:600;transition:opacity .4s,transform .45s cubic-bezier(.22,1,.36,1);display:inline-flex;position:absolute;bottom:1rem;left:50%;transform:translate(-50%,18px);box-shadow:0 10px 26px #0000004d}.proj-open svg{width:14px;height:14px}.proj-card:hover .proj-open{opacity:1;transform:translate(-50%)}.mock-phone{aspect-ratio:9/19;background:#0d0d0f;border-radius:26px;height:240px;padding:5px;transition:transform .45s cubic-bezier(.22,1,.36,1);position:relative;box-shadow:0 18px 40px #00000059,inset 0 0 0 1px #ffffff0f}.proj-stack{width:100%;height:100%;position:relative}.proj-stack-item{transition:transform .5s cubic-bezier(.22,1,.36,1);position:absolute;bottom:-14px;left:50%}.proj-stack-item .mock-phone{height:226px;margin-left:-57px}.proj-stack-item.s0{z-index:1;transform:translate(-48px,16px)rotate(-10deg)}.proj-stack-item.s1{z-index:2;transform:translate(48px,16px)rotate(10deg)}.proj-stack-item.s2{z-index:3;transform:translate(0)rotate(0)}.proj-card:hover .proj-stack-item.s0{transform:translate(-72px,4px)rotate(-14deg)}.proj-card:hover .proj-stack-item.s1{transform:translate(72px,4px)rotate(14deg)}.proj-card:hover .proj-stack-item.s2{transform:translateY(-8px)rotate(0)}.proj-stack-item.s0{transition-delay:40ms}.proj-stack-item.s1{transition-delay:90ms}.proj-webset{width:100%;height:100%;position:relative}.proj-web{background:#1b1b1f;border-radius:9px 9px 7px 7px;width:66%;transition:transform .55s cubic-bezier(.22,1,.36,1);position:absolute;overflow:hidden;box-shadow:0 18px 44px #0000006b}.proj-web-back{z-index:1;transform-origin:0 0;filter:brightness(.82);top:50px;left:7%;transform:rotate(-5deg)scale(.92)}.proj-web-front{z-index:3;transform-origin:100% 100%;bottom:26px;right:7%;transform:rotate(2deg)}.proj-card:hover .proj-web-back{transform:rotate(-8deg)scale(.92)translate(-6px,-6px)}.proj-card:hover .proj-web-front{transform:rotate(3deg)translateY(-6px)}.proj-web-bar{background:#2a2a30;align-items:center;gap:5px;height:20px;padding:0 8px;display:flex}.proj-web-bar i{background:#555;border-radius:50%;width:6px;height:6px}.proj-web-bar i:first-child{background:#ff5f57}.proj-web-bar i:nth-child(2){background:#febc2e}.proj-web-bar i:nth-child(3){background:#28c840}.proj-web-screen{aspect-ratio:1730/1000;background:#fff;width:100%;position:relative}.mock-notch{z-index:2;background:#0d0d0f;border-radius:0 0 9px 9px;width:34%;height:11px;position:absolute;top:9px;left:50%;transform:translate(-50%)}.mock-screen{background:#fff;border-radius:21px;width:100%;height:100%;position:relative;overflow:hidden}.mock-shot{object-fit:cover}.mock-browser{background:#1b1b1f;border-radius:10px 10px 8px 8px;width:86%;margin-bottom:18px;transition:transform .4s cubic-bezier(.22,1,.36,1);overflow:hidden;transform:translateY(8px);box-shadow:0 18px 44px #00000061}.proj-card:hover .mock-browser{transform:translateY(0)}.mock-bar{background:#2a2a30;align-items:center;gap:5px;height:22px;padding:0 9px;display:flex}.mock-bar i{background:#555;border-radius:50%;width:7px;height:7px}.mock-bar i:first-child{background:#ff5f57}.mock-bar i:nth-child(2){background:#febc2e}.mock-bar i:nth-child(3){background:#28c840}.mock-viewport{aspect-ratio:1730/1000;background:#fff;width:100%;position:relative}.lb-browser .mock-shot{object-fit:contain}.mock-soon{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.mock-mono{letter-spacing:.04em;color:#e8c97ad9;text-shadow:0 2px 30px #c9a84c4d;font-family:Fraunces,serif;font-size:3.4rem;font-style:italic;font-weight:300}.lb{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:none;background:#0d120fdb;justify-content:center;align-items:center;padding:1.5rem;animation:.3s lbFade;display:flex;position:fixed;inset:0}@keyframes lbFade{0%{opacity:0}to{opacity:1}}@keyframes lbPop{0%{opacity:0;transform:translateY(16px)scale(.985)}to{opacity:1;transform:none}}.lb-panel{background:var(--beige);border:1px solid #c9a84c38;border-radius:22px;grid-template-columns:1.02fr .98fr;width:min(1080px,94vw);max-height:88vh;animation:.4s cubic-bezier(.22,1,.36,1) lbPop;display:grid;position:relative;overflow:hidden;box-shadow:0 40px 120px #0000008c}.lb-close{z-index:5;width:38px;height:38px;color:var(--beige);cursor:pointer;background:#0d120f66;border:1px solid #f5f0e84d;border-radius:50%;font-size:.82rem;transition:all .3s;position:absolute;top:1rem;right:1rem}.lb-close:hover{background:var(--gold);color:var(--green);border-color:var(--gold);transform:rotate(90deg)}.lb-stage{background:radial-gradient(130% 90% at 50% 0%, #c9a84c29, transparent 60%), linear-gradient(160deg, var(--green) 0%, var(--green-mid) 100%);justify-content:center;align-items:center;padding:2.5rem;display:flex;position:relative;overflow:hidden}.lb-shot{aspect-ratio:1080/2340;background:#fff;border-radius:26px;height:min(66vh,600px);animation:.4s cubic-bezier(.22,1,.36,1) lbPop;position:relative;overflow:hidden;box-shadow:0 30px 70px #0006}.lb-stage .lb-browser{width:100%;max-width:540px;margin:0;transform:none}.lb-nav{z-index:3;width:44px;height:44px;color:var(--beige);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0d120f59;border:1px solid #f5f0e840;border-radius:50%;font-size:1.5rem;line-height:1;transition:all .25s;position:absolute;top:50%;transform:translateY(-50%)}.lb-prev{left:1rem}.lb-next{right:1rem}.lb-nav:hover{background:var(--gold);color:var(--green);border-color:var(--gold)}.lb-info{flex-direction:column;padding:2.8rem 2.6rem;display:flex;overflow-y:auto}.lb-kicker{align-items:baseline;gap:.8rem;margin-bottom:.5rem;display:flex}.lb-num{color:#c9a84c80;font-family:Fraunces,serif;font-size:2.6rem;font-style:italic;font-weight:300;line-height:1}.lb-kicker-label{letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-size:.62rem;font-weight:500}.lb-title{color:var(--green);margin-bottom:1rem;font-family:Fraunces,serif;font-size:clamp(1.7rem,3vw,2.3rem);font-weight:500;line-height:1.05}.lb-desc{color:#4a4a4a;margin-bottom:1.4rem;font-size:.9rem;line-height:1.75}.lb-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.4rem;display:flex}.lb-thumbs{flex-wrap:wrap;gap:.55rem;margin-top:auto;padding-top:1.2rem;display:flex}.lb-thumb{cursor:pointer;opacity:.5;background:#fff;border:1px solid #1c3a2a1f;border-radius:8px;width:46px;height:64px;padding:0;transition:all .25s;position:relative;overflow:hidden}.lb-thumb img{object-fit:cover}.lb-thumb:hover{opacity:.82}.lb-thumb.on{opacity:1;border-color:var(--gold);box-shadow:0 0 0 2px #c9a84c59}.lb-foot{border-top:1px solid #1c3a2a1a;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.6rem;padding-top:1.4rem;display:flex}.lb-cta{background:var(--green);color:var(--beige);letter-spacing:.12em;text-transform:uppercase;border-radius:999px;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-size:.7rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.lb-cta:hover{background:var(--gold);color:var(--green);transform:translateY(-2px)}.lb-count{letter-spacing:.12em;color:var(--gray);font-variant-numeric:tabular-nums;font-size:.78rem}#blog{background:var(--beige-dark);padding:7rem 5rem}.blog-header{margin-bottom:3.5rem}.blog-grid{grid-template-columns:repeat(2,1fr);gap:1.6rem;max-width:1000px;display:grid}.blog-card{background:var(--beige);border:1px solid var(--beige-dark);border-radius:16px;flex-direction:column;padding:2.2rem 2rem;text-decoration:none;transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s,border-color .5s;display:flex;position:relative;overflow:hidden}.blog-card:before{content:"";background:linear-gradient(90deg, var(--gold), var(--gold-light));transform-origin:0;height:2px;transition:transform .5s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.blog-card:hover{border-color:#c9a84c80;transform:translateY(-8px);box-shadow:0 26px 60px #1c3a2a29}.blog-card:hover:before{transform:scaleX(1)}.blog-meta{align-items:center;gap:.8rem;margin-bottom:1rem;display:flex}.blog-cat{letter-spacing:.16em;text-transform:uppercase;color:var(--gold);background:#c9a84c1f;border-radius:999px;padding:.25rem .65rem;font-size:.6rem;font-weight:600}.blog-date{letter-spacing:.1em;text-transform:uppercase;color:var(--gray);font-size:.68rem}.blog-title{color:var(--green);margin-bottom:.8rem;font-family:Fraunces,serif;font-size:1.4rem;font-weight:500;line-height:1.2}.blog-excerpt{color:var(--gray);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:1.4rem;font-size:.84rem;line-height:1.75;display:-webkit-box;overflow:hidden}.blog-readmore{letter-spacing:.12em;text-transform:uppercase;color:var(--gold);align-items:center;gap:.4rem;margin-top:auto;font-size:.7rem;font-weight:600;transition:gap .25s;display:inline-flex}.blog-readmore svg{width:14px;height:14px}.blog-card:hover .blog-readmore{gap:.7rem}.blog-all{letter-spacing:.14em;text-transform:uppercase;color:var(--green);border-bottom:1px solid var(--gold);align-items:center;margin-top:2.4rem;padding-bottom:.2rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .25s;display:inline-flex}.blog-all:hover{color:var(--gold)}#contact{grid-template-columns:1fr 1fr;min-height:70vh;display:grid}.contact-left{background:var(--green);flex-direction:column;justify-content:center;padding:7rem 5rem;display:flex}.contact-right{flex-direction:column;justify-content:center;padding:7rem 5rem;display:flex}.contact-right h3{color:var(--green);margin-bottom:2rem;font-family:Fraunces,serif;font-size:1.8rem;font-weight:400}.contact-line{color:#f5f0e8a6;border-bottom:1px solid #f5f0e81a;align-items:center;gap:1rem;padding:1rem 0;font-size:.87rem;text-decoration:none;transition:color .2s;display:flex}.contact-line:hover{color:var(--gold)}.contact-icon{width:34px;height:34px;color:var(--gold);border:1px solid #c9a84c4d;flex-shrink:0;justify-content:center;align-items:center;font-size:.82rem;display:flex}.form-group{margin-bottom:1.5rem}.form-group label{letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:.5rem;font-size:.7rem;display:block}.form-group input,.form-group textarea{border:1px solid var(--beige-dark);width:100%;color:var(--dark);resize:none;background:0 0;outline:none;padding:.9rem 1.2rem;font-family:Satoshi,sans-serif;font-size:.88rem;transition:border-color .25s}.form-group input:focus,.form-group textarea:focus{border-color:var(--gold)}.form-submit{background:var(--green);color:var(--beige);letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border:none;padding:1rem 2.5rem;font-family:Satoshi,sans-serif;font-size:.77rem;font-weight:500;transition:all .3s}.form-submit:hover{background:var(--green-mid);transform:translateY(-2px)}footer{color:#f5f0e866;letter-spacing:.1em;background:#0a0a0a;justify-content:space-between;align-items:center;padding:3rem 5rem;font-size:.77rem;display:flex}.footer-logo{color:var(--beige);font-family:Fraunces,serif;font-size:1.4rem;font-weight:600}.footer-links{gap:2rem;display:flex}.footer-links a{color:#f5f0e866;letter-spacing:.15em;text-transform:uppercase;font-size:.74rem;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--gold)}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reveal{opacity:0;transition:all .7s;transform:translateY(30px)}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width:900px){nav{padding:1.2rem 1.5rem}.nav-links{gap:1rem}.nav-links li:not(:last-child):not(:nth-last-child(2)){display:none}#hero,#about,#contact{grid-template-columns:1fr}.hero-left:after{display:none}.hero-left,.hero-right,.about-left,.about-right,.contact-left,.contact-right{padding:5rem 2rem}#cv-download{padding:3rem 2rem}.cv-inner{flex-direction:column;align-items:flex-start}.hero-photo-wrap{width:220px;height:280px}.skills-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.skill-card{padding:1.4rem 1.2rem}.projects-grid{grid-template-columns:1fr}.lb-panel{grid-template-columns:1fr;max-height:92vh;overflow-y:auto}.lb-stage{padding:2rem 1.5rem}.lb-shot{height:42vh}.lb-info{padding:1.8rem 1.5rem}.lb-thumbs{margin-top:1.2rem}#skills,#experience,#projects,#blog{padding:5rem 2rem}.blog-grid{grid-template-columns:1fr}footer{text-align:center;flex-direction:column;gap:1.5rem;padding:2.5rem 2rem}.hero-badge{display:none}}
