@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;650;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{color:#171818;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--background:#f7f6f4;--surface:#fff;--surface-soft:#f2f4f1;--surface-deep:#e4e7e3;--ink:#171818;--ink-soft:#3f4140;--muted:#686c6a;--line:#1718181f;--line-strong:#17181838;--accent:#f1414d;--accent-deep:#92001c;--accent-cool:#286d68;--terminal:#101011;--terminal-top:#18181a;--terminal-ink:#f2f0f0;--focus:#286d68;--shadow:0 1.35rem 3.1rem #1718181f;--shadow-soft:0 .85rem 1.8rem #17181814;background:#f7f6f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--background);scroll-behavior:smooth;min-height:100%}body{background-color:var(--background);min-width:320px;min-height:100vh;color:var(--ink);background-image:linear-gradient(90deg,#1718180e 1px,#0000 1px),linear-gradient(#1718180e 1px,#0000 1px),linear-gradient(135deg,#fbfbfa 0%,#f6f5f2 48%,#eef5f3 100%);background-size:2.5rem 2.5rem,2.5rem 2.5rem,100% 100%;margin:0;position:relative;overflow-x:hidden}body:before{z-index:0;content:"";pointer-events:none;background:linear-gradient(112deg,#0000 0 42%,#286d6812 62%,#0000 100%),linear-gradient(#ffffff9e,#0000 34%,#ffffff6b);position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000 0% 74%,#0000 100%);mask-image:linear-gradient(#000 0% 74%,#0000 100%)}body::selection{background:var(--accent);color:#fff}#root{z-index:1;min-height:100vh;position:relative}a,button{color:inherit;font:inherit;letter-spacing:0}a{text-decoration:none}button{cursor:pointer;background:0 0;border:0}a:focus-visible,button:focus-visible{outline:2px solid var(--focus);outline-offset:.25rem}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page-shell{flex-direction:column;min-height:100vh;display:flex;overflow:visible}@supports (height:100dvh){.page-shell{min-height:100dvh}}.home-grid,.site-footer{width:100%;max-width:90rem;margin:0 auto}.home-grid{flex:auto;grid-template-rows:minmax(16rem,auto) minmax(20rem,1fr);grid-template-columns:repeat(12,minmax(0,1fr));align-items:stretch;gap:clamp(1rem,2.1vh,1.8rem) clamp(1.1rem,2vw,1.8rem);min-height:0;padding:clamp(1.15rem,3.2vh,2rem) 4rem clamp(.75rem,2vh,1.25rem);display:grid}.hero-copy{flex-direction:column;grid-area:1/1/auto/span 7;justify-content:center;align-self:center;min-width:0;max-width:44rem;padding-top:0;animation:.52s cubic-bezier(.22,1,.36,1) both fade-up;display:flex}.hero-copy h1{max-width:7.5ch;color:var(--ink);letter-spacing:0;margin:0;font-size:clamp(3.85rem,6.1vw,5.35rem);font-weight:900;line-height:.92}.role,.descriptor{max-width:34rem;margin:0}.role{color:var(--ink);margin-top:clamp(.65rem,1.4vh,1rem);font-size:clamp(1.1rem,1.6vw,1.32rem);font-weight:800;line-height:1.2}.descriptor{color:var(--muted);margin-top:.42rem;font-size:clamp(.9rem,1.1vw,1rem);line-height:1.55}.tag-cloud{flex-wrap:wrap;gap:.42rem;max-width:38rem;margin-top:clamp(.72rem,1.5vh,1.05rem);display:flex}.tag-pill{border:1px solid var(--line);min-height:1.72rem;color:var(--ink-soft);white-space:nowrap;animation:tag-in .36s calc(var(--tag-index,0) * 38ms + .16s) cubic-bezier(.22, 1, .36, 1) both;background:#ffffff9e;border-radius:999px;align-items:center;padding:0 .76rem;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.72rem;font-weight:600;transition:border-color .18s,background .18s,color .18s,transform .18s;display:inline-flex}.tag-pill:hover{color:var(--accent-deep);background:#f1414d12;border-color:#f1414d6b;transform:translateY(-1px)}.hero-actions{flex-wrap:wrap;gap:.7rem;margin-top:clamp(.9rem,1.9vh,1.3rem);display:flex}.action-button{border:1px solid var(--ink);text-transform:uppercase;border-radius:.5rem;justify-content:center;align-items:center;min-width:7.5rem;min-height:2.5rem;padding:0 1rem;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.78rem;font-weight:700;transition:background .18s,border-color .18s,box-shadow .18s,color .18s,transform .18s;display:inline-flex}.action-button:hover{transform:translateY(-2px)}.action-button-primary{background:var(--ink);color:#fff;box-shadow:0 .7rem 1.2rem #1718181f}.action-button-primary:hover{background:#2a2a2b;border-color:#2a2a2b;box-shadow:0 .9rem 1.45rem #17181829}.action-button-secondary{color:var(--ink);background:#ffffffb8}.action-button-secondary:hover{border-color:var(--accent);color:var(--accent-deep)}.player-panel{isolation:isolate;flex-direction:column;grid-area:1/8/auto/-1;place-self:center end;align-items:center;gap:clamp(.45rem,1vh,.75rem);width:min(100%,24.5rem);min-width:0;padding-top:0;animation:.68s cubic-bezier(.22,1,.36,1) 80ms both visual-in;display:flex}.gramophone-frame{perspective:1000px;width:100%;max-width:min(16.8rem,27vh);transform-style:preserve-3d;transition:transform .7s cubic-bezier(.22,1,.36,1);position:relative}.gramophone-frame:after{z-index:-1;content:"";filter:blur(1rem);opacity:.78;background:#17181833;border-radius:50%;height:13%;position:absolute;bottom:3%;left:12%;right:13%;transform:translateY(.45rem)}.player-panel.is-playing .gramophone-frame{animation:5.8s ease-in-out infinite player-breathe}.gramophone-frame:hover{transform:translateY(-3px)rotateX(2deg)rotateY(-2deg)}.gramophone-image{pointer-events:none;filter:drop-shadow(0 1.3rem 2.1rem #1718182b);width:100%;height:auto;transition:filter .7s cubic-bezier(.22,1,.36,1);display:block}.gramophone-frame:hover .gramophone-image{filter:drop-shadow(0 1.7rem 2.7rem #17181836)}.record-stage{z-index:4;aspect-ratio:1;pointer-events:auto;transform-origin:50%;width:38.2%;transform-style:preserve-3d;position:absolute;top:58.6%;left:51.8%;transform:translate(-50%,-50%)rotate(-4deg)rotateX(64deg)}.record-control{cursor:pointer;opacity:.95;transform-style:preserve-3d;border-radius:50%;padding:0;display:block;position:absolute;inset:0}.record-control:focus-visible{outline-offset:.08rem;outline:1px solid #ffffffb8}.record-control:before,.record-control:after{content:"";pointer-events:none;border-radius:50%;position:absolute}.record-control:before{opacity:.86;background:radial-gradient(circle,#f1414dbf 0 9%,#0000 9.5%),repeating-radial-gradient(circle,#ffffff24 0 1px,#0000 1px 6px),radial-gradient(circle at 52% 44%,#ffffff29,#0000 28%),radial-gradient(circle,#0f0f10d1,#000000ad 62%,#ffffff1a 63%,#0000008a 100%);inset:3%;box-shadow:inset 0 0 0 1px #ffffff24,0 .25rem .65rem #00000042}.record-control:after{background:#fff9e8cc;inset:42%;box-shadow:0 0 0 1px #0000002e}.player-panel.is-playing .record-control:before,.player-panel.is-playing .record-control:after{animation:3.8s linear infinite record-spin}.mini-player{border:1px solid var(--line);background:linear-gradient(180deg, #ffffffc7, #ffffffa8), var(--surface);width:100%;max-width:22.75rem;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:.5rem;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.9rem;padding:.38rem;transition:border-color .22s,box-shadow .22s,transform .22s;display:grid;transform:translateY(-.25rem)}.player-panel:hover .mini-player,.player-panel.is-playing .mini-player{border-color:#286d683d;box-shadow:0 .9rem 2rem #1718181a}.transport-controls{background:#ffffffc2;border-radius:.5rem;align-items:center;gap:.32rem;padding:.28rem;display:flex;box-shadow:inset 0 1px #fffc}.transport-button{background:var(--surface-soft);width:1.95rem;height:1.95rem;color:var(--ink-soft);border:1px solid #17181826;border-radius:.5rem;place-items:center;font-size:.72rem;font-weight:800;transition:background .16s,border-color .16s,color .16s,transform .16s;display:inline-grid}.transport-button:hover{color:var(--ink);background:#fff;border-color:#17181842;transform:translateY(-1px)}.transport-button-play{background:var(--ink);color:#fff;width:2.35rem;height:2.35rem;box-shadow:0 .5rem 1.2rem #17181830}.transport-button-play:hover{color:#fff;background:#2b2b2c}.player-display{color:#13241c;background:#abc7b7;border:1px solid #1718182e;border-radius:.5rem;gap:.22rem;min-width:0;padding:.38rem .55rem .45rem;font-family:JetBrains Mono,ui-monospace,monospace;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 2px 5px #0000002e}.player-display:before{z-index:0;content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff38,#0000 50%),repeating-linear-gradient(0deg,#13241c0f 0 1px,#0000 1px 3px);position:absolute;inset:0}.player-display-top,.player-display-bottom,.player-progress{z-index:1;position:relative}.player-display-top,.player-display-bottom{justify-content:space-between;align-items:center;gap:.75rem;min-width:0;display:flex}.player-kicker,.player-time{flex:none;font-size:.66rem;font-weight:800}.player-time{color:#254135}.display-line{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.78rem;font-weight:700;overflow:hidden}.visualizer{flex:none;align-items:end;gap:.13rem;height:.86rem;display:flex}.visualizer-bar{width:.16rem;min-height:.1rem;height:var(--bar-height,18%);background:#13241c;border-radius:999px;transition:height 80ms cubic-bezier(.16,1,.3,1)}.player-panel.is-paused .visualizer-bar{opacity:.55}.player-progress{background:#13241c2e;border-radius:999px;height:.18rem;display:block;overflow:hidden}.player-progress span{border-radius:inherit;background:#13241c;width:0%;height:100%;transition:width .24s linear;display:block}.primary-nav{grid-area:2/1/auto/span 3;align-self:stretch;min-width:0;min-height:0;animation:.56s cubic-bezier(.22,1,.36,1) .16s both fade-up}.primary-tabs{border:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffa3;border-radius:.5rem;grid-template-rows:repeat(6,minmax(0,1fr));height:100%;min-height:0;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffffd1}.track-tab{border-bottom:1px solid var(--line);width:100%;min-height:2.55rem;color:var(--muted);text-align:left;opacity:0;animation:tab-in .32s calc(var(--item-index) * 38ms + .12s) cubic-bezier(.22, 1, .36, 1) both;border-radius:0;grid-template-columns:minmax(0,1fr) .7rem;align-items:center;gap:.6rem;padding:.48rem .82rem .48rem .86rem;transition:background .18s,color .18s,transform .18s;display:grid;position:relative;transform:translateY(.5rem)}.track-tab:before{background:var(--accent);content:"";opacity:0;transform-origin:50%;border-radius:0 999px 999px 0;width:.18rem;transition:opacity .18s,transform .22s cubic-bezier(.22,1,.36,1);position:absolute;top:.65rem;bottom:.65rem;left:0;transform:scaleY(.36)}.track-tab:last-child{border-bottom:0}.track-tab:hover{color:var(--ink);background:#ffffffbd;transform:translate(.12rem)}.track-tab[aria-selected=true]{color:var(--accent-deep);background:linear-gradient(90deg,#f1414d17,#0000 58%),#fff}.track-tab[aria-selected=true]:before{opacity:1;transform:scaleY(1)}.terminal-path,.terminal-link-state,.terminal-command,.terminal-line,.terminal-meta,.terminal-action,.site-footer{font-family:JetBrains Mono,ui-monospace,monospace}.tab-copy{min-width:0;display:grid}.tab-label{min-width:0;color:inherit;align-items:center;font-size:.88rem;font-weight:800;display:inline-flex}.ui-icon{flex:none;width:1.1rem;height:1.1rem;margin-right:.45rem}.external-mark{margin-left:.25rem;display:inline-block;transform:translateY(-.04rem)}.tab-cue{border:1px solid #66686875;border-radius:50%;justify-self:end;width:.44rem;height:.44rem;transition:background .18s,border-color .18s,transform .18s}.track-tab:hover .tab-cue,.track-tab[aria-selected=true] .tab-cue{border-color:var(--accent);background:var(--accent);transform:scale(1.12)}.terminal{background:linear-gradient(180deg, #ffffff12, transparent 9rem), linear-gradient(120deg, #286d6814, transparent 42%), var(--terminal);min-width:0;height:100%;min-height:0;color:var(--terminal-ink);border:1px solid #ffffff1a;border-radius:.5rem;flex-direction:column;grid-area:2/4/auto/-1;align-self:stretch;animation:.62s cubic-bezier(.22,1,.36,1) .2s both terminal-in;display:flex;position:relative;overflow:hidden;box-shadow:0 1.35rem 3rem #17181829,inset 0 1px #ffffff14}.terminal:before{content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#ffffff0a 1px,#0000 1px),linear-gradient(#ffffff08 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:3.25rem 3.25rem;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000,#0000 78%);mask-image:linear-gradient(#000,#0000 78%)}.terminal-chrome{z-index:1;background:linear-gradient(180deg, #ffffff0a, transparent), var(--terminal-top);border-bottom:1px solid #ffffff14;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.9rem;padding:.62rem .9rem;display:grid;position:relative}.chrome-lights{gap:.38rem;display:flex}.chrome-lights span{border-radius:50%;width:.72rem;height:.72rem}.chrome-lights span:first-child{background:#ff5f56}.chrome-lights span:nth-child(2){background:#ffbd2e}.chrome-lights span:nth-child(3){background:#27c93f}.terminal-path,.terminal-link-state{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.76rem;font-weight:650;overflow:hidden}.terminal-path{color:#f2f0f0a8}.terminal-link-state{color:#c9dfd9;justify-self:end}.terminal-content{z-index:1;flex:auto;min-height:0;padding:1rem 1.14rem 1.12rem;animation:.3s cubic-bezier(.22,1,.36,1) both terminal-swap;position:relative;overflow:auto}.terminal-command,.terminal-line{margin:0;font-size:.8rem;font-weight:650;line-height:1.52}.terminal-command{color:#fff;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:.72rem;display:grid}.terminal-prompt{color:#c9dfd9;white-space:nowrap}.command-text:after{background:var(--accent);content:"";width:.5rem;height:1em;margin-left:.42rem;animation:1.05s steps(2,jump-none) infinite caret;display:inline-block;transform:translateY(.15rem)}.terminal-body{gap:.34rem;margin-top:.72rem;display:grid}.terminal-meta{background:0 0;border:0;border-radius:0;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;margin:0 0 .32rem;display:grid;overflow:visible}.terminal-meta-card{background:linear-gradient(135deg,#ffffff17,#0000 68%),#101011d1;border:1px solid #ffffff1a;border-radius:.46rem;align-items:center;gap:.54rem;min-width:0;padding:.48rem .6rem;display:flex;box-shadow:inset 0 1px #ffffff12,0 .45rem 1rem #0000001f}.terminal-meta dt,.terminal-meta dd{text-overflow:ellipsis;white-space:nowrap;margin:0;overflow:hidden}.terminal-meta dt{color:#f2f0f06b;text-transform:uppercase;background:#f2f0f00d;border:1px solid #f2f0f017;border-radius:999px;flex:none;padding:.14rem .36rem;font-size:.62rem;font-weight:700}.terminal-meta dd{color:#f2f0f0;align-items:center;gap:.36rem;min-width:0;font-size:.76rem;font-weight:700;display:inline-flex}.terminal-status-dot{background:#27c93f;border-radius:50%;flex:none;width:.44rem;height:.44rem;box-shadow:0 0 0 .18rem #27c93f1f,0 0 .7rem #27c93f7a}.terminal-route-value{color:#c9dfd9;text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;display:block;overflow:hidden}.terminal-line{color:var(--terminal-ink);opacity:0;animation:line-in .28s calc(var(--line-index) * 62ms + 80ms) cubic-bezier(.22, 1, .36, 1) both;grid-template-columns:2.2rem minmax(0,1fr);gap:.82rem;display:grid;transform:translateY(.38rem)}.terminal-line-prefix{color:#f2f0f057;text-align:right;font-size:.76rem}.terminal-line-content{overflow-wrap:anywhere;min-width:0}.terminal-line-content-structured{grid-template-columns:minmax(5.7rem,max-content) minmax(0,1fr);align-items:start;gap:.7rem;display:grid}.terminal-line-key{color:#c9dfd9;text-transform:uppercase;white-space:nowrap;background:#c9dfd914;border:1px solid #c9dfd92e;border-radius:999px;min-width:0;padding:.05rem .38rem .06rem;font-size:.68rem;font-weight:800;line-height:1.35}.terminal-line-value{color:#f2f0f0eb;overflow-wrap:anywhere;min-width:0}.terminal-line a{color:#c9dfd9;text-underline-offset:.3em;text-decoration:none;transition:color .16s}.terminal-line a:hover{color:#fff;text-decoration:underline}.terminal-line a:hover .terminal-line-value{color:#fff}.terminal-actions{opacity:0;animation:line-in .28s calc(var(--line-index) * 62ms + .11s) cubic-bezier(.22, 1, .36, 1) both;flex-wrap:wrap;gap:.46rem;margin-top:.45rem;display:flex;transform:translateY(.38rem)}.terminal-action{color:#c9dfd9;background:#c9dfd917;border:1px solid #c9dfd952;border-radius:.5rem;align-items:center;gap:.32rem;min-height:2.05rem;padding:.4rem .58rem;font-size:.8rem;font-weight:760;transition:background .16s,border-color .16s,color .16s,transform .16s;display:inline-flex}.terminal-action:hover{color:#fff;background:#c9dfd926;border-color:#c9dfd99e;transform:translateY(-1px)}.site-footer{color:var(--muted);flex:none;justify-content:space-between;align-items:center;gap:1rem;margin-top:auto;padding:.48rem 4rem .68rem;font-size:.7rem;font-weight:650;display:flex}.site-footer p{gap:1rem;margin:0;display:flex}@keyframes fade-up{0%{opacity:0;transform:translateY(.8rem)}to{opacity:1;transform:translateY(0)}}@keyframes visual-in{0%{opacity:0;transform:translateY(.8rem)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes player-breathe{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-.18rem)rotate(-.35deg)}}@keyframes record-spin{to{transform:rotate(360deg)}}@keyframes tag-in{0%{opacity:0;transform:translateY(.35rem)}to{opacity:1;transform:translateY(0)}}@keyframes tab-in{to{opacity:1;transform:translateY(0)}}@keyframes terminal-in{0%{opacity:0;transform:translateY(.9rem)}to{opacity:1;transform:translateY(0)}}@keyframes terminal-swap{0%{opacity:0;transform:translateY(.4rem)}to{opacity:1;transform:translateY(0)}}@keyframes line-in{to{opacity:1;transform:translateY(0)}}@keyframes caret{0%,44%{opacity:1}45%,to{opacity:0}}@keyframes project-card-in{to{opacity:1;transform:translateY(0)}}@media (width<=1080px){.site-footer,.home-grid{padding-left:2rem;padding-right:2rem}.hero-copy h1{font-size:4.8rem}.role{font-size:1.16rem}}@media (width<=900px){.page-shell{height:auto;min-height:100vh;overflow:visible}.home-grid{grid-template-rows:auto;grid-template-columns:1fr;gap:2rem}.hero-copy,.player-panel,.primary-nav,.terminal{grid-area:auto/1}.player-panel{justify-self:center;width:min(100%,23rem)}.hero-copy{padding-top:2rem}.gramophone-frame{max-width:18rem}.primary-tabs{grid-template-rows:none;grid-template-columns:repeat(3,minmax(0,1fr));height:auto}.track-tab{border-right:1px solid var(--line)}.track-tab:nth-child(3n){border-right:0}.track-tab:nth-last-child(-n+3){border-bottom:0}}@media (width<=680px){html,body,#root,.page-shell{height:100%;min-height:100%;overflow:hidden}@supports (height:100dvh){html,body,#root,.page-shell{height:100dvh;min-height:100dvh}}body{background-image:linear-gradient(90deg,#1718180b 1px,#0000 1px),linear-gradient(#1718180b 1px,#0000 1px),radial-gradient(circle at 78% 24%,#f1414d1a,#0000 32%),linear-gradient(150deg,#fbfbfa 0%,#f6f5f2 52%,#eaf4f1 100%);background-size:2.25rem 2.25rem,2.25rem 2.25rem,100% 100%,100% 100%}.site-footer{padding-left:1rem;padding-right:1rem}.home-grid{height:100%;padding:max(.72rem, env(safe-area-inset-top)) .88rem max(1.75rem, calc(env(safe-area-inset-bottom) + 1.16rem));grid-template-rows:auto auto minmax(0,1fr);grid-template-columns:minmax(0,1fr);align-content:stretch;gap:clamp(.56rem,1.35vh,.82rem);overflow:hidden}.hero-copy,.player-panel,.primary-nav,.terminal{grid-column:1;min-width:0}.hero-copy{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"title actions""role actions""desc desc""tags tags";align-self:start;align-items:center;gap:.18rem .72rem;max-width:none;padding-top:0;display:grid}.hero-copy h1{grid-area:title;max-width:none;font-size:clamp(2.84rem,15vw,3.55rem);line-height:.92}.role{grid-area:role;margin-top:0;font-size:clamp(.9rem,4vw,1.06rem);line-height:1.08}.descriptor{color:#3f4140c7;-webkit-line-clamp:2;-webkit-box-orient:vertical;grid-area:desc;max-width:none;margin-top:.22rem;font-size:.8rem;line-height:1.36;display:-webkit-box;overflow:hidden}.tag-cloud{grid-area:tags;display:none}.hero-actions{grid-area:actions;justify-self:end;gap:0;margin-top:0;display:flex}.action-button{border-radius:.45rem;min-width:0;min-height:2.42rem;padding:0 .82rem;font-size:.68rem}.action-button-secondary,.player-panel{display:none}.primary-nav{grid-row:2;align-self:end;min-height:0}.primary-tabs{background:#ffffffb8;border-radius:.5rem;grid-template-rows:repeat(2,minmax(2.4rem,1fr));grid-template-columns:repeat(3,minmax(0,1fr));height:clamp(5rem,12.2vh,6rem);box-shadow:inset 0 1px #ffffffc7,0 .62rem 1.28rem #17181814}.track-tab{border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center;grid-template-columns:minmax(0,1fr);min-height:0;padding:.34rem .24rem;transform:none}.track-tab:nth-child(3n){border-right:0}.track-tab:nth-last-child(-n+3){border-bottom:0}.track-tab:hover{transform:none}.track-tab:before,.tab-cue{display:none}.tab-label{flex-direction:column;justify-content:center;gap:.22rem;width:100%;font-size:.66rem;line-height:1}.ui-icon{width:1.06rem;height:1.06rem;margin-right:0}.external-mark{display:none}.track-tab[aria-selected=true]{color:var(--accent-deep);background:linear-gradient(#f1414d24,#ffffffeb),#fff}.terminal{border-radius:.5rem;grid-row:3;align-self:stretch;height:auto;min-height:0;box-shadow:0 .82rem 1.6rem #17181824,inset 0 1px #ffffff14}.terminal-chrome{grid-template-columns:auto minmax(0,1fr);gap:.58rem;padding:.54rem .66rem;display:grid}.terminal:before{background-size:2.5rem 2.5rem}.terminal-content{flex:auto;height:auto;min-height:0;padding:.72rem .72rem .82rem;overflow:auto}.terminal-link-state{display:none}.terminal-path{font-size:.66rem}.terminal-body{gap:.34rem;margin-top:.56rem}.terminal-command,.terminal-line,.terminal-meta{font-size:.7rem}.terminal-line{grid-template-columns:1.55rem minmax(0,1fr);gap:.52rem;line-height:1.46}.terminal-line-prefix{font-size:.66rem;display:inline}.terminal-line-content{overflow-wrap:anywhere;display:block}.terminal-line-content-structured{grid-template-columns:minmax(4.95rem,max-content) minmax(0,1fr);gap:.48rem;display:grid}.terminal-line-key{padding:.04rem .3rem .05rem;font-size:.56rem}.terminal-line-value{line-height:1.48}.terminal-command{grid-template-columns:1fr;gap:.18rem;line-height:1.42}.terminal-prompt,.command-text{overflow-wrap:anywhere;min-width:0}.terminal-meta{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:.24rem}.terminal-meta-card{gap:.34rem;padding:.42rem .5rem}.terminal-meta dt{font-size:.58rem}.terminal-meta dd{font-size:.68rem}.terminal-actions{scrollbar-width:none;flex-wrap:wrap;gap:.36rem;max-height:4.1rem;margin-top:.36rem;padding-bottom:.12rem;overflow:hidden}.terminal-actions::-webkit-scrollbar{display:none}.terminal-action{white-space:nowrap;border-radius:.42rem;flex:calc(50% - .36rem);justify-content:center;min-height:1.86rem;padding:.3rem .52rem;font-size:.68rem}.site-footer{right:0;bottom:max(.42rem, env(safe-area-inset-bottom));z-index:5;color:#686c6ab8;pointer-events:none;justify-content:center;padding:0 .88rem;font-size:.62rem;line-height:1;display:flex;position:fixed;left:0}.site-footer p{justify-content:center}}@media (width<=420px){.hero-copy h1{font-size:clamp(2.72rem,14.4vw,3.2rem)}.descriptor{font-size:.76rem}.tag-pill{font-size:.72rem}.primary-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=680px) and (height>=760px){.home-grid{gap:clamp(.54rem,1.1vh,.72rem)}.tag-cloud{gap:.26rem;max-width:100%;max-height:3.05rem;margin-top:.24rem;display:flex;overflow:hidden}.tag-pill{min-height:1.32rem;padding:0 .48rem;font-size:.55rem}.terminal{height:auto}}@media (width<=680px) and (height<=720px){.home-grid{padding-top:max(.56rem, env(safe-area-inset-top));padding-bottom:max(1.55rem, calc(env(safe-area-inset-bottom) + .98rem));grid-template-rows:auto auto minmax(0,1fr);align-content:stretch;gap:.48rem}.descriptor{display:none}.action-button{min-height:2.12rem;padding:0 .66rem}.primary-tabs{grid-template-rows:repeat(2,minmax(2.2rem,1fr));height:4.72rem}.tab-label{font-size:.6rem}.ui-icon{width:.96rem;height:.96rem}.terminal{align-self:stretch;height:auto}.terminal-content{padding:.56rem .62rem .66rem}.terminal-action{flex:calc(50% - .36rem);min-height:1.62rem;font-size:.62rem}.terminal-actions{flex-wrap:wrap;overflow:hidden}}@media (width>=901px) and (height<=760px){.home-grid{gap:.55rem 1.1rem;padding-top:.55rem;padding-bottom:.4rem}.hero-copy h1{font-size:clamp(4.35rem,6.8vw,5.45rem)}.role{margin-top:.5rem;font-size:1.05rem}.descriptor{font-size:.84rem;line-height:1.35}.tag-cloud{gap:.3rem;margin-top:.45rem}.tag-pill{min-height:1.45rem;padding:0 .58rem;font-size:.66rem}.hero-actions{margin-top:.55rem}.action-button{min-width:6.6rem;min-height:2.1rem;font-size:.7rem}.gramophone-frame{max-width:min(12rem,20vh)}.mini-player{padding:.32rem}.transport-button{width:1.7rem;height:1.7rem}.transport-button-play{width:2.1rem;height:2.1rem}.player-display{padding:.3rem .48rem .36rem}.player-kicker,.player-time{font-size:.58rem}.display-line{font-size:.68rem}.visualizer{height:.7rem}.track-tab{min-height:2.15rem;padding:.38rem .64rem}.tab-label{font-size:.82rem}.ui-icon{width:1rem;height:1rem;margin-right:.36rem}.terminal-chrome{padding:.46rem .68rem}.terminal-path,.terminal-link-state{font-size:.68rem}.terminal-content{min-height:0;padding:.68rem .82rem .78rem}.terminal-command,.terminal-line{font-size:.72rem;line-height:1.32}.terminal-body{gap:.22rem;margin-top:.42rem}.terminal-meta{margin-bottom:.2rem}.terminal-meta-card{padding:.32rem .42rem}.terminal-meta dt{font-size:.58rem}.terminal-meta dd{font-size:.66rem}.terminal-actions{gap:.35rem;margin-top:.32rem}.terminal-action{min-height:1.75rem;padding:.28rem .46rem;font-size:.66rem}.site-footer{padding-top:.3rem;padding-bottom:.42rem;font-size:.64rem}}.page-shell-projects{overflow:visible}body[data-page=projects],body[data-page=projects] #root,body[data-page=projects] .page-shell{height:auto;min-height:100%;overflow:hidden auto}@supports (height:100dvh){body[data-page=projects],body[data-page=projects] #root,body[data-page=projects] .page-shell{min-height:100dvh}}.projects-page{flex:auto;width:100%;max-width:90rem;margin:0 auto;padding:clamp(1rem,3vh,1.8rem) 4rem 3rem}.projects-topbar{justify-content:space-between;align-items:center;gap:1rem;min-height:3rem;animation:.42s cubic-bezier(.22,1,.36,1) both fade-up;display:flex}.projects-brand,.projects-nav,.projects-nav-button,.projects-eyebrow,.portfolio-project .project-category,.project-highlights,.project-note,.project-link,.portfolio-screen span{font-family:JetBrains Mono,ui-monospace,monospace}.projects-brand{min-width:0;color:var(--ink);text-align:left;gap:.05rem;padding:0;display:inline-grid}.projects-brand span:first-child{font-size:1.04rem;font-weight:900;line-height:1}.projects-brand span:last-child{color:var(--muted);text-transform:uppercase;font-size:.68rem;font-weight:700}.projects-nav{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.projects-nav-button{border:1px solid var(--line-strong);min-height:2.18rem;color:var(--ink);text-transform:uppercase;background:#ffffffad;border-radius:.5rem;justify-content:center;align-items:center;padding:0 .78rem;font-size:.72rem;font-weight:800;transition:background .17s,border-color .17s,color .17s,transform .17s;display:inline-flex}.projects-nav-button:hover{color:var(--accent-deep);background:#fff;border-color:#f1414d73;transform:translateY(-1px)}.projects-nav-button-primary{border-color:var(--ink);background:var(--ink);color:#fff}.projects-nav-button-primary:hover{color:#fff;background:#2a2a2b;border-color:#2a2a2b}.projects-hero{max-width:56rem;padding:clamp(2rem,5.6vh,4.2rem) 0 clamp(1.4rem,3.4vh,2.4rem);animation:.52s cubic-bezier(.22,1,.36,1) 70ms both fade-up;display:block}.projects-eyebrow{color:var(--accent-deep);text-transform:uppercase;margin:0 0 .72rem;font-size:.72rem;font-weight:850}.projects-hero h1{max-width:12ch;color:var(--ink);letter-spacing:0;margin:0;font-size:clamp(3.2rem,6vw,5.8rem);font-weight:900;line-height:.94}.projects-lede{max-width:48rem;color:var(--ink-soft);margin:1rem 0 0;font-size:clamp(.98rem,1.25vw,1.12rem);line-height:1.6}.portfolio-list{gap:clamp(1rem,2.4vw,1.6rem);display:grid}.portfolio-project{border-top:1px solid var(--line-strong);opacity:0;min-width:0;animation:project-card-in .42s calc(var(--project-index,0) * 80ms + .12s) cubic-bezier(.22, 1, .36, 1) both;grid-template-columns:minmax(18rem,.48fr) minmax(0,1fr);align-items:center;gap:clamp(1rem,3vw,2rem);padding:clamp(1rem,2.4vw,1.45rem) 0;display:grid;transform:translateY(.55rem)}.portfolio-project:last-child{border-bottom:1px solid var(--line)}.portfolio-project-copy{min-width:0}.portfolio-project .project-category{color:var(--accent-deep);text-transform:uppercase;margin:0 0 .64rem;font-size:.68rem;font-weight:850;display:inline-flex}.portfolio-project h2{color:var(--ink);letter-spacing:0;margin:0;font-size:clamp(2rem,3.1vw,3.35rem);font-weight:900;line-height:.98}.portfolio-project .project-headline{color:var(--ink);margin:.74rem 0 0;font-size:clamp(1rem,1.25vw,1.1rem);font-weight:800;line-height:1.36}.portfolio-project .project-summary{color:var(--ink-soft);margin:.54rem 0 0;font-size:.92rem;line-height:1.58}.project-highlights{color:var(--muted);gap:.34rem;margin:.85rem 0 0;padding:0;font-size:.72rem;font-weight:760;line-height:1.42;list-style:none;display:grid}.project-highlights li{padding-left:1rem;position:relative}.project-highlights li:before{background:var(--accent-cool);content:"";border-radius:50%;width:.38rem;height:.38rem;position:absolute;top:.54em;left:0}.project-note{color:#686c6ad6;margin:.76rem 0 0;font-size:.68rem;font-weight:700;line-height:1.45}.portfolio-project .project-link{color:var(--accent-deep);text-transform:uppercase;align-items:center;gap:.3rem;margin-top:1rem;font-size:.72rem;font-weight:850;transition:color .16s,transform .16s;display:inline-flex}.portfolio-project .project-link:hover{color:var(--accent);transform:translate(.08rem)}.portfolio-screens{grid-template-columns:minmax(0,1fr) minmax(7rem,.23fr);align-items:end;gap:clamp(.55rem,1.4vw,.9rem);min-width:0;display:grid;position:relative}.portfolio-screen{border:1px solid var(--line-strong);background:var(--surface);min-width:0;box-shadow:var(--shadow-soft);border-radius:.5rem;transition:box-shadow .18s,transform .18s;display:block;position:relative;overflow:hidden}.portfolio-screen:hover{transform:translateY(-.12rem);box-shadow:0 1.1rem 2.4rem #17181821}.portfolio-screen span{z-index:1;color:#fff;text-transform:uppercase;background:#101011b8;border:1px solid #ffffffa3;border-radius:999px;align-items:center;min-height:1.35rem;padding:0 .42rem;font-size:.58rem;font-weight:850;display:inline-flex;position:absolute;top:.58rem;left:.58rem}.portfolio-screen img{object-fit:cover;width:100%;height:100%;display:block}.portfolio-screen-web{aspect-ratio:3/2}.portfolio-screen-mobile{aspect-ratio:390/844}@media (width<=1080px){.projects-page{padding-left:2rem;padding-right:2rem}.portfolio-project{grid-template-columns:1fr}.portfolio-project-copy{max-width:44rem}}@media (width<=680px){body[data-page=projects] .site-footer{pointer-events:auto;padding:.9rem 1rem 1.2rem;position:static}.projects-page{padding:max(.84rem, env(safe-area-inset-top)) .88rem 1.2rem}.projects-topbar{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#f7f6f4d1;align-items:start;min-height:2.7rem;margin-left:-.88rem;margin-right:-.88rem;padding:.28rem .88rem .48rem;position:sticky;top:0}.projects-brand span:first-child{font-size:.94rem}.projects-brand span:last-child{font-size:.58rem}.projects-nav{gap:.36rem}.projects-nav-button{min-height:2rem;padding:0 .58rem;font-size:.64rem}.projects-hero{padding:1.2rem 0 .72rem}.projects-eyebrow{margin-bottom:.5rem;font-size:.62rem}.projects-hero h1{max-width:12ch;font-size:clamp(2.7rem,14vw,3.45rem)}.projects-lede{margin-top:.78rem;font-size:.88rem;line-height:1.5}.portfolio-list{overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;align-items:flex-start;gap:.72rem;margin-left:-.88rem;margin-right:-.88rem;padding:0 .88rem .35rem;scroll-padding:.88rem;display:flex;overflow-x:auto}.portfolio-list::-webkit-scrollbar{display:none}.portfolio-project{border:1px solid var(--line);scroll-snap-align:start;background:#ffffffb8;border-radius:.5rem;flex:0 0 min(88vw,23rem);gap:.86rem;padding:.9rem;overflow:hidden;box-shadow:0 .72rem 1.45rem #17181814,inset 0 1px #ffffffc7}.portfolio-project h2{font-size:clamp(1.82rem,9.2vw,2.42rem)}.portfolio-project .project-category{margin-bottom:.52rem;font-size:.58rem}.portfolio-project .project-headline{font-size:.92rem}.portfolio-project .project-summary{font-size:.82rem;line-height:1.5}.portfolio-project .project-link{border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:.5rem;justify-content:center;width:100%;min-height:2.28rem;margin-top:.86rem}.portfolio-project .project-link:hover{color:#fff;transform:translateY(-1px)}.project-highlights{flex-wrap:wrap;gap:.34rem;font-size:.62rem;display:flex}.project-highlights li{min-height:1.52rem;color:var(--accent-cool);background:#286d6812;border:1px solid #286d682e;border-radius:999px;padding:.22rem .48rem}.project-highlights li:before{display:none}.project-note{font-size:.62rem}.portfolio-screens{grid-template-columns:minmax(0,.58fr) minmax(0,1fr);align-items:start;gap:.55rem;margin:0;padding:0;display:grid;overflow:visible}.portfolio-screen{min-width:0;box-shadow:0 .58rem 1.2rem #1718181a}.portfolio-screen:hover{transform:none}.portfolio-screen-web{width:auto}.portfolio-screen-mobile{order:-1;width:auto}.portfolio-screen span{min-height:1.12rem;font-size:.5rem;top:.42rem;left:.42rem}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
