:root{--color-primary:#00f;--color-background:#000;--color-text-primary:#fff;--color-text-secondary:#ccc;--color-text-muted:#999;--color-text-accent:#00f;--color-border:#ffffff1a;--color-overlay:#000000b3;--color-selection:#00f;--color-selection-text:#000;--font-primary:"Inter",sans-serif;--font-secondary:"Chivo",sans-serif;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-bold:700;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-size-6xl:3.75rem;--line-height-tight:1.1;--line-height-snug:1.2;--line-height-normal:1.4;--line-height-relaxed:1.6;--letter-spacing-tight:-0.025em;--letter-spacing-normal:0;--letter-spacing-wide:0.025em;--letter-spacing-wider:0.05em;--letter-spacing-widest:0.1em;--space-0:0;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--border-radius-none:0;--border-radius-sm:0.125rem;--border-radius-base:0.25rem;--border-radius-md:0.375rem;--border-radius-lg:0.5rem;--border-radius-xl:0.75rem;--border-radius-2xl:1rem;--border-radius-full:9999px;--border-width-thin:1px;--border-width-medium:2px;--border-width-thick:3px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-base:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--transition-fast:0.15s ease;--transition-base:0.3s ease;--transition-slow:0.5s ease;--transition-slower:0.8s ease;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--z-toast:1080;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}*{box-sizing:border-box;cursor:crosshair;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{background-color:#000;background-color:var(--color-background);cursor:crosshair;font-family:Chivo,sans-serif;font-family:var(--font-secondary);font-size:1rem;font-size:var(--font-size-base);font-weight:300;font-weight:var(--font-weight-light);height:100vh;line-height:1.4;line-height:var(--line-height-normal);overflow-x:hidden;overflow-y:auto;position:relative;width:100%}body,h1,h2,h3,h4,h5,h6{color:#fff;color:var(--color-text-primary)}h1,h2,h3,h4,h5,h6{font-family:Inter,sans-serif;font-family:var(--font-primary);font-weight:400;font-weight:var(--font-weight-regular);margin:0;padding:0}h1,h2,h3,h4,h5,h6{line-height:1.1;line-height:var(--line-height-tight)}h1{font-size:3rem;font-size:var(--font-size-5xl)}h2{font-size:2.25rem;font-size:var(--font-size-4xl)}h2,h3{line-height:1.2;line-height:var(--line-height-snug)}h3{font-size:1.875rem;font-size:var(--font-size-3xl)}h4{font-size:1.5rem;font-size:var(--font-size-2xl);line-height:1.2;line-height:var(--line-height-snug)}h5{font-size:1.25rem;font-size:var(--font-size-xl)}h5,h6{line-height:1.4;line-height:var(--line-height-normal)}h6{font-size:1.125rem;font-size:var(--font-size-lg)}p{color:#ccc;color:var(--color-text-secondary);font-family:Chivo,sans-serif;font-family:var(--font-secondary);font-size:1.25rem;font-size:var(--font-size-xl);font-weight:300;font-weight:var(--font-weight-light);line-height:1.2;line-height:var(--line-height-snug);margin:0;padding:0}a{color:inherit;text-decoration:none;transition:color .3s ease;transition:color var(--transition-base)}a:hover{color:#00f;color:var(--color-text-accent)}button{background:none;border:none;border-radius:.25rem;border-radius:var(--border-radius-base);color:inherit;cursor:crosshair;font-family:inherit;transition:all .3s ease;transition:all var(--transition-base)}button:hover{color:#00f;color:var(--color-text-accent)}input,select,textarea{background-color:initial;border:1px solid #ffffff1a;border:var(--border-width-thin) solid var(--color-border);border-radius:.25rem;border-radius:var(--border-radius-base);color:#fff;color:var(--color-text-primary);font-family:Chivo,sans-serif;font-family:var(--font-secondary);font-size:1rem;font-size:var(--font-size-base);line-height:1.4;line-height:var(--line-height-normal);padding:.75rem 1rem;padding:var(--space-3) var(--space-4);transition:border-color .3s ease;transition:border-color var(--transition-base)}input:focus,select:focus,textarea:focus{border-color:#00f;border-color:var(--color-text-accent);outline:none}.m-0{margin:0;margin:var(--space-0)}.m-1{margin:.25rem;margin:var(--space-1)}.m-2{margin:.5rem;margin:var(--space-2)}.m-3{margin:.75rem;margin:var(--space-3)}.m-4{margin:1rem;margin:var(--space-4)}.m-5{margin:1.25rem;margin:var(--space-5)}.m-6{margin:1.5rem;margin:var(--space-6)}.m-8{margin:2rem;margin:var(--space-8)}.m-10{margin:2.5rem;margin:var(--space-10)}.m-12{margin:3rem;margin:var(--space-12)}.m-16{margin:4rem;margin:var(--space-16)}.m-20{margin:5rem;margin:var(--space-20)}.m-24{margin:6rem;margin:var(--space-24)}.m-32{margin:8rem;margin:var(--space-32)}.p-0{padding:0;padding:var(--space-0)}.p-1{padding:.25rem;padding:var(--space-1)}.p-2{padding:.5rem;padding:var(--space-2)}.p-3{padding:.75rem;padding:var(--space-3)}.p-4{padding:1rem;padding:var(--space-4)}.p-5{padding:1.25rem;padding:var(--space-5)}.p-6{padding:1.5rem;padding:var(--space-6)}.p-8{padding:2rem;padding:var(--space-8)}.p-10{padding:2.5rem;padding:var(--space-10)}.p-12{padding:3rem;padding:var(--space-12)}.p-16{padding:4rem;padding:var(--space-16)}.p-20{padding:5rem;padding:var(--space-20)}.p-24{padding:6rem;padding:var(--space-24)}.p-32{padding:8rem;padding:var(--space-32)}.text-primary{color:#fff;color:var(--color-text-primary)}.text-secondary{color:#ccc;color:var(--color-text-secondary)}.text-muted{color:#999;color:var(--color-text-muted)}.text-accent{color:#00f;color:var(--color-text-accent)}.font-primary{font-family:Inter,sans-serif;font-family:var(--font-primary)}.font-secondary{font-family:Chivo,sans-serif;font-family:var(--font-secondary)}.font-light{font-weight:300;font-weight:var(--font-weight-light)}.font-regular{font-weight:400;font-weight:var(--font-weight-regular)}.font-medium{font-weight:500;font-weight:var(--font-weight-medium)}.font-bold{font-weight:700;font-weight:var(--font-weight-bold)}.rounded-none{border-radius:0;border-radius:var(--border-radius-none)}.rounded-sm{border-radius:.125rem;border-radius:var(--border-radius-sm)}.rounded{border-radius:.25rem;border-radius:var(--border-radius-base)}.rounded-md{border-radius:.375rem;border-radius:var(--border-radius-md)}.rounded-lg{border-radius:.5rem;border-radius:var(--border-radius-lg)}.rounded-xl{border-radius:.75rem;border-radius:var(--border-radius-xl)}.rounded-2xl{border-radius:1rem;border-radius:var(--border-radius-2xl)}.rounded-full{border-radius:9999px;border-radius:var(--border-radius-full)}.transition-fast{transition:all .15s ease;transition:all var(--transition-fast)}.transition-base{transition:all .3s ease;transition:all var(--transition-base)}.transition-slow{transition:all .5s ease;transition:all var(--transition-slow)}.transition-slower{transition:all .8s ease;transition:all var(--transition-slower)}.btn{align-items:center;background:#0000;border:1px solid #ffffff1a;border:var(--border-width-thin) solid var(--color-border);border-radius:.25rem;border-radius:var(--border-radius-base);color:#fff;color:var(--color-text-primary);cursor:crosshair;display:inline-flex;font-family:Inter,sans-serif;font-family:var(--font-primary);font-size:1rem;font-size:var(--font-size-base);font-weight:500;font-weight:var(--font-weight-medium);justify-content:center;line-height:1.2;line-height:var(--line-height-snug);padding:.75rem 1.5rem;padding:var(--space-3) var(--space-6);text-decoration:none;transition:all .3s ease;transition:all var(--transition-base)}.btn:hover{background:#fff;background:var(--color-text-primary);border-color:#fff;border-color:var(--color-text-primary)}.btn-primary,.btn:hover{color:#000;color:var(--color-background)}.btn-primary{background:#00f;background:var(--color-text-accent)}.btn-primary,.btn-primary:hover{border-color:#00f;border-color:var(--color-text-accent)}.btn-primary:hover{background:#0000;color:#00f;color:var(--color-text-accent)}.card{background:#000;background:var(--color-background);border:1px solid #ffffff1a;border:var(--border-width-thin) solid var(--color-border);border-radius:.5rem;border-radius:var(--border-radius-lg);padding:1.5rem;padding:var(--space-6);transition:all .3s ease;transition:all var(--transition-base)}.card:hover{border-color:#00f;border-color:var(--color-text-accent);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.animate-fade-in{animation:fadeIn .8s ease forwards}.animate-spin{animation:spin 1s linear infinite}@media (max-width:768px){:root{--font-size-5xl:2rem;--font-size-4xl:1.8rem;--font-size-3xl:1.5rem}h1{font-size:3rem;font-size:var(--font-size-5xl)}h1,h1:after,h1:before{background-image:none!important;background:none!important}h1:after,h1:before{content:none!important;display:none!important}h2{font-size:2.25rem;font-size:var(--font-size-4xl)}h3{font-size:1.875rem;font-size:var(--font-size-3xl)}p{font-size:1rem;font-size:var(--font-size-base)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#000;background:var(--color-background)}::-webkit-scrollbar-thumb{background:#333;border-radius:.25rem;border-radius:var(--border-radius-base)}::-webkit-scrollbar-thumb:hover{background:#555}::selection{background-color:#00f;background-color:var(--color-selection);color:#000;color:var(--color-selection-text)}::-moz-selection{background-color:#00f;background-color:var(--color-selection);color:#000;color:var(--color-selection-text)}.animate-in{animation:fadeIn .8s ease forwards}.floating-text-bar{background:var(--color-overlay);padding:var(--space-4) 0;z-index:var(--z-fixed)}.floating-text-content{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-light);letter-spacing:var(--letter-spacing-wider)}#close-menu,#menu-toggle,.about-link,.about-text,.contact-item,a,button{cursor:crosshair!important}@media (max-width:768px){.floating-text-content{font-size:var(--font-size-xs)}}.floating-nav{background:#0000;height:100vh;left:0;padding:var(--space-6);pointer-events:none;position:fixed;top:0;width:180px;z-index:var(--z-fixed)}.floating-nav,.nav-content{align-items:flex-start;display:flex;flex-direction:column;justify-content:flex-start}.nav-content{pointer-events:auto;width:100%}.nav-logo{border-radius:var(--border-radius-base);cursor:pointer;margin:calc(var(--space-2)*-1) calc(var(--space-4)*-1) var(--space-4) calc(var(--space-4)*-1);padding:var(--space-2) var(--space-4);pointer-events:auto;position:relative}.nav-logo,.nav-logo span{transition:all var(--transition-base)}.nav-logo span{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider)}.nav-logo:hover{background:var(--color-text-primary)}.nav-logo:hover span{color:var(--color-background)}.vertical-nav{pointer-events:auto}.vertical-nav,.vertical-nav ul{align-items:flex-start;display:flex;flex-direction:column}.vertical-nav ul{gap:var(--space-1);list-style:none;margin:0;padding:0}.vertical-nav li{margin:0}.nav-link{background:none;border:none;border-radius:var(--border-radius-base);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:calc(var(--space-1)*-1) calc(var(--space-4)*-1);padding:var(--space-1) var(--space-4);position:relative;text-decoration:none;transition:all var(--transition-base)}.nav-link.active,.nav-link:hover{background:var(--color-text-primary);color:var(--color-background)}.connect-link{color:var(--color-text-primary)!important;margin-top:0}.connect-link.active,.connect-link:hover{background:var(--color-text-primary);color:var(--color-background)!important}.mobile-menu-toggle{background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:none;font-size:var(--font-size-lg);margin-top:var(--space-8);padding:0}.mobile-menu{align-items:center;background:var(--color-overlay);display:flex;flex-direction:column;height:100vh;justify-content:center;left:0;position:fixed;top:0;transform:translateX(100%);transition:transform var(--transition-base);width:100%;z-index:var(--z-modal)}.mobile-menu.open{transform:translateX(0)}.close-menu{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-4xl);padding:0;position:absolute;right:var(--space-8);top:var(--space-8)}.mobile-nav ul{list-style:none;margin:0;padding:0;text-align:center}.mobile-nav li{margin:var(--space-8) 0}.mobile-nav .nav-link{background:none;color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);margin:0;padding:0;text-decoration:none;transition:color var(--transition-base)}.mobile-nav .nav-link.active,.mobile-nav .nav-link:hover{background:none;color:var(--color-text-muted)}@media (max-width:768px){.floating-nav{background:var(--color-overlay);height:var(--space-16);padding:0 var(--space-4);width:100%}.floating-nav,.nav-content{flex-direction:row;justify-content:space-between}.nav-content{align-items:center;height:100%}.nav-logo{margin-bottom:0}.nav-logo span{font-size:var(--font-size-base)}.vertical-nav{display:none}.mobile-menu-toggle{display:block;margin-top:0}.mobile-nav .nav-link{font-size:var(--font-size-3xl)}}body{padding-left:0;padding-top:0}@media (max-width:768px){body{padding-left:0;padding-top:var(--space-16)}}.work-page{background:#0000;color:var(--color-text-primary);min-height:100vh;padding:var(--space-8) var(--space-6) var(--space-10);padding-left:180px;position:relative;width:100%}.work-header{margin-bottom:var(--space-16);margin-left:auto;margin-right:auto;max-width:800px;position:relative;text-align:center;z-index:10}.work-header h1{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-5xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-5)}.work-subtitle{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-12)}.projects-list{margin:0 auto;max-width:900px}.project-row,.projects-list{display:flex;flex-direction:column}.project-row{background:#0000;border-bottom:1px solid #ffffff1a;color:inherit;padding:18px 0;text-align:left}.project-row:hover .project-row-name{color:var(--color-text-accent)}.project-row-title{align-items:baseline;display:flex;gap:16px;justify-content:space-between}.project-row-name{font-size:var(--font-size-xl)}.project-row-desc,.project-row-meta{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.project-row-desc{margin-top:6px}.hover-preview{animation:previewIn .25s ease-out forwards;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000004d;border-radius:10px;box-shadow:var(--shadow-lg);opacity:0;overflow:hidden;pointer-events:none;position:fixed;transform:translate(-10%,-10%);width:360px;z-index:var(--z-tooltip)}.hover-preview img,.hover-preview-bg{display:block;height:100%;object-fit:cover;position:relative;width:100%}.hover-preview-caption{bottom:8px;color:#fff;font-size:var(--font-size-xs);left:10px;position:absolute;text-shadow:0 1px 2px #0006}.hover-dissolve{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(8,1fr);inset:0;pointer-events:none;position:absolute}.hover-dissolve-cell{animation:cellOut .25s linear forwards;background:#000;opacity:1}@keyframes cellOut{0%{opacity:1}to{opacity:0}}@keyframes previewIn{0%{opacity:0}to{opacity:1}}.hover-preview:after{background-image:radial-gradient(#ffffff14 1px,#0000 0);background-size:2px 2px;content:"";inset:0;mix-blend-mode:soft-light;pointer-events:none;position:absolute}.grid-item{background:#ffe6e6;border-radius:0;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px));cursor:pointer;height:100%;overflow:hidden;position:relative;width:100%;will-change:transform}.grid-item.aspect-square{aspect-ratio:1/1;grid-row:span 2}.grid-item.aspect-portrait{aspect-ratio:3/4;grid-row:span 3}.grid-item.aspect-landscape{aspect-ratio:4/3;grid-row:span 2}.grid-item-image{overflow:hidden;position:relative}.grid-item-image,.grid-item-image-bg{height:100%;width:100%}.grid-item-overlay{align-items:center;background:var(--color-overlay);bottom:0;display:flex;justify-content:center;left:0;opacity:0;padding:var(--space-8);pointer-events:none;position:absolute;right:0;top:0;transition:opacity var(--transition-base)}.grid-item:hover .grid-item-overlay{opacity:1}.grid-item-content{color:var(--color-text-primary);text-align:center;width:100%}.grid-item-title{align-items:center;color:var(--color-text-primary);display:flex;font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-medium);gap:var(--space-2);justify-content:center;line-height:var(--line-height-snug);margin:0 0 var(--space-2) 0}.external-link-icon{color:var(--color-text-accent);font-size:var(--font-size-base);font-weight:var(--font-weight-regular)}.grid-item-category{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-regular);letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-1) 0;text-transform:uppercase}.grid-item-year{color:var(--color-text-muted);font-family:var(--font-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-light);margin:0}.loading-indicator{align-items:center;display:flex;justify-content:center;padding:var(--space-10) 0;width:100%}.loading-spinner{animation:spin 1s linear infinite;border:var(--border-width-thick) solid #0000ff4d;border-radius:var(--border-radius-full);border-top:var(--border-width-thick) solid var(--color-text-accent);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.view-project-cursor{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-lg);color:var(--color-background);font-family:var(--font-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-regular);padding:var(--space-2) var(--space-4);pointer-events:none;position:fixed;transform:translate(-50%,-50%);white-space:nowrap;z-index:var(--z-tooltip)}@media (max-width:768px){.work-page{padding:var(--space-6) var(--space-4) var(--space-8);padding-left:var(--space-4)}.work-header h1{font-size:var(--font-size-4xl)}.work-subtitle{font-size:var(--font-size-base)}.grid-item-overlay{padding:var(--space-5)}.grid-item-title{font-size:var(--font-size-xl)}}.animate-line{animation:fadeIn .8s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.grid-item{cursor:none}.simple-image-list{display:flex;flex-direction:column;gap:2rem;margin:2rem 0}.image-item{margin:0 auto;max-width:800px;width:100%}.image-item img{border-radius:8px;box-shadow:0 4px 12px #0000004d;display:block;height:auto;transition:transform .3s ease;width:100%}.image-item img:hover{transform:scale(1.02)}@media (max-width:768px){.simple-image-list{gap:1.5rem}.image-item{max-width:100%}}@media (max-width:480px){.simple-image-list{gap:1rem}.image-item img{border-radius:4px}}.project-page{background:#0000;color:#fff;min-height:100vh;padding:40px 0 40px 180px;position:relative}.project-header{margin-bottom:3rem}.back-button{background:none;border:none;color:#3aeba6;cursor:pointer;font-family:Chivo,sans-serif;font-size:1rem;margin-bottom:2rem;padding:0;transition:color .3s ease}.back-button:hover{color:#fff}.project-title{color:#fff;font-family:"IBM Plex Serif",serif;font-size:3.5rem;font-weight:400;line-height:1.2;margin-bottom:2rem}.project-content{display:flex;flex-direction:column;gap:3rem}.project-description p{color:#ccc;font-family:Chivo,sans-serif;font-size:1.2rem;font-weight:300;line-height:1.6;margin-bottom:0}.project-section{margin:3rem 0}.project-section-title{color:#fff;font-family:"IBM Plex Serif",serif;font-size:2rem;font-weight:400;line-height:1.3;margin:0 0 1.5rem}.project-section-content{color:#e0e0e0;font-family:Chivo,sans-serif;font-size:1.1rem;font-weight:300;line-height:1.7}.project-section-content p{margin:0 0 1.5rem}.project-section-content h3{color:#fff;font-family:"IBM Plex Serif",serif;font-size:1.5rem;font-weight:400;line-height:1.3;margin:2rem 0 1rem}.project-section-content ul{list-style-type:disc;margin:0 0 1.5rem;padding-left:2rem}.project-section-content li{margin-bottom:.5rem}.project-section-images{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:2rem 0 3rem}.project-section-image{border-radius:8px;overflow:hidden;width:100%}.project-section-image img{display:block;height:auto;object-fit:cover;width:100%}.project-custom-content{background:#ffffff0d;border-left:4px solid #3aeba6;border-radius:8px;margin:2rem 0;padding:2rem}.project-custom-content p{color:#e0e0e0;font-family:Chivo,sans-serif;font-size:1.1rem;font-weight:300;line-height:1.7;margin:0 0 1.5rem}.project-custom-content h2{color:#fff;font-family:"IBM Plex Serif",serif;font-size:2rem;font-weight:400;line-height:1.3;margin:2.5rem 0 1.5rem}.project-custom-content h2:first-child{margin-top:0}.project-custom-content h3{color:#fff;font-family:"IBM Plex Serif",serif;font-size:1.5rem;font-weight:400;line-height:1.3;margin:2rem 0 1rem}.project-custom-content ul{color:#e0e0e0;font-family:Chivo,sans-serif;font-size:1.1rem;font-weight:300;line-height:1.7;list-style-type:disc;margin:0 0 1.5rem;padding-left:2rem}.project-custom-content li{margin-bottom:.5rem}.project-gallery,.project-video{margin:2rem 0}.video-link{border:2px solid #3aeba6;border-radius:8px;color:#3aeba6;display:inline-block;font-family:Chivo,sans-serif;font-size:1.1rem;font-weight:400;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.video-link:hover{background:#3aeba6;color:#000;transform:translateY(-2px)}.video-embed{border-radius:8px;box-shadow:0 4px 12px #0000004d;margin:0 auto;max-width:800px;overflow:hidden;width:100%}.video-embed iframe{border:none;border-radius:8px;height:400px;width:100%}@media (max-width:768px){.video-embed iframe{height:250px}}.project-loading{align-items:center;color:#ccc;display:flex;font-family:Chivo,sans-serif;font-size:1.2rem;justify-content:center;min-height:60vh}@media (max-width:768px){.project-page{padding:30px 0 30px 2rem}.project-title{font-size:2.5rem}.project-description p{font-size:1.1rem}.project-custom-content h2{font-size:1.75rem}.project-custom-content h3{font-size:1.25rem}.project-custom-content p,.project-custom-content ul{font-size:1rem}.project-section-title{font-size:1.75rem}.project-section-content{font-size:1rem}.project-section-content h3{font-size:1.25rem}.project-section-images{gap:1.5rem;grid-template-columns:1fr}.video-link{font-size:1rem;padding:.8rem 1.5rem}}@media (max-width:480px){.project-page{padding:20px 0 20px 1rem}.project-title{font-size:2rem}.project-description p{font-size:1rem}.project-custom-content{padding:1.5rem}.project-custom-content h2{font-size:1.5rem}.project-custom-content h3{font-size:1.1rem}.project-custom-content p,.project-custom-content ul{font-size:.95rem}.project-section-title{font-size:1.5rem}.project-section-content{font-size:.95rem}.project-section-content h3{font-size:1.1rem}.project-section-images{gap:1rem}.video-link{font-size:.9rem;padding:.7rem 1.2rem}}.about-page{min-height:100vh;padding:var(--space-8) 0;padding-left:200px;width:100%}.about-content{display:flex;flex-direction:column;gap:var(--space-16)}.about-section{margin-bottom:var(--space-8);text-align:center}.about-section h1{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-5xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-8)}.about-text{margin:0 auto;max-width:800px;text-align:left}.about-text p{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-6)}.about-link{color:var(--color-text-accent);text-decoration:none;transition:color var(--transition-base)}.about-link:hover{color:var(--color-text-primary)}.cv-section{margin-top:var(--space-16)}.cv-section h2{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-4xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-12);text-align:left}.cv-timeline-grid{grid-gap:var(--space-4) var(--space-16);display:grid;gap:var(--space-4) var(--space-16);grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1200px;padding:0 var(--space-8)}.cv-item{align-items:flex-start;display:flex;gap:var(--space-4);padding:var(--space-1) 0}.cv-year{color:var(--color-text-accent);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);min-width:60px;text-align:right}.cv-content{flex:1 1}.cv-title{color:var(--color-text-primary);font-family:var(--font-secondary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-regular);line-height:var(--line-height-tight);margin:0}.experience-list{max-width:100%;padding:0 var(--space-8);width:100%}.experience-list ul{grid-gap:var(--space-4) var(--space-8);display:grid;gap:var(--space-4) var(--space-8);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));list-style:none;margin:0;padding:0;width:100%}.experience-list li{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);padding-left:var(--space-6);position:relative}.experience-list li:before{color:var(--color-text-accent);content:"•";font-size:var(--font-size-2xl);left:0;line-height:var(--line-height-normal);position:absolute}.about-footer{border-top:var(--border-width-thin) solid var(--color-border);margin-top:var(--space-16);padding-top:var(--space-8);text-align:center}.about-footer p{color:var(--color-text-muted);font-family:var(--font-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-2)}@media (max-width:768px){.about-page{padding:var(--space-4);padding-left:var(--space-4)}.about-section h1{font-size:var(--font-size-4xl)}.about-text p{font-size:var(--font-size-base)}.cv-timeline-grid{gap:var(--space-2);grid-template-columns:1fr;max-width:600px}.cv-timeline-grid,.experience-list{padding:0 var(--space-4)}.experience-list ul{gap:var(--space-3) var(--space-4);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.experience-list li{font-size:var(--font-size-base)}.cv-item{flex-direction:column;gap:var(--space-1);padding:var(--space-1) 0;text-align:center}.cv-year{min-width:auto;text-align:center}}@media (max-width:480px){.about-content{gap:var(--space-8)}.cv-section h2{font-size:var(--font-size-4xl)}.cv-timeline-grid,.experience-list{padding:0 var(--space-2)}.experience-list ul{gap:var(--space-2);grid-template-columns:1fr}.experience-list li{font-size:var(--font-size-sm)}}.manifesto-page{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:var(--space-8)}.manifesto-content{margin:0 auto;max-width:800px;width:100%}.manifesto-header{margin-bottom:var(--space-16);text-align:center}.manifesto-header h1{color:var(--color-text-accent);font-family:var(--font-primary);font-size:var(--font-size-6xl);font-weight:var(--font-weight-regular);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight);margin:0}.manifesto-text{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-8)}.manifesto-text p{margin-bottom:var(--space-8);text-align:left}.manifesto-list{list-style:none;margin:var(--space-8) 0;padding:0}.manifesto-list li{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-4)}.manifesto-actions{margin:var(--space-12) 0;text-align:center}.manifesto-actions p{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-4)}.manifesto-emphasis{color:var(--color-text-accent)!important;font-family:var(--font-primary);font-size:var(--font-size-4xl)!important;font-weight:var(--font-weight-regular)!important;margin-bottom:var(--space-12)!important;margin-top:var(--space-8)!important;text-align:center!important}.manifesto-footer{border-top:var(--border-width-thin) solid var(--color-border);margin-top:var(--space-16);padding-top:var(--space-8);text-align:center}.manifesto-footer p{color:var(--color-text-muted);font-family:var(--font-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-2)}.animate-line{transition:opacity .8s ease,transform .8s ease}@media (max-width:768px){.manifesto-page{padding:var(--space-4)}.manifesto-header h1{font-size:var(--font-size-5xl)}.manifesto-text{font-size:var(--font-size-lg)}.manifesto-list li{font-size:var(--font-size-base)}.manifesto-actions p{font-size:var(--font-size-xl)}.manifesto-emphasis{font-size:var(--font-size-3xl)!important}}@media (max-width:480px){.manifesto-header h1{font-size:var(--font-size-4xl)}.manifesto-text{font-size:var(--font-size-base)}.manifesto-actions p{font-size:var(--font-size-lg)}.manifesto-emphasis{font-size:var(--font-size-2xl)!important}}.connect-page{min-height:100vh;padding:var(--space-8) 0;padding-left:200px;width:100%}.connect-content{display:flex;flex-direction:column;gap:var(--space-16)}.connect-section{margin-bottom:var(--space-8);text-align:center}.connect-section h1{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-5xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-8)}.connect-text{margin:0 auto;max-width:800px;text-align:left}.connect-text p{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-xl);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-6)}.connect-link{color:var(--color-text-accent);text-decoration:none;transition:color var(--transition-base)}.connect-link:hover{color:var(--color-text-primary)}.contact-links-section{margin-top:var(--space-8);text-align:center}.contact-links-section h2{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-4xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-8)}.contact-links{align-items:center;display:flex;flex-direction:column;gap:var(--space-4)}.contact-item{margin:0}.contact-link{color:var(--color-text-accent);font-family:var(--font-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-light);padding:var(--space-2) var(--space-4);position:relative;text-decoration:none}.contact-link,.contact-link:after{transition:all var(--transition-base)}.contact-link:after{background-color:var(--color-text-accent);bottom:0;content:"";height:var(--border-width-thin);left:50%;position:absolute;transform:translateX(-50%);width:0}.contact-link:hover{color:var(--color-text-primary)}.contact-link:hover:after{width:100%}.services-section{margin-top:var(--space-16)}.services-section h2{color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-4xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-12);text-align:center}.services-grid{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.service-item{background:#0000ff0d;border:var(--border-width-thin) solid #0000;border-radius:var(--border-radius-lg);padding:var(--space-8);transition:all var(--transition-base)}.service-item:hover{background:#0000ff1a;border-color:#0000ff4d;transform:translateY(-5px)}.service-item h3{color:var(--color-text-accent);font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-regular);margin-bottom:var(--space-4)}.service-item p{color:var(--color-text-secondary);font-family:var(--font-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-light);line-height:var(--line-height-relaxed)}.connect-footer{border-top:var(--border-width-thin) solid var(--color-border);margin-top:var(--space-16);padding-top:var(--space-8);text-align:center}.connect-footer p{color:var(--color-text-muted);font-family:var(--font-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-light);line-height:var(--line-height-normal);margin-bottom:var(--space-2)}.animate-line{opacity:0;transform:translateY(20px);transition:all .8s ease}.animate-line.visible{opacity:1;transform:translateY(0)}@media (max-width:768px){.connect-page{padding:var(--space-4);padding-left:var(--space-4)}.connect-section h1{font-size:var(--font-size-4xl)}.connect-text p{font-size:var(--font-size-base)}.services-grid{grid-template-columns:1fr}.contact-link{font-size:var(--font-size-base)}}@media (max-width:480px){.connect-content{gap:var(--space-8)}.contact-links-section h2,.services-section h2{font-size:var(--font-size-4xl)}.service-item{padding:var(--space-6)}}.floating-text-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;bottom:0;left:0;overflow:hidden;padding:1rem 0;position:fixed;white-space:nowrap;width:100%;z-index:50}.floating-text-content{animation:floatText 60s linear infinite;color:#fff;display:inline-block;font-family:Chivo,sans-serif;font-size:.875rem;font-weight:300;letter-spacing:.2em}@keyframes floatText{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@media (max-width:768px){.floating-text-content{font-size:.75rem}}.loading-screen{align-items:center;background-color:#000;color:#fff;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:10000}.loading-content{max-width:400px;text-align:center;width:100%}.loading-text-container{align-items:center;display:flex;height:4rem;justify-content:center;margin-bottom:2rem;position:relative}.loading-subtitle,.loading-title{font-family:"IBM Plex Serif",serif;font-size:2.5rem;font-weight:400;left:50%;letter-spacing:2px;margin:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .8s ease-in-out}.loading-title{opacity:1;transform:translate(-50%,-50%) scale(1)}.loading-subtitle,.loading-title.fade-out{opacity:0;transform:translate(-50%,-50%) scale(.8)}.loading-subtitle.fade-in{opacity:1;transform:translate(-50%,-50%) scale(1)}.loading-bar-container{background-color:#333;height:2px;margin-bottom:1rem;overflow:hidden;position:relative;width:100%}.loading-bar{background-color:#3aeba6;height:100%;position:relative;transition:width .3s ease}.loading-bar:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.loading-text{color:#888;font-family:Chivo,sans-serif;font-size:1rem;margin:0}@media (max-width:768px){.loading-subtitle,.loading-title{font-size:2rem}.loading-text-container{height:3.5rem}.loading-content{max-width:300px;padding:0 1rem}}.dithering-background{background-color:#0a0a0a;height:100vh;left:0;mix-blend-mode:normal;opacity:.06;pointer-events:none;position:fixed;top:0;width:100vw;z-index:-10}@media (max-width:768px){.dithering-background{opacity:.05}}.App{background-color:initial;color:var(--color-text-primary);min-height:100vh;position:relative}.main-content{margin:0 auto;max-width:1400px;min-height:calc(100vh - var(--space-20));padding-left:var(--space-5);padding-right:var(--space-5);padding-top:var(--space-20);position:relative;z-index:1}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{transition:opacity var(--transition-slow),transform var(--transition-slow)}.page-enter-active,.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity var(--transition-base),transform var(--transition-base)}@media (max-width:768px){.main-content{min-height:calc(100vh - var(--space-16));padding-top:var(--space-16)}}.main-content{padding-bottom:var(--space-16)}.load-grid{display:none;gap:0;grid-template-columns:repeat(24,1fr);grid-template-rows:repeat(16,1fr);height:100vh;left:0;pointer-events:none;position:fixed;top:0;width:100vw;z-index:9999}.load-grid-item{background-color:#000;height:100%;opacity:0;width:100%}.load-grid{z-index:10000}.page-preloader{align-items:center;background-color:var(--color-overlay);color:var(--color-text-primary);display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:var(--z-modal)}.preloader-content{text-align:center}.preloader-spinner{animation:spin 1s linear infinite;border:var(--border-width-medium) solid #333;border-radius:var(--border-radius-full);border-top:var(--border-width-medium) solid var(--color-text-accent);height:40px;margin:0 auto var(--space-4);width:40px}.preloader-content p{color:var(--color-text-muted);font-family:var(--font-secondary);margin-bottom:var(--space-4)}.preloader-progress{background-color:#333;border-radius:var(--border-radius-full);height:2px;margin:0 auto;overflow:hidden;position:relative;width:200px}.preloader-progress-bar{background-color:var(--color-text-accent);height:100%;transition:width var(--transition-base)}
/*# sourceMappingURL=main.39600ea4.css.map*/