.preview-scatter-container{position:relative;width:100%;height:480px;overflow:visible}.preview-scatter-card{will-change:transform,opacity;pointer-events:auto;cursor:pointer}.preview-scatter-img-wrap{border-radius:8px;overflow:hidden;background-color:var(--color-bg-secondary, #fafafa);box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a;transition:box-shadow .2s ease,transform .2s ease}.preview-scatter-card:hover .preview-scatter-img-wrap{box-shadow:0 8px 24px #0000001f,0 0 0 1px #0000000f;transform:scale(1.03)}.preview-scatter-img{width:100%;height:auto;display:block}@media(max-width:1024px){.preview-scatter-card{display:none}}@media(prefers-reduced-motion:reduce){.preview-scatter-card,.preview-scatter-img-wrap{transition:none!important;animation:none!important}}.preview-media-reveal{will-change:transform,opacity,clip-path;pointer-events:auto;cursor:pointer;position:relative;transition:none}.mode-work .preview-media-reveal{display:none}.preview-mask-container{width:100%;height:100%;overflow:hidden;position:relative}.preview-state-label{position:absolute;bottom:1rem;left:1rem;font-size:.6875rem;font-family:Courier New,monospace;letter-spacing:.05em;text-transform:lowercase;font-weight:400;color:#ffffffe6;background:#000000b3;padding:.25rem .75rem;pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-image,.preview-video{width:100%;height:auto;display:block;border-radius:0;transition:transform .2s cubic-bezier(.2,.8,.2,1)}.mode-chaos .preview-image,.mode-chaos .preview-video{border-radius:12px;box-shadow:none}.mode-work .preview-image,.mode-work .preview-video{box-shadow:0 0 0 1px #00000014,0 8px 24px #0000001f}.preview-media-reveal:hover .preview-image,.preview-media-reveal:hover .preview-video{transform:scale(1.01)}.preview-video{object-fit:cover}.preview-media-reveal.pattern-a:hover .preview-image,.preview-media-reveal.pattern-a:hover .preview-video{transform:scale(1.03) translate(8px)}.preview-media-reveal.pattern-b:hover .preview-image,.preview-media-reveal.pattern-b:hover .preview-video{transform:scale(1.02) translateY(-4px)}.preview-media-reveal.pattern-c:hover .preview-image,.preview-media-reveal.pattern-c:hover .preview-video{transform:translateY(-12px)}.preview-media-reveal.pattern-d:hover .preview-video{transform:none}@media(max-width:1024px){.preview-media-reveal{display:none}}@media(prefers-reduced-motion:reduce){.preview-media-reveal,.preview-image,.preview-video,.preview-state-label{transition:none!important;animation:none!important;transform:none!important}}.mode-chaos .preview-media-reveal{display:block}.mode-chaos .preview-media-reveal:hover .preview-image,.mode-chaos .preview-media-reveal:hover .preview-video{transform:scale(1.03);transition:transform .35s cubic-bezier(.4,0,.2,1)}.mode-chaos .preview-state-label{display:none}.mode-work .preview-media-reveal,.mode-work .preview-state-label{display:none!important}.holographic-panel{display:none}.mode-work .holographic-panel{display:block;position:absolute;top:100px;right:80px;width:320px;min-height:180px;background:linear-gradient(135deg,#00ffff14,#00c8ff1f,#00ffff0f);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(0,255,255,.35);padding:1.5rem;z-index:100;pointer-events:none;will-change:transform,opacity;clip-path:polygon(0 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%);animation:holo-float 3s ease-in-out infinite;box-shadow:0 0 20px #00ffff4d,0 0 40px #00ffff26,inset 0 0 20px #00ffff0d}.holo-edge{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(0,255,255,.8) 50%,transparent 100%);animation:edge-sweep 2s ease-in-out infinite}.holo-content{position:relative;z-index:2;font-family:Courier New,Consolas,monospace;font-size:.8125rem;line-height:1.6;color:#fffffff2}.holo-metadata{display:flex;gap:.75rem;margin-bottom:.75rem;align-items:baseline}.holo-label{color:#00ffffe6;font-weight:600;letter-spacing:.05em;text-transform:lowercase;min-width:80px}.holo-value{color:#ffffffd9;font-weight:400;letter-spacing:.02em}.scanline-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,255,255,.03) 2px,rgba(0,255,255,.03) 4px);pointer-events:none;z-index:1;opacity:.5}@keyframes holo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes edge-sweep{0%,to{opacity:.3}50%{opacity:1}}.mode-work .holographic-panel{animation:holo-float 3s ease-in-out infinite,holo-glow-pulse 2s ease-in-out infinite}@keyframes holo-glow-pulse{0%,to{box-shadow:0 0 20px #00ffff40,0 0 40px #00ffff1f,inset 0 0 20px #00ffff0d}50%{box-shadow:0 0 30px #0ff6,0 0 60px #0ff3,inset 0 0 30px #00ffff14}}@media(max-width:1024px){.mode-work .holographic-panel{display:none}}@media(prefers-reduced-motion:reduce){.mode-work .holographic-panel,.holo-edge,.scanline-overlay{animation:none!important}}.mode-switcher{position:fixed;top:2rem;right:clamp(1.5rem,5vw,4rem);z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.mode-switcher-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-tertiary);font-weight:600;font-family:var(--font-primary)}.mode-buttons{display:flex;gap:.375rem;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:.375rem;border-radius:8px;border:1px solid var(--color-border-light);box-shadow:0 2px 12px #0000000a}.mode-button{position:relative;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;font-family:var(--font-display);color:var(--color-text-tertiary);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all var(--duration-base) var(--ease-smooth);white-space:nowrap;letter-spacing:.01em}.mode-button:hover,.mode-button.active{color:var(--color-text)}.mode-button-text{position:relative;z-index:2}.mode-button-indicator{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-bg);border-radius:6px;border:1px solid var(--color-border);z-index:1}@media(max-width:768px){.mode-switcher{top:1.5rem;right:1.5rem}.mode-switcher-label{display:none}.mode-button{padding:.375rem .75rem;font-size:.75rem}}@media(prefers-reduced-motion:reduce){.mode-button-indicator{transition:none!important}}.mode-work .mode-switcher{background:var(--color-module-bg);border:1px solid var(--color-border);border-radius:0;padding:.875rem;-webkit-backdrop-filter:none;backdrop-filter:none;transform:none}.mode-work .mode-switcher:before{content:"[mode_select]";display:block;font-size:.6rem;font-weight:700;color:var(--color-system-label);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.5rem;opacity:.6}.mode-work .mode-switcher-label{display:none}.mode-work .mode-button{border-radius:0;border:1px solid var(--color-border);background:transparent;font-weight:700;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;transition:all .12s cubic-bezier(.4,0,.2,1);color:var(--color-text-secondary)}.mode-work .mode-button:hover{border-color:var(--color-accent);color:var(--color-accent)}.mode-work .mode-button.active{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.mode-work .mode-button-indicator{display:none}.skills-section{padding:clamp(4rem,8vw,8rem) 0;opacity:0;transform:translateY(24px);transition:opacity var(--duration-slow) var(--ease-smooth),transform var(--duration-slow) var(--ease-smooth)}.skills-section.visible{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.skills-section{opacity:1;transform:none;transition:none}.skills-category,.skill-item{opacity:1!important;transform:none!important;transition:background-color .2s ease,border-color .2s ease!important}}.skills-header{margin-bottom:clamp(3rem,6vw,6rem);max-width:560px}.skills-eyebrow{display:block;font-size:.6875rem;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-tertiary);font-weight:600;margin-bottom:var(--space-3)}.skills-title{font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--color-text);margin-bottom:var(--space-4);line-height:1.1;letter-spacing:-.02em}.skills-description{font-size:1rem;color:var(--color-text-secondary);line-height:1.7;font-weight:300}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem 3rem}@media(max-width:1024px){.skills-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 3rem}}@media(max-width:640px){.skills-grid{grid-template-columns:1fr;gap:2rem}.skills-title{font-size:2rem}.skills-header{margin-bottom:2.5rem}}.skills-category{opacity:0;transform:translateY(20px);animation:skillCategoryReveal .6s ease forwards;animation-delay:var(--stagger-delay, 0ms)}.skills-section.visible .skills-category{opacity:1;transform:translateY(0)}@keyframes skillCategoryReveal{to{opacity:1;transform:translateY(0)}}.skills-category-label{font-size:.8rem;font-weight:600;color:var(--text-primary, #1c1917);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;padding-bottom:.625rem;border-bottom:1px solid var(--border, #e7e5e4)}.skills-list{list-style:none;padding:0;margin:0}.skill-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid transparent;opacity:0;transform:translate(-10px);animation:skillItemReveal .4s ease forwards;animation-delay:var(--skill-delay, 0ms);transition:all .3s cubic-bezier(.16,1,.3,1);cursor:default;position:relative;overflow:visible;z-index:1}.skills-section.visible .skill-item{opacity:1;transform:translate(0)}@keyframes skillItemReveal{to{opacity:1;transform:translate(0)}}.skill-item:hover{padding-left:.5rem;border-bottom-color:var(--border, #e7e5e4)}.skill-item:last-child{border-bottom:none}.skill-item:last-child:hover{border-bottom-color:transparent}.skill-name{font-size:1rem;color:var(--text-primary, #1c1917);font-weight:500;position:relative;transition:color .3s ease}.skill-item:hover .skill-name{color:var(--accent, #212121)}.skill-name:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent, #212121);transition:width .3s ease}.skill-item:hover .skill-name:after{width:100%}.skill-level{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .625rem;border-radius:4px;font-weight:500;opacity:0;transform:translate(10px);transition:opacity .3s ease,transform .3s ease}.skill-item:hover .skill-level{opacity:1;transform:translate(0)}.skill-level.advanced{background:#21212114;color:var(--accent, #212121)}.skill-level.intermediate{background:#57534e14;color:var(--text-secondary, #57534e)}.skill-level.learning{background:#e7e5e480;color:var(--text-secondary, #57534e)}.skills-section.compact{padding:0}.skills-section.compact .skills-header{margin-bottom:1.5rem}.skills-section.compact .skills-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary, #57534e);font-weight:600}.skills-section.compact .skills-eyebrow,.skills-section.compact .skills-description{display:none}.skills-section.compact .skills-grid{grid-template-columns:1fr;gap:1.5rem}.skills-section.compact .skills-category-label{font-size:.85rem;margin-bottom:.75rem;padding-bottom:0;border-bottom:none}.skills-section.compact .skill-item{padding:.5rem 0}.skills-section.compact .skills-list{display:flex;flex-wrap:wrap;gap:.5rem}.skills-section.compact .skill-item{padding:.5rem 1rem;background:var(--bg-primary, #fafaf9);border:1px solid var(--border, #e7e5e4);border-radius:20px}.skills-section.compact .skill-item:hover{padding-left:1rem;background:var(--accent, #212121);border-color:var(--accent, #212121)}.skills-section.compact .skill-item:hover .skill-name{color:#fff}.skills-section.compact .skill-name:after{display:none}.skills-section.compact .skill-level{display:none}.skills-title,.skills-category-label{font-family:var(--font-display);font-weight:600}.mode-chaos .skill-item:nth-child(odd){transform:translate(2px)}.mode-chaos .skill-item:nth-child(2n){transform:translate(-2px)}.mode-chaos .skill-item:hover{transform:translate(8px) rotate(.3deg)!important}.mode-chaos .skill-name:after{display:none}.mode-chaos .skill-item:hover{padding-left:0;border-bottom-color:transparent}.mode-work .skills-section{background:transparent}.mode-work .skill-item:hover{background-color:#d4a5740d;padding-left:var(--space-3)}.mode-work .skill-name:after{background:var(--color-accent)}.mode-work .skills-category-label{color:var(--color-accent);border-bottom-color:var(--color-border)}.mode-work .skills-section:not(.skills-work-mode) .skills-grid,.mode-work .skills-section:not(.skills-work-mode) .skills-header{display:none}.skills-work-mode{padding:clamp(4rem,8vw,8rem) 0;position:relative;z-index:1}.holo-background{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden}.scanlines{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,240,255,.045) 2px,rgba(0,240,255,.045) 4px);opacity:.6;animation:scanline-drift 8s linear infinite}@keyframes scanline-drift{0%{transform:translateY(0)}to{transform:translateY(20px)}}.code-stream{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0%,rgba(0,240,255,.025) 20%,rgba(0,240,255,.035) 50%,rgba(0,240,255,.025) 80%,transparent 100%);opacity:.15;animation:code-scroll 20s linear infinite}@keyframes code-scroll{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.nano-grid{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,240,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,240,255,.04) 1px,transparent 1px);background-size:40px 40px;opacity:.35}.noise-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-image:url('data:image/svg+xml;utf8,<svg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg"><filter id="noiseFilter"><feTurbulence type="fractalNoise" baseFrequency="4" numOctaves="3" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23noiseFilter)"/></svg>');opacity:.025;animation:noise-flicker .3s steps(2) infinite}@keyframes noise-flicker{0%,to{opacity:.025}50%{opacity:.035}}.holo-background:before{content:"→ < > { } [ ] * _ → < > { } [ ] * _ → < > { } [ ] * _";position:absolute;top:-50%;left:0;right:0;font-family:Courier New,Consolas,monospace;font-size:.75rem;color:#00f0ff14;letter-spacing:2rem;word-spacing:1.5rem;white-space:nowrap;overflow:hidden;opacity:.6;animation:ascii-stream-down 25s linear infinite;pointer-events:none;z-index:-1}.holo-background:after{content:"[ ] < > { } → * _ [ ] < > { } → * _";position:absolute;top:-30%;left:0;right:0;font-family:Courier New,Consolas,monospace;font-size:.625rem;color:#b900ff0f;letter-spacing:1.8rem;word-spacing:1.2rem;white-space:nowrap;overflow:hidden;opacity:.5;animation:ascii-stream-down 30s linear infinite 3s;pointer-events:none;z-index:-1}@keyframes ascii-stream-down{0%{transform:translateY(-50%)}to{transform:translateY(200%)}}.skills-header-work{display:flex;align-items:center;gap:.75rem;margin-bottom:clamp(3rem,6vw,5rem);font-family:Courier New,Consolas,monospace;color:#ffffffe6}.terminal-prompt{font-size:1rem;color:#00f0ffcc;font-weight:600}.skills-title-work{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:400;letter-spacing:.02em;color:#fffffff2;margin:0}.terminal-cursor{width:10px;height:20px;background:#00f0ffcc;animation:cursor-blink 1.2s step-end infinite}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.skills-column-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3rem 2.5rem;position:relative;z-index:2;padding:0 1rem}.skill-column{position:relative;display:flex;flex-direction:column;gap:1rem}.skill-column-header{font-family:Courier New,Consolas,monospace;font-size:.875rem;font-weight:700;letter-spacing:.15em;color:#fff;margin-bottom:.5rem;text-transform:uppercase;text-shadow:0 0 15px rgba(0,240,255,.4);position:relative;opacity:.95;transition:opacity .18s ease,text-shadow .18s ease}.skill-column-header:hover{opacity:1;text-shadow:0 0 20px rgba(0,240,255,.6)}.skill-list{display:flex;flex-direction:column;gap:.875rem}@media(max-width:1024px){.skills-column-grid{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}.skill-column-header{font-size:.8125rem}}@media(max-width:640px){.skills-column-grid{grid-template-columns:1fr;gap:2rem}.skills-header-work{margin-bottom:2.5rem}.skill-column-header{font-size:.75rem}}.skill-holo-item{position:relative;display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#0f0f14;border:1px solid rgba(0,240,255,.18);font-family:Courier New,Consolas,monospace;cursor:pointer;transition:all .18s cubic-bezier(.25,.8,.25,1);will-change:transform,box-shadow;overflow:visible;z-index:1;animation:skill-float 4s ease-in-out infinite;animation-delay:var(--float-delay, 0s);box-shadow:inset 0 0 20px #00f0ff0a}.skill-scanlines{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(to bottom,transparent,transparent 2px,rgba(0,240,255,.03) 2px,rgba(0,240,255,.03) 4px);background-size:100% 4px;background-repeat:repeat-y;pointer-events:none;opacity:.5;animation:scanline-move 8s linear infinite}@keyframes scanline-move{0%{transform:translateY(0)}to{transform:translateY(4px)}}.skill-holo-item:hover .skill-scanlines,.skill-holo-item.glitch-active .skill-scanlines{opacity:.8;background-size:100% 3px;animation:scanline-glitch .4s linear infinite}@keyframes scanline-glitch{0%,to{transform:translateY(0);opacity:.8}25%{transform:translateY(1px);opacity:.9}50%{transform:translateY(-1px);opacity:.7}75%{transform:translateY(2px);opacity:.85}}.holo-glow-inner,.holo-glow-outer{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;opacity:0;transition:opacity .18s cubic-bezier(.25,.8,.25,1);z-index:-1}.holo-glow-inner{box-shadow:inset 0 0 20px #00f0ff26;border:1px solid rgba(0,240,255,.2)}.holo-glow-outer{box-shadow:0 0 30px #b900ff1f,0 0 60px #00f0ff14}.skill-holo-item:hover .holo-glow-inner,.skill-holo-item.hovered .holo-glow-inner{opacity:1}.skill-holo-item:hover .holo-glow-outer,.skill-holo-item.hovered .holo-glow-outer{opacity:.8;animation:glow-pulse 2s ease-in-out infinite}@keyframes glow-pulse{0%,to{box-shadow:0 0 30px #b900ff1f,0 0 60px #00f0ff14}50%{box-shadow:0 0 40px #b900ff29,0 0 80px #00f0ff1f}}@keyframes skill-float{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.skill-holo-item:hover,.skill-holo-item.hovered{transform:scale(1.025) translateY(-2px) translateZ(15px);background:#0f0f14;border-color:#00f0ff80;box-shadow:0 0 40px #00f0ff59,0 0 75px #b900ff40,0 0 10px #ff00c126,0 8px 35px #0006,inset 0 0 40px #00f0ff26;z-index:10}.skill-holo-item:hover .skill-name-holo,.skill-holo-item.hovered .skill-name-holo{font-weight:600;letter-spacing:.03em}.skill-holo-item:hover{animation:accent-flicker .18s cubic-bezier(.25,.8,.25,1)}@keyframes accent-flicker{0%,to{border-color:#00f0ff80}30%{border-color:#ff00c159}50%{border-color:#b900ff66}70%{border-color:#00baff73}}.skill-ripple{position:absolute;width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,rgba(0,240,255,.4) 0%,rgba(0,240,255,.2) 30%,transparent 70%);pointer-events:none;transform:translate(-50%,-50%);z-index:5}.skill-symbol-start,.skill-symbol-end{font-size:.875rem;color:#00f0ff99;font-weight:600;opacity:.5;transition:all .22s cubic-bezier(.25,.8,.25,1);display:inline-block;animation:symbol-oscillate 3s ease-in-out infinite}.skill-symbol-start{animation-delay:0s}.skill-symbol-end{animation-delay:.15s}@keyframes symbol-oscillate{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}.skill-holo-item:hover .skill-symbol-start,.skill-holo-item:hover .skill-symbol-end,.skill-holo-item.hovered .skill-symbol-start,.skill-holo-item.hovered .skill-symbol-end{color:#00f0fff2;opacity:.95;text-shadow:0 0 8px rgba(0,240,255,.5)}.skill-name-holo{font-size:.9375rem;color:#fff;font-weight:400;letter-spacing:.02em;flex:1;opacity:.92;transition:opacity .22s cubic-bezier(.25,.8,.25,1),font-weight .22s cubic-bezier(.25,.8,.25,1),letter-spacing .22s cubic-bezier(.25,.8,.25,1),text-shadow .22s cubic-bezier(.25,.8,.25,1);position:relative}.skill-holo-item:hover .skill-name-holo,.skill-holo-item.glitch-active .skill-name-holo{opacity:1;text-shadow:0 0 12px rgba(0,240,255,.3)}@keyframes char-glitch{0%,to{transform:translate(0);text-shadow:none}10%{transform:translate(-1px);text-shadow:1px 0 rgba(0,240,255,.5),-1px 0 rgba(185,0,255,.3)}20%{transform:translate(1px);text-shadow:-1px 0 rgba(0,240,255,.5),1px 0 rgba(185,0,255,.3)}30%{transform:translate(-.5px)}40%{transform:translate(.5px)}50%{transform:translate(0);text-shadow:none}}.skill-holo-item.glitch-active .skill-name-holo{animation:char-glitch .3s ease-in-out,micro-flicker .15s step-end 2}@keyframes micro-flicker{0%,to{opacity:1}50%{opacity:.92}}.skill-terminal-label{position:absolute;top:-38px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.375rem;padding:.375rem .875rem;background:#000000f2;border:1px solid rgba(0,240,255,.5);font-size:.6875rem;color:#00f0fff2;letter-spacing:.05em;white-space:nowrap;pointer-events:none;z-index:20;box-shadow:0 0 20px #00f0ff4d,0 0 40px #00f0ff26,inset 0 0 15px #00f0ff14;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.label-text{font-family:Courier New,Consolas,monospace}.label-cursor{width:6px;height:12px;background:#00f0ffe6;animation:cursor-blink 1s step-end infinite}.skill-ascii-animation{position:absolute;right:-45px;top:50%;transform:translateY(-50%);font-family:Courier New,Consolas,monospace;font-size:.875rem;color:#00f0ffd9;font-weight:600;pointer-events:none;z-index:15;text-shadow:0 0 8px rgba(0,240,255,.4);white-space:nowrap}.skill-code-snippet{position:absolute;bottom:-28px;left:0;right:0;font-family:Courier New,Consolas,monospace;font-size:.6875rem;color:#00baffcc;letter-spacing:.02em;pointer-events:none;z-index:15;text-align:center;text-shadow:0 0 8px rgba(0,186,255,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 .5rem}@media(max-width:1024px){.skill-ascii-animation{right:-35px;font-size:.8125rem}.skill-code-snippet{font-size:.625rem;bottom:-24px}}@media(max-width:640px){.skill-ascii-animation{position:static;transform:none;display:inline-block;margin-left:.5rem;font-size:.75rem}.skill-code-snippet{position:static;margin-top:.375rem;font-size:.625rem;text-align:left}}@media(max-width:640px){.skill-terminal-label{position:static;transform:none;margin-top:.5rem;display:inline-flex}}@media(prefers-reduced-motion:reduce){.skill-holo-item{animation:none!important}.terminal-cursor,.label-cursor{animation:none!important;opacity:1}.skill-holo-item:hover{transform:scale(1.02) translateY(-2px)!important;animation:none!important}.skill-symbol-start,.skill-symbol-end,.holo-glow-outer,.skill-ascii-animation,.skill-code-snippet{animation:none!important}.holo-background:before,.holo-background:after{animation:none!important;opacity:.3}.scanlines,.code-stream,.noise-overlay{animation:none!important}.skill-ripple{display:none}.skill-group-label{text-shadow:none!important}}@media(max-width:1024px){.skill-holo-item:hover,.skill-holo-item.hovered{box-shadow:0 0 15px #00f0ff33,0 0 30px #00f0ff1a,inset 0 0 15px #00f0ff0d}.holo-background{opacity:.5}}@media(max-width:640px){.skill-holo-item{padding:.75rem .875rem}.holo-background{opacity:.3}.nano-grid{background-size:20px 20px}}.skills-section:not(.skills-work-mode) .skill-terminal-label{background:#212121eb;border-color:#21212159;color:#fff;box-shadow:0 4px 14px #0000002e,0 0 0 1px #21212114;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);top:-34px;font-size:.65rem;padding:.3rem .7rem;border-radius:4px}.skills-section:not(.skills-work-mode) .label-cursor{background:#ffffffb3}.skills-section:not(.skills-work-mode) .skill-ascii-animation{color:var(--color-text-tertiary, #a8a29e);text-shadow:none;right:-40px;font-size:.8rem}.skills-section:not(.skills-work-mode) .skill-code-snippet{color:var(--color-text-tertiary, #a8a29e);text-shadow:none;font-size:.65rem;bottom:-24px}.skills-section:not(.skills-work-mode) .skill-item.hovered{z-index:10}@media(max-width:640px){.skills-section:not(.skills-work-mode) .skill-terminal-label,.skills-section:not(.skills-work-mode) .skill-ascii-animation,.skills-section:not(.skills-work-mode) .skill-code-snippet{display:none}}.education-section{padding:6rem 0;opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}.education-section.visible{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.education-section{opacity:1;transform:none;transition:none}.education-entry{opacity:1!important;transform:none!important;transition:none!important}.timeline-dot,.education-entry-header,.education-description-text,.education-highlights{transition:none!important}}.education-header{margin-bottom:4rem;max-width:600px}.education-eyebrow{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-secondary, #57534e);font-weight:600;margin-bottom:.75rem}.education-title{font-size:2.5rem;font-weight:700;color:var(--text-primary, #1c1917);margin-bottom:1rem;line-height:1.2}.education-description{font-size:1.1rem;color:var(--text-secondary, #57534e);line-height:1.7}.education-timeline{position:relative}.education-entry{display:grid;grid-template-columns:40px 1fr;gap:2rem;padding-bottom:3rem;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease;transition-delay:var(--entry-delay, 0ms)}.education-section.visible .education-entry{opacity:1;transform:translateY(0)}.education-entry:last-child{padding-bottom:0}.education-timeline-marker{display:flex;flex-direction:column;align-items:center;position:relative}.timeline-dot{width:12px;height:12px;background:var(--bg-secondary, #ffffff);border:2px solid var(--accent, #212121);border-radius:50%;position:relative;z-index:2;transition:all .3s ease}.education-entry:hover .timeline-dot{background:var(--accent, #212121);transform:scale(1.2)}.timeline-line{position:absolute;top:16px;width:2px;height:calc(100% + 3rem - 16px);background:linear-gradient(to bottom,var(--border, #e7e5e4) 0%,var(--border, #e7e5e4) 80%,transparent 100%)}.education-content{padding-bottom:1rem}.education-entry-header{margin-bottom:1rem}.education-meta{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.education-period{font-size:.85rem;font-weight:600;color:var(--text-secondary, #57534e);letter-spacing:.02em}.education-status{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;padding:.25rem .625rem;border-radius:4px;font-weight:600}.education-status.in-progress{background:#21212114;color:var(--accent, #212121)}.education-status.completed{background:#57534e14;color:var(--text-secondary, #57534e)}.education-program{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1c1917);line-height:1.3;margin-bottom:.5rem;transition:color .3s ease}.education-entry:hover .education-program{color:var(--accent, #212121)}.education-institution-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.education-institution{font-size:1rem;color:var(--text-secondary, #57534e);font-weight:500}.education-degree{font-size:.85rem;color:var(--text-secondary, #57534e);padding:.25rem .75rem;background:var(--bg-primary, #fafaf9);border:1px solid var(--border, #e7e5e4);border-radius:4px}.education-description-text{font-size:1rem;color:var(--text-secondary, #57534e);line-height:1.7;margin-bottom:1.25rem}.education-highlights{margin-top:1rem}.highlights-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary, #57534e);font-weight:600;margin-bottom:.75rem}.highlights-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;padding:0;margin:0}.highlight-item{font-size:.85rem;color:var(--text-primary, #1c1917);padding:.5rem 1rem;background:var(--bg-primary, #fafaf9);border:1px solid var(--border, #e7e5e4);border-radius:20px;transition:all .3s ease}.highlight-item:hover{background:var(--accent, #212121);color:#fff;border-color:var(--accent, #212121)}.education-section.compact{padding:0}.education-section.compact .education-header{margin-bottom:1.5rem}.education-section.compact .education-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary, #57534e);font-weight:600}.education-section.compact .education-eyebrow,.education-section.compact .education-description{display:none}.education-section.compact .education-entry{grid-template-columns:1fr;gap:0;padding-bottom:1.5rem}.education-section.compact .education-timeline-marker{display:none}.education-section.compact .education-content{padding:1.5rem;background:var(--bg-primary, #fafaf9);border-radius:12px;border:1px solid var(--border, #e7e5e4);transition:all .3s ease}.education-section.compact .education-content:hover{border-color:var(--accent, #212121)}.education-section.compact .education-program{font-size:1.1rem}.education-section.compact .education-description-text{display:none}.education-section.compact .education-highlights{margin-top:.75rem}@media(max-width:768px){.education-entry{grid-template-columns:24px 1fr;gap:1rem}.education-title{font-size:2rem}.education-program{font-size:1.25rem}.timeline-dot{width:10px;height:10px}.timeline-line{top:14px;height:calc(100% + 3rem - 14px)}}@media(max-width:480px){.education-institution-row{flex-direction:column;align-items:flex-start;gap:.5rem}}.education-title,.contact-title{font-family:var(--font-display);font-weight:600}.education-entry-title{font-family:var(--font-display)}.mode-chaos .education-entry:nth-child(odd){transform:translate(-1%)}.mode-chaos .education-entry:nth-child(2n){transform:translate(1%)}.mode-chaos .timeline-connector{opacity:.3}.mode-work .education-timeline-marker .timeline-dot{background:var(--color-accent);border-color:var(--color-accent)}.mode-work .education-entry{background:#fff9f04d;border-radius:12px;padding:var(--space-6)}.mode-work .education-entry-title{color:var(--color-text)}.mode-work .education-entry:hover{background:#fff9f080;box-shadow:0 4px 12px #d4a5741a}.home{min-height:100vh;display:flex;flex-direction:column}.home-main{flex:1;padding-top:var(--space-32);padding-bottom:var(--space-24)}.home-hero{margin-bottom:clamp(6rem,12vw,12rem);padding-top:clamp(4rem,10vw,8rem);padding-bottom:clamp(4rem,8vw,6rem);max-width:none;position:relative}.hero-content-terminal,.hero-ctas-terminal{display:none}.hero-content{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(3rem,6vw,6rem);align-items:start;position:relative;z-index:1}.hero-letter{display:inline-block;will-change:transform,opacity}.magnetic-active .home-hero-title{letter-spacing:-.06em}.hero-left{display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,1.5rem)}.home-hero-title{font-size:clamp(3.5rem,10vw,8rem);font-weight:700;font-family:var(--font-display);letter-spacing:-.05em;margin:0;color:var(--color-text);line-height:.92;will-change:transform;transition:letter-spacing .4s ease}.home-hero-subtitle{font-size:clamp(1rem,1.5vw,1.125rem);line-height:1.8;color:var(--color-text-secondary);max-width:480px;font-weight:300}.hero-right{display:flex;flex-direction:column;gap:1.25rem;padding-top:clamp(.5rem,2vw,1.5rem)}.hero-system-label{font-family:Courier New,Consolas,monospace;font-size:.6875rem;font-weight:400;letter-spacing:.08em;color:var(--color-text-tertiary);white-space:nowrap}.hero-primary-cta{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;min-width:280px;background-color:var(--color-accent, #212121);color:var(--color-bg, #fff);font-size:.9375rem;font-weight:500;letter-spacing:.01em;text-decoration:none;border-radius:4px;border:none;box-shadow:0 1px 3px #0000001f,0 4px 12px #00000014;transition:box-shadow .22s cubic-bezier(.4,0,.2,1);cursor:pointer;white-space:nowrap;align-self:flex-start;will-change:transform}.hero-primary-cta:hover{box-shadow:0 2px 8px #0000002e,0 10px 28px #00000024,0 0 0 3px #2121210f}.magnetic-active .hero-primary-cta{box-shadow:0 2px 6px #00000024,0 6px 18px #0000001a}.hero-primary-cta:active{transform:scale(.99)}.cta-text{display:inline-block;min-width:240px;text-align:center;font-family:inherit;transition:none}.hero-primary-cta .cta-text{font-variant-ligatures:none}.hero-inline-links{display:flex;flex-wrap:wrap;gap:.25rem 1.25rem;align-items:center}.hero-inline-link{font-size:.8125rem;font-weight:400;color:var(--color-text-secondary);text-decoration:none;position:relative;padding:.25rem 0;transition:color .2s ease,transform .2s ease}.hero-inline-link:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--color-accent, #212121);transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.4,0,.2,1)}.hero-inline-link:hover{color:var(--color-accent, #212121);transform:translate(5px)}.hero-inline-link:hover:after{transform:scaleX(1)}.home-projects{margin-top:clamp(6rem,12vw,12rem);margin-bottom:clamp(6rem,12vw,12rem)}.home-projects-header-terminal,.projects-list-terminal{display:none}.home-projects-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:clamp(4rem,8vw,8rem);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}.home-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-tertiary)}.home-section-subtitle{font-size:.6875rem;color:var(--color-text-tertiary);font-weight:400;font-variant-numeric:tabular-nums;letter-spacing:.05em}.projects-container{position:relative;margin-top:0}.projects-explorer{display:grid;grid-template-columns:300px 1fr;gap:0;align-items:start}.projects-folders{display:flex;flex-direction:column;gap:0;border-right:1px solid var(--color-border, rgba(0, 0, 0, .08));padding-right:0}.folder-item-link{display:block;text-decoration:none;color:inherit;position:relative}.folder-item{position:relative;background:transparent;padding:1rem 1.25rem 1rem 1.5rem;cursor:pointer;border:none;border-bottom:1px solid rgba(0,0,0,.04);transition:background .2s ease,box-shadow .2s ease,opacity .2s ease}.folder-item:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 3px 3px 0;background:transparent;transition:background .2s ease}.folder-tab{display:flex;align-items:baseline;gap:0;margin:0;padding:0;border:none;background:none;border-radius:0}.folder-tab-label{font-size:.9375rem;font-weight:600;letter-spacing:-.01em;color:var(--color-text);line-height:1.35}.folder-body{padding:.25rem 0 0;display:flex;flex-direction:column;gap:.25rem}.folder-meta{display:flex;align-items:center;gap:.325rem;font-size:.625rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary)}.folder-category{font-weight:600}.folder-dot{opacity:.3;font-weight:300}.folder-year{font-weight:400;font-variant-numeric:tabular-nums}.folder-index{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:400;opacity:.4;font-size:.5625rem;letter-spacing:.06em}.folder-description{font-size:.75rem;line-height:1.5;color:var(--color-text-secondary);opacity:.7;margin:0;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.folder-item:hover{background:#00000005}.folder-item:hover:before{background:var(--color-text-tertiary)}.folder-active{background:#00000008}.folder-active:before{background:var(--color-accent, #212121)!important}.folder-active .folder-tab-label{color:var(--color-accent, #212121)}.folder-dimmed{opacity:.45}.projects-preview{position:sticky;top:clamp(80px,10vw,120px);align-self:start;padding-left:clamp(24px,3vw,48px)}.preview-window{border:1px solid rgba(0,0,0,.08);border-radius:10px;overflow:hidden;background:var(--color-bg, #fff);box-shadow:0 2px 12px #0000000a}.preview-window-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid rgba(0,0,0,.06);background:#00000004}.preview-window-dot{width:8px;height:8px;border-radius:50%;background:#00000014}.preview-window-title{margin-left:8px;font-size:.6875rem;font-weight:500;color:var(--color-text-tertiary);letter-spacing:.01em}.preview-window-body{position:relative;min-height:320px;max-height:520px;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-window-content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.preview-window-content .preview-media-reveal{position:relative!important;top:auto!important;right:auto!important;width:100%!important;max-width:100%}.preview-window-content .preview-scatter-container{width:100%;height:100%;min-height:480px}.preview-window-content .preview-image,.preview-window-content .preview-video{width:100%;height:auto;max-height:480px;object-fit:contain;border-radius:0}.preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 2rem;width:100%;min-height:320px}.preview-empty-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(0,0,0,.06) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.preview-empty-text{position:relative;z-index:1;font-size:.6875rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-tertiary);opacity:.5}.projects-list-terminal{display:none}.preview-area-absolute{position:absolute;top:0;right:0;width:50%;min-height:100vh;pointer-events:none}@media(max-width:1024px){.home-hero{gap:var(--space-12)}.hero-content{grid-template-columns:1fr;gap:var(--space-8)}.home-hero-title{font-size:clamp(2.5rem,8vw,4rem)}.home-hero-subtitle{max-width:100%}.hero-right{padding-top:0}.projects-explorer{grid-template-columns:1fr;gap:0}.projects-folders{border-right:none;border-bottom:1px solid var(--color-border, rgba(0, 0, 0, .08));padding-bottom:.5rem}.projects-preview{position:relative;top:0;padding-left:0;padding-top:1.5rem}.preview-window-body{min-height:240px}.preview-area-absolute{display:none}}@media(max-width:640px){.home-main{padding-top:var(--space-12);padding-bottom:var(--space-12)}.home-hero{padding-top:var(--space-12);padding-bottom:var(--space-12);margin-bottom:var(--space-16)}.home-hero-title{font-size:2.5rem}.home-hero-subtitle{font-size:1rem}.hero-right{align-items:stretch}.hero-primary-cta{align-self:stretch;justify-content:center;min-width:0}.cta-text{min-width:0}.hero-inline-links{justify-content:center}.home-projects{margin-top:var(--space-16);margin-bottom:var(--space-16)}.home-projects-header{flex-direction:column;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-12)}.projects-preview{display:none}.folder-item{padding:.75rem 1rem .75rem 1.25rem}.folder-description{display:none}}@media(prefers-reduced-motion:reduce){.hero-letter{opacity:1!important;transform:none!important}.home-hero-title{letter-spacing:-.05em!important;transition:none!important}.hero-primary-cta{transform:none!important}}.home-loading{display:flex;justify-content:center;align-items:center;min-height:400px}.loading-spinner{width:32px;height:32px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%}.home-footer{margin-top:clamp(8rem,12vw,12rem);padding:var(--space-12) 0 var(--space-8) 0;border-top:1px solid var(--color-border)}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-links{display:flex;gap:var(--space-8)}.footer-link{font-size:.8125rem;color:var(--color-text-secondary);transition:color var(--duration-base) var(--ease-smooth);letter-spacing:.01em}.footer-link:hover{color:var(--color-text)}.footer-copyright{font-size:var(--font-size-sm);color:var(--color-text-tertiary);letter-spacing:.01em}@media(max-width:768px){.footer-content{flex-direction:column;gap:var(--space-4);text-align:center}.footer-links{flex-direction:column;gap:var(--space-3)}}.home-hero-title{font-family:var(--font-display);font-weight:700}.mode-chaos .home-hero-title{animation:wiggle 3s ease-in-out infinite}.mode-chaos .home-hero{padding-top:clamp(6rem,12vw,10rem)}.mode-chaos .home-projects-header{border-bottom:none}.mode-chaos .folder-item:hover{background:#00000006;transform:translate(2px)}.mode-chaos .folder-active{transform:translate(2px)}.mode-work .home-hero-title{font-size:clamp(2.5rem,7vw,5.5rem);line-height:1;letter-spacing:-.04em;margin-bottom:1.5rem;font-weight:700}.mode-work .home-hero-subtitle{max-width:580px;font-size:.9rem;line-height:1.65;opacity:.85}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-.5deg)}75%{transform:rotate(.5deg)}}.mode-chaos .hero-primary-cta:hover{transform:scale(1.02) rotate(1deg)}.mode-work .home-section-title{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:clamp(3rem,5vw,4rem);color:var(--color-text)}.mode-work .hero-content-default,.mode-work .hero-ctas-default{display:none}.mode-work .hero-content-terminal,.mode-work .hero-ctas-terminal{display:block}.mode-work .home-hero{background:#0a0a12;border:1px solid rgba(0,240,255,.2);padding:clamp(3rem,6vw,5rem) clamp(2rem,5vw,4rem);margin-bottom:clamp(4rem,8vw,8rem);margin-top:-2rem;position:relative;overflow:hidden}.mode-work .home-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:#00f0ff26}.terminal-line{font-family:Courier New,Consolas,monospace;font-size:clamp(.9rem,1.5vw,1.125rem);line-height:1.8;color:#ffffffe6;margin-bottom:.25rem;letter-spacing:.02em}.terminal-prompt{color:#00f0ffcc;font-weight:600;margin-right:.5rem}.terminal-text{color:#fff;font-weight:500}.terminal-label{color:#ffffff80;font-weight:400;min-width:90px;display:inline-block}.terminal-value{color:#ffffffd9;font-weight:400}.terminal-cursor{font-family:Courier New,Consolas,monospace;font-size:clamp(.9rem,1.5vw,1.125rem);color:#00f0ffe6;margin-left:.25rem;display:inline-block}.hero-ctas-terminal{display:flex;gap:clamp(1rem,2vw,1.5rem);align-items:center;margin-top:clamp(2rem,4vw,3rem);flex-wrap:wrap}.terminal-cta-link{font-family:Courier New,Consolas,monospace;font-size:.875rem;color:#ffffffb3;text-decoration:none;position:relative;padding:.125rem 0;transition:all .15s cubic-bezier(.2,.8,.2,1);letter-spacing:.02em}.terminal-cta-link:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:#00f0ffcc;transform:scaleX(0);transform-origin:left;transition:transform .15s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 8px #00f0ff66}.terminal-cta-link:hover{color:#fff;transform:translate(3px)}.terminal-cta-link:hover:after{transform:scaleX(1)}.terminal-separator{font-family:Courier New,Consolas,monospace;font-size:.875rem;color:#ffffff4d;-webkit-user-select:none;user-select:none}.mode-chaos .hero-content-terminal,.mode-chaos .hero-ctas-terminal{display:none}.mode-chaos .hero-content-default{display:grid}@media(max-width:768px){.mode-work .home-hero{padding:2rem 1.5rem;margin-top:0}.terminal-line{font-size:.8125rem}.terminal-label{min-width:70px}.hero-ctas-terminal{gap:.75rem}.terminal-cta-link{font-size:.75rem}}@media(prefers-reduced-motion:reduce){.terminal-cursor{animation:none!important;opacity:.7!important}.terminal-cta-link{transition:none!important}.terminal-cta-link:hover{transform:none!important}}.mode-work .home-projects-header-default{display:none}.mode-work .home-projects-header-terminal{display:block;font-family:Courier New,Consolas,monospace;font-size:clamp(.9rem,1.5vw,1.125rem);line-height:1.8;color:#ffffffe6;margin-bottom:clamp(2rem,4vw,3rem);padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,.08)}.mode-work .terminal-count{color:#ffffff80;font-size:.875rem;margin-left:.5rem}.mode-work .projects-explorer-default{display:none}.mode-work .projects-list-terminal{display:flex;flex-direction:column;gap:0}.mode-work .home-projects{background:#0a0a0a;background:linear-gradient(135deg,#0f0f0f,#0a0a0a);border:1px solid rgba(255,255,255,.08);padding:clamp(2rem,4vw,3rem) clamp(2rem,5vw,4rem);margin-top:clamp(4rem,8vw,6rem);position:relative}.mode-work .home-projects:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%)}.terminal-project-entry{padding:clamp(.5rem,1vw,.75rem) 0;border-bottom:1px solid rgba(255,255,255,.04);transition:all .16s cubic-bezier(.2,.8,.2,1)}.terminal-project-entry:last-child{border-bottom:none}.terminal-project-entry:hover{background:#ffffff05;padding-left:.5rem}.terminal-project-link{display:flex;align-items:center;gap:clamp(1rem,2vw,1.5rem);font-family:Courier New,Consolas,monospace;text-decoration:none;color:inherit;position:relative}.terminal-project-number{font-size:.8125rem;color:#ffffff80;font-weight:400;letter-spacing:.05em;min-width:2.5rem;transition:opacity .16s cubic-bezier(.2,.8,.2,1)}.terminal-project-title{font-size:clamp(1rem,2vw,1.25rem);color:#ffffffd9;font-weight:400;letter-spacing:.02em;flex:0 0 auto;min-width:200px;transition:all .16s cubic-bezier(.2,.8,.2,1)}.terminal-project-status{font-size:.75rem;color:#fff6;font-weight:400;letter-spacing:.05em;margin-left:auto;transition:opacity .16s cubic-bezier(.2,.8,.2,1)}.terminal-project-indicator{font-size:.75rem;color:#ffffff80;font-weight:400;letter-spacing:.05em;transition:opacity .16s cubic-bezier(.2,.8,.2,1)}.terminal-project-cursor{font-size:clamp(1rem,2vw,1.25rem);color:#fff9;margin-left:.25rem}.mode-work .preview-media-reveal{transition:all .15s cubic-bezier(.2,.8,.2,1)}.mode-chaos .home-projects-header-terminal{display:none}.mode-chaos .home-projects-header-default{display:flex}.mode-chaos .projects-list-terminal{display:none}.mode-chaos .projects-list-default{display:flex}@media(max-width:768px){.mode-work .home-projects{padding:1.5rem 1rem;margin-top:2rem}.mode-work .home-projects-header-terminal{font-size:.8125rem;margin-bottom:1.5rem;padding:1rem 0}.terminal-project-link{flex-wrap:wrap;gap:.5rem}.terminal-project-title{font-size:.9375rem;min-width:auto;flex:1 1 100%}.terminal-project-status,.terminal-project-indicator{font-size:.6875rem}.terminal-project-status{margin-left:0}}@media(prefers-reduced-motion:reduce){.terminal-project-entry,.terminal-project-number,.terminal-project-title,.terminal-project-status,.terminal-project-indicator{transition:none!important}.terminal-project-cursor{animation:none!important;opacity:.6!important}.terminal-project-entry:hover{padding-left:0}}.mode-work .section-title{font-weight:700;font-size:1.5rem;letter-spacing:-.03em}.sections-container{max-width:900px;margin:0 auto;padding:0 3rem}@media(max-width:768px){.sections-container{padding:0 1.5rem}}.section-divider{height:1px;background:linear-gradient(to right,transparent,var(--border, #e7e5e4) 20%,var(--border, #e7e5e4) 80%,transparent);margin:2rem 0}.section-wrapper{position:relative}.section-wrapper+.section-wrapper{margin-top:2rem}.section-wrapper:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--border, #e7e5e4) 10%,var(--border, #e7e5e4) 90%,transparent)}.section-wrapper:first-child:before{display:none}.floating-sections{display:grid;grid-template-columns:1fr;gap:6rem;padding:4rem 0}@media(min-width:1200px){.floating-sections.two-column{grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.floating-sections.two-column>*:nth-child(2){position:sticky;top:2rem}}.staggered-layout{display:flex;flex-direction:column;gap:8rem}.staggered-layout>*:nth-child(odd){align-self:flex-start;max-width:85%}.staggered-layout>*:nth-child(2n){align-self:flex-end;max-width:85%}@media(max-width:768px){.staggered-layout>*:nth-child(odd),.staggered-layout>*:nth-child(2n){max-width:100%;align-self:stretch}.staggered-layout{gap:5rem}}.section-full-width{margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding-left:calc(50vw - 50%);padding-right:calc(50vw - 50%);background:var(--bg-secondary, #ffffff);border-top:1px solid var(--border, #e7e5e4);border-bottom:1px solid var(--border, #e7e5e4)}.section-accent-bg{background:var(--bg-primary, #fafaf9);padding:4rem 3rem;border-radius:24px;margin:2rem 0}@media(max-width:768px){.section-accent-bg{padding:2.5rem 1.5rem;border-radius:16px}}.scroll-reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}.scroll-reveal.revealed{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.scroll-reveal{opacity:1;transform:none;transition:none}}.mode-work .skills-section:before{content:"[technical_capabilities]";display:block;font-size:.65rem;font-weight:700;color:var(--color-system-label);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1.5rem;opacity:.6}.mode-work .skills-section{border-top:1px solid var(--color-border);padding-top:3rem}.mode-work .skills-title{font-weight:700;letter-spacing:-.03em}.mode-work .skills-eyebrow{color:var(--color-system-label);text-transform:uppercase;font-size:.7rem;letter-spacing:.12em;font-weight:700}.mode-work .skill-card{background:var(--color-module-bg);border:1px solid var(--color-border);padding:1.5rem;transition:all .12s cubic-bezier(.4,0,.2,1)}.mode-work .skill-card:hover{border-color:var(--color-accent)}.mode-work .skill-category{display:inline-block;background:transparent;border:1px solid var(--color-border);color:var(--color-system-label);padding:.25rem .75rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}.mode-work .skill-list{list-style:none;padding:0}.mode-work .skill-item{color:var(--color-text-secondary);font-size:.875rem;padding:.375rem 0;border-bottom:1px solid var(--color-border-light);transition:all .1s cubic-bezier(.4,0,.2,1)}.mode-work .skill-item:last-child{border-bottom:none}.mode-work .skill-item:hover{color:var(--color-accent);padding-left:.5rem}.mode-work .skill-item:before{content:">";margin-right:.5rem;opacity:0;transition:opacity .1s cubic-bezier(.4,0,.2,1)}.mode-work .skill-item:hover:before{opacity:1}.mode-work .education-section:before{content:"[credentials_database]";display:block;font-family:Courier New,Consolas,monospace;font-size:.65rem;font-weight:700;color:#00f0ffb3;text-transform:uppercase;letter-spacing:.15em;margin-bottom:1.5rem;opacity:.6}.mode-work .education-section{border-top:1px solid rgba(0,240,255,.15);padding-top:3rem}.mode-work .education-title{font-family:Courier New,Consolas,monospace;font-weight:700;letter-spacing:-.03em;color:#fff}.mode-work .education-eyebrow{font-family:Courier New,Consolas,monospace;color:#00f0ffb3;text-transform:uppercase;font-size:.7rem;letter-spacing:.12em;font-weight:700}.mode-work .education-timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;position:relative}@media(max-width:768px){.mode-work .education-timeline{grid-template-columns:1fr;gap:1.5rem}}.mode-work .education-timeline-marker{display:none}.mode-work .education-entry{display:block;padding-bottom:0}.mode-work .education-content{background:#0f0f14;border:1px solid rgba(0,240,255,.2);padding:1.5rem;transition:all .15s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;animation:edu-float 4s ease-in-out infinite;animation-delay:calc(var(--entry-delay, 0ms) * .5)}@keyframes edu-float{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.mode-work .education-content:hover{border-color:#00f0ff80;box-shadow:0 0 20px #00f0ff26,inset 0 0 20px #00f0ff0d;transform:translateY(-3px)}.mode-work .education-content:before{content:">>";position:absolute;top:1rem;right:1rem;font-family:Courier New,Consolas,monospace;font-size:.75rem;color:#00f0ff99;opacity:0;transition:opacity .15s cubic-bezier(.4,0,.2,1)}.mode-work .education-content:hover:before{opacity:1}.mode-work .education-status{font-family:Courier New,Consolas,monospace;background:transparent;border:1px solid rgba(0,240,255,.3);color:#00f0ffd9;font-size:.625rem;padding:.25rem .5rem;letter-spacing:.08em;border-radius:2px;text-transform:uppercase}.mode-work .education-status.in-progress{border-color:#00f0ff66;color:#00f0fff2}.mode-work .education-period{font-family:Courier New,Consolas,monospace;color:#fff9;font-size:.7rem;letter-spacing:.05em}.mode-work .education-program{font-family:Courier New,Consolas,monospace;font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:#fff;margin-bottom:.75rem;margin-top:.75rem}.mode-work .education-institution{font-family:Courier New,Consolas,monospace;color:#00f0ffd9;font-size:.8rem;font-weight:600;letter-spacing:.05em}.mode-work .education-degree{font-family:Courier New,Consolas,monospace;background:transparent;border:1px solid rgba(0,240,255,.25);color:#00f0ffbf;padding:.25rem .625rem;font-size:.65rem;font-weight:600;letter-spacing:.08em;border-radius:2px}.mode-work .education-description-text{font-family:Courier New,Consolas,monospace;color:#ffffffa6;font-size:.8rem;line-height:1.7;margin-top:1rem;margin-bottom:1rem}.mode-work .highlights-label{font-family:Courier New,Consolas,monospace;color:#00f0ffb3;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:.75rem}.mode-work .highlight-item{font-family:Courier New,Consolas,monospace;background:transparent;border:1px solid rgba(0,240,255,.2);color:#ffffffb3;padding:.375rem .75rem;font-size:.7rem;border-radius:2px;transition:all .15s cubic-bezier(.4,0,.2,1);letter-spacing:.05em}.mode-work .highlight-item:hover{border-color:#00f0ff80;color:#fff;background:#00f0ff0d;box-shadow:0 0 10px #00f0ff26}@media(prefers-reduced-motion:reduce){.mode-work .education-content{animation:none!important}.mode-work .education-content:hover{transform:none!important}}.pivot-section{margin-top:var(--space-12)}.pivot-block{margin-bottom:var(--space-12)}.pivot-block:last-child{margin-bottom:0}.pivot-divider{border:none;height:1px;background:var(--color-border);opacity:.3;margin:0;max-width:560px}.process-timeline-track{display:flex;align-items:flex-start;width:100%;max-width:560px;position:relative;margin-bottom:var(--space-8)}.process-timeline-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;padding:0 var(--space-3)}.process-timeline-dot{width:7px;height:7px;border-radius:50%;background-color:var(--color-border);opacity:.35;flex-shrink:0;position:relative;z-index:1}.process-timeline-step.is-active .process-timeline-dot{width:11px;height:11px;opacity:1;background-color:var(--color-accent);box-shadow:0 0 0 4px #21212112}[data-theme=dark] .process-timeline-step.is-active .process-timeline-dot{box-shadow:0 0 0 4px #fafafa14}.process-timeline-connector{position:absolute;top:3px;left:calc(50% + 4px);width:calc(100% - 7px);height:1px;background-color:var(--color-border);opacity:.25}.process-timeline-step.is-active .process-timeline-connector{top:5px}.process-timeline-label{margin-top:var(--space-3);font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-tertiary);opacity:.4;text-align:center;line-height:1.3;font-weight:400}.process-timeline-step.is-active .process-timeline-label{color:var(--color-text);font-weight:600;opacity:1}.graveyard-heading{font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-8)}.graveyard-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8);max-width:900px}.graveyard-item{font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary)}.graveyard-reflection{font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary);max-width:900px}@media(max-width:600px){.pivot-section{margin-top:var(--space-10)}.pivot-block{margin-bottom:var(--space-8)}.process-timeline-track{flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.process-timeline-step{flex-direction:row;align-items:center;gap:var(--space-3);padding:0}.process-timeline-connector{top:7px;left:3px;width:1px;height:calc(100% + var(--space-4))}.process-timeline-step.is-active .process-timeline-connector{top:11px;left:5px}.process-timeline-label{margin-top:0;text-align:left}}.pvt-stack{display:flex;flex-direction:column;gap:var(--space-10, 40px);margin-top:var(--space-8)}.pvt-card{display:flex;flex-direction:column;max-width:900px;width:100%}.pvt-viewport{position:relative;width:100%;aspect-ratio:16 / 10;border-radius:16px;overflow:hidden;cursor:pointer;border:1.5px solid rgba(0,0,0,.06);background:var(--color-bg-secondary, #f5f5f5);margin-bottom:var(--space-5, 20px);padding:0;font:inherit;color:inherit;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;transition:transform .25s ease,box-shadow .25s ease,border-color .35s ease;box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a}.pvt-viewport:hover{transform:translateY(-4px);box-shadow:0 2px 8px #0000000d,0 8px 28px #00000012}.pvt-viewport:active{transform:translateY(-2px) scale(.985);transition-duration:.1s}.pvt-viewport:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.pvt-viewport[data-after]{border-color:color-mix(in srgb,var(--color-accent) 25%,transparent);animation:pvt-border-settle .8s ease-out forwards}.pvt-viewport:not([data-after]){border-color:#00000014;animation:none}@keyframes pvt-border-settle{0%{box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a,0 0 color-mix(in srgb,var(--color-accent) 0%,transparent)}35%{box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a,0 0 0 6px color-mix(in srgb,var(--color-accent) 8%,transparent)}to{box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a,0 0 0 1px color-mix(in srgb,var(--color-accent) 18%,transparent)}}.pvt-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:12px}.pvt-layer--before{z-index:1;filter:grayscale(.2)}.pvt-layer--after{z-index:2}.pvt-svg{display:block;width:100%;height:auto;border-radius:6px}.pvt-svg-bg{fill:var(--color-bg-secondary, #f5f5f5)}.pvt-cta{fill:var(--color-accent)}.pvt-indicator{position:absolute;top:12px;right:14px;z-index:5;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);opacity:.6;pointer-events:none;transition:opacity .2s ease;line-height:1}.pvt-viewport:hover .pvt-indicator{opacity:.85}.pvt-text{padding:0 var(--space-1, 4px);min-height:80px}.pvt-title{font-size:clamp(1.05rem,1.3vw,1.2rem);font-weight:600;line-height:1.4;color:var(--color-text);letter-spacing:-.01em;margin:0 0 var(--space-2, 8px) 0}.pvt-desc{font-size:clamp(1rem,1.1vw,1.1rem);line-height:1.7;color:var(--color-text-secondary);margin:0;max-width:620px}[data-theme=dark] .pvt-viewport{background:var(--color-bg-secondary, #1a1a1a);border-color:#ffffff0f;box-shadow:0 1px 3px #00000026,0 4px 16px #0000001f}[data-theme=dark] .pvt-viewport:hover{box-shadow:0 2px 8px #0003,0 8px 28px #0000002e}[data-theme=dark] .pvt-viewport[data-after]{border-color:color-mix(in srgb,var(--color-accent) 20%,transparent)}[data-theme=dark] .pvt-viewport:not([data-after]){border-color:#ffffff0f}[data-theme=dark] .pvt-svg-bg{fill:var(--color-bg-secondary, #1a1a1a)}[data-theme=dark] .pvt-layer--before{filter:grayscale(.15)}@media(prefers-reduced-motion:reduce){.pvt-viewport,.pvt-layer,.pvt-indicator{transition:none!important;animation:none!important}.pvt-viewport:hover,.pvt-viewport:active{transform:none}}@media(max-width:768px){.pvt-stack{gap:var(--space-8)}.pvt-viewport{aspect-ratio:4 / 3;border-radius:12px}.pvt-viewport:hover{transform:none}.pvt-viewport:active{transform:scale(.985)}.pvt-indicator{top:10px;right:10px;font-size:.7rem}.pvt-title{font-size:clamp(1rem,3.5vw,1.15rem)}}.wl{margin-top:var(--space-16);margin-bottom:var(--space-24)}.wl-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-4);font-weight:500}.wl-title{font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-8);max-width:900px}.wl-caption{margin-top:var(--space-8);font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary);max-width:900px}.wl-arrow-icon{opacity:.5;flex-shrink:0}.wl-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);min-height:240px;width:100%;border:1.5px dashed var(--color-border);border-radius:8px;background:var(--color-bg-secondary);padding:var(--space-8)}.wl-ph--before{opacity:.6;filter:grayscale(.5)}.wl-ph-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2)}.wl-ph-pill{padding:3px var(--space-3);border:1px solid var(--color-border);border-radius:4px;font-size:11px;color:var(--color-text-tertiary)}.wl-ph--before .wl-ph-pill{text-decoration:line-through;text-decoration-color:var(--color-border)}.wl-ph-hint{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);opacity:.6;margin-top:var(--space-2)}.wl-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:start;width:100%;max-width:900px}.wl-side{display:flex;flex-direction:column;gap:var(--space-4)}.wl-side-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-3);font-weight:500}.wl-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.wl-pill{display:inline-block;border-radius:5px;line-height:1.4}.wl-pill--muted{padding:3px var(--space-3);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:11px;text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:var(--color-border);opacity:.7}.wl-pill--primary{padding:var(--space-4) var(--space-6);background-color:var(--color-accent);color:var(--color-bg);font-weight:600;font-size:var(--font-size-lg);letter-spacing:-.01em;border-radius:6px}.wl-pill--secondary{padding:var(--space-1) var(--space-3);background-color:transparent;color:var(--color-text-tertiary);border:1px solid var(--color-border);font-size:11px;opacity:.55}.wl-sbs{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);max-width:900px;width:100%}.wl-sbs-col{display:flex;flex-direction:column;gap:0}.wl-sbs-tag{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);font-weight:500;margin-bottom:var(--space-3)}.wl-sbs-frame{border-radius:8px;overflow:hidden;background:var(--color-bg-secondary)}.wl-sbs-frame--muted{filter:grayscale(.65) brightness(1.05);opacity:.7;border:1px solid var(--color-border)}.wl-sbs-img{display:block;width:100%;height:auto;object-fit:cover}.wl-sbs-captions{list-style:none;padding:0;margin:var(--space-4) 0 0;display:flex;flex-direction:column;gap:var(--space-1)}.wl-sbs-caption{font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-secondary);padding-left:var(--space-3);position:relative}.wl-sbs-caption:before{content:"·";position:absolute;left:0;color:var(--color-text-tertiary)}.wl-sbs-caption--muted{text-decoration:line-through;text-decoration-color:var(--color-border);opacity:.6}.wl-sbs-caption--primary{font-weight:600;color:var(--color-text);text-decoration:none;opacity:1}.wl-sbs-caption--secondary{opacity:.6}.wl-stack{display:flex;flex-direction:column;gap:0;max-width:900px;width:100%}.wl-stack-block{display:flex;flex-direction:column}.wl-stack-tag{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);font-weight:500;margin-bottom:var(--space-3)}.wl-stack-frame{border-radius:8px;overflow:hidden;background:var(--color-bg-secondary)}.wl-stack-frame--muted{filter:grayscale(.6) brightness(1.05);opacity:.75;border:1px solid var(--color-border)}.wl-stack-img{display:block;width:100%;height:auto;object-fit:cover}.wl-stack-summary{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-tertiary);margin-top:var(--space-3);margin-bottom:0}.wl-stack-summary--primary{color:var(--color-text);font-weight:600;font-size:var(--font-size-base)}.wl-stack-divider{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6) 0;transform-origin:left center}.wl-stack-divider-line{flex:1;height:1px;background:var(--color-border)}.wl-stack-divider-arrow{color:var(--color-text-tertiary);flex-shrink:0;opacity:.5}.wl-slider{max-width:900px;width:100%}.wl-slider-box{position:relative;border-radius:8px;overflow:hidden;cursor:ew-resize;user-select:none;-webkit-user-select:none;background:var(--color-bg-secondary)}.wl-slider-layer{width:100%}.wl-slider-layer img,.wl-slider-layer .wl-ph{display:block;width:100%;height:100%;object-fit:cover}.wl-slider-layer--before{position:relative}.wl-slider-layer--before img{filter:grayscale(.6) brightness(1.05)}.wl-slider-layer--after{position:absolute;top:0;left:0;height:100%;will-change:clip-path}.wl-slider-tag{position:absolute;bottom:var(--space-4);font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;padding:4px 10px;border-radius:4px;pointer-events:none}.wl-slider-tag--left{left:var(--space-4);background:#0000008c;color:#fff}.wl-slider-tag--right{right:var(--space-4);background:var(--color-accent);color:var(--color-bg)}.wl-slider-divider{position:absolute;top:0;bottom:0;width:2px;background:#fff;transform:translate(-50%);pointer-events:none;z-index:2;box-shadow:0 0 6px #00000026}.wl-slider-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0003;display:flex;align-items:center;justify-content:center;color:var(--color-text);pointer-events:auto;cursor:ew-resize;animation:wl-pulse 2.5s ease-in-out 1s 3}@keyframes wl-pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}.wl-slider-range{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:3;margin:0}.wl-slider-captions{display:flex;justify-content:space-between;margin-top:var(--space-4);padding:0 var(--space-2)}.wl-slider-cap{font-size:var(--font-size-sm);color:var(--color-text-tertiary);max-width:45%}.wl-slider-cap--primary{text-align:right;color:var(--color-text);font-weight:600}@media(max-width:640px){.wl{margin-top:var(--space-12)}.wl-title{margin-bottom:var(--space-8)}.wl-grid{grid-template-columns:1fr;gap:var(--space-4)}.wl-sbs{grid-template-columns:1fr;gap:var(--space-6)}.wl-ph{min-height:180px}.wl-caption{margin-top:var(--space-8)}.wl-slider-captions{flex-direction:column;gap:var(--space-2)}.wl-slider-cap{max-width:100%}.wl-slider-cap--primary{text-align:left}}.sht-container{position:relative}.sht-token{position:relative;display:inline;transition:color .21s cubic-bezier(.22,1,.36,1),opacity .21s cubic-bezier(.22,1,.36,1),font-weight .21s cubic-bezier(.22,1,.36,1),letter-spacing .21s cubic-bezier(.22,1,.36,1)}.sht-token-text{position:relative;z-index:1}.sht-token-underline{position:absolute;bottom:-1px;left:0;right:0;height:1.5px;border-radius:1px;transform-origin:left center;pointer-events:none}.sht-token--stepped{color:var(--color-text-tertiary);font-weight:400;letter-spacing:0em}.sht-token--stepped .sht-token-underline{background:transparent;transform:scaleX(0);transition:transform .21s cubic-bezier(.22,1,.36,1),background-color .21s cubic-bezier(.22,1,.36,1)}.sht-token--stepped.sht-token--active{font-weight:500;letter-spacing:-.01em}.sht-token--stepped.sht-token--active .sht-token-underline{transform:scaleX(1)}.sht-token--stepped.sht-token--active.sht-accent--auto{color:var(--color-text)}.sht-token--stepped.sht-token--active.sht-accent--auto .sht-token-underline{background:color-mix(in srgb,var(--color-accent) 25%,transparent)}.sht-token--stepped.sht-token--active.sht-accent--text{color:var(--color-text)}.sht-token--stepped.sht-token--active.sht-accent--text .sht-token-underline{background:color-mix(in srgb,var(--color-text) 18%,transparent)}.sht-token--stepped.sht-token--active.sht-accent--accent{color:var(--color-accent)}.sht-token--stepped.sht-token--active.sht-accent--accent .sht-token-underline{background:color-mix(in srgb,var(--color-accent) 30%,transparent)}.sht-token--smooth{--sht-reveal: 0}.sht-token--smooth.sht-accent--auto{color:color-mix(in srgb,var(--color-text-tertiary) calc((1 - var(--sht-reveal)) * 100%),var(--color-text) calc(var(--sht-reveal) * 100%))}.sht-token--smooth.sht-accent--auto .sht-token-underline{background:color-mix(in srgb,var(--color-accent) 25%,transparent)}.sht-token--smooth.sht-accent--text{color:color-mix(in srgb,var(--color-text-tertiary) calc((1 - var(--sht-reveal)) * 100%),var(--color-text) calc(var(--sht-reveal) * 100%))}.sht-token--smooth.sht-accent--text .sht-token-underline{background:color-mix(in srgb,var(--color-text) 18%,transparent)}.sht-token--smooth.sht-accent--accent{color:color-mix(in srgb,var(--color-text-tertiary) calc((1 - var(--sht-reveal)) * 100%),var(--color-accent) calc(var(--sht-reveal) * 100%))}.sht-token--smooth.sht-accent--accent .sht-token-underline{background:color-mix(in srgb,var(--color-accent) 30%,transparent)}.sht-token--smooth .sht-token-underline{transform-origin:left center}@media(prefers-reduced-motion:reduce){.sht-token,.sht-token--stepped,.sht-token--smooth,.sht-token--stepped .sht-token-underline{transition-duration:0ms!important}}.css-spacer{position:relative;height:280vh}.css-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.css-content{width:100%;max-width:780px;padding:0 var(--space-4);display:flex;flex-direction:column;align-items:center}.css-header{text-align:center;margin-bottom:var(--space-6)}.css-label{display:inline-block;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:var(--space-2)}.css-heading{font-size:clamp(1.15rem,1.5vw,1.4rem);font-weight:600;color:var(--color-text);line-height:1.35;max-width:34ch;margin:0 auto}.css-canvas{position:relative;width:100%;max-width:720px;aspect-ratio:16 / 10;border:1px solid var(--color-border);border-radius:14px;background:var(--color-bg-secondary);overflow:hidden;display:flex;flex-direction:column;transition:aspect-ratio .5s cubic-bezier(.22,1,.36,1)}.css-nav{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);flex-shrink:0}.css-nav-logo{width:24px;height:24px;border-radius:6px;background:color-mix(in srgb,var(--color-text) 12%,transparent);flex-shrink:0}.css-nav-pills{display:flex;gap:var(--space-2);flex-wrap:wrap}.css-pill{font-size:.65rem;font-weight:550;letter-spacing:.02em;color:var(--color-text-secondary);padding:3px 10px;border-radius:100px;background:color-mix(in srgb,var(--color-text) 6%,transparent);white-space:nowrap;-webkit-user-select:none;user-select:none}.css-body{flex:1;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4) var(--space-4);min-height:0;transition:gap .6s cubic-bezier(.22,1,.36,1)}.css-sidebar{flex:0 0 22%;display:flex;flex-direction:column;gap:var(--space-2);transition:flex-basis .5s cubic-bezier(.22,1,.36,1),opacity .4s ease}.css-sidebar-block{border-radius:8px;background:color-mix(in srgb,var(--color-text) 6%,transparent)}.css-sidebar-block--tall{flex:2}.css-sidebar-block--short{flex:1}.css-main{flex:1;display:flex;flex-direction:column;gap:var(--space-3);min-width:0;transition:max-width .5s cubic-bezier(.22,1,.36,1),margin .5s cubic-bezier(.22,1,.36,1)}.css-filters{display:flex;gap:var(--space-2);align-items:center}.css-filter-chip{height:18px;border-radius:100px;background:color-mix(in srgb,var(--color-text) 8%,transparent);flex:0 0 48px}.css-filter-chip--wide{flex:0 0 72px}.css-content-row{display:flex;gap:var(--space-2);flex:1;transition:flex-direction .4s ease}.css-content-block{border-radius:8px;background:color-mix(in srgb,var(--color-text) 5%,transparent)}.css-content-block--lg{flex:2}.css-content-block--sm{flex:1}.css-cta{align-self:center;padding:8px 28px;border-radius:100px;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;position:relative;isolation:isolate;cursor:default;flex-shrink:0}.css-cta:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:inherit;background:radial-gradient(ellipse at center,color-mix(in srgb,var(--color-accent) 25%,transparent),transparent 70%);opacity:var(--glow, 0);z-index:-1;pointer-events:none;transition:opacity .3s ease}.css-cta-label{font-size:.7rem;font-weight:650;letter-spacing:.02em}.css-canvas--compressed .css-body{gap:0}.css-canvas--compressed .css-sidebar{flex-basis:0;overflow:hidden;opacity:0;pointer-events:none}.css-canvas--compressed .css-content-row{flex-direction:column}.css-canvas--compressed .css-main{max-width:70%;margin:0 auto}.css-annotation{width:100%;max-width:720px;margin-top:var(--space-5);min-height:56px;display:flex;align-items:flex-start;justify-content:center}.css-annotation-inner{text-align:center}.css-phase-badge{display:inline-block;font-size:var(--font-size-xs);font-weight:650;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-1)}.css-phase-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin:0;max-width:42ch}.css-caption{margin-top:var(--space-4);text-align:center;font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.45;max-width:48ch}@media(max-width:768px){.css-spacer{height:220vh}.css-canvas{aspect-ratio:4 / 3;border-radius:10px}.css-nav-pills{display:none}.css-sidebar{flex-basis:28%}.css-heading{font-size:clamp(1rem,4vw,1.15rem)}.css-canvas--compressed .css-main{max-width:85%}.css-content{padding:0 var(--space-3)}}.mi-mono{font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,Cascadia Code,Consolas,monospace;text-transform:uppercase;font-weight:550;letter-spacing:.1em;line-height:1}.mi-section-index{display:block;font-size:11px;color:var(--color-text-tertiary);opacity:.65;margin-bottom:6px;-webkit-user-select:none;user-select:none}.mi-section-meta{display:flex;align-items:center;gap:8px;margin-top:4px;margin-bottom:var(--space-6)}.mi-section-tag{font-size:10px;color:var(--color-text-tertiary);opacity:.55}.mi-section-version{font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,Cascadia Code,Consolas,monospace;font-size:10px;font-weight:500;letter-spacing:.08em;color:var(--color-text-tertiary);opacity:.55;text-transform:lowercase}.mi-scroll-progress{position:sticky;top:var(--space-16);align-self:start;padding-left:var(--space-8);min-width:100px;max-width:140px;-webkit-user-select:none;user-select:none}.mi-progress-value{font-size:11px;color:var(--color-text-tertiary);opacity:.6;white-space:nowrap}.mi-fig-label{display:block;font-size:10px;color:var(--color-text-tertiary);opacity:.55;margin-bottom:6px;-webkit-user-select:none;user-select:none}@media(max-width:900px){.mi-scroll-progress{position:fixed;top:var(--space-3);right:var(--space-4);left:auto;padding-left:0;z-index:40;min-width:auto;max-width:none;background:color-mix(in srgb,var(--color-bg) 85%,transparent);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:var(--space-1) var(--space-3);border-radius:4px}}@media(max-width:480px){.mi-section-index{font-size:10px}.mi-section-tag,.mi-section-version,.mi-fig-label{font-size:9px}}.evo-flow{display:flex;flex-direction:column;align-items:stretch;margin-top:var(--space-10);max-width:780px}.evo-step{display:flex;flex-direction:column;align-items:flex-start}.evo-connector{width:1px;height:28px;margin-left:32px;background:var(--color-border)}.evo-block{position:relative;width:100%;padding:var(--space-6) var(--space-8);background:var(--color-bg);border:1px solid var(--color-border);border-radius:14px;z-index:2;transition:box-shadow .3s cubic-bezier(.22,1,.36,1),transform .3s cubic-bezier(.22,1,.36,1)}.evo-block:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000000f,0 1px 3px #0000000a}.evo-layer{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;border:1px solid var(--color-border);background:var(--color-bg);pointer-events:none}.evo-layer--1{z-index:-1;transform:translate(3px,3px);opacity:.5}.evo-layer--2{z-index:-2;transform:translate(6px,6px);opacity:.25}.evo-pill{position:absolute;top:-10px;right:var(--space-6);padding:3px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-bg);background:var(--color-accent);border-radius:20px;box-shadow:0 2px 8px #0000001f,0 0 0 2px var(--color-bg);z-index:3;line-height:1.4;white-space:nowrap}.evo-chip{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;padding:2px 8px;margin-bottom:var(--space-3);line-height:1.4}.evo-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0 0 var(--space-2) 0;line-height:1.35}.evo-outcome{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.65;margin:0}.evo-impact-wrap{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.evo-impact-label{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-1)}.evo-impact{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.55;margin:0}@media(max-width:600px){.evo-flow{max-width:100%}.evo-block{padding:var(--space-5) var(--space-5);border-radius:12px}.evo-layer{border-radius:12px}.evo-connector{height:20px;margin-left:24px}.evo-pill{right:var(--space-4)}.evo-title{font-size:var(--font-size-base)}}.fe-wrapper{width:100%;max-width:900px;margin-top:var(--space-6, 24px);margin-bottom:var(--space-4, 16px)}.fe-viewport{position:relative;width:100%;border-radius:12px;overflow:hidden;background:var(--color-bg-secondary, #f5f5f5);border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a;transition:transform .25s ease,box-shadow .3s ease}.fe-viewport:hover{transform:translateY(-4px);box-shadow:0 2px 8px #0000000d,0 8px 28px #00000012}.fe-viewport--proto{max-width:420px;margin:0 auto}.fe-iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none;opacity:0;transition:opacity .4s ease}.fe-iframe--ready{opacity:1}.fe-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:2}.fe-skeleton-pulse{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#0000000a,#00000014,#0000000a);background-size:200% 200%;animation:fe-pulse 1.6s ease-in-out infinite}.fe-skeleton-label{font-size:.75rem;font-weight:500;letter-spacing:.04em;color:var(--color-text-tertiary, #999);opacity:.6}@keyframes fe-pulse{0%,to{background-position:0% 50%;opacity:.5}50%{background-position:100% 50%;opacity:1}}.fe-header{display:flex;align-items:center;padding:0 var(--space-1, 4px) var(--space-3, 12px)}.fe-footer{padding:var(--space-3, 12px) var(--space-1, 4px) 0}.fe-caption{font-size:clamp(.85rem,1vw,.95rem);line-height:1.5;color:var(--color-text-tertiary, #888);margin:0;flex:1}.fe-proto-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--color-accent, #4a6cf7);text-decoration:none;white-space:nowrap;transition:opacity .2s ease;flex-shrink:0}.fe-proto-link:hover{opacity:.75}.fe-proto-link-text{border-bottom:1px solid transparent;transition:border-color .2s ease}.fe-proto-link:hover .fe-proto-link-text{border-color:currentColor}.fe-proto-link-icon{transition:transform .2s ease}.fe-proto-link:hover .fe-proto-link-icon{transform:translate(1px,-1px)}[data-theme=dark] .fe-viewport{background:var(--color-bg-secondary, #1a1a1a);border-color:#ffffff0f;box-shadow:0 1px 3px #00000026,0 4px 16px #0000001f}[data-theme=dark] .fe-viewport:hover{box-shadow:0 2px 8px #0003,0 8px 28px #0000002e}[data-theme=dark] .fe-skeleton-pulse{background:linear-gradient(135deg,#ffffff0a,#ffffff14,#ffffff0a);background-size:200% 200%}@media(prefers-reduced-motion:reduce){.fe-iframe,.fe-skeleton,.fe-proto-link-icon{transition:none!important}.fe-skeleton-pulse{animation:none!important;opacity:.6}.fe-viewport{transition:none!important;transform:none!important}.fe-viewport:hover{transform:none!important}}@media(max-width:768px){.fe-viewport{border-radius:10px}.fe-viewport--proto{max-width:100%}.fe-viewport:hover{transform:none;box-shadow:0 1px 3px #00000008,0 4px 16px #0000000a}}.project-detail{min-height:100vh;padding:var(--space-8) 0 var(--space-24)}.project-detail-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}.project-detail-back{margin-bottom:var(--space-8);padding:0 var(--gutter)}.back-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);background-color:var(--color-bg-secondary);border-radius:8px;transition:all var(--duration-fast) var(--ease-smooth)}.back-button:hover{color:var(--color-text);background-color:var(--color-border)}.project-hero{padding:var(--space-16) 0;border-bottom:1px solid var(--color-border)}.project-hero-meta{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.project-tag{padding:var(--space-1) var(--space-3);background-color:var(--color-bg-secondary);border-radius:4px;font-weight:500}.project-year{opacity:.7}.project-hero-title{font-size:var(--font-size-3xl);font-weight:600;letter-spacing:-.03em;margin-bottom:var(--space-6);max-width:800px}.project-hero-tagline{font-size:var(--font-size-lg);line-height:1.7;color:var(--color-text-secondary);margin-bottom:var(--space-8);max-width:700px}.project-hero-ctas{display:flex;gap:var(--space-3);margin-bottom:var(--space-12)}.project-cta-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);background-color:transparent;border:1px solid var(--color-border);border-radius:8px;transition:all .3s cubic-bezier(.16,1,.3,1)}.project-cta-link.secondary{border-color:transparent;background-color:var(--color-bg-secondary)}.project-cta-link.secondary:hover{background-color:var(--color-border)}.project-cta-link:hover{border-color:var(--color-text);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.project-cta-link svg{opacity:.7;transition:opacity .3s cubic-bezier(.16,1,.3,1)}.project-cta-link:hover svg{opacity:1}.project-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-8);margin-bottom:var(--space-8);max-width:800px}.project-meta-item{display:flex;flex-direction:column;gap:var(--space-2)}.meta-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);font-weight:500}.meta-value{font-size:var(--font-size-base);color:var(--color-text)}.project-tools{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tool-tag{padding:var(--space-2) var(--space-3);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.project-content{padding-top:var(--space-24)}.project-section{margin-bottom:var(--space-24);max-width:900px}.section-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-4);font-weight:500}.section-title{font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;margin-bottom:var(--space-6)}.section-description{font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--space-8)}.section-images{display:flex;flex-direction:column;gap:var(--space-6)}.section-image{position:relative;border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary);cursor:pointer;transform-origin:center}.section-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#21212108,#2121210f);pointer-events:none;z-index:1}.section-image img{width:100%;max-width:100%;height:auto;display:block}.image-carousel{margin-top:var(--space-6);margin-bottom:var(--space-6)}.carousel-viewport{position:relative;border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary)}.carousel-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .2s ease}.carousel-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-text-secondary)}.carousel-counter{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-variant-numeric:tabular-nums;min-width:48px;text-align:center}.carousel-dots{display:flex;justify-content:center;gap:6px;margin-top:var(--space-3)}.carousel-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--color-border);background:transparent;cursor:pointer;padding:0;transition:all .2s ease}.carousel-dot.active{background:var(--color-text);border-color:var(--color-text)}.carousel-dot:hover:not(.active){background:var(--color-text-tertiary)}.accordion-group{display:flex;flex-direction:column;gap:0;margin-top:var(--space-8)}.accordion-item{border-bottom:1px solid var(--color-border)}.accordion-item:first-child{border-top:1px solid var(--color-border)}.accordion-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) 0;background:none;border:none;cursor:pointer;color:var(--color-text);text-align:left;transition:all .3s cubic-bezier(.16,1,.3,1)}.accordion-trigger:hover{color:var(--color-text-secondary);padding-left:var(--space-2)}.accordion-label{font-size:var(--font-size-base);font-weight:500}.accordion-chevron{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0;transition:color .3s cubic-bezier(.16,1,.3,1)}.accordion-open .accordion-chevron{color:var(--color-text)}.accordion-body{overflow:hidden}.accordion-content{padding-bottom:var(--space-6)}.accordion-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-4)}.hifi-screen-image{position:relative;border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary);margin-bottom:var(--space-4)}.hifi-screen-image img{width:100%;height:auto;display:block}.persona-image{border-radius:12px;overflow:hidden;margin-bottom:var(--space-6)}.persona-image img{width:100%;height:auto;display:block;border-radius:12px}.objectives-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-4)}.objective-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:8px}.objective-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-accent);color:var(--color-bg);border-radius:4px;font-size:var(--font-size-xs);font-weight:600;flex-shrink:0}.objective-text{font-size:var(--font-size-base);line-height:1.6;color:var(--color-text)}.outcomes-section{margin-top:var(--space-16);padding-top:var(--space-16);border-top:1px solid var(--color-border)}.outcomes-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-8);margin-top:var(--space-8)}.outcome-metric{text-align:center;padding:var(--space-8);background-color:var(--color-bg-secondary);border-radius:12px;transition:all .3s cubic-bezier(.16,1,.3,1)}.outcome-metric:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.metric-value{font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;margin-bottom:var(--space-3);color:var(--color-text)}.metric-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4}.features-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.feature-item{padding:var(--space-6);background-color:var(--color-bg-secondary);border-radius:12px;transition:all .3s cubic-bezier(.16,1,.3,1)}.feature-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000000f}.feature-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-3);color:var(--color-text)}.feature-description{font-size:var(--font-size-base);line-height:1.7;color:var(--color-text-secondary)}.quotes-list{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-8)}.validation-quote{padding:var(--space-6) var(--space-8);background-color:var(--color-bg-secondary);border-left:3px solid var(--color-accent);border-radius:8px;font-style:italic}.quote-text{font-size:var(--font-size-lg);line-height:1.7;color:var(--color-text);margin-bottom:var(--space-3)}.quote-author{font-size:var(--font-size-sm);font-style:normal;color:var(--color-text-tertiary);display:block}.insights-list{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-8)}.insight-item{padding:var(--space-6);background-color:var(--color-bg-secondary);border-radius:12px;transition:all .3s cubic-bezier(.16,1,.3,1)}.insight-item:hover{transform:translate(4px)}.insight-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-3);color:var(--color-text)}.insight-description{font-size:var(--font-size-base);line-height:1.7;color:var(--color-text-secondary)}.next-steps-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-8)}.next-step-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background-color:var(--color-bg-secondary);border-radius:8px;transition:all .3s cubic-bezier(.16,1,.3,1)}.next-step-item:hover{transform:translate(4px);background-color:var(--color-border)}.step-icon{color:var(--color-accent);font-weight:600;flex-shrink:0}.step-text{font-size:var(--font-size-base);line-height:1.6;color:var(--color-text)}.project-responsibilities{margin-top:var(--space-8)}.responsibilities-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.responsibility-item{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding-left:var(--space-4);position:relative}.responsibility-item:before{content:"•";position:absolute;left:0;color:var(--color-accent)}.project-tools-categorized{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-8)}.tools-category{display:flex;flex-direction:column;gap:var(--space-2)}.tools-category-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.tools-category-items{display:flex;flex-wrap:wrap;gap:var(--space-2)}.research-methods,.research-findings{margin-top:var(--space-8)}.subsection-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4);color:var(--color-text)}.methods-list,.findings-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.method-item,.finding-item{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-secondary)}.finding-icon{color:var(--color-accent);flex-shrink:0}.participant-count{margin-top:var(--space-6);font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.research-reflection{margin-top:var(--space-8);padding:var(--space-6);background-color:var(--color-bg-secondary);border-left:3px solid var(--color-accent);border-radius:8px;font-style:italic;color:var(--color-text-secondary)}.technical-decisions,.development-constraints{margin-top:var(--space-8)}.decisions-list,.constraints-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.decision-item,.constraint-item{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-secondary)}.decision-icon{color:var(--color-accent);flex-shrink:0}.feature-item{position:relative}.feature-why{margin-top:var(--space-2);font-size:var(--font-size-sm);font-style:italic;color:var(--color-text-tertiary)}.feature-image{margin-top:var(--space-4);border-radius:8px;overflow:hidden}.feature-image img{width:100%;height:auto;display:block}.validation-method{margin-top:var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.validation-outcomes{margin-top:var(--space-8)}.outcomes-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.outcome-item{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-secondary);padding-left:var(--space-4);position:relative}.outcome-item:before{content:"✓";position:absolute;left:0;color:var(--color-accent)}.next-step-item{display:flex;flex-direction:column;gap:var(--space-2)}.step-content{display:flex;flex-direction:column;gap:var(--space-1)}.step-priority{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent)}.priority-high .step-priority{color:#e63946}.priority-medium .step-priority{color:#f77f00}.priority-low .step-priority{color:var(--color-text-tertiary)}.prototype-embed{margin-top:var(--space-12);padding:var(--space-8);background-color:var(--color-bg-secondary);border-radius:12px}.prototype-description{font-size:var(--font-size-base);line-height:1.7;color:var(--color-text-secondary);margin-bottom:var(--space-6);text-align:center}.prototype-iframe-container{position:relative;width:100%;padding-bottom:56.25%;border-radius:8px;overflow:hidden;background-color:var(--color-bg)}.prototype-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.prototype-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:500;color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;transition:all .3s cubic-bezier(.16,1,.3,1)}.prototype-link:hover{border-color:var(--color-text);transform:translateY(-2px)}.image-caption{margin-top:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:center;font-style:italic}@media(max-width:768px){.project-detail{padding:var(--space-4) 0 var(--space-16)}.project-hero{padding:var(--space-12) 0}.project-hero-title{font-size:var(--font-size-2xl)}.project-hero-tagline{font-size:var(--font-size-base)}.project-hero-ctas{flex-direction:column;align-items:stretch}.project-cta-link{justify-content:center}.project-meta-grid{grid-template-columns:1fr;gap:var(--space-4)}.project-content{padding-top:var(--space-16)}.project-section{margin-bottom:var(--space-16)}.section-title{font-size:var(--font-size-xl)}.section-description{font-size:var(--font-size-base)}.accordion-trigger{padding:var(--space-3) 0}.accordion-trigger:hover{padding-left:0}.accordion-label{font-size:var(--font-size-sm)}}.compact-project{max-width:1200px;margin:0 auto}.compact-hero{padding:var(--space-12) 0 var(--space-16);text-align:center}.compact-title{font-size:var(--font-size-4xl);font-weight:500;letter-spacing:-.03em;margin-bottom:var(--space-4);max-width:900px;margin-left:auto;margin-right:auto}.compact-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-8);max-width:700px;margin-left:auto;margin-right:auto;line-height:1.6}.compact-ctas{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-8)}.compact-cta-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);background-color:transparent;border:1px solid var(--color-border);border-radius:8px;transition:all .3s cubic-bezier(.16,1,.3,1)}.compact-cta-link:hover{border-color:var(--color-text);box-shadow:0 4px 12px #00000014}.compact-cta-link.secondary{border-color:transparent;background-color:var(--color-bg-secondary)}.compact-cta-link.secondary:hover{background-color:var(--color-border)}.compact-cta-link svg{opacity:.7;transition:opacity .3s}.compact-cta-link:hover svg{opacity:1}.compact-hero-image{padding:var(--space-16) 0}.hero-image-wrapper{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #0000001f,0 4px 16px #00000014;transform-origin:center}.hero-image{width:100%;height:auto;display:block}.compact-description{padding:var(--space-16) 0;max-width:700px;margin:0 auto}.description-text{font-size:18px;line-height:1.8;color:var(--color-text-secondary);text-align:center;margin:0}.hover-preview-gallery{border-bottom:none}.highlight-bullet{font-size:var(--font-size-lg);color:var(--color-text-tertiary);opacity:.4;flex-shrink:0}.highlight-text{font-size:var(--font-size-base);line-height:1.7;color:var(--color-text)}.compact-gallery{padding:var(--space-24) 0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-12);padding:var(--space-8) 0}.gallery-item{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 12px 40px #00000014,0 2px 8px #0000000a;transform-origin:center;cursor:pointer}.gallery-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#21212105,#2121210d);pointer-events:none;z-index:1}.gallery-image{width:100%;height:auto;display:block}@media(max-width:768px){.compact-title{font-size:var(--font-size-2xl)}.compact-subtitle{font-size:var(--font-size-base)}.compact-ctas{flex-direction:column;align-items:stretch}.compact-cta-link{justify-content:center}.gallery-grid{grid-template-columns:1fr;gap:var(--space-8)}.compact-hero{padding:var(--space-8) 0 var(--space-12)}.compact-description{padding:var(--space-12) 0}.description-text{font-size:16px}.compact-gallery{padding:var(--space-16) 0}}.project-layout-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}.project-layout{min-height:100vh;padding:var(--space-8) 0 0}.project-layout-back{margin-bottom:var(--space-8);padding:0 var(--gutter)}.pl-hero{padding:var(--space-12) 0 var(--space-8)}.pl-hero-meta{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pl-hero-title{font-size:var(--font-size-4xl);font-weight:700;letter-spacing:-.04em;margin-bottom:var(--space-4);max-width:800px;line-height:1.1}.pl-hero-tagline{font-size:var(--font-size-lg);line-height:1.7;color:var(--color-text-secondary);margin-bottom:var(--space-8);max-width:640px}.pl-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-6);margin-bottom:var(--space-6);max-width:640px}.pl-meta-item{display:flex;flex-direction:column;gap:var(--space-2)}.pl-hero-image{width:100%;max-width:var(--max-width);margin:0 auto var(--space-16);padding:0 var(--gutter)}.pl-hero-image img{width:100%;height:auto;display:block;border-radius:16px;background-color:var(--color-bg-secondary)}.pl-content{padding-bottom:var(--space-16)}.pl-section{margin-bottom:var(--space-20);max-width:900px}.pl-section-images{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-8)}.pl-section-image{border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary);cursor:pointer}.pl-section-image img{width:100%;height:auto;display:block}.image-carousel{margin-top:var(--space-8)}.carousel-viewport{position:relative;border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary);cursor:pointer}.carousel-viewport img{width:100%;height:auto;display:block}.carousel-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-4)}.carousel-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border, #e0e0e0);background:var(--color-bg, #fff);color:var(--color-text, #1a1a1a);cursor:pointer;transition:all .2s ease}.carousel-btn:hover{background:var(--color-bg-secondary, #f5f5f5);border-color:var(--color-text-secondary, #666)}.carousel-counter{font-size:.875rem;color:var(--color-text-secondary, #666);font-variant-numeric:tabular-nums;min-width:48px;text-align:center}.carousel-dots{display:flex;justify-content:center;gap:6px;margin-top:12px}.carousel-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--color-border, #e0e0e0);background:transparent;cursor:pointer;padding:0;transition:all .2s ease}.carousel-dot.active{background:var(--color-text, #1a1a1a);border-color:var(--color-text, #1a1a1a)}.carousel-dot:hover:not(.active){background:var(--color-text-tertiary, #999)}.pl-objectives{list-style:none;display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-4)}.pl-objective-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:8px}.pl-process-timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.pl-process-step{padding:var(--space-6);background-color:var(--color-bg-secondary);border-radius:12px;transition:transform .3s cubic-bezier(.16,1,.3,1)}.pl-process-step:hover{transform:translateY(-3px)}.pl-process-number{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-tertiary);margin-bottom:var(--space-3);letter-spacing:.05em}.pl-process-info{display:flex;flex-direction:column;gap:var(--space-2)}.pl-process-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text)}.pl-process-duration{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pl-process-activities{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.pl-activity-tag{padding:var(--space-1) var(--space-3);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.pl-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.pl-metric-card{text-align:center;padding:var(--space-8);background-color:var(--color-bg-secondary);border-radius:12px;transition:transform .3s cubic-bezier(.16,1,.3,1)}.pl-metric-card:hover{transform:translateY(-4px)}.pl-metric-value{display:block;font-size:var(--font-size-2xl);font-weight:600;letter-spacing:-.02em;margin-bottom:var(--space-2)}.pl-metric-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pl-gallery{padding:var(--space-16) 0 var(--space-20);border-top:1px solid var(--color-border)}.pl-gallery .section-label{display:block;margin-bottom:var(--space-8)}.pl-gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);max-width:var(--max-width);margin:0 auto;padding:0 var(--gutter)}.pl-gallery-grid .pl-gallery-item:first-child{grid-column:1 / -1}.pl-gallery-item{position:relative;border-radius:12px;overflow:hidden;background-color:var(--color-bg-secondary);cursor:pointer;transition:transform .4s cubic-bezier(.16,1,.3,1)}.pl-gallery-item:hover{transform:scale(1.015)}.pl-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.pl-gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4) var(--space-6);background:linear-gradient(transparent,#0009);color:#fff;font-size:var(--font-size-sm);line-height:1.5;opacity:0;transition:opacity .3s ease}.pl-gallery-item:hover .pl-gallery-caption{opacity:1}.pl-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000e6;padding:var(--space-8);cursor:pointer}.pl-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px}.pl-lightbox-close{position:absolute;top:var(--space-6);right:var(--space-6);background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;opacity:.7;transition:opacity .2s;line-height:1}.pl-lightbox-close:hover{opacity:1}.pl-footer-nav{padding:var(--space-12) 0 var(--space-16);border-top:1px solid var(--color-border)}.pl-footer-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color .2s}.pl-footer-link:hover{color:var(--color-text);opacity:1}@media(max-width:768px){.pl-hero-title{font-size:var(--font-size-2xl)}.pl-gallery-grid{grid-template-columns:1fr}.pl-gallery-grid .pl-gallery-item:first-child{grid-column:1}.pl-process-timeline{grid-template-columns:1fr}.pl-meta-grid{grid-template-columns:1fr 1fr}.pl-hero-image{padding:0}.pl-hero-image img{border-radius:0}}.app{min-height:100vh;position:relative}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .4s var(--ease-smooth),transform .4s var(--ease-smooth)}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .2s var(--ease-smooth)}:root{--color-bg: #ffffff;--color-bg-secondary: #fafafa;--color-text: #1a1a1a;--color-text-secondary: #737373;--color-text-tertiary: #a3a3a3;--color-border: #e5e5e5;--color-accent: #212121;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-size-xs: .6875rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-4xl: 3rem;--font-size-5xl: 4rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--max-width: 1280px;--gutter: var(--space-6);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .2s;--duration-base: .3s;--duration-slow: .5s;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}[data-theme=dark]{--color-bg: #0a0a0a;--color-bg-secondary: #171717;--color-text: #fafafa;--color-text-secondary: #a3a3a3;--color-text-tertiary: #737373;--color-border: #262626;--color-accent: #fafafa}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--duration-base) var(--ease-smooth),color var(--duration-base) var(--ease-smooth)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}p{line-height:1.7}a{color:inherit;text-decoration:none;transition:opacity var(--duration-fast) var(--ease-smooth)}a:hover{opacity:.7}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--gutter)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
