@import"https://fonts.cdnfonts.com/css/thegoodmonolith";@import"https://fonts.cdnfonts.com/css/pp-neue-montreal";@import"https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=Space+Grotesk:wght@300;400;500;600;700&display=swap";.preloader{position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#000;z-index:var(--z-preloader);display:flex;justify-content:center;align-items:center;overflow:hidden;transition:clip-path .64s cubic-bezier(.65,.05,.36,1);clip-path:polygon(0% 0%,100% 0%,100% 100%,0% 100%)}.preloader--exiting{clip-path:polygon(0% 0%,100% 0%,100% 0%,0% 0%)}.preloader__terminal{width:90%;max-width:800px;position:relative;padding:1rem 0}.preloader__terminal-header{display:flex;justify-content:space-between;padding:0 10px;margin-bottom:20px;font-family:PP Neue Montreal,sans-serif;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.1em}.preloader__terminal-content{position:relative;height:350px;padding:10px;overflow:hidden}.preloader__terminal-line{position:absolute;font-family:PP Neue Montreal,sans-serif;font-size:.9rem;font-weight:300;line-height:1.2;letter-spacing:.05em;white-space:nowrap;overflow:hidden;width:100%;left:0;padding-left:10px;text-transform:uppercase}.preloader__terminal-line--highlight{color:#fff;font-weight:400}.preloader__terminal-line--faded{color:#ffffff80}.preloader__progress-section{display:flex;align-items:center;padding:0 10px;margin-top:20px;gap:10px}.preloader__progress-label{font-family:PP Neue Montreal,sans-serif;font-size:.9rem;font-weight:400;color:#fff;text-transform:uppercase;letter-spacing:.08em}.preloader__progress-bar{width:200px;height:1px;background-color:#fff3;position:relative;overflow:hidden}.preloader__progress-fill{height:100%;background-color:#fff;transition:width .1s ease}.preloader__progress-text{font-family:PP Neue Montreal,sans-serif;font-size:.9rem;font-weight:400;color:#fff;text-transform:uppercase;letter-spacing:.08em}.preloader__terminal-footer{display:flex;justify-content:space-between;padding:0 10px;margin-top:20px;font-family:PP Neue Montreal,sans-serif;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.1em}@media(max-width:768px){.preloader__terminal{width:95%}.preloader__terminal-content{height:300px}.preloader__terminal-line{font-size:.75rem}.preloader__progress-bar{width:120px}.preloader__terminal-header,.preloader__terminal-footer{font-size:.65rem}}@font-face{font-family:Cabinet Grotesk;font-style:normal;font-weight:800;src:local("Cabinet Grotesk"),url(https://fonts.cdnfonts.com/s/85514/CabinetGrotesk-Extrabold.woff) format("woff")}@font-face{font-family:Cabinet Grotesk;font-style:normal;font-weight:400;src:local("Cabinet Grotesk"),url(https://fonts.cdnfonts.com/s/85514/CabinetGrotesk-Medium.woff) format("woff")}.desktop-landing{--bg-color: #ffffff;--text-color: #333333;--title-color: #000000;--overlay-text-color: rgba(0, 0, 0, .05);--shelf-bg: linear-gradient(to bottom, #f0f0f0, #e0e0e0);--shelf-edge-top: rgba(255, 255, 255, .01);--shelf-edge-bottom: rgba(0, 0, 0, .1);--book-back-cover: #111111;--book-page: #ffffff;--book-page-border: rgba(0, 0, 0, .2);--book-shadow: rgba(0, 0, 0, .15);--book-shadow-strong: rgba(0, 0, 0, .35);--toggle-dot: #333333}.desktop-landing.dark-mode{--bg-color: #121212;--text-color: #e0e0e0;--title-color: #ffffff;--overlay-text-color: rgba(255, 255, 255, .05);--shelf-bg: linear-gradient(to bottom, #2a2a2a, #1a1a1a);--shelf-edge-top: rgba(255, 255, 255, .03);--shelf-edge-bottom: rgba(0, 0, 0, .3);--book-back-cover: #ffffff;--book-page: #ffffff;--book-page-border: rgba(0, 0, 0, .2);--book-shadow: rgba(0, 0, 0, .3);--book-shadow-strong: rgba(0, 0, 0, .5);--toggle-dot: #ffffff}.desktop-landing{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--bg-color);display:flex;justify-content:center;align-items:center;overflow:hidden;font-family:Cabinet Grotesk,sans-serif;letter-spacing:-.02em;color:var(--text-color);transition:background-color .5s ease,color .5s ease;z-index:0}.desktop-landing__grid{position:absolute;width:100%;height:100%;z-index:0;pointer-events:none}.desktop-landing.dark-mode .desktop-landing__grid circle{fill:#ffffff26}.dot-grid{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:hidden}.dot-grid__dot{position:absolute;font-size:10px;color:#333;transition:all .15s ease;will-change:transform,color;pointer-events:none}.landing-footer{position:fixed;bottom:0;left:0;width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 40px;font-family:Cabinet Grotesk,sans-serif;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-color);opacity:.6;z-index:50}.landing-footer__left,.landing-footer__right{display:flex;gap:30px}.landing-footer__center{position:absolute;left:50%;transform:translate(-50%)}.theme-toggle{position:fixed;top:20px;right:20px;width:8px;height:8px;border-radius:50%;background-color:var(--toggle-dot);cursor:pointer;z-index:100;transition:background-color .3s ease}.book-title-overlay{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:-1;opacity:1;pointer-events:none}.book-title-text{font-family:Cabinet Grotesk,sans-serif;font-weight:800;font-size:clamp(8rem,20vw,20rem);color:var(--overlay-text-color);text-transform:uppercase;text-align:center;line-height:1;max-width:90vw;transition:color .5s ease}.shelf-container{position:relative;width:100%;height:500px;margin:0 auto;display:flex;justify-content:center;z-index:1}.shelf{display:block;position:absolute;bottom:270px;width:100%;max-width:800px;height:15px;background:var(--shelf-bg);border-radius:1px;z-index:20;box-shadow:0 -1px 1px #ffffff26,0 2px 3px #0000001f,0 5px 10px #00000014,0 15px 20px #0000000f,0 25px 30px #0000000a,0 40px 60px #0003,0 60px 80px #0000001f;transition:background .5s ease,box-shadow .5s ease}.shelf:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background-color:var(--shelf-edge-bottom);transition:background-color .5s ease}.shelf:before{content:"";position:absolute;top:-2px;left:0;width:100%;height:2px;background-color:var(--shelf-edge-top);transition:background-color .5s ease}.books-wrapper{position:absolute;bottom:287px;left:50%;transform:translate(-50%);display:flex;justify-content:center;align-items:flex-end;gap:2rem;z-index:10}.books__item{text-align:center;cursor:default;height:220px}.books__container{position:relative;width:160px;margin:0 auto;height:100%}.books__cover{position:relative;will-change:transform;height:100%}.books__hitbox{position:absolute;width:100%;height:100%;top:0;left:0;z-index:10;cursor:pointer}.books__back-cover{position:absolute;width:96%;height:96%;top:2%;left:2%;background:var(--book-back-cover);border-radius:0 6px 6px 0;box-shadow:2px 2px 5px #00000040;z-index:-10;transition:background .5s ease}.books__inside{position:absolute;width:90%;height:94%;top:3%;left:5%;z-index:0}.books__page{position:absolute;top:0;right:0;width:98%;height:100%;background:var(--book-page);border:1px solid var(--book-page-border);border-radius:0 6px 6px 0;box-shadow:0 1px 3px #00000026;transform-origin:right center;z-index:-5;transition:background .5s ease,border-color .5s ease}.books__image{line-height:0;position:relative;border-radius:2px 6px 6px 2px;height:100%;box-shadow:var(--book-shadow) 10px -5px 20px,var(--book-shadow) 20px 0 30px;transform-origin:left center;cursor:pointer;will-change:transform,box-shadow;z-index:10;transition:box-shadow .5s ease}.books__image img{width:100%;height:100%;object-fit:cover;border-radius:2px 6px 6px 2px}.books__effect{position:absolute;width:24px;height:100%;margin-left:12px;top:0;border-left:2px solid rgba(0,0,0,.08);background-image:linear-gradient(90deg,#ffffff40,#fff0);transform-origin:left center;z-index:5;pointer-events:none;will-change:margin-left}.books__light{width:100%;height:100%;position:absolute;border-radius:2px 6px 6px 2px;background-image:linear-gradient(90deg,#fff0,#ffffff80);top:0;left:0;right:0;bottom:0;opacity:.15;transform-origin:left center;z-index:4;pointer-events:none;mix-blend-mode:overlay;will-change:opacity}.book-shadow{position:absolute;bottom:285px;left:50%;transform:translate(-50%);display:flex;justify-content:center;align-items:flex-end;gap:2rem;z-index:15}.book-shadow__item{width:120px;height:2px;background:radial-gradient(ellipse at center,var(--book-shadow) 0%,rgba(0,0,0,0) 70%);border-radius:50%;will-change:width,opacity;transition:background .5s ease}.book-descriptions{position:absolute;bottom:30px;left:50%;transform:translate(-50%);width:100%;max-width:640px;z-index:5;height:200px}.book-description{position:absolute;top:0;left:0;width:100%;opacity:0;visibility:hidden;font-family:Cabinet Grotesk,sans-serif;font-weight:400;font-size:1.1rem;line-height:1.5;color:var(--text-color);transition:opacity .3s ease,visibility .3s ease,color .5s ease;text-align:center;padding:0 1rem}.book-description.active{opacity:1;visibility:visible}.book-description h3{font-weight:800;font-size:1.8rem;margin-bottom:.5rem;color:var(--title-color);transition:color .5s ease}.book-description .author{font-style:italic;opacity:.8;margin-bottom:1rem}.book-description p{margin-bottom:.75rem}.lines-animation{overflow:hidden}@media(max-width:768px){.books-wrapper{gap:1rem}.books__container{width:120px}.books__item{height:170px}.book-title-text{font-size:clamp(4rem,15vw,10rem)}.book-descriptions{padding:0 1rem}.book-description{font-size:.9rem}.book-description h3{font-size:1.4rem}}.control-panel{--control-size: min(30vw, 400px);position:relative;width:var(--control-size);height:calc(var(--control-size) * 1.4);font-family:TheGoodMonolith,monospace;font-size:clamp(10px,1.5vw,14px);overflow:hidden;border-radius:16px}.control-panel[data-theme=light]{--bg: hsl(223, 10%, 95%);--fg: hsl(223, 10%, 15%);--accent: hsl(0, 80%, 55%);--dot-bg-color: #222;--dot-fg-color: #fff;--bg-pattern-color: rgba(0, 0, 0, .07);background-color:var(--bg);color:var(--fg)}.control-panel[data-theme=dark]{--bg: #000000;--fg: #ffffff;--accent: hsl(0, 80%, 55%);--dot-bg-color: #333;--dot-fg-color: #ffffff;--bg-pattern-color: rgba(255, 255, 255, .15);background-color:var(--bg);color:var(--fg)}.control-panel__grid{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.control-panel__main{display:flex;overflow-x:hidden;padding:1.5em 0;width:100%;height:100%;position:relative;z-index:1}.control-panel__grid-controls{display:grid;gap:1.5em;grid-template-columns:repeat(2,1fr);margin:auto;padding:0 1em}.control-container{display:flex;flex-direction:column;align-items:center}.dot-control{position:relative;width:calc(var(--control-size) * .4);height:calc(var(--control-size) * .9);margin:auto;cursor:pointer}.dot-control canvas{position:absolute;top:0;left:0;width:100%;height:100%}.control-label{text-transform:uppercase;letter-spacing:1px;margin-top:.8rem;color:var(--fg);transition:color .5s ease;font-size:11px}.control-value{margin-top:.2rem;color:var(--accent);transition:color .5s ease;font-size:12px;font-weight:600}.mode-display{position:absolute;top:1rem;right:1rem;letter-spacing:1px;color:var(--fg);transition:color .3s ease;display:flex;align-items:center;gap:.5rem;z-index:10;font-size:10px}.mode-indicator{display:inline-block;width:.6em;height:.6em;border-radius:50%;background-color:var(--fg);transition:background-color .3s ease}.mode-text{margin:0;text-transform:uppercase}.quote-container{position:absolute;bottom:1rem;left:1rem;right:1rem;letter-spacing:.5px;color:var(--fg);transition:color .3s ease;z-index:10;font-size:10px;opacity:.7}.quote-container p{margin:0}.taskbar{position:fixed;bottom:var(--spacing-lg);left:0;right:0;margin:0 auto;width:fit-content;display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:#0009;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:50px;box-shadow:0 8px 32px #0000004d;z-index:var(--z-taskbar)}.taskbar__center{display:flex;align-items:center;gap:var(--spacing-xs)}.taskbar__item{position:relative;display:flex;align-items:center;gap:8px;padding:10px 16px;background:transparent;border:none;cursor:pointer;transition:all .3s ease;color:#ffffffb3;font-family:PP Neue Montreal,sans-serif;font-size:12px;font-weight:500;border-radius:25px}.taskbar__item:hover{background:#ffffff1a;color:#fff}.taskbar__item--active{background:#ff6b6b33;color:#fff}.taskbar__item-symbol{font-size:16px;display:inline-block;transition:transform .4s ease}.taskbar__item-label{font-family:PP Neue Montreal,sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.taskbar__item--active .taskbar__item-symbol{color:#ff6b6b}.taskbar__item-indicator{position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;background:#ff6b6b;border-radius:50%}.taskbar__control-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;transition:all .3s ease;color:#ffffffb3;font-size:16px}.taskbar__control-btn:hover{background:#ffffff1a;border-color:#ffffff4d;color:#fff}.taskbar__control-btn--active{background:#ff6b6b33;border-color:#ff6b6b;color:#ff6b6b}.control-popup{position:fixed;bottom:calc(var(--spacing-lg) + 70px);left:50%;transform:translate(-50%);z-index:calc(var(--z-taskbar) + 1);width:320px;max-width:90vw}@media(max-width:600px){.taskbar{padding:var(--spacing-xs) var(--spacing-md);gap:var(--spacing-sm)}.taskbar__item{padding:8px 12px;gap:6px}.taskbar__item-label{font-size:10px}.taskbar__item-symbol{font-size:14px}.taskbar__control-btn{width:36px;height:36px;font-size:14px}}.window{position:absolute;display:flex;flex-direction:column;background-color:var(--color-bg);border:var(--window-border);box-shadow:var(--shadow-brutal-lg);overflow:hidden;-webkit-user-select:none;user-select:none}.window:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--color-bg-secondary);z-index:-1}.window__header{display:flex;align-items:center;height:var(--window-header-height);padding:0 var(--spacing-sm);background-color:var(--color-text);color:var(--color-bg);cursor:grab;flex-shrink:0}.window__header:active{cursor:grabbing}.window__controls{display:flex;gap:var(--spacing-xs)}.window__control{width:16px;height:16px;border:2px solid var(--color-bg);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:12px;font-weight:700;color:var(--color-bg);transition:background-color var(--transition-fast)}.window__control span{line-height:1;margin-top:-2px}.window__control:hover{background-color:var(--color-bg);color:var(--color-text)}.window__control--close:hover{background-color:#ff5f56;border-color:#ff5f56;color:#000}.window__control--maximize:hover{background-color:#27c93f;border-color:#27c93f;color:#000}.window__title{flex:1;text-align:center;padding:0 var(--spacing-md)}.window__title-text{font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:700;text-transform:uppercase;letter-spacing:.1em}.window__header-spacer{width:36px}.window--fullscreen{border:none;box-shadow:none}.window--fullscreen .window__header{cursor:default}.window__content{flex:1;overflow:auto;position:relative;background-color:var(--color-bg)}.window--work .window__header{background-color:var(--color-brutal-blue)}.window--thoughts .window__header{background-color:var(--color-brutal-purple)}.window--photography .window__header{background-color:var(--color-brutal-pink)}.window--control .window__header{background-color:var(--color-brutal-yellow)}@media(max-width:768px){.window{width:100%!important;height:calc(100% - 60px)!important;left:0!important;top:0!important}}.work-window{position:relative;width:100%;height:100%;background:#0a0a0a;color:#f0f0f0;font-family:TheGoodMonolith,monospace;overflow-y:auto;padding:30px;display:flex;flex-direction:column;align-items:center}.work-window__container{width:100%;max-width:1200px}.work-window__hero{text-align:center;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.work-window__title{font-size:48px;font-weight:700;letter-spacing:8px;margin:0 0 10px}.work-window__subtitle{font-size:12px;letter-spacing:3px;opacity:.6;margin:0}.work-window__columns{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}.work-window__column{display:flex;flex-direction:column;gap:20px}.work-window__section{border:1px solid rgba(255,255,255,.15);padding:20px}.work-window__section-title{font-size:16px;font-weight:700;letter-spacing:2px;margin:0 0 15px;color:#fff}.work-window__table{width:100%;border-collapse:collapse;font-size:14px}.work-window__table tr{border-bottom:1px solid rgba(255,255,255,.08)}.work-window__table tr:last-child{border-bottom:none}.work-window__table td{padding:12px 10px;vertical-align:top}.work-window__table td:first-child{font-weight:700;color:#fff}.work-window__table td:nth-child(2){opacity:.7}.work-window__table-year,.work-window__table-status{text-align:right;opacity:.5;font-size:12px}.work-window__animations{display:grid;grid-template-columns:1fr 1fr;gap:20px}.work-window__animation-spacer{display:block}.work-window__animation-box{position:relative;border:1px solid rgba(255,255,255,.15);aspect-ratio:1;display:flex;align-items:center;justify-content:center;transition:border-color .3s ease}.work-window__animation-box:hover{border-color:#ffffff4d}.work-window__animation-box .corner{position:absolute;width:16px;height:16px;color:#fff;opacity:0;z-index:10;pointer-events:none;transition:opacity .3s ease}.work-window__animation-box:hover .corner{opacity:1}.work-window__animation-box .corner.top-left{top:-8px;left:-8px;transition-delay:0s}.work-window__animation-box .corner.top-right{top:-8px;right:-8px;transform:rotate(90deg);transition-delay:.1s}.work-window__animation-box .corner.bottom-left{bottom:-8px;left:-8px;transform:rotate(-90deg);transition-delay:.2s}.work-window__animation-box .corner.bottom-right{bottom:-8px;right:-8px;transform:rotate(180deg);transition-delay:.3s}.work-window__animation-box canvas{display:block;max-width:100%;max-height:100%;width:auto;height:auto}.work-window__skills{display:flex;flex-wrap:wrap;gap:8px}.work-window__skill{font-size:14px;padding:6px 12px;border:1px solid rgba(255,255,255,.2);letter-spacing:1px;transition:all .2s ease}.work-window__skill:hover{background:#ffffff1a;border-color:#fff6}.work-window__services-section{border:1px solid rgba(255,255,255,.15);padding:20px}.work-window__services{display:grid;grid-template-columns:repeat(4,1fr)}.work-window__service-item{padding:15px;border-right:1px solid rgba(255,255,255,.1);transition:background .2s ease}.work-window__service-item:last-child{border-right:none}.work-window__service-item:hover{background:#ffffff08}.work-window__service-item h3{font-size:15px;font-weight:700;letter-spacing:1px;margin:0 0 8px}.work-window__service-item p{font-size:14px;line-height:1.5;opacity:.7;margin:0}@media(max-width:1200px){.work-window{padding:20px}.work-window__container{max-width:100%}}@media(max-width:700px){.work-window{padding:15px}.work-window__columns,.work-window__animations,.work-window__services{grid-template-columns:1fr}.work-window__service-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}.work-window__service-item:last-child{border-bottom:none}.work-window__title{font-size:32px;letter-spacing:4px}}.thoughts-window{--warm-off-white: #ffffff;--warm-off-white-dim: #cccccc;--text-primary: #ffffff;--text-secondary: #cccccc;--background-dark: #1a1a1a;--font-primary: "PP Neue Montreal", sans-serif;--font-secondary: monospace;--font-sans: "PP Neue Montreal", sans-serif;--font-size-small: 10px;--font-size-regular: 1rem;--font-size-medium: 1.5rem;--font-size-large: 3rem;--spacing-small: .5rem;--spacing-medium: 1rem;--spacing-large: 2rem;--transition-fast: .3s ease;--transition-medium: .5s cubic-bezier(.445, .05, .55, .95);position:relative;width:100%;height:100%;background-color:var(--background-dark);color:var(--text-primary);font-family:var(--font-secondary);font-size:var(--font-size-small);overflow:hidden}.thoughts-window:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(https://img.freepik.com/premium-photo/white-dust-scratches-black-background_279525-2.jpg?w=640);background-repeat:repeat;opacity:.2;mix-blend-mode:multiply;pointer-events:none;z-index:1}.thoughts-window__canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;background:#0f0f0f}.thoughts-window__canvas canvas{display:block;width:100%!important;height:100%!important}.thoughts-window__content{position:relative;width:100%;height:100%;overflow-y:auto;overflow-x:hidden;z-index:2;display:flex;flex-direction:column;align-items:center}.thoughts-window__content>*{width:100%;max-width:1400px}.thoughts-window__header{position:absolute;top:var(--spacing-large);left:0;width:100%;padding:0 var(--spacing-large);display:flex;justify-content:center;z-index:10}.logo-container{position:absolute;left:var(--spacing-large);top:0;display:flex;align-items:center;height:2rem;z-index:10;cursor:pointer}.logo-circles{position:relative;width:100%;height:100%}.circle{position:absolute;border-radius:50%;transition:transform var(--transition-medium);width:1.4rem;height:1.4rem;background-color:var(--text-primary);top:50%}.circle-1{left:0;transform:translateY(-50%)}.circle-2{left:.8rem;transform:translateY(-50%);mix-blend-mode:exclusion}.logo-container:hover .circle-1{transform:translate(-.5rem,-50%)}.logo-container:hover .circle-2{transform:translate(.5rem,-50%)}.center-logo{text-align:center;z-index:10;height:2rem}#logo-text{font-family:var(--font-primary);font-weight:400;font-size:var(--font-size-medium);line-height:1;margin:0;color:var(--text-primary);text-transform:none}.thoughts-window__hero{position:relative;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:10;color:var(--text-primary);padding:6rem var(--spacing-large)}.thoughts-window__hero h1{font-family:var(--font-primary);font-weight:400;font-size:var(--font-size-large);line-height:.9;letter-spacing:-.02em;color:var(--text-primary);text-transform:none;margin:0 0 2rem;max-width:600px}.thoughts-window__hero h2{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;line-height:1.4;opacity:.7;transition:opacity var(--transition-fast);font-weight:400;margin:0}.thoughts-window__hero:hover h2{opacity:1}.thoughts-window__contact{position:absolute;top:50%;left:var(--spacing-large);transform:translateY(-50%);z-index:10;font-family:var(--font-secondary);letter-spacing:.05em;font-size:var(--font-size-small);color:var(--text-primary);text-transform:uppercase}.contact-heading{font-size:var(--font-size-small);color:var(--text-secondary);margin-bottom:var(--spacing-small)}.contact-email{display:block;color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.contact-email:hover{color:var(--text-secondary)}.thoughts-window__footer-links{position:absolute;bottom:var(--spacing-large);left:var(--spacing-large);z-index:10;display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;font-family:var(--font-sans);font-weight:400;font-size:var(--font-size-regular)}.footer-link{color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast);position:relative;padding-left:0;text-transform:none;font-size:1rem}.footer-link:before{content:"";position:absolute;left:0;top:50%;width:0;height:1px;background-color:var(--text-primary);transform:translateY(-50%);transition:width var(--transition-fast),opacity var(--transition-fast);opacity:0}.footer-link:hover{color:var(--text-primary);padding-left:1.2rem}.footer-link:hover:before{width:.8rem;opacity:1}.thoughts-window__coordinates{position:absolute;bottom:var(--spacing-large);right:var(--spacing-large);text-align:right;z-index:10;font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--text-secondary)}.thoughts-window__coordinates p{margin:0}.thoughts-window__list{position:relative;z-index:10;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-medium);padding:var(--spacing-large);padding-top:0;margin-top:var(--spacing-large)}.thoughts-window__card{background:#0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:var(--spacing-medium);transition:all var(--transition-fast)}.thoughts-window__card:hover{background:#0009;border-color:#fff3;transform:translate(-4px)}.thoughts-window__card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-small)}.thoughts-window__card-category{font-family:var(--font-secondary);font-size:var(--font-size-small);color:#9b5de5;text-transform:uppercase;letter-spacing:.1em}.thoughts-window__card-date{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--text-secondary)}.thoughts-window__card-title{font-family:var(--font-primary);font-size:var(--font-size-regular);font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-small) 0;line-height:1.3}.thoughts-window__card-excerpt{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--text-secondary);line-height:1.5;margin:0 0 var(--spacing-small) 0}.thoughts-window__card-link{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--text-primary);background:transparent;border:none;padding:0;cursor:pointer;text-transform:uppercase;letter-spacing:.1em;transition:color var(--transition-fast)}.thoughts-window__card-link:hover{color:#9b5de5}.thought-modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.thought-modal{position:relative;background:#0a0a0a;border:1px solid rgba(255,255,255,.2);max-width:700px;width:100%;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.thought-modal__close{position:absolute;top:20px;right:20px;width:32px;height:32px;background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;font-family:TheGoodMonolith,monospace}.thought-modal__close:hover{background:#ffffff1a;border-color:#fff}.thought-modal__grid-header{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid rgba(255,255,255,.15);font-family:TheGoodMonolith,monospace}.thought-modal__grid-row{display:flex;flex-direction:column;padding:20px 25px;border-right:1px solid rgba(255,255,255,.1)}.thought-modal__grid-row:last-child{border-right:none}.thought-modal__label{font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:#fff6;margin-bottom:6px}.thought-modal__value{font-size:13px;color:#9b5de5;text-transform:uppercase;letter-spacing:.05em}.thought-modal__title{font-family:PP Neue Montreal,-apple-system,BlinkMacSystemFont,sans-serif;font-size:28px;font-weight:500;letter-spacing:-.02em;margin:0;padding:30px 25px 20px;color:#fff;line-height:1.2}.thought-modal__content{padding:0 25px 30px;font-family:PP Neue Montreal,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.75;color:#ffffffd9}.thought-modal__content p{margin:0 0 18px}.thought-modal__content p:last-child{margin-bottom:0}.thought-modal__footer{display:flex;justify-content:space-between;padding:15px 25px;border-top:1px solid rgba(255,255,255,.1);font-family:TheGoodMonolith,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d}@media(max-width:600px){.thoughts-window__list{grid-template-columns:1fr;padding:var(--spacing-medium)}.thoughts-window__hero{padding:var(--spacing-medium);padding-top:4rem}}.thoughts-window__index{display:block}@font-face{font-family:PP Supply Mono;src:url(https://assets.codepen.io/7558/PPSupplyMono-Variable.woff2) format("woff2");font-weight:100 900;font-display:swap}.photography-window{position:relative;width:100%;height:100%;font-family:PP Supply Mono,monospace;background-color:#050505;color:#fae1fa;display:flex;justify-content:center;align-items:center;font-weight:400;font-size:12px;text-transform:uppercase;letter-spacing:.05em;overflow:hidden;z-index:10}.photography-window:after{content:"";position:absolute;top:0;left:0;height:100%;width:100%;background-image:repeating-linear-gradient(transparent,transparent 2px,#ffffff0d 4px);background-size:auto 100%;pointer-events:none;z-index:-1}.portfolio-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#050505;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='4' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.3;z-index:100;pointer-events:none;mix-blend-mode:overlay}.portfolio-container{display:flex;flex-direction:column;gap:0;width:100%;max-width:1200px;height:100%;padding:2rem;margin:0 auto;position:relative;counter-reset:project-counter 0;overflow-y:auto;z-index:10}.project-list{list-style:none;margin:0;padding:0}.album-detail-header{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(200,255,200,.1);z-index:10;position:relative}.back-btn{background:none;border:none;color:#fae1fa;font-family:var(--font-mono, monospace);font-size:12px;cursor:pointer;padding:0 0 1rem;text-transform:uppercase;transition:all .3s ease;display:inline-block;position:relative}.back-btn:hover{opacity:.8}.album-detail-info h2{font-size:24px;margin:0 0 .5rem;color:#fae1fa;font-weight:400;letter-spacing:.1em}.album-detail-info p{margin:0;opacity:.7;max-width:600px;line-height:1.5}.project-item{cursor:pointer;width:100%;display:grid;grid-template-columns:40px 1fr 2fr 1fr 1fr 80px;grid-column-gap:2rem;padding:12px 0;align-items:center;border-bottom:1px solid rgba(200,255,200,.1);transition:all .3s ease;opacity:1;position:relative}.project-item.active{opacity:1;box-shadow:inset 0 1px #c8ffc833,inset 0 -1px #c8ffc833}.portfolio-container.has-active .project-item{opacity:.3}.portfolio-container.has-active .project-item.active{opacity:1}.project-item:before{content:counter(project-counter,decimal-leading-zero);counter-increment:project-counter;padding:4px 0;line-height:.8;opacity:.6;justify-self:start;z-index:10;position:relative;transition:opacity .1s ease}.project-item.counter-hidden:before{opacity:.05}.project-data{font-family:PP Supply Mono,monospace;position:relative;white-space:nowrap;text-decoration:none;color:#fae1fa;z-index:1;transition:all .3s ease;overflow:hidden;text-overflow:ellipsis;line-height:1;padding:2px}.project-data.title,.project-data.location,.project-data.category,.project-data.camera{justify-self:start}.project-data.year{justify-self:end;text-align:right}.project-data:after{content:"";position:absolute;top:0;left:-8px;width:calc(100% + 16px);height:calc(100% - 2px);background:#ffdf00;transition:transform .3s ease;transform:scaleX(0);transform-origin:left;z-index:-1}.project-item:hover .project-data:after{transform:scaleX(1)}.project-item:hover .project-data{color:#0a0a0a!important}.background-image{position:absolute;top:50%;left:50%;width:800px;height:600px;transform:translate(-50%,-50%) scale(1);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity .6s ease,transform .8s cubic-bezier(.25,.46,.45,.94);z-index:5;pointer-events:none}.corner-elements{position:absolute;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:0;width:100%;height:100%;pointer-events:none;padding:2rem;z-index:200}.corner-item{font-family:PP Supply Mono,monospace;color:#fae1fa;font-size:12px;padding:8px;pointer-events:auto}.corner-item a{color:#fae1fa;text-decoration:none}.corner-item a:hover{text-decoration:underline}.top-left{grid-column:1 / 2;grid-row:1 / 2;align-self:start;justify-self:start}.top-right{grid-column:2 / 3;grid-row:1 / 2;align-self:start;justify-self:end}.bottom-left{grid-column:1 / 2;grid-row:2 / 3;align-self:end;justify-self:start}.bottom-right{grid-column:2 / 3;grid-row:2 / 3;align-self:end;justify-self:end}.corner-square{background-color:#fae1fa;width:8px;height:8px}.time-blink{animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:1200px){.project-item{grid-template-columns:30px 1fr 1.5fr .8fr .8fr 60px;grid-column-gap:1rem}.background-image{width:600px;height:450px}}@media(max-width:768px){.portfolio-container{padding:1rem}.project-item{grid-template-columns:30px 1fr 1fr;grid-column-gap:1rem}.project-data:not(.title):not(.location){display:none}.background-image{width:400px;height:300px}}:root{--brightness: 1}.app{width:100%;height:100vh;position:relative;overflow:hidden;background-color:var(--color-bg);transition:filter var(--transition-medium);filter:brightness(calc(.3 + var(--brightness) * .7))}:root{--color-bg: #0a0a0a;--color-bg-rgb: 10, 10, 10;--color-bg-secondary: #151515;--color-bg-tertiary: #1a1a1a;--color-text: #f5f5f5;--color-text-rgb: 245, 245, 245;--color-text-muted: #a0a0a0;--color-text-dim: #666666;--color-accent: #ffffff;--color-accent-secondary: #cccccc;--color-border: #333333;--color-border-strong: #555555;--color-brutal-yellow: #FFE156;--color-brutal-blue: #4ECDC4;--color-brutal-pink: #FF6B9D;--color-brutal-orange: #FF8C42;--color-brutal-purple: #9B5DE5;--shadow-brutal: 4px 4px 0px var(--color-text);--shadow-brutal-lg: 8px 8px 0px var(--color-text);--shadow-brutal-sm: 2px 2px 0px var(--color-text);--shadow-soft: 0 4px 20px rgba(0, 0, 0, .3);--font-primary: "Space Grotesk", sans-serif;--font-mono: "Space Mono", monospace;--font-size-xs: .625rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 3rem;--font-size-massive: clamp(8rem, 15vw, 20rem);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--border-width: 3px;--border-radius: 0px;--border-radius-sm: 2px;--transition-fast: .15s ease;--transition-medium: .3s ease;--transition-slow: .5s cubic-bezier(.25, 1, .5, 1);--window-header-height: 40px;--window-border: var(--border-width) solid var(--color-text);--z-desktop: 1;--z-window: 10;--z-window-active: 100;--z-taskbar: 500;--z-control-panel: 600;--z-preloader: 1000}[data-theme=light]{--color-bg: #f5f5f5;--color-bg-rgb: 245, 245, 245;--color-bg-secondary: #e8e8e8;--color-bg-tertiary: #ffffff;--color-text: #0a0a0a;--color-text-rgb: 10, 10, 10;--color-text-muted: #555555;--color-text-dim: #888888;--color-accent: #000000;--color-accent-secondary: #333333;--color-border: #cccccc;--color-border-strong: #999999;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background-color:var(--color-bg);color:var(--color-text);overflow:hidden;height:100vh;width:100vw;transition:background-color var(--transition-medium),color var(--transition-medium)}#root{height:100%;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);font-weight:700;letter-spacing:-.02em}p{line-height:1.6}a{color:inherit;text-decoration:none}code,pre,.text-mono{font-family:var(--font-mono)}.text-uppercase{text-transform:uppercase;letter-spacing:.1em}.text-muted{color:var(--color-text-muted)}.btn-brutal{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-text);color:var(--color-bg);border:var(--border-width) solid var(--color-text);font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-brutal-sm)}.btn-brutal:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-brutal)}.btn-brutal:active{transform:translate(2px,2px);box-shadow:none}.btn-brutal--outline{background:transparent;color:var(--color-text)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border:1px solid var(--color-bg)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background:var(--color-text);color:var(--color-bg)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.dotted-grid{background-image:radial-gradient(circle,var(--color-border) 1px,transparent 1px);background-size:30px 30px}
