:root{--paper:#f8f7f3;--paper-dim:#efede5;--ink:#111110;--ink-2:#181816;--ink-3:#222220;--amber:#F9B646;--amber-deep:#e09a1f;--coral:#ff5f6d;--line:#e2dfd6;--line-dark:rgba(248,247,243,0.14);--muted:#6f6c62;--muted-dark:#a39f92;--font-display:"Clash Display","Arial Black",sans-serif;--font-body:"General Sans","Helvetica Neue",sans-serif;--font-mono:"JetBrains Mono","SFMono-Regular",monospace;--gutter:clamp(20px,4vw,64px);--radius:24px}*{margin:0;padding:0;box-sizing:border-box}::selection{background:var(--amber);color:var(--ink)}html{scroll-behavior:smooth;scrollbar-width:none}::-webkit-scrollbar{display:none}body{-ms-overflow-style:none;font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.5;overflow-x:clip}body.is-loading{overflow:hidden;height:100dvh}.page{opacity:0}body.is-ready .page{opacity:1}@media (scripting:none){.page{opacity:1}.loader{display:none}}img{max-width:100%;display:block}a{color:inherit}.mono{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}.amber{color:var(--amber)}.coral{color:var(--coral)}.highlight{color:var(--amber)}.grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:9000;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)'/%3E%3C/svg%3E");will-change:transform;animation:grainShift .9s steps(4) infinite}@keyframes grainShift{0%{transform:translate(0)}25%{transform:translate(-2%,1%)}50%{transform:translate(1%,-2%)}75%{transform:translate(-1%,2%)}to{transform:translate(2%,-1%)}}.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%);display:none}@media (pointer:fine){.cursor-dot,.cursor-ring{display:block}}.cursor-dot{width:7px;height:7px;background:var(--amber);mix-blend-mode:difference}.cursor-ring{width:36px;height:36px;border:1.5px solid var(--amber);opacity:.55;transition:width .25s ease,height .25s ease,opacity .25s ease}body.cursor-hover .cursor-ring{width:64px;height:64px;opacity:.9}.loader{position:fixed;inset:0;z-index:9990;background:var(--ink);overflow:hidden;display:flex;justify-content:center;align-items:center}.loader:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(248,247,243,.04) 1px,transparent 0),linear-gradient(90deg,rgba(248,247,243,.04) 1px,transparent 0);background-size:72px 72px}.loader-road{position:absolute;left:0;right:0;top:calc(50% + clamp(110px, 21vw, 195px));height:2px;background:linear-gradient(90deg,transparent,rgba(248,247,243,.35),transparent)}.loader-streaks{position:absolute;inset:0;overflow:hidden}.streak{position:absolute;left:0;height:2px;width:22vw;border-radius:2px;background:linear-gradient(90deg,transparent,var(--amber));opacity:0;will-change:transform,opacity}.streak.white{background:linear-gradient(90deg,transparent,rgba(248,247,243,.8));height:1px}.loader-wheel-wrap{position:relative;width:clamp(220px,42vw,390px);height:clamp(220px,42vw,390px);will-change:transform}.loader-wheel{width:100%;height:100%;display:block;transform-origin:50% 50%;will-change:transform}.loader-wheel-ghost{position:absolute;inset:0;filter:blur(14px);opacity:.45}.loader-meta{position:absolute;top:clamp(20px,4vw,44px);left:var(--gutter);display:flex;flex-direction:column;gap:6px}.loader-brand{font-family:var(--font-display);font-weight:600;font-size:26px;color:var(--paper);line-height:1}.loader-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-dark)}.loader-speedo{position:absolute;right:var(--gutter);bottom:clamp(16px,4vw,40px);text-align:right}.loader-counter{font-family:var(--font-mono);font-weight:500;font-style:italic;font-size:clamp(72px,14vw,168px);line-height:.85;color:var(--paper);letter-spacing:-.04em;display:block;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.loader-counter .amber{color:var(--amber)}.loader-unit{font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-dark);display:block;margin-top:10px}.loader-line{position:absolute;left:var(--gutter);bottom:clamp(24px,5vw,52px);width:min(220px,30vw);height:2px;background:rgba(248,247,243,.12);overflow:hidden}.loader-line i{position:absolute;inset:0;background:var(--amber);transform:scaleX(0);transform-origin:left}.page-out{position:fixed;inset:0;z-index:9991;background:var(--ink);display:flex;align-items:center;justify-content:center;-webkit-clip-path:inset(0 0 100% 0);clip-path:inset(0 0 100% 0);opacity:0;pointer-events:none}.page-out svg{width:84px;height:84px}.scroll-wheel{position:fixed;right:22px;bottom:22px;width:52px;height:52px;z-index:900;opacity:0;pointer-events:auto;cursor:pointer;transition:opacity .4s ease}body.is-ready .scroll-wheel{opacity:1}.scroll-wheel svg{width:100%;height:100%;display:block}.scroll-wheel .sw-rotor{transform-origin:50% 50%}.scroll-wheel .sw-progress{fill:none;stroke:var(--amber);stroke-width:6;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%}.site-header{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px var(--gutter);border-bottom:1px solid var(--line);position:relative;z-index:20}.site-footer .brand img,.site-header .brand img{height:44px;width:92px;object-fit:cover}.site-footer nav ul,.site-header nav ul{display:flex;flex-wrap:wrap;justify-content:center;list-style:none;gap:4px}.site-footer nav a,.site-header nav a{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;padding:8px 12px;border-radius:99px;transition:background .25s ease,color .25s ease}.site-header nav a:hover{background:var(--ink);color:var(--paper)}.site-header nav a.active{background:var(--amber);color:var(--ink)}.header-flag img{height:40px;width:80px;object-fit:cover}.hero{position:relative;overflow:clip;background:var(--paper)}.hero-ghost{position:absolute;bottom:-.18em;left:0;width:100%;font-family:var(--font-display);font-weight:700;font-size:clamp(180px,32vw,480px);line-height:1;color:transparent;-webkit-text-stroke:1px var(--line);white-space:nowrap;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:0}.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;grid-gap:clamp(24px,4vw,64px);gap:clamp(24px,4vw,64px);padding:clamp(16px,2.5vh,36px) var(--gutter) clamp(20px,3vh,44px);align-items:center;min-height:calc(100svh - 88px)}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--muted);margin-bottom:clamp(14px,2vh,26px)}.hero-eyebrow:before{content:"";width:34px;height:1px;background:var(--amber)}.hero-title{font-family:var(--font-display);font-weight:600;font-size:clamp(52px,min(9.5vw,13vh),150px);line-height:.92;letter-spacing:-.03em;text-transform:lowercase;margin-bottom:clamp(10px,1.6vh,22px)}.hero-title .line{display:block;overflow:hidden}.hero-title .word{display:inline-block;will-change:transform}.hero-title .amp{font-style:italic;color:var(--amber);font-weight:500}.hero-swoosh{display:block;width:min(420px,60%);margin-top:-.35em;overflow:visible}.hero-swoosh path{fill:none;stroke:var(--amber);stroke-width:5;stroke-linecap:round}.hero-copy{font-size:clamp(15px,1.3vw,18px);font-weight:500;color:var(--muted);max-width:46ch;margin-bottom:clamp(16px,2.2vh,26px)}.hero-copy strong{color:var(--ink)}.social-row{flex-wrap:wrap;gap:0;margin-bottom:clamp(16px,2vh,24px)}.social-icon,.social-row{display:flex;align-items:center}.social-icon{position:relative;justify-content:center;width:46px;height:46px;border:1.5px solid var(--ink);border-radius:50%;text-decoration:none;font-family:var(--font-mono);font-size:12px;z-index:1;transition:background .25s ease,color .25s ease,transform .25s ease,z-index 0s}.social-icon+.social-icon{margin-left:-5px}.social-icon:hover{background:var(--ink);color:var(--amber);z-index:3;transform:translateY(-4px) rotate(-8deg)}.cta-row{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:clamp(16px,2.4vh,30px)}.cta-row .btn-pill.cta-secondary{height:50px;padding:0 30px;box-sizing:border-box}.resume-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;padding:0 30px;border-radius:99px;background:var(--ink);color:var(--paper);border:1.5px solid var(--ink);text-decoration:none;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;transition:background .25s ease,color .25s ease}.resume-btn:hover{background:var(--amber);color:var(--ink);border-color:var(--amber)}.stats{display:flex;gap:clamp(24px,4vw,64px);border-top:1px solid var(--line);padding-top:clamp(12px,1.8vh,20px)}.stat-item h2{font-family:var(--font-display);font-weight:600;font-size:clamp(30px,3.4vw,50px);line-height:1}.stat-item h2 .plus{color:var(--amber)}.stat-item p{font-size:13px;color:var(--muted);font-weight:500;margin-top:6px}.stat-item a{color:var(--ink);font-weight:700;text-decoration:none;border-bottom:1.5px solid var(--amber)}.hero-right,.portrait-card{position:relative}.portrait-card{border-radius:var(--radius);overflow:hidden;background:var(--ink);transform:rotate(2deg);box-shadow:24px 24px 0 -6px var(--amber);will-change:transform;max-height:calc(100svh - 150px)}.portrait-card img{width:100%;height:100%;aspect-ratio:1/1.08;object-fit:cover;transform:scale(1.12);will-change:transform}.portrait-badge{position:absolute;left:16px;bottom:16px;background:rgba(17,17,16,.82);color:var(--paper);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(248,247,243,.18);border-radius:99px;padding:9px 18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.portrait-badge .amber{color:var(--amber)}.scroll-cue{position:absolute;z-index:3;right:var(--gutter);bottom:22px;display:flex;align-items:center;gap:10px;color:var(--muted)}.scroll-cue svg{width:22px;height:22px;animation:cueSpin 2.6s linear infinite}@keyframes cueSpin{to{transform:rotate(1turn)}}.band{overflow:hidden;white-space:nowrap;padding:clamp(10px,1.4vw,20px) 0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.band-track{will-change:transform}.band-chunk,.band-track{display:inline-flex;gap:.6em}.band-chunk{font-family:var(--font-display);font-weight:600;font-size:clamp(44px,7vw,110px);line-height:1;text-transform:lowercase;letter-spacing:-.02em;align-items:center}.band-chunk .o{color:transparent;-webkit-text-stroke:1.5px currentColor}.band-chunk .dot{width:.28em;height:.28em;border-radius:50%;background:var(--amber);flex-shrink:0}.band-dark{background:var(--ink);color:var(--paper);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}.band-light{background:var(--amber);color:var(--ink)}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:clamp(56px,9vh,110px) var(--gutter) clamp(28px,4vh,48px)}.section-head.on-dark{color:var(--paper)}.section-kicker{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.section-kicker .idx{color:var(--amber)}.section-kicker:after{content:"";width:44px;height:1px;background:currentColor;opacity:.4}.section-title{font-family:var(--font-display);font-weight:600;font-size:clamp(40px,6.5vw,96px);line-height:.95;letter-spacing:-.025em;text-transform:lowercase}.section-title .word{display:inline-block}.section-note{max-width:30ch;font-size:14px;color:var(--muted);font-weight:500;text-align:right}.on-dark .section-kicker,.on-dark .section-note{color:var(--muted-dark)}.doodle{overflow:visible;pointer-events:none}.doodle path{fill:none;stroke:var(--amber);stroke-width:3;stroke-linecap:round}.reel{background:var(--ink);color:var(--paper);position:relative;overflow:clip}.reel:before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:80%;height:100%;background:radial-gradient(ellipse 60% 45% at 50% 0,rgba(249,182,70,.09),transparent 70%);pointer-events:none}.reel-frame{position:relative;margin:0 var(--gutter) clamp(64px,10vh,120px);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-dark);box-shadow:0 40px 120px rgba(0,0,0,.55)}.reel-frame:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.18) 0 1px,transparent 1px 4px);pointer-events:none;opacity:.5}.reel-frame img,.reel-frame video{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;transform:scale(1.15);will-change:transform}@media (min-width:1025px){.reel-frame img,.reel-frame video{aspect-ratio:auto;height:86vh;max-height:90vh}}.reel-bar{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;justify-content:space-between;align-items:center;padding:14px 20px;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);background:linear-gradient(transparent,rgba(17,17,16,.85));pointer-events:none}.reel-bar .rec{display:inline-flex;align-items:center;gap:8px}.reel-bar .rec:before{content:"";width:9px;height:9px;border-radius:50%;background:var(--coral);animation:blink 1.2s steps(2) infinite}@keyframes blink{50%{opacity:.15}}.discography{position:relative;z-index:2;margin:0 var(--gutter) clamp(64px,10vh,120px)}.disco-head{display:flex;flex-wrap:wrap;gap:16px 24px;align-items:baseline;justify-content:space-between;padding-bottom:22px;margin-bottom:24px;border-bottom:1px solid var(--line-dark)}.disco-kicker{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-dark)}.disco-platforms{display:flex;flex-wrap:wrap;gap:9px}.disco-plat{font-family:var(--font-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--paper);text-decoration:none;padding:7px 13px;border:1px solid var(--line-dark);border-radius:999px;transition:border-color .25s ease,color .25s ease,background .25s ease}.disco-plat:hover{color:var(--ink);background:var(--amber);border-color:var(--amber)}.disco-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);grid-gap:0 clamp(32px,5vw,72px);gap:0 clamp(32px,5vw,72px)}@media (max-width:760px){.disco-list{grid-template-columns:1fr}}.disco-track{display:block;padding:15px 4px;border-bottom:1px solid var(--line-dark);transition:padding-left .3s ease;outline:none}.disco-track:focus-within,.disco-track:hover{padding-left:14px}.disco-track.is-current{padding-left:14px}.disco-track.is-current .disco-num,.disco-track.is-current .disco-title{color:var(--amber)}.disco-track.is-playing .disco-num{animation:discoPulse 1s ease-in-out infinite}@keyframes discoPulse{50%{opacity:.35}}.disco-main{display:flex;align-items:baseline;gap:16px}.disco-reveal{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}.disco-track:focus-within .disco-reveal,.disco-track:hover .disco-reveal{grid-template-rows:1fr}.disco-detail{overflow:hidden}.disco-detail-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:11px}.disco-genre{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);border:1px solid color-mix(in srgb,var(--amber) 38%,transparent);padding:3px 9px;border-radius:999px}.disco-genre,.disco-lyrics{font-family:var(--font-mono)}.disco-lyrics{font-size:11px;letter-spacing:.04em;color:var(--paper-dim);text-decoration:none;white-space:nowrap;transition:color .2s ease}.disco-lyrics:hover{color:var(--amber)}.disco-lyrics--soon{opacity:.4}@media (hover:none),(max-width:600px){.disco-reveal{grid-template-rows:1fr}}.disco-num{font-family:var(--font-mono);font-size:11px;color:var(--amber);min-width:22px}.disco-title{flex:1 1;font-size:clamp(15px,1.5vw,18px);color:var(--paper);letter-spacing:-.01em}.disco-tags{display:inline-flex;align-items:center;gap:12px;flex-shrink:0}.disco-lang{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-dark)}.disco-lang,.disco-year{font-family:var(--font-mono)}.disco-year{font-size:11px;color:var(--paper-dim);opacity:.6}.play-pause-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;width:clamp(72px,9vw,110px);height:clamp(72px,9vw,110px);border-radius:50%;border:1px solid rgba(248,247,243,.35);background:rgba(17,17,16,.45);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--amber);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:top .6s cubic-bezier(.22,1,.36,1),left .6s cubic-bezier(.22,1,.36,1),width .6s cubic-bezier(.22,1,.36,1),height .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1),background .3s ease,color .3s ease}.play-pause-btn:hover{transform:translate(-50%,-50%) scale(1.1);background:var(--amber);color:var(--ink)}@media (min-width:1025px){.reel-frame.is-playing .play-pause-btn{top:24px;left:calc(100% - 24px);width:56px;height:56px;transform:translate(-100%)}.reel-frame.is-playing .play-pause-btn:hover{transform:translate(-100%) scale(1.1)}.reel-frame.is-playing .play-pause-btn svg{width:18px;height:18px}}@media (max-width:1024px){.reel-frame.is-playing .play-pause-btn{top:16px;left:calc(100% - 16px);width:46px;height:46px;transform:translate(-100%)}.reel-frame.is-playing .play-pause-btn:hover{transform:translate(-100%) scale(1.1)}.reel-frame.is-playing .play-pause-btn svg{width:16px;height:16px}}.portfolio{position:relative;padding:0 var(--gutter) clamp(32px,5vh,64px)}.portfolio-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);grid-gap:clamp(10px,1.4vw,20px);gap:clamp(10px,1.4vw,20px);max-width:1080px;margin:0 auto}.portfolio .card{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--paper-dim);z-index:1;will-change:transform;display:block;text-decoration:none;transition:box-shadow .4s ease}.portfolio .card:hover{box-shadow:0 22px 60px -18px color-mix(in srgb,var(--amber) 55%,transparent),0 0 0 1px color-mix(in srgb,var(--amber) 30%,transparent)}.portfolio .card .card-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(12px,1.4vw,18px);background:linear-gradient(0deg,rgba(17,17,16,.94) 0,rgba(17,17,16,.62) 45%,rgba(17,17,16,.12));opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease;pointer-events:none}.portfolio .card:focus-visible .card-overlay,.portfolio .card:hover .card-overlay{opacity:1;transform:none}.card-name{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(17px,1.9vw,23px);line-height:1.05;letter-spacing:-.02em;color:var(--paper)}.card-desc{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-top:7px;font-size:12.5px;line-height:1.45;color:var(--paper-dim)}.card-overlay-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px}.card-tech{display:flex;flex-wrap:wrap;gap:6px}.card-tech-tag{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--amber);border:1px solid color-mix(in srgb,var(--amber) 35%,transparent);border-radius:999px;padding:3px 7px}.card-tech-tag,.card-view{font-family:var(--font-mono);white-space:nowrap}.card-view{font-size:11px;color:var(--paper)}.card-view .arr{display:inline-block;transition:transform .25s ease}.portfolio .card:hover .card-view .arr{transform:translateX(3px)}@media (hover:none),(max-width:600px){.portfolio .card .card-overlay{opacity:1;transform:none;background:linear-gradient(0deg,rgba(17,17,16,.92) 0,rgba(17,17,16,.4) 60%,transparent)}.card-desc{-webkit-line-clamp:2}}.portfolio .card img{display:block;width:100%;height:clamp(150px,27vh,290px);object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1),filter .6s ease}.portfolio .card:hover img{transform:scale(1.07);filter:saturate(1.15)}.card-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;width:100%;height:clamp(150px,27vh,290px);padding:18px;text-align:center;background:radial-gradient(120% 130% at 50% 0,color-mix(in srgb,var(--amber) 18%,transparent),transparent 62%),linear-gradient(160deg,var(--ink-3),var(--ink))}.card-fallback-name{font-family:var(--font-display);font-weight:700;font-size:clamp(20px,2.4vw,30px);line-height:1.05;letter-spacing:-.02em;color:var(--paper);transition:opacity .35s ease}.card-fallback-tag{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--amber);transition:opacity .35s ease}.portfolio .card:focus-visible .card-fallback-name,.portfolio .card:focus-visible .card-fallback-tag,.portfolio .card:hover .card-fallback-name,.portfolio .card:hover .card-fallback-tag{opacity:0}@media (hover:none),(max-width:600px){.card-fallback-name,.card-fallback-tag{opacity:0}}.portfolio-title{position:absolute;top:47%;left:50%;transform:translate(-50%,-50%);width:100%;text-align:center;font-family:var(--font-display);font-weight:700;font-size:clamp(64px,13vw,210px);line-height:.9;color:var(--amber);text-transform:lowercase;letter-spacing:-.035em;pointer-events:none;z-index:2;white-space:nowrap;text-shadow:0 14px 70px rgba(17,17,16,.28)}.portfolio .card.last-card{z-index:3}.project{width:100%;position:relative;padding-bottom:clamp(40px,7vh,80px)}.menu{width:100%;border-top:1px solid var(--line)}.menu-item{width:100%;padding:clamp(18px,2.6vh,30px) var(--gutter);display:flex;align-items:center;cursor:pointer;border-bottom:1px solid var(--line);position:relative;transition:background .3s ease}.menu-item:hover{background:rgba(17,17,16,.03)}.menu p{position:absolute;top:0;width:100%;font-weight:600;text-transform:uppercase;line-height:100%;letter-spacing:-.01em;transition:color .25s}.info,.name,.tag{position:relative;overflow:hidden}.info,.tag{flex:1 1;height:14px;font-size:12px;font-family:var(--font-mono);letter-spacing:.1em;color:var(--muted)}.tag{text-align:right}.name{flex:4 1;height:clamp(34px,4.2vw,58px);font-size:clamp(30px,3.8vw,54px);text-align:center;font-family:var(--font-display);font-weight:600;text-transform:lowercase;letter-spacing:-.02em}.info p:nth-child(2),.name p:nth-child(2),.tag p:nth-child(2){top:100%;color:var(--amber)}.menu:hover .info p:first-child,.menu:hover .name p:first-child,.menu:hover .tag p:first-child{color:rgba(17,17,16,.3)}.preview{position:fixed;top:0;left:0;width:460px;height:260px;z-index:50;pointer-events:none}.preview-img{position:absolute;width:100%;height:100%;border-radius:14px;overflow:hidden}.preview-img-2{top:18px;left:18px}.preview-img img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.project-cta{display:flex;justify-content:center;padding-top:clamp(32px,5vh,56px)}.btn-pill{display:inline-flex;align-items:center;gap:12px;padding:18px 38px;border-radius:99px;border:1.5px solid var(--ink);background:transparent;color:var(--ink);text-decoration:none;font-family:var(--font-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;transition:background .3s ease,color .3s ease,gap .3s ease}.btn-pill:hover{background:var(--ink);color:var(--amber);gap:20px}.btn-pill .arr{font-family:var(--font-body)}.media-modal{display:none;position:fixed;z-index:9500;inset:0;background:rgba(17,17,16,.88);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.media-content,.media-modal{justify-content:center;align-items:center}.media-content{position:relative;max-width:min(880px,92vw);max-height:90vh;background:var(--ink);padding:10px;border-radius:16px;border:1px solid var(--line-dark);display:flex}.media-content video{width:100%;border-radius:10px;display:none}.media-content img{width:auto;max-width:100%;max-height:85vh;border-radius:10px;display:none}.close-btn{position:absolute;top:-16px;right:-16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--amber);color:var(--ink);font-weight:700;font-size:20px;border-radius:50%;cursor:pointer;transition:transform .25s ease,background .25s ease}.close-btn:hover{transform:rotate(90deg);background:var(--coral);color:var(--paper)}.contact{background:var(--ink);color:var(--paper);position:relative;overflow:clip}.contact-container{display:grid;grid-template-columns:.9fr 1.1fr;grid-gap:clamp(32px,5vw,80px);gap:clamp(32px,5vw,80px);padding:0 var(--gutter) clamp(64px,10vh,120px);max-width:1380px;margin:0 auto}.contact-image{position:relative;border-radius:var(--radius);overflow:hidden;align-self:start;transform:rotate(-2deg);box-shadow:-20px 20px 0 -6px var(--amber)}.contact-image img{width:100%;aspect-ratio:1/1.05;object-fit:cover}.gmailTxt{font-family:var(--font-mono);font-weight:400;font-size:14px;letter-spacing:.06em;color:var(--muted-dark);margin-bottom:clamp(24px,4vh,40px)}.gmailTxt a{color:var(--amber);text-decoration:none;border-bottom:1px solid rgba(249,182,70,.4)}.form-row{display:flex;gap:30px;margin-bottom:30px}.form-group{flex:1 1;position:relative;margin-top:20px}.form-group input,.form-group textarea{width:100%;border:none;border-bottom:1px solid rgba(248,247,243,.25);background:transparent;padding:12px 0;font-size:16px;color:var(--paper);outline:none;border-radius:0;font-family:var(--font-body);transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{border-bottom-color:var(--amber)}.form-group textarea{resize:vertical;min-height:110px;line-height:1.5}.form-group label{position:absolute;top:12px;left:0;font-family:var(--font-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-dark);pointer-events:none;transition:all .3s ease;transform-origin:left top}.form-group input:focus+label,.form-group input:not(:placeholder-shown)+label,.form-group textarea:focus+label,.form-group textarea:not(:placeholder-shown)+label{transform:translateY(-32px) scale(.85);color:var(--amber)}.message-group{margin-bottom:36px;margin-top:44px}.selection-group{margin-bottom:26px}.selection-group label{display:block;font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark);margin-bottom:14px}.pills{display:flex;flex-wrap:wrap;gap:10px}.pill-btn{border:1px solid rgba(248,247,243,.3);background:transparent;color:var(--paper);padding:10px 22px;border-radius:99px;font-size:14px;font-family:var(--font-body);cursor:pointer;transition:all .3s ease}.pill-btn:hover{border-color:var(--amber);color:var(--amber)}.pill-btn.active{border-color:var(--amber)}.pill-btn.active,.submit-btn{background:var(--amber);color:var(--ink);font-weight:600}.submit-btn{align-self:flex-start;border:1.5px solid var(--amber);padding:16px 48px;border-radius:99px;font-family:var(--font-mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:all .3s ease;margin-top:8px}.submit-btn:hover{background:transparent;color:var(--amber)}.submit-btn:disabled{opacity:.6;cursor:wait}.about{padding:clamp(72px,12vh,140px) var(--gutter);position:relative}.about-statement{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,3.6vw,52px);line-height:1.25;letter-spacing:-.01em;max-width:22ch}.about-statement .w{opacity:.14;will-change:opacity}.about-statement .accent{color:var(--coral);font-weight:600}.about-statement .highlight{color:var(--amber);font-weight:600}.logoMarquee{width:100%;position:relative;display:flex;align-items:center;overflow:hidden;margin:clamp(48px,8vh,90px) calc(-1 * var(--gutter)) 0;width:calc(100% + 2 * var(--gutter));padding:clamp(24px,4vh,40px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.marqueeInner{display:flex;width:max-content;animation:skillScroll 36s linear infinite}.logo-set{display:flex;gap:clamp(48px,7vw,100px);padding-right:clamp(48px,7vw,100px);align-items:center;flex-shrink:0}.marqueeInner img{height:clamp(44px,6vw,72px);width:auto;max-width:clamp(90px,12vw,150px);flex-shrink:0;object-fit:contain;filter:grayscale(100%);opacity:.55;transition:filter .3s ease,opacity .3s ease,transform .3s ease}.marqueeInner img:hover{filter:grayscale(0);opacity:1;transform:scale(1.15)}@keyframes skillScroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.about-quote{margin-top:clamp(48px,8vh,90px);margin-left:auto;max-width:24ch;text-align:right;font-size:clamp(18px,1.8vw,24px);font-weight:500;font-style:italic;color:var(--muted);position:relative}.about-quote .accent,.about-quote .highlight{font-style:normal;font-weight:700}.about-quote .accent{color:var(--coral)}.site-footer{background:var(--ink);color:var(--paper);padding:clamp(40px,7vh,72px) var(--gutter) 28px;position:relative;overflow:clip}.site-footer .footer-top{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:18px;padding-bottom:24px;border-bottom:1px solid var(--line-dark)}.site-footer nav a:hover{background:var(--paper);color:var(--ink)}.footer-giant{font-family:var(--font-display);font-weight:600;font-size:clamp(56px,11vw,180px);line-height:.95;letter-spacing:-.03em;text-transform:lowercase;padding:clamp(36px,7vh,80px) 0 clamp(24px,4vh,48px)}.footer-giant .row{display:block;overflow:hidden}.footer-giant .row>span{display:inline-block;will-change:transform}.footer-giant .ghost{color:transparent;-webkit-text-stroke:1.5px var(--paper)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-right:64px;padding-top:20px;border-top:1px solid var(--line-dark);font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dark)}.footer-bottom a{color:var(--amber);text-decoration:none}#toast-container{position:fixed;top:20px;right:20px;z-index:9600;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;justify-content:space-between;min-width:300px;padding:15px 20px;border-radius:14px;background:rgba(17,17,16,.88);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line-dark);color:var(--paper);transform:translateX(110%);animation:toastIn .35s cubic-bezier(.22,1,.36,1) forwards;cursor:pointer;font-size:14px;font-weight:500}.toast.success{border-left:4px solid var(--amber)}.toast.error{border-left:4px solid var(--coral)}.toast.hide{animation:toastOut .3s ease forwards}@keyframes toastIn{to{transform:translateX(0)}}@keyframes toastOut{to{opacity:0;transform:translateX(110%)}}@media (max-width:1024px){.hero-inner{grid-template-columns:1fr;min-height:0;gap:40px}.hero-right{order:-1}.portrait-card{max-width:480px;max-height:none;margin:0 auto;box-shadow:14px 14px 0 -4px var(--amber)}.site-header{flex-wrap:wrap;justify-content:space-between}.site-header nav{order:3;width:100%;display:flex;justify-content:center}.scroll-cue{display:none}.footer-bottom{padding-right:0}.section-head{flex-direction:column;align-items:flex-start}.section-note{text-align:left}.contact-container{grid-template-columns:1fr}.contact-image{max-width:440px;margin:0 auto}.menu-item{flex-direction:column;gap:10px;align-items:flex-start;padding:26px var(--gutter)}.info,.name,.tag{overflow:visible;height:auto;flex:none;width:100%}.name{font-size:clamp(28px,6vw,44px)}.name,.tag{text-align:left}.info p,.name p,.tag p{position:relative;top:auto}.info p:nth-child(2),.name p:nth-child(2),.tag p:nth-child(2){display:none}.menu:hover .info p:first-child,.menu:hover .name p:first-child,.menu:hover .tag p:first-child{color:inherit}.preview,.scroll-wheel{display:none}}@media (max-width:640px){.form-row{gap:10px}.form-row,.stats{flex-direction:column}.stats{align-items:center;text-align:center;gap:24px}.social-row{justify-content:center}.cta-row{flex-direction:column;align-items:stretch}.cta-row .btn-pill.cta-secondary,.resume-btn{margin-left:0;width:100%;justify-content:center;text-align:center}.portfolio-grid{grid-template-columns:repeat(3,1fr);gap:6px}.portfolio .card img{height:clamp(96px,19vh,150px)}.portfolio-title{top:47%;font-size:clamp(40px,13vw,96px);letter-spacing:-.04em}.close-btn{top:8px;right:8px}#toast-container{right:50%;transform:translateX(50%);width:90%}.toast{width:100%;min-width:auto}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.cursor-dot,.cursor-ring,.grain{display:none}.marqueeInner,.scroll-cue svg{animation:none}.about-statement .w{opacity:1}}