.logo-img{display:block;height:auto}body.dark-mode .logo-img{filter:invert(1) brightness(1.15) contrast(1.02)}:root{--bg-color: #ffffff;--text-main: #1a1a1a;--text-secondary: #555555;--text-muted: #888888;--border-color: #eeeeee;--card-bg: #f0f0f0;--hero-bg: #eeeeee;--hover-opacity: .6;--btn-hover: #000000;--tag-bg: #f7f9fc;--tag-text: #475569;--header-tint: rgba(255, 255, 255, .94);--input-placeholder: #a0a0a0;--img-bg: #2b2b2b;--frame-fade: 1s;--frame-interval: 2.8s;--hero-padding-x: 2rem;--hero-padding-y: 2.25rem;--hero-inner-gap: 1.25rem;--hero-top-vert-adjust: 6px;--section-padding-y: 6rem;--section-spacing: 6rem;--section-spacing-mobile: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 999px}@font-face{font-family:Switzer;src:url(/fonts/Switzer-Variable.woff2) format("woff2"),url(/fonts/Switzer-Variable.woff) format("woff"),url(/fonts/Switzer-Variable.ttf) format("truetype"),url(/fonts/Switzer-Variable.eot);font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:"Instrument Serif";src:url(/fonts/InstrumentSerif-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}body.dark-mode{--bg-color: #121212;--text-main: #e0e0e0;--text-secondary: #aaaaaa;--text-muted: #666666;--border-color: #333333;--card-bg: #1e1e1e;--hero-bg: #222222;--hover-opacity: .8;--btn-hover: #ffffff;--tag-bg: #272727;--tag-text: #cfcfcf;--header-tint: rgba(0, 0, 0, .9);--input-placeholder: #555555}*{margin:0;padding:0;box-sizing:border-box}::selection{background:#000;color:#fff}::-moz-selection{background:#000;color:#fff}body.dark-mode ::selection{background:#fff;color:#000}body.dark-mode ::-moz-selection{background:#fff;color:#000}body{font-family:Switzer,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-main);line-height:1.6;overflow-x:hidden;transition:background-color .3s,color .3s}a{text-decoration:none;color:inherit;transition:opacity .3s;cursor:pointer}a:hover{opacity:var(--hover-opacity)}h1{font-size:2.5rem;font-weight:600;letter-spacing:-.03em;margin-bottom:.5rem}h2{font-size:1.8rem;font-weight:600;margin-bottom:1rem;letter-spacing:-.02em}h3{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}p{margin-bottom:1.5rem;font-size:1rem;color:var(--text-secondary);max-width:700px;transition:color .3s}.subtitle{color:var(--text-muted);font-size:1rem;margin-bottom:3rem;transition:color .3s}.services-subtitle{margin-bottom:1rem}.container{max-width:1200px;margin:0 auto;padding:2rem 2rem 0;position:relative;z-index:1;transition:margin-top .1s ease-out}@media(max-width:768px){.container{padding:2rem 1rem 0!important}.navbar{padding:1.5rem 1rem!important}}.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s cubic-bezier(.4,0,.2,1),visibility .4s cubic-bezier(.4,0,.2,1);cursor:zoom-out}.lightbox.active{opacity:1;visibility:visible}.lightbox-image{max-width:90%;max-height:90vh;object-fit:contain;transform:scale(.9);opacity:0;filter:blur(20px);border-radius:8px;border:1px solid var(--border-color);transition:transform .6s cubic-bezier(.2,.8,.2,1),opacity .6s cubic-bezier(.2,.8,.2,1),filter .6s cubic-bezier(.2,.8,.2,1);cursor:default;will-change:transform,opacity,filter}.lightbox.active .lightbox-image{transform:scale(1);opacity:1;filter:blur(0)}.lightbox-close{position:absolute;top:2rem;right:2rem;background:transparent;border:none;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ffffffb3;transition:all .3s ease;z-index:10001}.lightbox-close:hover{color:#fff;background:transparent}.lightbox-close svg{width:24px;height:24px}@media(max-width:768px){.lightbox-close{top:1rem;right:1rem;width:40px;height:40px}.lightbox-image{max-width:95%;max-height:85vh}}.page-transition{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:9999;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s cubic-bezier(.4,0,.2,1),visibility .35s cubic-bezier(.4,0,.2,1)}.page-transition.active{opacity:1;visibility:visible;pointer-events:auto}.transition-rect{display:none}.progressive-blur-top{position:fixed;top:0;left:0;right:0;height:120px;z-index:199;pointer-events:none;backdrop-filter:blur(48px);-webkit-backdrop-filter:blur(48px);mask-image:linear-gradient(to bottom,#000,#000000b3 40%,#0000004d 75%,#0000);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.3) 75%,rgba(0,0,0,0) 100%);opacity:0;transition:opacity .6s}.progressive-blur-top.visible{opacity:1}.gradient-overlay-top{position:fixed;top:0;left:0;right:0;height:120px;z-index:198;pointer-events:none;background:linear-gradient(to bottom,rgba(255,255,255,.5) 0%,rgba(255,255,255,.3) 30%,rgba(255,255,255,.1) 60%,transparent 100%);opacity:0;transition:opacity .6s}.gradient-overlay-top.visible{opacity:1}body.dark-mode .gradient-overlay-top{background:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,rgba(0,0,0,.3) 30%,rgba(0,0,0,.1) 60%,transparent 100%)}.navbar{position:fixed;top:0;left:0;right:0;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;z-index:200;opacity:0;filter:blur(10px);pointer-events:none;transition:opacity .6s,filter .6s}.navbar.visible{opacity:1;filter:blur(0);pointer-events:auto}.nav-right{display:flex;align-items:center;gap:2rem}.nav-links{display:flex;gap:2rem}.nav-btn{font-size:.9rem;text-transform:uppercase;letter-spacing:.03em;font-weight:400;color:var(--text-secondary);transition:color .4s cubic-bezier(.4,0,.2,1),font-weight .5s cubic-bezier(.4,0,.2,1),letter-spacing .4s cubic-bezier(.4,0,.2,1);position:relative}.nav-btn:hover{color:var(--text-main);opacity:1}.nav-btn.active{color:var(--text-main);opacity:1;font-weight:700;letter-spacing:.1em}.theme-toggle{background:none;border:none;cursor:pointer;color:var(--text-main);padding:5px;display:flex;align-items:center;justify-content:center;transition:opacity .3s}.theme-toggle:hover{opacity:.6}.theme-icon{width:24px;height:24px;fill:currentColor;transition:transform .6s cubic-bezier(.4,0,.2,1)}body.dark-mode .theme-icon{transform:rotate(180deg)}.burger-menu{display:none;position:relative;width:24px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:300}.burger-line{position:absolute;width:100%;height:2px;background-color:var(--text-main);border-radius:2px;left:0;transition:top .3s .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),opacity .3s .3s cubic-bezier(.4,0,.2,1)}.burger-line:nth-child(1){top:0;transform:translateY(0)}.burger-line:nth-child(2){top:50%;transform:translateY(-50%)}.burger-line:nth-child(3){top:100%;transform:translateY(-100%)}.burger-menu.active .burger-line{transition:top .3s cubic-bezier(.4,0,.2,1),transform .3s .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1)}.burger-menu.active .burger-line:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.burger-menu.active .burger-line:nth-child(2){opacity:0;transform:translateY(-50%) scale(.1)}.burger-menu.active .burger-line:nth-child(3){top:50%;transform:translateY(-50%) rotate(-45deg)}@media(max-width:768px){.burger-menu{display:flex}.nav-links{position:fixed;top:0;right:-100%;height:100vh;width:100%;background:var(--bg-color);flex-direction:column;align-items:flex-start;justify-content:center;padding:2rem;gap:2rem;transition:right .4s cubic-bezier(.4,0,.2,1);z-index:250}.nav-links.active{right:0}.nav-btn{font-size:2rem;width:100%;text-align:left}body.mobile-menu-open{overflow:hidden}.mobile-menu-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;opacity:0;visibility:hidden;transition:opacity .4s cubic-bezier(.4,0,.2,1),visibility .4s cubic-bezier(.4,0,.2,1);z-index:200}.mobile-menu-backdrop.active{opacity:1;visibility:visible}.navbar{z-index:300}}header#main-header{position:absolute;top:0;left:0;width:100%;min-height:100vh;min-height:calc(var(--vh, 1vh) * 100);min-height:100dvh;height:100vh;height:calc(var(--vh, 1vh) * 100);height:100dvh;max-height:100vh;max-height:calc(var(--vh, 1vh) * 100);max-height:100dvh;z-index:100;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;background-color:var(--bg-color);transform-origin:top center;transition:transform .1s ease-out,opacity .1s ease-out,border-width .1s ease-out,border-radius .1s ease-out,background-color .1s ease-out,height .15s ease-out,min-height .15s ease-out,max-height .15s ease-out;will-change:transform,opacity,border-width,border-radius,background-color,height;border:0 solid var(--border-color);border-radius:0;box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom,0)}#ascii-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none;overflow:hidden;opacity:1;transition:opacity .5s ease}@media(max-width:768px){#ascii-background{display:none}}.header-contact-text{position:absolute;top:2.25rem;right:2rem;font-size:3rem;font-weight:400;letter-spacing:-.03em;line-height:1;color:var(--text-main);text-decoration:none;z-index:5;cursor:pointer;transition:opacity .3s ease,font-weight .3s ease}.header-contact-text:hover{opacity:1;font-weight:600}.hero-content{flex-grow:1;display:block;padding:2rem;width:100%;height:100%;position:relative;z-index:2}.hero-content h1{position:absolute;top:2rem;left:2rem;font-size:3.5rem;font-weight:400;letter-spacing:-.03em;line-height:1;margin:0;z-index:5;cursor:default}.hero-name{display:inline-block;white-space:nowrap}.hero-name .char{display:inline-block;font-weight:400;transition:font-weight .15s ease-out;will-change:font-weight}.mobile-hero-intro{display:none}.hero-thumbnail-frame{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:560px;height:420px;background-color:var(--card-bg);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;visibility:hidden;pointer-events:none;z-index:6;border:1px solid var(--border-color);transition:opacity .3s cubic-bezier(.4,0,.2,1),visibility .3s cubic-bezier(.4,0,.2,1);box-shadow:none;border-radius:0;overflow:hidden}.frame-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease-in-out;z-index:4}.frame-video.visible{opacity:1}.frame-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:2;transition:filter .6s ease-in-out;filter:blur(0px) brightness(1);-webkit-filter:blur(0px) brightness(1);will-change:filter}@media(max-width:768px){.hero-thumbnail-frame.visible{pointer-events:auto;touch-action:pan-y}}.frame-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;pointer-events:none;z-index:5;transition:opacity .6s ease-in-out,filter .6s ease-in-out;filter:blur(0px) brightness(1);-webkit-filter:blur(0px) brightness(1);will-change:opacity,filter}.swipe-container-current,.swipe-container-next,.swipe-slide{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:3;transform:translate(0) scale(1);transition:none;will-change:transform,opacity;border-radius:inherit}.swipe-container-current,.swipe-slide-current{opacity:1;z-index:3}.swipe-container-next,.swipe-slide-next{opacity:0;z-index:2}.swipe-indicator{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:none;gap:.5rem;align-items:center;justify-content:center;z-index:10;pointer-events:none}@media(max-width:768px){.swipe-indicator{display:flex;bottom:auto;top:calc(48% + 37.5vw + 1rem);transform:translate(-50%)}}.swipe-dot{width:6px;height:6px;border-radius:50%;background-color:#fff6;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0}.swipe-dot.active{width:24px;height:6px;border-radius:3px;background-color:#ffffffe6;box-shadow:0 0 8px #ffffff80}body.dark-mode .swipe-dot{background-color:#ffffff4d}body.dark-mode .swipe-dot.active{background-color:#fffc;box-shadow:0 0 8px #fff6}.frame-loader{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background-color:var(--card-bg);z-index:1}.frame-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(0,0,0,.1);border-top-color:var(--text-main);animation:spin .9s linear infinite}body.dark-mode .frame-spinner{border-color:#ffffff1a;border-top-color:var(--text-main)}.frame-show-all-text{position:absolute;inset:0;display:none;align-items:center;justify-content:center;text-align:center;font-size:4rem;font-weight:400;color:var(--text-main);line-height:1.2;z-index:2;pointer-events:none;padding:1.5rem;flex-wrap:wrap;gap:.5rem}.frame-word,.frame-arrow{display:inline-block;opacity:0;transform:translateY(30px);will-change:opacity,transform}.frame-arrow{font-size:1.2em;margin-left:.25rem}@keyframes frameTextFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.frame-show-all-text{font-size:2.5rem;padding:1rem}}@media(max-height:700px){.frame-show-all-text{font-size:3rem;padding:1rem;line-height:1.1}}@media(max-height:600px){.frame-show-all-text{font-size:2.25rem;padding:.75rem;line-height:1.1}}@media(max-height:500px){.frame-show-all-text{font-size:1.75rem;padding:.5rem;line-height:1;gap:.25rem}}.hero-thumbnail-frame.visible{opacity:1;visibility:visible;animation:frameScaleUp .25s cubic-bezier(.2,.8,.2,1) forwards}.hero-thumbnail-frame.fading-out{animation:frameFadeOut .2s ease-out forwards!important}@keyframes frameFadeOut{0%{opacity:1}to{opacity:0}}.hero-thumbnail-frame.zooming{position:fixed!important;z-index:10002!important;opacity:1!important;visibility:visible!important;animation:none!important;transition:transform .4s cubic-bezier(.4,0,.2,1),border-width .4s cubic-bezier(.4,0,.2,1),border-color .4s cubic-bezier(.4,0,.2,1)!important;will-change:transform;transform-origin:center center;border-width:0!important;border-color:transparent!important}@keyframes frameScaleUp{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.swipe-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:none;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:999px;box-shadow:0 2px 8px #0000004d;opacity:0;visibility:hidden;transition:opacity .4s ease-out,visibility .4s ease-out;pointer-events:none;z-index:15;font-size:.75rem;color:#ffffffe6;white-space:nowrap}@media(max-width:768px){.swipe-hint{bottom:1rem;left:50%;transform:translate(-50%)}}.swipe-hint.visible{opacity:1;visibility:visible}.swipe-hint-icon{display:inline-block;font-size:.9rem;letter-spacing:.2em;animation:swipeHintSlide 1.5s ease-in-out infinite}@keyframes swipeHintSlide{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.swipe-hint-text{font-weight:500}body.dark-mode .swipe-hint{background:#ffffff26;color:#fffffff2;box-shadow:0 2px 8px #ffffff1a}.hero-project-list{position:absolute;bottom:2rem;left:2rem;list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.1rem;width:200px}.hero-project-item{font-size:1.1rem;font-weight:400;color:var(--text-secondary);letter-spacing:.02em;cursor:pointer;transition:color .3s ease,font-weight .2s ease;display:flex;align-items:center;gap:.5rem;width:100%;padding:.15rem 0}.hero-project-item .arrow-indicator{opacity:0;transition:opacity .3s ease,color .3s ease,text-shadow .3s ease;font-size:.9em;margin-left:.05rem;color:#34d399;text-shadow:0 0 5px rgba(52,211,153,.6),0 0 10px rgba(52,211,153,.4),0 0 16px rgba(52,211,153,.2);animation:arrow-glow 2s ease-in-out infinite}.hero-project-item.active{color:var(--text-main);font-weight:600}.hero-project-item.active .arrow-indicator{opacity:1}@keyframes arrow-glow{0%,to{text-shadow:0 0 5px rgba(52,211,153,.6),0 0 10px rgba(52,211,153,.4),0 0 16px rgba(52,211,153,.2)}50%{text-shadow:0 0 8px rgba(52,211,153,.8),0 0 14px rgba(52,211,153,.5),0 0 22px rgba(52,211,153,.3)}}.hero-project-item:hover{color:var(--text-main);font-weight:600}.hero-project-dot{display:none}.scroll-down-button{position:absolute;bottom:2rem;right:2rem;width:120px;height:120px;background:transparent;border:none;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;opacity:1;transform:scale(1);transition:opacity .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1);pointer-events:auto}.scroll-down-button.hidden{opacity:0;transform:scale(.9);pointer-events:none}.scroll-down-button:hover{transform:scale(1.05)}.scroll-down-button:active{transform:scale(.95)}.scroll-down-circle{width:100%;height:100%;position:absolute;top:0;left:0;color:var(--text-main);animation:rotate 20s linear infinite}.scroll-circle-bg{opacity:.3;transition:opacity .3s ease}.scroll-down-button:hover .scroll-circle-bg{opacity:.6}.scroll-text{font-size:9px;font-weight:600;letter-spacing:.08em;fill:currentColor;opacity:.7;text-transform:uppercase}.scroll-arrow{position:relative;z-index:2;color:var(--text-main);transition:transform .3s ease}.scroll-down-button:hover .scroll-arrow{transform:translateY(4px)}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.mobile-card-stack{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:85%;max-width:320px;aspect-ratio:4 / 3;z-index:6;pointer-events:auto}.mobile-card{position:absolute;top:0;left:0;width:100%;height:100%;aspect-ratio:4 / 3;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 10px 40px #0000001a;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;transition:transform .3s ease-out,opacity .3s ease-out;will-change:transform;transform-origin:center center;pointer-events:auto;overflow:hidden}.mobile-card-image{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;transition:filter .4s ease-out;will-change:filter;filter:brightness(1) blur(0px)}.mobile-card:active{cursor:grabbing}.mobile-project-info{display:none;position:absolute;bottom:120px;left:50%;transform:translate(-50%);text-align:center;z-index:7;width:85%;max-width:320px;pointer-events:auto}.mobile-project-title{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--text-main);margin-bottom:.5rem;display:block;opacity:1;transform:translateY(0);filter:blur(0px);transition:opacity .2s ease-out,transform .2s ease-out,filter .2s ease-out}.mobile-project-title.fade-out{opacity:0;transform:translateY(-20px);filter:blur(8px)}.mobile-project-title.fade-in{opacity:0;transform:translateY(20px);filter:blur(8px);animation:fadeInUpBlur .3s ease-out forwards}@keyframes fadeInUpBlur{to{opacity:1;transform:translateY(0);filter:blur(0px)}}.mobile-project-tag{font-size:.9rem;color:var(--text-secondary);display:block;margin-bottom:1rem;opacity:1;transform:translateY(0);filter:blur(0px);transition:opacity .2s ease-out,transform .2s ease-out,filter .2s ease-out}.mobile-project-tag.fade-out{opacity:0;transform:translateY(-15px);filter:blur(6px)}.mobile-project-tag.fade-in{opacity:0;transform:translateY(15px);filter:blur(6px);animation:fadeInUpBlurTag .3s ease-out forwards}@keyframes fadeInUpBlurTag{to{opacity:1;transform:translateY(0);filter:blur(0px)}}.mobile-view-project-btn{padding:12px 32px;background-color:var(--text-main);color:var(--bg-color);border:none;border-radius:999px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .3s;font-family:inherit}.mobile-view-project-btn:hover{opacity:.8}.scroll-down-text{display:none;position:absolute;bottom:2rem;left:50%;transform:translate(-50%);font-size:.85rem;font-weight:400;color:var(--text-secondary);text-transform:lowercase;letter-spacing:.05em;z-index:5;pointer-events:none;animation:sweep 3s ease-in-out infinite;transition:none}@media(max-width:768px){.scroll-down-text{bottom:calc(env(safe-area-inset-bottom,0px) + 5rem)}.header-contact-text{top:1.5rem;right:1rem;font-size:2rem}.hero-content{padding:1rem}.hero-content h1{top:1.5rem;left:1rem;font-size:2rem;max-width:calc(100% - 2rem)}.hero-name{white-space:normal;word-break:break-word}.mobile-hero-intro{display:block;position:absolute;top:4.5rem;left:1rem;right:1rem;z-index:5}.mobile-intro-text{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--text-secondary);margin:0;max-width:280px}.hero-thumbnail-frame{width:100vw!important;height:75vw!important;max-width:100vw;max-height:75vw;top:48%!important;transform:translate(-50%,-50%)!important}.hero-thumbnail-frame.visible{width:100vw!important;height:75vw!important;top:48%!important;transform:translate(-50%,-50%) scale(1)!important}}@media(max-width:480px){.header-contact-text{top:1.25rem;right:.75rem;font-size:1.75rem}.hero-content h1{top:1.25rem;left:.75rem;font-size:1.75rem;max-width:calc(100% - 1.5rem)}.mobile-hero-intro{top:4rem;left:.75rem;right:.75rem}.mobile-intro-text{font-size:.9rem;max-width:240px}.hero-thumbnail-frame,.hero-thumbnail-frame.visible{top:46%!important}.swipe-indicator{top:calc(46% + 37.5vw + 1rem)}}@media(max-width:360px){.header-contact-text{top:1rem;right:.5rem;font-size:1.5rem}.hero-content h1{top:1rem;left:.5rem;font-size:1.5rem;max-width:calc(100% - 1rem)}}@keyframes sweep{0%,to{opacity:.7}50%{opacity:1}}@media(max-height:600px){header#main-header{min-height:100vh;height:100vh}.hero-project-list{bottom:1rem;left:1rem;gap:.05rem}.hero-project-item{font-size:.85rem;padding:.1rem 0}.scroll-down-button{width:80px;height:80px;bottom:1rem;right:1rem}.scroll-text{font-size:7px}.scroll-arrow{width:16px;height:16px}.header-contact-text{font-size:1.5rem}.hero-content h1{font-size:1.75rem}.hero-thumbnail-frame{width:min(70vw,calc((100vh - 8rem) * 4 / 3))!important;height:min(52.5vw,calc(100vh - 8rem))!important;max-width:70vw;max-height:calc(100vh - 8rem);transform:translate(-50%,-50%) scale(1)}.hero-thumbnail-frame.visible{animation:frameScaleUpSmall .25s cubic-bezier(.2,.8,.2,1) forwards;width:min(70vw,calc((100vh - 8rem) * 4 / 3))!important;height:min(52.5vw,calc(100vh - 8rem))!important;max-height:calc(100vh - 8rem)}@keyframes frameScaleUpSmall{0%{transform:translate(-50%,-50%) scale(.9);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}}@media(max-height:450px){.hero-project-list{bottom:.75rem;left:.75rem}.hero-project-item{font-size:.75rem}.scroll-down-button{width:60px;height:60px;bottom:.75rem;right:.75rem}.scroll-text{font-size:6px}.scroll-arrow{width:14px;height:14px}.header-contact-text{font-size:1.25rem}.hero-content h1{font-size:1.5rem}.hero-thumbnail-frame{width:min(60vw,calc((100vh - 6rem) * 4 / 3))!important;height:min(45vw,calc(100vh - 6rem))!important;max-width:60vw;max-height:calc(100vh - 6rem);transform:translate(-50%,-50%) scale(1)}.hero-thumbnail-frame.visible{width:min(60vw,calc((100vh - 6rem) * 4 / 3))!important;height:min(45vw,calc(100vh - 6rem))!important;max-height:calc(100vh - 6rem);transform:translate(-50%,-50%) scale(1)}}#scroll-spacer{height:100vh;width:100%;transition:height .1s ease-out}body:not(:has(header#main-header)) .container{margin-top:0;padding-top:2rem}body:not(:has(header#main-header)) #portfolio-grid{margin-top:0}.work-page-title{font-size:4rem;font-weight:600;letter-spacing:-.03em;margin-bottom:3rem;color:var(--text-main);line-height:1.1}@media(max-width:768px){.work-page-title{font-size:2.5rem;margin-bottom:2rem}}body.collapsed-mode .container{margin-top:90px}body.collapsed-mode #scroll-spacer{display:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.anim-item{opacity:0;transform:translateY(40px)}section.visible .anim-item{animation:fadeInUp .9s cubic-bezier(.2,.8,.2,1) forwards}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}.delay-4{animation-delay:.4s}.delay-5{animation-delay:.5s}section{display:none;opacity:0;transition:opacity .5s}section.visible{opacity:1}#portfolio-grid,#project-tags-section,#works-section,#info-section,#contact-section{display:block}#portfolio-grid.visible{display:grid}#project-tags-section{padding-top:1.5rem;padding-bottom:3rem;margin-bottom:0}.project-tags-container{display:flex;flex-direction:column;gap:2rem;align-items:flex-start;width:fit-content}.project-tag-wrapper{display:flex;align-items:flex-start;gap:.75rem;opacity:0;transform:translateY(60px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform;width:fit-content}.project-tag-wrapper.animate{opacity:1;transform:translateY(0)}.project-tag-title{font-size:6rem;font-weight:600;letter-spacing:-.04em;line-height:.9;color:var(--text-main);cursor:default;transition:opacity .3s ease;display:inline-block;width:fit-content}.project-tags-container:has(.project-tag-wrapper:hover) .project-tag-wrapper:not(:hover) .project-tag-title{opacity:.4}.project-tag-circle{width:auto;height:40px;padding:0 1rem;border-radius:20px;background-color:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0;margin-top:.15em;white-space:nowrap}@media(max-width:768px){#project-tags-section{padding-top:1rem;padding-bottom:2rem;margin-bottom:0}.project-tag-title{font-size:2.25rem;white-space:nowrap}.project-tag-circle{width:auto;height:36px;padding:0 .875rem;font-size:.85rem}}#works-view{display:none}#works-view .back-btn{margin-bottom:0;margin-top:0}#works-view .container{padding-top:0}#works-section{padding-top:0;padding-bottom:var(--section-padding-y);margin-bottom:0;margin-top:0}.works-container{width:100%}.works-header{margin-bottom:3rem;margin-top:0}.works-header h2{font-family:"Instrument Serif",serif;font-size:3rem;font-weight:600;letter-spacing:-.03em;color:var(--text-main);margin-bottom:0}.works-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;width:100%}.works-item{cursor:pointer;opacity:0;transform:translateY(30px);transition:opacity .6s cubic-bezier(.2,.8,.2,1),transform .6s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform}.works-item.animate{opacity:1;transform:translateY(0)}.works-thumbnail{width:100%;aspect-ratio:4 / 3;background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:1rem;transition:border-color .3s ease,transform .3s ease;overflow:hidden}.works-item:hover .works-thumbnail{border-color:var(--text-main)}.works-content{display:flex;flex-direction:column;gap:.5rem}.works-title{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;color:var(--text-main);margin:0;transition:color .3s ease}.works-meta{display:flex;align-items:center;gap:1rem;font-size:.9rem;color:var(--text-secondary)}.works-tag{font-weight:500}.works-year{color:var(--text-muted);font-variant-numeric:tabular-nums}@media(max-width:768px){#works-view .container{padding-top:0!important}#works-section{padding-top:0;padding-bottom:var(--section-spacing-mobile);margin-bottom:0}.works-header h2{font-size:3.5rem}.works-grid{grid-template-columns:1fr;gap:2.5rem}.works-thumbnail{aspect-ratio:16 / 10}}#works-section.visible{margin-top:0}#info-section{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);margin-top:0;margin-bottom:0}#info-section.visible{margin-top:0}#contact-section{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y);margin-top:0;margin-bottom:0}#contact-section.visible{margin-top:0}.cursor-pill{position:fixed;z-index:9999;pointer-events:none;padding:8px 12px;background:#080a1480;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;font-weight:700;font-size:.85rem;border-radius:999px;transform:translateY(-50%) translate(0) scale(.96);opacity:0;filter:blur(8px);transition:opacity .3s cubic-bezier(.2,.9,.2,1),transform .35s cubic-bezier(.2,.9,.2,1),filter .35s cubic-bezier(.2,.9,.2,1);will-change:opacity,transform,filter;display:inline-block;box-shadow:0 6px 16px #0206173d}.cursor-pill.visible{opacity:1;transform:translateY(-50%) translate(4px) scale(1);filter:blur(0)}body.dark-mode .cursor-pill{background:#1a1a1a4f;color:var(--text-main);border:1px solid rgba(161,161,161,.22);box-shadow:0 10px 30px #00000073}.contact-form-wrapper{grid-column:1 / -1;margin-top:6rem;padding-top:4rem;border-top:1px solid var(--border-color);display:grid;grid-template-columns:1fr 1fr;gap:4rem;transition:border-color .3s ease}.form-title h2{font-size:2rem;margin-bottom:1rem;color:var(--text-main)}.simple-form{display:flex;flex-direction:column;gap:2rem}.form-group{position:relative}.form-input{width:100%;padding:12px 0;background:none;border:none;border-bottom:1px solid var(--border-color);color:var(--text-main);font-family:inherit;font-size:1rem;outline:none;border-radius:0;transition:border-color .3s ease}.form-input:focus{border-bottom-color:var(--text-main)}.form-input::placeholder{color:var(--input-placeholder);transition:color .3s}.auto-resize{resize:none;min-height:50px}.submit-btn{align-self:flex-start;padding:12px 32px;background-color:var(--text-main);color:var(--bg-color);border:none;border-radius:999px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .3s,background-color .3s,color .3s}.submit-btn:hover{opacity:.8}.success-message{color:var(--text-main);font-weight:500;display:none}.local-time{color:var(--text-main);font-variant-numeric:tabular-nums}.footer-copyright{margin-top:auto;color:var(--text-muted);font-size:.85rem}.footer-brand-text{width:100vw;margin-left:calc(-50vw + 50%);font-size:11.2vw;font-weight:800;letter-spacing:-.04em;line-height:.75;text-align:center;padding:0;margin-top:6rem;margin-bottom:0;display:block;text-transform:lowercase;white-space:nowrap;background:linear-gradient(to bottom,#000,#0000);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none;overflow:hidden;opacity:.15}body.dark-mode .footer-brand-text{background:linear-gradient(to bottom,#fff,#fff0);-webkit-background-clip:text;background-clip:text}@media(max-width:768px){.footer-brand-text{font-size:14vw;margin-top:3rem}}.back-btn{display:inline-block;margin-bottom:2rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:transform .2s ease,color .3s ease}.back-btn:hover{color:var(--text-main);transform:translate(-5px)}.detail-header{margin-bottom:3rem}.detail-hero{width:100%;height:60vh;background-color:var(--hero-bg);margin-bottom:3rem;object-fit:cover;transition:background-color .3s ease;border-radius:4px}.project-detail{display:flex;flex-direction:column;gap:3.25rem}.pd-hero{width:100%;aspect-ratio:1200 / 800;border-radius:var(--radius-sm);background-size:contain;background-position:center;background-repeat:no-repeat;background-color:var(--card-bg)}.pd-info{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;width:100%}.pd-info-left{display:flex;flex-direction:column}.pd-info h1{font-family:"Instrument Serif",serif;margin:0;font-size:5.5rem;letter-spacing:-.03em;line-height:1.05;font-weight:600}.pd-info-right{display:flex;flex-direction:column;justify-content:flex-start}.pd-meta-grid{margin-top:0;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;border-top:none;padding-top:0}.pd-meta-item{display:flex;flex-direction:column;gap:.5rem}.pd-meta-caption{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.pd-meta-value{font-size:1.5rem;color:var(--text-main);font-weight:600;letter-spacing:-.01em}.pd-description-section{margin:0;width:100%}.pd-description{color:var(--text-secondary);max-width:none!important;width:100%!important;font-size:1.25rem;line-height:1.7;margin:0}.pd-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}.pd-row.two-images .pd-image{height:auto;aspect-ratio:1200 / 800;border-radius:var(--radius-sm)}.pd-image{background-size:contain;background-position:center;background-repeat:no-repeat;border-radius:var(--radius-sm);aspect-ratio:1200 / 800;position:relative;overflow:hidden;background-color:var(--card-bg)}.pd-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm)}.pd-full-image,.pd-image-full{width:100%;aspect-ratio:1200 / 800;border-radius:var(--radius-sm);background-size:contain;background-position:center;background-repeat:no-repeat;background-color:var(--card-bg);position:relative;overflow:hidden}.pd-text{color:var(--text-secondary);line-height:1.85;font-size:1.25rem;max-width:none!important;width:100%}.pd-text p{max-width:none!important;width:100%!important}.pd-text p{font-size:inherit}.pd-text h3{margin-top:0;margin-bottom:1rem;font-size:1.5rem;color:var(--text-main)}.pd-legal{font-size:.75rem;color:var(--text-muted);border-top:1px dashed var(--border-color);padding-top:2rem;margin-top:4rem}.pd-legal p{opacity:.5}.behance-btn{display:inline-flex;align-items:center;gap:8px;margin-top:2rem;padding:0 0 4px;background:none;color:#000;font-size:1.5rem;font-weight:400;text-decoration:none;border-radius:0;border-bottom:2px solid currentColor;box-shadow:none;transition:opacity .3s}body.dark-mode .behance-btn{color:#fff}.behance-btn:hover{opacity:.6;transform:none;box-shadow:none}.behance-btn svg{width:1em;height:1em;transition:transform .3s}.behance-btn:hover svg{transform:translate(3px,-3px)}.project-pagination{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border-color)}.pagination-btn{display:flex;align-items:flex-start;gap:.75rem;background:transparent;border:none;cursor:pointer;padding:0;color:var(--text-main);font-family:inherit;transition:opacity .3s ease}.pagination-btn:hover{opacity:.6}.pagination-btn svg{width:14px;height:14px;flex-shrink:0;margin-top:2px;transition:transform .3s cubic-bezier(.4,0,.2,1)}.prev-btn{text-align:left}.next-btn{text-align:right;margin-left:auto}.prev-btn:hover svg{transform:translate(-3px)}.next-btn:hover svg{transform:translate(3px)}.pagination-info{display:flex;flex-direction:column;gap:.25rem}.pagination-label{font-size:.75rem;color:var(--text-muted);font-weight:400;margin-bottom:.125rem}.pagination-title{font-size:1rem;font-weight:400;color:var(--text-main)}@media(max-width:768px){.pagination-title{font-size:.9rem}.pagination-label{font-size:.7rem}}@media(max-width:1100px){.pd-row{grid-template-columns:1fr;display:flex;flex-direction:column;gap:2rem}.pd-row.text-left-img-right .pd-image{order:-1}.pd-full-image,.pd-hero,.pd-row.two-images .pd-image{aspect-ratio:1200 / 800}.pd-image,.pd-image-full{aspect-ratio:1200 / 800;width:100%}.pd-info{padding:0 1rem;grid-template-columns:1fr;gap:2rem}.pd-info h1{font-size:3.5rem}.pd-meta-grid{gap:1.5rem}.pd-meta-value{font-size:1.25rem}.pd-meta-caption{font-size:.8rem}.pd-description,.pd-text{font-size:1rem;line-height:1.6}.pd-info-left{text-align:center}.pd-meta-grid{text-align:center;justify-items:center}.pd-meta-item{align-items:center}}@media(max-width:640px){.pd-hero,.pd-full-image,.pd-image-full,.pd-row.two-images .pd-image{aspect-ratio:1200 / 800}.pd-info{grid-template-columns:1fr;gap:2rem}.pd-info h1{font-size:2.5rem}.pd-meta-value{font-size:1.1rem}.pd-meta-caption{font-size:.75rem}.pd-description,.pd-text{font-size:.96rem;line-height:1.5}}.pd-image,.pd-full-image,.pd-hero{position:relative;overflow:hidden}.img-loader-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000008}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:var(--text-main);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.no-image{background-color:#2b2b2b;color:#ffffffbf;display:flex;align-items:center;justify-content:center;font-size:3rem}.case-study{display:grid;grid-template-columns:1fr 2fr;gap:4rem;margin-bottom:4rem}.case-meta h4{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;transition:color .3s ease}.case-meta p{margin-bottom:1.5rem;color:var(--text-main)}.gallery{display:flex;flex-direction:column;gap:2rem}.gallery-img{width:100%;background-color:var(--card-bg);min-height:400px;transition:background-color .3s ease;border-radius:4px}.profile-grid{display:grid;grid-template-columns:140px 1fr;gap:3rem;margin-bottom:4rem;align-items:start}.profile-image-container{width:120px;height:120px;aspect-ratio:1/1;background-color:var(--card-bg);border-radius:50%;overflow:hidden;position:relative;transition:background-color .3s ease}.cv-text{margin-top:1.5rem;color:var(--text-secondary);font-size:1rem}.cv-link{color:var(--text-main);font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;display:inline-flex;align-items:center;gap:4px;transition:opacity .3s ease}.cv-link:hover{opacity:.6}.cv-icon{width:16px;height:16px;fill:currentColor}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem;padding-top:3rem;border-top:1px solid var(--border-color)}.contact-list a{display:block;margin-bottom:.5rem;border-bottom:1px solid transparent;width:fit-content}.contact-list a:hover{border-bottom-color:var(--text-main)}footer{margin-top:var(--section-spacing);padding-top:var(--section-padding-y);padding-bottom:0;border-top:1px solid var(--border-color);font-size:.9rem;color:var(--text-muted);transition:border-color .3s ease,color .3s ease}.footer-content{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:3rem}.footer-col{display:flex;flex-direction:column;gap:2rem}.footer-left{align-items:flex-start}.footer-logo{cursor:pointer}.footer-nav{display:flex;flex-direction:column;gap:.8rem}.footer-nav a{color:var(--text-main);font-weight:500;transition:opacity .3s ease;width:fit-content}.footer-nav a:hover{opacity:.6}.footer-socials{display:flex;gap:1.2rem;margin-top:.5rem}.social-icon{width:20px;height:20px;fill:var(--text-muted);transition:fill .3s ease,transform .2s ease}.social-icon:hover{fill:var(--text-main);transform:translateY(-2px)}.footer-right{align-items:flex-end;text-align:right;justify-content:space-between}.footer-copy{margin-bottom:.5rem}.footer-time{font-variant-numeric:tabular-nums;color:var(--text-muted)}@media(max-width:768px){.grid,.case-study,.info-grid,.profile-grid,.contact-form-wrapper{grid-template-columns:1fr}.profile-grid,.contact-form-wrapper{gap:2rem}.profile-image-container{width:120px;height:120px;margin:0 auto}.info-text-col{text-align:center}h1{font-size:2rem}.detail-hero{height:40vh}.navbar{flex-direction:row}.contact-form-wrapper{padding-top:3rem;margin-top:4rem}footer{padding-bottom:var(--section-spacing-mobile);padding-top:var(--section-spacing-mobile);margin-top:var(--section-spacing-mobile)}.footer-content{flex-direction:column;gap:3rem}.footer-right{align-items:flex-start;text-align:left;gap:.5rem}}.info-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:0}.profile-pic{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:.6rem;background-color:var(--card-bg)}.profile-wrapper{display:inline-flex;align-items:center;gap:.75rem}.status-pill{display:inline-flex;align-items:center;gap:.6rem;padding:8px 14px;border-radius:16px 16px 16px 4px;background-color:var(--tag-bg);color:var(--text-secondary);font-weight:500;font-size:.9rem;border:1px solid rgba(0,0,0,.06);position:relative;margin-left:4px;opacity:0}.status-pill.animate{animation:popInBlur .6s cubic-bezier(.2,.8,.2,1) forwards}@keyframes popInBlur{0%{opacity:0;transform:scale(.8) translateY(10px) translate(-5px);filter:blur(10px)}to{opacity:1;transform:scale(1) translateY(0) translate(0);filter:blur(0)}}.status-dot{width:10px;height:10px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#6ee7b7,#34d399);position:relative;box-shadow:0 0 6px #34d39999,0 0 12px #34d39966,0 0 20px #34d39933,inset 0 1px 2px #ffffff4d;animation:status-glow 2s ease-in-out infinite}.status-dot:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background-color:#34d39966;animation:status-pulse 1.6s infinite;box-shadow:0 0 8px #34d39980}@keyframes status-pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.8;box-shadow:0 0 8px #34d39980}50%{transform:translate(-50%,-50%) scale(2.2);opacity:0;box-shadow:0 0 20px #34d3994d}to{transform:translate(-50%,-50%) scale(1);opacity:0;box-shadow:0 0 8px #34d39980}}@keyframes status-glow{0%,to{box-shadow:0 0 6px #34d39999,0 0 12px #34d39966,0 0 20px #34d39933,inset 0 1px 2px #ffffff4d}50%{box-shadow:0 0 10px #34d399cc,0 0 18px #34d39980,0 0 28px #34d3994d,inset 0 1px 2px #fff6}}@media(max-width:640px){.profile-wrapper{gap:.5rem}.status-pill{font-size:.82rem;padding:5px 8px}.profile-pic{width:64px;height:64px}}.info-tech-stack{margin-top:2.5rem}.tech-stack-list{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.tech-pill{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-main);border-radius:999px;font-size:.95rem;font-weight:500;cursor:default}.contact-container{max-width:800px;margin:0 auto;padding:0}.contact-content{text-align:center}.contact-title{font-size:3.5rem;font-weight:600;line-height:1.1;margin-bottom:1.5rem}.contact-description{font-size:1.15rem;color:var(--text-secondary);margin-bottom:4rem;max-width:600px;margin-left:auto;margin-right:auto}.contact-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:700px;margin:0 auto}.contact-method{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.contact-method:hover{border-color:var(--text-main);box-shadow:0 8px 24px #00000014}body.dark-mode .contact-method:hover{box-shadow:0 8px 24px #0000004d}.contact-method-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.contact-method-icon img{width:48px;height:48px;object-fit:contain}.icon-dark,body.dark-mode .icon-light{display:none}body.dark-mode .icon-dark{display:block}.contact-method-content{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.contact-method-label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.contact-method-value{font-size:1.05rem;font-weight:500;color:var(--text-main)}@media(max-width:768px){.contact-container{padding:0}.contact-title{font-size:2.5rem}.contact-description{font-size:1rem;margin-bottom:3rem}.contact-methods{grid-template-columns:1fr;gap:1.5rem}.contact-method{padding:1.5rem}.contact-method-icon,.contact-method-icon img{width:40px;height:40px}}.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;padding-bottom:2rem}.footer-col h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.5rem;color:var(--text-muted)}.footer-links{display:flex;flex-direction:column;gap:.8rem}.footer-links a{font-size:.95rem;color:var(--text-main)}.footer-links a:hover{opacity:.6}@media(max-width:768px){#info-section,#contact-section{padding-top:var(--section-spacing-mobile);padding-bottom:var(--section-spacing-mobile)}.info-layout{grid-template-columns:1fr;gap:3rem}.footer-grid{grid-template-columns:1fr 1fr;grid-template-areas:"sitemap socials" "logo logo" "copy copy";gap:2rem 1rem}.footer-col:nth-child(1){grid-area:logo;align-items:center;justify-content:center;margin-bottom:.5rem;margin-top:1rem}.footer-col:nth-child(2){grid-area:sitemap;align-items:flex-start}.footer-col:nth-child(3){grid-area:socials;align-items:flex-end;text-align:right}.footer-col:nth-child(3) .footer-links{align-items:flex-end}.footer-col:nth-child(4){display:contents}.footer-col:nth-child(4) .local-time{display:none}.footer-col:nth-child(4) .footer-copyright{grid-area:copy;text-align:center;justify-self:center;width:100%;color:var(--text-muted);font-size:.8rem;margin-top:.5rem}.footer-col:nth-child(4) h4{display:none}.contact-header h2{font-size:2.5rem}}#loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--bg-color);z-index:10000;display:flex;justify-content:center;align-items:center;transition:opacity .5s cubic-bezier(.4,0,.2,1)}#loading-screen.hidden{opacity:0;pointer-events:none}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;width:100%;height:100%}.loading-logo{width:60px;height:60px;margin-bottom:2rem;opacity:0;transform:translateY(20px);animation:fadeInUpLoading .8s cubic-bezier(.2,.8,.2,1) forwards}body.dark-mode .loading-logo{filter:invert(1) brightness(1.15) contrast(1.02)}@media(min-width:769px){.loading-logo{display:none}}.loading-counter{font-family:Switzer,sans-serif;font-size:18vw;line-height:1;font-weight:600;letter-spacing:-.04em;color:var(--text-main);font-variant-numeric:tabular-nums;opacity:0;animation:fadeInLoading .5s .3s forwards;position:absolute;bottom:2rem;right:2rem}@media(max-width:768px){.loading-counter{font-size:20vw;bottom:10rem;right:50%;transform:translate(50%)}.loading-logo{margin-bottom:0}}@keyframes fadeInUpLoading{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLoading{0%{opacity:0}to{opacity:1}}.projects-canvas-section{position:relative;width:100%;min-height:100vh;height:100vh;overflow:hidden;background:var(--bg-color);margin-top:0;padding:0}.canvas-container{position:relative;width:100%;height:100%;cursor:grab;touch-action:none}.canvas-container:active{cursor:grabbing}.canvas-grid{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);will-change:transform}.canvas-item{position:absolute;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:box-shadow .3s ease;background:var(--card-bg);box-shadow:0 4px 12px #0000001a}.canvas-item:hover{box-shadow:0 8px 24px #0003;z-index:10}.canvas-item-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.7) 100%);opacity:0;transition:opacity .3s ease;display:flex;align-items:flex-end;padding:1.5rem;pointer-events:none}.canvas-item:hover .canvas-item-overlay{opacity:1}.canvas-item-info{color:#fff;width:100%}.canvas-item-title{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;line-height:1.2}.canvas-item-category{font-size:.875rem;font-weight:400;margin:0 0 .25rem;opacity:.9}.canvas-item-year{font-size:.75rem;font-weight:400;margin:0;opacity:.8}.canvas-item-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;pointer-events:none}body.dark-mode .canvas-item{box-shadow:0 4px 12px #0000004d}body.dark-mode .canvas-item:hover{box-shadow:0 8px 24px #00000080}@media(max-width:768px){.projects-canvas-section{height:100vh}.canvas-item{border-radius:var(--radius-md)}.canvas-item-title{font-size:1rem}.canvas-item-category,.canvas-item-year{font-size:.75rem}.canvas-item-overlay{padding:1rem}}
