*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg: #0d0f12;--panel: #14171c;--accent: #ffb020;--accent-ink: #1a1205;--text: #f2f2f2;--muted: #9aa0a8;--line: rgba(255, 255, 255, .1);--header-bg: rgba(13, 15, 18, .9);--footer-bg: #090a0c;--input-bg: #0f1216;--dot-bg: rgba(255, 255, 255, .22);--dot-bg-hover: rgba(255, 255, 255, .45)}[data-theme=light]{--bg: #f5f6f8;--panel: #ffffff;--accent: #d97706;--accent-ink: #ffffff;--text: #16191e;--muted: #5b626b;--line: rgba(0, 0, 0, .12);--header-bg: rgba(245, 246, 248, .85);--footer-bg: #eceef1;--input-bg: #ffffff;--dot-bg: rgba(0, 0, 0, .2);--dot-bg-hover: rgba(0, 0, 0, .42)}[data-theme=ocean]{--bg: #0b1016;--panel: #131c26;--accent: #38bdf8;--accent-ink: #04222e;--text: #eef3f7;--muted: #92a3b3;--line: rgba(255, 255, 255, .1);--header-bg: rgba(11, 16, 22, .9);--footer-bg: #070c11;--input-bg: #0d141b;--dot-bg: rgba(255, 255, 255, .22);--dot-bg-hover: rgba(255, 255, 255, .45)}[data-theme=forest]{--bg: #0a130f;--panel: #111d18;--accent: #34d399;--accent-ink: #042319;--text: #ecf4f0;--muted: #8fa69c;--line: rgba(255, 255, 255, .1);--header-bg: rgba(10, 19, 15, .9);--footer-bg: #06100b;--input-bg: #0c1611;--dot-bg: rgba(255, 255, 255, .22);--dot-bg-hover: rgba(255, 255, 255, .45)}[data-theme=crimson]{--bg: #120d0e;--panel: #1d1417;--accent: #fb6360;--accent-ink: #2c0909;--text: #f6eeef;--muted: #b69a9d;--line: rgba(255, 255, 255, .1);--header-bg: rgba(18, 13, 14, .9);--footer-bg: #0e0809;--input-bg: #1a1113;--dot-bg: rgba(255, 255, 255, .22);--dot-bg-hover: rgba(255, 255, 255, .45)}[data-theme=violet]{--bg: #100d16;--panel: #181323;--accent: #a78bfa;--accent-ink: #1b1033;--text: #f1eef8;--muted: #a499b7;--line: rgba(255, 255, 255, .1);--header-bg: rgba(16, 13, 22, .9);--footer-bg: #0b0812;--input-bg: #15111f;--dot-bg: rgba(255, 255, 255, .22);--dot-bg-hover: rgba(255, 255, 255, .45)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}.site-header{position:fixed;top:0;left:0;right:0;height:64px;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1.2rem,4vw,3rem);background:linear-gradient(to bottom,var(--header-bg),transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .4s ease,opacity .4s ease}.site-header.revealed{transform:translateY(0);opacity:1;pointer-events:auto}.brand-group{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem}.brand{font-weight:800;font-size:1.15rem;letter-spacing:.04em;color:var(--text);text-decoration:none}.brand span{color:var(--accent)}.made-by{font-size:.75rem;color:var(--muted);letter-spacing:.03em;white-space:nowrap}@media (max-width: 560px){.made-by{display:none}}.nav{display:flex;gap:clamp(1rem,3vw,2.4rem)}.nav a{color:var(--muted);text-decoration:none;font-size:.95rem;transition:color .2s ease}.nav a:hover{color:var(--text)}.stage{position:relative;height:420vh}.sticky-wrap{position:sticky;top:0;height:100vh;overflow:hidden}.sticky-wrap.split{display:grid;grid-template-columns:42% 58%}.intro{position:relative;z-index:5;display:flex;flex-direction:column;justify-content:center;gap:1.4rem;padding:0 clamp(1.5rem,4vw,4rem)}.intro-brand .brand{font-size:clamp(1.3rem,2.2vw,1.8rem)}.intro-title{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:800;line-height:1.05;letter-spacing:-.02em}.intro-desc{max-width:46ch;color:var(--muted);font-size:clamp(.95rem,1.2vw,1.1rem);line-height:1.6}.viewer-col{position:relative;height:100vh}#scene{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.scroll-cue{margin-top:1rem;color:var(--muted);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.scroll-cue span{width:1px;height:32px;background:linear-gradient(var(--accent),transparent);animation:cue 1.8s ease-in-out infinite}@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}@media (max-width: 820px){.sticky-wrap.split{display:block}.viewer-col{position:absolute;top:0;right:0;bottom:0;left:0}.intro{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;justify-content:flex-end;padding-bottom:12vh;background:linear-gradient(to top,#0d0f12eb 22%,#0d0f1200 62%)}}.content{position:relative;z-index:2;background:var(--bg)}.projects{max-width:1500px;margin:0 auto;padding:clamp(4rem,12vh,9rem) clamp(1.2rem,4vw,3rem) clamp(2rem,6vh,4rem);text-align:center}.projects h2{font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:700}.projects .lead{margin:1rem auto 0;color:var(--muted)}.carousel{position:relative;margin-top:2.5rem}.carousel-viewport{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:16px;background:var(--panel);aspect-ratio:16 / 9;max-height:min(86vh,1000px)}.carousel-track{display:flex;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}.slide{position:relative;flex:0 0 100%;height:100%}.slide img{width:100%;height:100%;object-fit:cover;display:block}.slide-caption{position:absolute;left:0;right:0;bottom:0;padding:2.5rem clamp(1.2rem,4vw,2.4rem) 1.4rem;display:flex;flex-direction:column;align-items:flex-start;gap:.3rem;text-align:left;background:linear-gradient(to top,#08090bd1,#08090b00)}.slide-tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:700}.slide-title{font-size:clamp(1.1rem,2.4vw,1.7rem);font-weight:700;color:#fff}.carousel .arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:#0d0f128c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.carousel .arrow:active{transform:translateY(-50%) scale(.92)}.carousel .arrow.prev{left:clamp(.6rem,2vw,1.2rem)}.carousel .arrow.next{right:clamp(.6rem,2vw,1.2rem)}.carousel-dots{display:flex;justify-content:center;gap:.6rem;margin-top:1.4rem}.carousel-dots .dot{width:9px;height:9px;padding:0;border-radius:50%;border:0;cursor:pointer;background:var(--dot-bg);transition:background .25s ease,transform .25s ease}.carousel-dots .dot:hover{background:var(--dot-bg-hover)}.carousel-dots .dot.active{background:var(--accent);transform:scale(1.25)}.slide{cursor:pointer}.slide img{transition:transform .6s ease}.slide:hover img{transform:scale(1.03)}.slide-hint{margin-top:.4rem;font-size:.82rem;font-weight:600;color:var(--text);opacity:0;transform:translateY(4px);transition:opacity .25s ease,transform .25s ease}.slide:hover .slide-hint,.slide:focus-visible .slide-hint{opacity:.92;transform:none}.project-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);opacity:0;pointer-events:none;transition:opacity .3s ease}.project-modal.open{opacity:1;pointer-events:auto}.pm-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#060709c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.pm-dialog{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.2fr;width:min(1100px,100%);max-height:88vh;background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 30px 80px #00000080;transform:translateY(12px) scale(.98);transition:transform .35s cubic-bezier(.4,0,.2,1)}.project-modal.open .pm-dialog{transform:none}.pm-info{padding:clamp(1.6rem,3vw,3rem);display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.pm-tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:700}.pm-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;line-height:1.1}.pm-meta{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin:.2rem 0;padding:.9rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.pm-meta li{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem}.pm-k{color:var(--muted)}.pm-v{color:var(--text);font-weight:600}.pm-desc{color:var(--muted);line-height:1.7;font-size:clamp(.95rem,1.1vw,1.05rem)}.pm-image{position:relative;min-height:280px;background:#0a0b0d}.pm-image img{width:100%;height:100%;object-fit:cover;display:block}.pm-close{position:absolute;top:.8rem;right:.8rem;z-index:2;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#0d0f1299;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .2s ease,border-color .2s ease}.pm-close:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.pm-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:clamp(44px,5vw,56px);height:clamp(44px,5vw,56px);border-radius:50%;border:1px solid var(--line);background:#14171cb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text);font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .1s ease}.pm-arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.pm-arrow:active{transform:translateY(-50%) scale(.92)}.pm-arrow.prev{left:clamp(.5rem,3vw,2rem)}.pm-arrow.next{right:clamp(.5rem,3vw,2rem)}@media (max-width: 760px){.pm-dialog{grid-template-columns:1fr;grid-template-rows:auto 1fr;max-height:90vh}.pm-image{grid-row:1;min-height:200px;max-height:38vh}.pm-info{grid-row:2}.pm-arrow{top:auto;bottom:1rem;transform:none}.pm-arrow:active{transform:scale(.92)}}.gallery{max-width:1100px;margin:0 auto;padding:clamp(4rem,12vh,9rem) clamp(1.2rem,4vw,3rem) clamp(2rem,6vh,4rem);text-align:center}.gallery h2{font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:700}.gallery .lead{margin:1rem auto 0;color:var(--muted)}.viewer{margin-top:2.5rem;display:flex;align-items:center;gap:clamp(.5rem,2vw,1.5rem)}.viewer-stage{position:relative;flex:1;height:min(60vh,520px);border:1px solid var(--line);border-radius:16px;overflow:hidden;background:radial-gradient(circle at 50% 40%,#14181d,#0a0b0d)}#gallery-canvas{display:block;width:100%;height:100%}.arrow{flex:0 0 auto;width:clamp(44px,6vw,60px);height:clamp(44px,6vw,60px);border-radius:50%;border:1px solid var(--line);background:#ffffff0a;color:var(--text);font-size:1.8rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .1s ease}.arrow:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.arrow:active{transform:scale(.92)}.viewer-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a0b0dbf;color:var(--muted);font-size:.95rem;letter-spacing:.05em;transition:opacity .3s ease}.viewer-loading.hidden{opacity:0;pointer-events:none}.viewer-meta{margin-top:1.5rem;display:flex;align-items:baseline;justify-content:center;gap:1rem}.viewer-meta .v-name{font-size:1.4rem;font-weight:700}.viewer-meta .v-count{color:var(--muted);font-variant-numeric:tabular-nums}.panel{max-width:1100px;margin:0 auto;padding:clamp(4rem,12vh,9rem) clamp(1.2rem,4vw,3rem)}.panel h2{font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:700}.panel .lead{margin-top:1rem;max-width:60ch;color:var(--muted);font-size:1.05rem;line-height:1.6}.spec-grid{margin-top:2.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}.spec{background:var(--panel);padding:1.6rem 1.4rem;display:flex;flex-direction:column;gap:.35rem}.spec .num{font-size:1.5rem;font-weight:700;color:var(--accent)}.spec .lbl{font-size:.85rem;color:var(--muted)}.nav a.active{color:var(--text)}.about-hero{position:relative;min-height:70vh;display:flex;align-items:flex-end;padding:6rem clamp(1.2rem,4vw,3rem) clamp(2.5rem,6vw,4.5rem);background:linear-gradient(to top,var(--bg) 1%,rgba(13,15,18,.2) 55%,rgba(13,15,18,.55) 100%),url(/assets/project-5-zzYWkigK.jpg);background-size:cover;background-position:center 35%}.about-hero-inner{max-width:1100px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:.9rem}.about-eyebrow{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:var(--accent)}.about-hero h1{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;line-height:1.05;letter-spacing:-.02em;max-width:18ch}.about-hero p{max-width:56ch;color:#d7dbe0;font-size:clamp(1rem,1.4vw,1.2rem);line-height:1.6}.about-story{max-width:1100px}.story-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:stretch}.story-prose{display:flex;flex-direction:column;gap:1.2rem}.story-prose p{color:var(--muted);line-height:1.8;font-size:clamp(.98rem,1.15vw,1.1rem)}.story-figure{border-radius:16px;border:1px solid var(--line);min-height:360px;background:url(/assets/project-3-Cw4QAbKv.jpg);background-size:cover;background-position:center}.stats-heading{margin-top:clamp(3rem,6vw,4.5rem);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.story-stats{margin-top:1.2rem}@media (max-width: 820px){.story-grid{grid-template-columns:1fr}.story-figure{min-height:220px;order:-1}}.contact-page{max-width:1100px}.contact-grid{margin-top:2.5rem;display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-method{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.2rem;border:1px solid var(--line);border-radius:12px;background:var(--panel);color:var(--text);text-decoration:none;transition:border-color .2s ease,transform .12s ease,background .2s ease}a.contact-method:hover{border-color:var(--accent);transform:translateY(-2px)}.contact-method svg{width:24px;height:24px;flex:0 0 auto;color:var(--accent);stroke-linecap:round;stroke-linejoin:round}.cm-text{display:flex;flex-direction:column;gap:2px}.cm-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.cm-value{font-size:1rem;font-weight:600}.contact-form{display:flex;flex-direction:column;gap:1.1rem;text-align:left}.field{display:flex;flex-direction:column;gap:.4rem}.field label{font-size:.85rem;color:var(--muted)}.field input,.field textarea{width:100%;padding:.8rem .9rem;background:var(--input-bg);border:1px solid var(--line);border-radius:10px;color:var(--text);font:inherit;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #ffb02026}.field textarea{resize:vertical;min-height:140px}.btn-primary{align-self:flex-start;padding:.85rem 1.7rem;background:var(--accent);color:var(--accent-ink);font:inherit;font-weight:700;font-size:.98rem;border:0;border-radius:10px;cursor:pointer;transition:filter .2s ease,transform .1s ease}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:active{transform:scale(.97)}.form-note{font-size:.8rem;color:var(--muted)}.form-note.sent{color:var(--accent)}@media (max-width: 820px){.contact-grid{grid-template-columns:1fr}}.site-footer{position:relative;z-index:2;background:var(--footer-bg);border-top:1px solid var(--line);padding:clamp(3rem,8vh,5rem) clamp(1.2rem,4vw,3rem) 2rem}.foot-cols{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem}.foot-brand p{margin-top:.8rem;color:var(--muted);max-width:32ch}.foot-col h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:1rem}.foot-col a{display:block;color:var(--text);text-decoration:none;margin-bottom:.6rem;font-size:.95rem;transition:color .2s ease}.foot-col a:hover{color:var(--accent)}.foot-bottom{max-width:1100px;margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;color:var(--muted);font-size:.85rem}@media (max-width: 720px){.foot-cols{grid-template-columns:1fr 1fr}}#loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg);transition:opacity .6s ease}#loader.hidden{opacity:0;pointer-events:none}#loader .bar{width:min(260px,60vw);height:4px;background:#ffffff1f;border-radius:2px;overflow:hidden}#loader .fill{height:100%;width:0%;background:var(--accent);transition:width .2s ease}#loader p{font-size:.85rem;color:var(--muted);letter-spacing:.05em}.theme-switch{position:fixed;right:18px;bottom:18px;z-index:80}.theme-toggle{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #0000004d;transition:transform .15s ease,border-color .2s ease}.theme-toggle:hover{border-color:var(--accent);transform:translateY(-2px)}.theme-toggle svg{width:22px;height:22px;color:var(--accent)}.theme-menu{position:absolute;right:0;bottom:56px;min-width:156px;padding:6px;display:flex;flex-direction:column;gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 14px 40px #00000073;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.theme-switch.open .theme-menu{opacity:1;transform:none;pointer-events:auto}.theme-opt{display:flex;align-items:center;gap:10px;padding:8px 10px;border:0;border-radius:8px;background:transparent;color:var(--text);font:inherit;font-size:.9rem;text-align:left;cursor:pointer}.theme-opt:hover{background:#7f7f7f26}.theme-opt.active{background:#7f7f7f1f}.theme-opt .sw{width:16px;height:16px;border-radius:50%;border:1px solid var(--line);flex:0 0 auto}.theme-opt.active .sw{box-shadow:0 0 0 2px var(--accent)}
