:root{--bg: #f4f3ef;--surface: #ffffff;--ink: #131110;--ink-soft: #2b2823;--muted: #6f6b63;--faint: #9b968d;--line: rgba(19, 17, 15, .12);--line-strong: rgba(19, 17, 15, .22);--accent: #2456d6;--accent-ink: #ffffff;--font-display: "Sora", system-ui, sans-serif;--font-body: "Manrope", system-ui, sans-serif;--maxw: 1280px;--gutter: clamp(20px, 5vw, 64px);--r-sm: 10px;--r: 16px;--r-lg: 24px;--ease: cubic-bezier(.22, .61, .36, 1)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:17px;font-weight:450;line-height:1.6;letter-spacing:-.003em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body.menu-open,body.locale-modal-open{overflow:hidden}::selection{background:var(--ink);color:var(--bg)}a{color:inherit;text-decoration:none}img,svg{display:block}h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:600}p{margin:0;text-wrap:pretty}.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}.section{padding-block:clamp(72px,11vh,140px)}.kicker{display:inline-flex;align-items:center;gap:9px;color:var(--muted);font-size:12.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase}.kicker:before{content:"";width:22px;height:1.5px;background:currentColor}.btn{--pad-y: 15px;--pad-x: 26px;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:var(--pad-y) var(--pad-x);border:1.5px solid transparent;border-radius:999px;font-size:15px;font-weight:600;letter-spacing:-.01em;line-height:1;cursor:pointer;transition:transform .4s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);white-space:nowrap}.btn svg,.arrow-link svg{width:16px;height:16px;transition:transform .4s var(--ease)}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:hover{transform:translateY(-2px)}.btn-primary:hover svg,.arrow-link:hover svg{transform:translate(4px,-4px)}.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn-lg{--pad-y: 18px;--pad-x: 32px;font-size:16px}.arrow-link{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:15px;font-weight:600}.nav{position:fixed;inset:0 0 auto;z-index:100;border-bottom:1px solid transparent;transition:background .35s var(--ease),border-color .35s var(--ease),backdrop-filter .35s var(--ease)}.nav.scrolled{background:color-mix(in srgb,var(--bg) 80%,transparent);border-bottom-color:var(--line);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}.brand{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.02em}.brand-mark{display:grid;width:32px;height:32px;place-items:center;border-radius:8px;background:var(--ink);color:var(--bg);font-size:13px;font-weight:700;transition:transform .5s var(--ease)}.brand:hover .brand-mark{transform:rotate(-8deg) scale(1.06)}.brand-hidden{width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.nav-links{display:flex;align-items:center;gap:34px}.locale-switch{display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid var(--line);border-radius:999px;background:color-mix(in srgb,var(--surface) 88%,transparent)}.locale-btn{padding:8px 12px;border:0;border-radius:999px;background:transparent;color:var(--muted);font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease)}.locale-btn.is-active{background:var(--ink);color:var(--bg)}.nav-links a:not(.btn){position:relative;color:var(--ink-soft);font-size:15px;font-weight:500;white-space:nowrap}.nav-links a:not(.btn):after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:1.5px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}.nav-links a:not(.btn):hover:after{transform:scaleX(1)}.nav-cta{padding:11px 20px;font-size:14px}.nav-toggle{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;width:42px;height:42px;border:1px solid var(--line-strong);border-radius:10px;background:transparent;cursor:pointer}.nav-toggle span{width:18px;height:1.6px;background:var(--ink);transition:.3s var(--ease)}.nav-toggle.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}.nav-sheet{position:fixed;inset:76px 0 auto;z-index:99;display:none;flex-direction:column;gap:6px;padding:18px var(--gutter) 30px;border-bottom:1px solid var(--line);background:var(--bg);opacity:0;pointer-events:none;transform:translateY(-12px);transition:transform .35s var(--ease),opacity .35s var(--ease)}.nav-sheet.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-sheet a{padding:12px 0;border-bottom:1px solid var(--line);font-family:var(--font-display);font-size:26px;font-weight:500}.nav-sheet .btn{margin-top:16px}.locale-mobile-trigger{display:none;width:100%;margin-top:14px;padding:14px 16px;border:1px solid var(--line-strong);border-radius:18px;background:color-mix(in srgb,var(--surface) 92%,transparent);color:var(--ink);font-family:var(--font-display);font-size:18px;font-weight:600;text-align:left}.locale-mobile-trigger-label{display:block}.locale-modal{position:fixed;inset:0;z-index:120;display:none}.locale-modal.open{display:block}.locale-modal-backdrop{position:absolute;inset:0;background:#13110f38;backdrop-filter:blur(10px)}.locale-modal-card{position:absolute;left:50%;bottom:22px;width:min(calc(100% - 32px),420px);padding:20px;border:1px solid var(--line);border-radius:28px;background:color-mix(in srgb,var(--bg) 94%,transparent);box-shadow:0 24px 80px #13110f29;transform:translate(-50%) translateY(18px);opacity:0;transition:transform .32s var(--ease),opacity .32s var(--ease)}.locale-modal.open .locale-modal-card{transform:translate(-50%) translateY(0);opacity:1}.locale-modal-kicker{margin-bottom:14px;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.locale-modal-option{display:flex;align-items:center;width:100%;margin-top:10px;padding:18px 20px;border:1px solid var(--line-strong);border-radius:18px;background:var(--surface);color:var(--ink);font-family:var(--font-display);font-size:26px;font-weight:500;letter-spacing:-.02em;text-align:left;transition:transform .28s var(--ease),border-color .28s var(--ease),background .28s var(--ease)}.locale-modal-option.is-active{border-color:var(--ink);background:var(--ink);color:var(--bg)}.hero{position:relative;overflow:hidden;padding-top:clamp(130px,19vh,200px);padding-bottom:clamp(60px,9vh,110px)}.hero-top{display:flex;margin-bottom:34px}.avail{display:inline-flex;align-items:center;gap:9px;padding:7px 14px 7px 12px;border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--ink-soft);font-size:13.5px;font-weight:600}.dot{position:relative;width:8px;height:8px;border-radius:50%;background:#1f9d57}.dot:after{content:"";position:absolute;inset:0;border-radius:inherit;background:#1f9d57;animation:ping 2.4s infinite}@keyframes ping{0%{opacity:.5;transform:scale(.6)}70%,to{opacity:0;transform:scale(1.8)}}.hero h1{max-width:17ch;font-size:clamp(40px,7.1vw,104px);line-height:.98;letter-spacing:-.035em;text-wrap:balance}.hero .em{font-style:italic;font-weight:500}.hero-lead{max-width:55ch;margin-top:32px;color:var(--ink-soft);font-size:clamp(17px,1.55vw,21px);line-height:1.55}.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:40px}.marquee{margin-top:clamp(64px,10vh,110px);padding-block:20px;overflow:hidden;border-block:1px solid var(--line);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.marquee-track{display:flex;width:max-content;animation:marquee 34s linear infinite}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-item{display:inline-flex;align-items:center;gap:22px;padding-right:22px;color:var(--ink-soft);font-family:var(--font-display);font-size:clamp(18px,2vw,26px);font-weight:500;white-space:nowrap}.marquee-item:after{content:"✦";color:var(--faint);font-size:.8em}@keyframes marquee{to{transform:translate(-50%)}}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:clamp(48px,7vh,86px)}.section-head h2{max-width:18ch;margin-top:18px;font-size:clamp(30px,4.6vw,58px);line-height:1.02;letter-spacing:-.03em;text-wrap:balance}.section-head p{max-width:42ch;color:var(--muted)}.projects-grid{display:grid;gap:clamp(54px,8vh,104px)}.proj{display:grid;grid-template-columns:1fr 1.05fr;grid-template-rows:auto auto;column-gap:clamp(36px,5vw,80px);align-items:center}.proj:nth-child(2n){grid-template-columns:1.05fr 1fr}.proj-media{grid-column:2;grid-row:1 / span 2}.proj:nth-child(2n) .proj-media{grid-column:1}.proj-index-group{grid-column:1;grid-row:1;align-self:end;display:flex;align-items:center;gap:14px;margin-bottom:6px}.proj-idx{color:var(--faint);font-family:var(--font-display);font-size:clamp(44px,5vw,78px);line-height:.8;letter-spacing:-.04em}.proj-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid rgba(191,146,0,.18);border-radius:999px;background:#ffd65729;color:#7a6100;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.proj-badge-dot{width:8px;height:8px;border-radius:50%;background:#d7a400}.proj-info{grid-column:1;grid-row:2;display:flex;flex-direction:column;align-items:flex-start;gap:14px}.proj:nth-child(2n) .proj-index-group,.proj:nth-child(2n) .proj-info{grid-column:2}.proj-cat{color:var(--muted);font-size:12.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase}.proj-name{font-size:clamp(30px,3.4vw,46px);line-height:1.04;letter-spacing:-.03em}.proj-desc{max-width:48ch;color:var(--ink-soft)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-block:4px 2px}.tag-list span{padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:12px;font-weight:600}.proj:hover .ph{transform:scale(1.035)}.mock{overflow:hidden;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);box-shadow:0 20px 70px #13110f12}.mock-bar{display:flex;align-items:center;gap:16px;height:40px;padding:0 14px;border-bottom:1px solid var(--line)}.mock-dots{display:flex;gap:7px}.mock-dots i{width:10px;height:10px;border-radius:50%;background:var(--line-strong)}.mock-url{max-width:320px;padding:5px 12px;overflow:hidden;border:1px solid var(--line);border-radius:999px;color:var(--faint);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11.5px;text-overflow:ellipsis;white-space:nowrap}.ph{position:relative;display:grid;min-height:220px;place-items:center;overflow:hidden;background:repeating-linear-gradient(135deg,rgba(19,17,15,.035) 0 1px,transparent 1px 11px),#eceae3;transition:transform .7s var(--ease)}.mock-image,.mock-video{overflow:hidden;background:#eceae3}.mock-video video{width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:#f7f5ef}.mock-image img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .7s var(--ease)}.proj:hover .mock-image img{transform:scale(1.035)}.ph:after{content:attr(data-label);padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:color-mix(in srgb,var(--bg) 82%,transparent);color:var(--faint);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}.about{border-block:1px solid var(--line);background:var(--surface)}.about-grid{display:grid;grid-template-columns:minmax(220px,360px) 1.15fr;gap:clamp(36px,6vw,90px);align-items:center}.about-portrait img{width:100%;max-width:340px;aspect-ratio:1 / 1;object-fit:cover;object-position:center;border-radius:var(--r);box-shadow:0 20px 70px #13110f14}.about-body h2{margin-top:22px;font-size:clamp(26px,3.2vw,42px);font-weight:500;line-height:1.18;letter-spacing:-.03em;text-wrap:balance}.about-body b{font-weight:700}.muted-lead{margin-top:24px;color:var(--muted);font-size:clamp(17px,1.5vw,20px)}.about-stats{display:flex;flex-wrap:wrap;gap:34px 44px;margin-top:40px}.about-stat .n{font-family:var(--font-display);font-size:clamp(24px,3vw,40px);font-weight:600;line-height:1;letter-spacing:-.04em}.about-stat .l{margin-top:8px;color:var(--muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.services,.footer{background:var(--ink);color:var(--bg)}.services .kicker,.services .section-head p{color:#f4f3ef99}.services .section-head h2{color:var(--bg)}.services-list{border-top:1px solid rgba(244,243,239,.16)}.service{position:relative;display:grid;grid-template-columns:64px 1fr minmax(220px,40ch);gap:26px;align-items:center;overflow:hidden;padding-block:clamp(22px,3vh,34px);border-bottom:1px solid rgba(244,243,239,.16);transition:color .35s var(--ease),padding-left .45s var(--ease)}.service:before{content:"";position:absolute;inset:0;z-index:0;background:var(--bg);transform:scaleY(0);transform-origin:bottom;transition:transform .45s var(--ease)}.service>*{position:relative;z-index:1}.service:hover{padding-left:24px;color:var(--ink)}.service:hover:before{transform:scaleY(1)}.service-n{color:#f4f3ef80;font-family:var(--font-display);font-size:14px}.service-name{font-family:var(--font-display);font-size:clamp(22px,2.8vw,36px);font-weight:500;line-height:1.08}.service-desc{color:#f4f3ef99;font-size:15px;text-align:right}.service:hover .service-n,.service:hover .service-desc{color:var(--ink-soft)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start}.contact-lead h2{margin-top:22px;font-size:clamp(30px,4.4vw,56px);line-height:1.02;letter-spacing:-.03em;text-wrap:balance}.contact-lead p{margin-top:24px;max-width:44ch;color:var(--muted)}.contact-meta{display:grid;gap:14px;margin-top:36px}.contact-meta a,.contact-meta span{display:flex;gap:18px;color:var(--ink-soft)}.ml{width:78px;flex:none;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.form{display:flex;flex-direction:column;gap:20px}.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}.field{display:flex;flex-direction:column;gap:9px}.field label{font-size:14px;font-weight:600}.field input,.field textarea{width:100%;padding:15px 16px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--ink);font:inherit;outline:none;transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}.field textarea{resize:vertical}.field input:focus,.field textarea:focus{border-color:var(--ink);box-shadow:0 0 0 4px #13110f12}.field.invalid input,.field.invalid textarea{border-color:#c5462f;box-shadow:0 0 0 4px #c5462f14}.err{min-height:18px;color:#c5462f;font-size:13px}.form-ok{display:none;align-items:center;gap:12px;margin-top:18px;padding:18px;border:1px solid rgba(31,157,87,.25);border-radius:var(--r);background:#1f9d5714;color:var(--ink-soft)}.form-ok.show{display:flex}.form-ok.is-error{border-color:#c5462f40;background:#c5462f14}.form-ok.is-error svg path{stroke:#c5462f}.form-ok svg{width:24px;height:24px;flex:none}.detail-hero{padding-top:clamp(120px,17vh,180px)}.back-link{display:inline-flex;align-items:center;gap:8px;width:fit-content;margin-bottom:42px;color:var(--muted);font-weight:600}.back-link svg{width:18px;height:18px;transition:transform .35s var(--ease)}.back-link:hover svg{transform:translate(-4px)}.detail-cat{display:block;margin-bottom:18px}.detail-hero h1{font-size:clamp(40px,7vw,92px);line-height:.98;letter-spacing:-.035em}.detail-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:clamp(44px,7vh,72px);padding-top:24px;border-top:1px solid var(--line)}.mv{margin-top:8px;font-family:var(--font-display);font-size:18px;font-weight:600;line-height:1.25}.status-chip{display:inline-flex;align-items:center;width:fit-content;padding:8px 12px;border-radius:999px;border:1px solid var(--line)}.status-success{border-color:#1f9d572e;background:#1f9d571a;color:#176b41}.status-warning{border-color:#bf92002e;background:#ffd65729;color:#7a6100}.detail-figure{margin-top:clamp(40px,7vh,76px)}.detail-body{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px)}.detail-block h2{margin-bottom:18px;color:var(--muted);font-size:12.5px;font-family:var(--font-body);font-weight:700;letter-spacing:.13em;text-transform:uppercase}.detail-block p{font-size:clamp(19px,2.1vw,26px);line-height:1.4;letter-spacing:-.02em}.did-list{display:grid;margin:0;padding:0;list-style:none;border-top:1px solid var(--line)}.did-list li{display:grid;grid-template-columns:42px 1fr;gap:18px;padding-block:18px;border-bottom:1px solid var(--line)}.did-list .n{color:var(--faint);font-family:var(--font-display);font-size:13px;font-weight:700}.result-section{padding-top:0}.result-copy{max-width:760px;margin-top:18px;margin-bottom:32px;color:var(--ink-soft);font-size:clamp(19px,2vw,25px);line-height:1.45}.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,32px)}.gallery .mock:first-child{grid-column:1 / -1}.detail-cta{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:clamp(30px,5vh,52px);border-radius:var(--r-lg);background:var(--ink);color:var(--bg)}.detail-cta h3{max-width:16ch;font-size:clamp(28px,4vw,52px);line-height:1.03;letter-spacing:-.03em}.detail-cta .btn-primary{background:var(--bg);color:var(--ink)}.next-proj{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:clamp(48px,8vh,90px);padding-block:34px;border-top:1px solid var(--line)}.next-proj svg{width:40px;height:40px;transition:transform .4s var(--ease)}.next-proj:hover svg{transform:translate(4px,-4px)}.nl{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}.nn{margin-top:8px;font-family:var(--font-display);font-size:clamp(26px,4vw,48px);font-weight:600;letter-spacing:-.03em;transition:color .3s var(--ease)}.next-proj:hover .nn{color:var(--accent)}.footer{margin-top:clamp(72px,11vh,140px);padding-top:clamp(60px,9vh,100px);padding-bottom:36px}.footer-top{display:flex;justify-content:space-between;gap:52px}.footer-big{max-width:10ch;font-family:var(--font-display);font-size:clamp(34px,6vw,84px);font-weight:600;line-height:.98;letter-spacing:-.03em}.footer-big a{background-image:linear-gradient(currentColor,currentColor);background-repeat:no-repeat;background-position:0 100%;background-size:0 1.5px;transition:background-size .35s var(--ease)}.footer-big a:hover{background-size:100% 1.5px}.footer-nav{display:flex;gap:70px}.footer-col{display:flex;flex-direction:column;gap:10px;min-width:120px}.footer-col h4{margin:0 0 8px;color:#f4f3ef80;font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}.footer-col a{color:#f4f3efbd;transition:color .25s var(--ease)}.footer-col a:hover{color:var(--bg)}.footer-bottom{display:flex;justify-content:space-between;gap:24px;margin-top:clamp(54px,9vh,92px);padding-top:24px;border-top:1px solid rgba(244,243,239,.16);color:#f4f3ef8c;font-size:13.5px}@media(max-width:1000px){.about-grid,.detail-body{grid-template-columns:1fr}.about-portrait{max-width:360px}.service{grid-template-columns:44px 1fr}.service-desc{display:none}.detail-meta{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){body{font-size:16px}.nav-links,.nav-inner>.locale-switch{display:none}.nav-toggle,.nav-sheet{display:flex}.locale-mobile-trigger{display:block}.hero h1{max-width:12ch}.section-head,.contact-grid,.footer-top,.footer-bottom{flex-direction:column;display:flex;align-items:flex-start}.proj,.proj:nth-child(2n){grid-template-columns:1fr;grid-template-rows:auto;gap:22px}.proj-media,.proj:nth-child(2n) .proj-media{grid-column:1;grid-row:1}.proj-index-group,.proj:nth-child(2n) .proj-index-group{grid-column:1;grid-row:2}.proj-info,.proj:nth-child(2n) .proj-info{grid-column:1;grid-row:3}.contact-grid,.gallery{display:grid;grid-template-columns:1fr}.gallery .mock:first-child{grid-column:auto}.detail-meta{grid-template-columns:1fr}.detail-cta{align-items:flex-start;flex-direction:column}.footer-nav{gap:44px}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
