:root{--bg:#080807;--ink:#f6f0df;--muted:rgba(246, 240, 223, 0.66);--faint:rgba(246, 240, 223, 0.34);--line:rgba(246, 240, 223, 0.16);--line2:rgba(246, 240, 223, 0.30);--accent:#ff4b22;--acid:#d8ff3e;--blue:#5364ff;--dark:#030302;--panel:rgba(246, 240, 223, 0.055);--project-surface:rgba(246, 240, 223, 0.035);--project-hover:rgba(246, 240, 223, 0.075);--paper:#f4efdf;--font:"Niramit", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--display:"Inter", system-ui, sans-serif;--serif:"Instrument Serif", Georgia, serif;--ease:cubic-bezier(0.16, 1, 0.3, 1);--header-h:54px;--header-top:14px;--page-x:20px}html[data-theme="white"],
body[data-theme="white"]{--bg:#f4efdf;--ink:#10100e;--muted:rgba(16, 16, 14, 0.66);--faint:rgba(16, 16, 14, 0.34);--line:rgba(16, 16, 14, 0.16);--line2:rgba(16, 16, 14, 0.28);--accent:#ec4a25;--acid:#9cb800;--blue:#2638c8;--dark:#f9f4e8;--panel:rgba(16, 16, 14, 0.045);--project-surface:rgba(16, 16, 14, 0.03);--project-hover:rgba(16, 16, 14, 0.07);--paper:#f4efdf}*,
*::before,
*::after{box-sizing:border-box}html{width:100%;max-width:100%;scroll-behavior:smooth;background:var(--bg);color-scheme:dark;overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}html[data-theme="white"]{color-scheme:light}body{width:100%;min-width:0;max-width:100%;margin:0;overflow-x:hidden;background:var(--bg);color:var(--ink);font-family:var(--font);font-size:14px;line-height:1.5;letter-spacing:0.005em;transition:background-color 0.32s var(--ease),
    color 0.32s var(--ease)}body.modal-open,
html.is-loading,
html.is-loading body{overflow:hidden}a{color:inherit;text-decoration:none}button,
input,
textarea,
select{max-width:100%;font:inherit}button{color:inherit}img,
video,
canvas,
svg,
iframe,
model-viewer{display:block;max-width:100%}img,
video{height:auto}h1,
h2,
h3,
h4,
p,
span,
a,
li,
strong,
em,
b,
small,
button{overflow-wrap:break-word;word-break:normal}::selection{background:var(--accent);color:#fff}.background-click-layer,
.burst-layer,
.art-bg-canvas,
.motion-orbs{display:none !important}.ripple,
.bg-glitch-slice,
.click-firework-ring,
.theme-flash{display:none !important}.site-header,
main,
.site-footer{position:relative;z-index:10}.loader{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;overflow:hidden;padding:28px;background:radial-gradient(circle at 50% 48%, rgba(138, 252, 93, 0.055), transparent 22%),
    radial-gradient(circle at 20% 15%, rgba(77, 225, 255, 0.035), transparent 34%),
    radial-gradient(circle at 80% 80%, rgba(83, 100, 255, 0.07), transparent 36%),
    #000;color:#f6f0df;opacity:1;visibility:visible;transition:opacity 0.85s var(--ease),
    visibility 0.85s,
    filter 0.85s var(--ease),
    transform 0.85s var(--ease)}.loader::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 48%, transparent 0 22%, rgba(0, 0, 0, 0.64) 72%, #000 100%)}.loader.is-accelerating .loader-portal{animation:loaderExitPortal 0.92s var(--ease) forwards}.loader.is-hidden{opacity:0;visibility:hidden;filter:blur(14px);transform:scale(1.08)}.loader-atmosphere{position:absolute;inset:0;overflow:hidden}.loader-atmosphere i{position:absolute;width:38vw;aspect-ratio:1;border-radius:50%;filter:blur(80px);opacity:0.11;background:var(--accent);animation:loaderAtmosphere 7s ease-in-out infinite alternate}.loader-atmosphere i:nth-child(1){left:-12vw;top:-8vh}.loader-atmosphere i:nth-child(2){right:-14vw;top:24vh;background:var(--blue);animation-delay:-2s}.loader-atmosphere i:nth-child(3){left:36vw;bottom:-28vh;background:var(--acid);opacity:0.05;animation-delay:-4s}.loader-portal{position:relative;z-index:2;width:min(330px, 72vw);aspect-ratio:1;display:grid;place-items:center;transform:scale(0.82);will-change:transform, opacity, filter}.loader-portal-glow{position:absolute;inset:18%;border-radius:50%;background:radial-gradient(circle, rgba(138, 252, 93, 0.18), transparent 38%),
    radial-gradient(circle, rgba(77, 225, 255, 0.08), transparent 68%);filter:blur(14px);animation:loaderGlow 3.4s ease-in-out infinite}.loader-ring{position:absolute;border-radius:50%;border:1px solid rgba(138, 252, 93, 0.20);box-shadow:inset 0 0 28px rgba(138, 252, 93, 0.025),
    0 0 24px rgba(138, 252, 93, 0.035)}.loader-ring::after{content:"";position:absolute;left:50%;top:-3px;width:6px;height:6px;border-radius:50%;background:#8afc5d;box-shadow:0 0 16px rgba(138, 252, 93, 0.72)}.loader-ring-a{width:44%;height:44%;transform:rotateX(68deg);animation:loaderSpinA 2.1s linear infinite}.loader-ring-b{width:68%;height:68%;transform:rotateX(74deg) rotateY(45deg);animation:loaderSpinB 3s linear infinite reverse}.loader-ring-c{width:96%;height:42%;opacity:0.42;transform:rotateX(82deg) rotateY(-25deg);animation:loaderSpinC 4.8s linear infinite}.loader.is-accelerating .loader-ring-a{animation-duration:0.46s}.loader.is-accelerating .loader-ring-b{animation-duration:0.60s}.loader.is-accelerating .loader-ring-c{animation-duration:0.74s}.loader-orbit{position:absolute;width:78%;height:78%;border-radius:50%;transform:rotateX(70deg);animation:loaderOrbit 5.6s linear infinite}.loader-orbit i{position:absolute;left:50%;top:50%;width:4px;height:4px;margin:-2px;border-radius:50%;background:#8afc5d;box-shadow:0 0 10px rgba(138, 252, 93, 0.55)}.loader-orbit i:nth-child(1){transform:rotate(0deg) translateY(-128px)}.loader-orbit i:nth-child(2){transform:rotate(45deg) translateY(-128px);opacity:0.7}.loader-orbit i:nth-child(3){transform:rotate(90deg) translateY(-128px);opacity:0.5}.loader-orbit i:nth-child(4){transform:rotate(135deg) translateY(-128px);opacity:0.8}.loader-orbit i:nth-child(5){transform:rotate(180deg) translateY(-128px);opacity:0.46}.loader-orbit i:nth-child(6){transform:rotate(225deg) translateY(-128px);opacity:0.64}.loader-orbit i:nth-child(7){transform:rotate(270deg) translateY(-128px);opacity:0.4}.loader-orbit i:nth-child(8){transform:rotate(315deg) translateY(-128px);opacity:0.58}.loader-core{width:18px;height:18px;border-radius:50%;background:#8afc5d;box-shadow:0 0 18px rgba(138, 252, 93, 0.82),
    0 0 42px rgba(77, 225, 255, 0.26),
    0 0 74px rgba(138, 252, 93, 0.18);animation:loaderCore 1.5s ease-in-out infinite}.loader-meta{display:none}.loader-track{position:absolute;left:24px;right:24px;bottom:28px;z-index:3;height:5px;overflow:visible;border-radius:999px;background:rgba(255, 255, 255, 0.10);box-shadow:0 0 0 1px rgba(255, 255, 255, 0.06),
    0 0 22px rgba(138, 252, 93, 0.13)}.loader-track span{position:relative;display:block;width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg, #8afc5d, #b5ff7a, #4de1ff, #fff);box-shadow:0 0 10px rgba(138, 252, 93, 0.72),
    0 0 26px rgba(138, 252, 93, 0.38);transition:width 0.12s linear}.loader-track span::after{content:"";position:absolute;top:50%;right:-7px;width:14px;height:14px;border-radius:50%;transform:translateY(-50%);background:#fff;box-shadow:0 0 14px rgba(255, 255, 255, 0.68),
    0 0 24px rgba(138, 252, 93, 0.58)}html.is-index-entering main,
html.is-index-entering .site-header,
html.is-index-entering .site-footer{animation:indexEnter 1.05s var(--ease) both}@keyframes loaderAtmosphere{from{transform:translate3d(-3vw, 2vh, 0) scale(0.9)}to{transform:translate3d(6vw, -4vh, 0) scale(1.1)}}@keyframes loaderGlow{0%, 100%{transform:scale(0.9);opacity:0.64}50%{transform:scale(1.08);opacity:1}}@keyframes loaderSpinA{to{transform:rotateX(68deg) rotateZ(360deg)}}@keyframes loaderSpinB{to{transform:rotateX(74deg) rotateY(45deg) rotateZ(360deg)}}@keyframes loaderSpinC{to{transform:rotateX(82deg) rotateY(-25deg) rotateZ(360deg)}}@keyframes loaderOrbit{to{transform:rotateX(70deg) rotateZ(360deg)}}@keyframes loaderCore{0%, 100%{transform:scale(0.72);opacity:0.72}50%{transform:scale(1.2);opacity:1}}@keyframes loaderExitPortal{0%{transform:scale(0.82);opacity:1;filter:blur(0)}42%{transform:scale(1.15) rotateZ(8deg);opacity:1;filter:blur(1px)}100%{transform:scale(2.3) rotateZ(18deg);opacity:0;filter:blur(20px)}}@keyframes indexEnter{from{opacity:0;transform:translate3d(0, 24px, 0) scale(1.04);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}.cursor-dot,
.cursor-ring{position:fixed;left:0;top:0;z-index:9998;pointer-events:none;opacity:0;transform:translate(-50%, -50%);transition:opacity 0.2s,
    width 0.2s,
    height 0.2s,
    background 0.2s,
    border-color 0.2s}.cursor-dot{width:6px;height:6px;border-radius:50%;background:var(--ink)}.cursor-ring{width:38px;height:38px;border:1px solid var(--line2);border-radius:50%;display:grid;place-items:center}.cursor-ring span{opacity:0;color:var(--bg);font-size:9px;font-weight:900;letter-spacing:0.1em;text-transform:uppercase}.cursor-ready .cursor-dot,
.cursor-ready .cursor-ring{opacity:1}.cursor-hover .cursor-ring{width:70px;height:70px;background:var(--ink);border-color:var(--ink)}.cursor-hover .cursor-ring span{opacity:1}.hover-preview{position:fixed;z-index:8000;width:210px;height:142px;pointer-events:none;opacity:0;transform:translate(-50%, -52%) scale(0.94) rotate(-2deg);transition:opacity 0.18s var(--ease),
    transform 0.22s var(--ease);padding:5px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 82%, var(--ink) 12%);box-shadow:0 24px 70px rgba(0, 0, 0, 0.25)}.hover-preview.is-visible{opacity:1;transform:translate(-50%, -56%) scale(1) rotate(-2deg)}.hover-preview img{width:100%;height:100%;padding:4px;object-fit:contain;background:var(--bg)}.hover-preview em{position:absolute;left:8px;bottom:8px;padding:4px 6px;color:var(--bg);background:var(--ink);font-size:9px;font-weight:900;font-style:normal;letter-spacing:0.12em;text-transform:uppercase}.fx-click-core,
.fx-click-ray{position:absolute;left:0;top:0;pointer-events:none}.fx-click-core{width:7px;height:7px;border-radius:50%;transform:translate(-50%, -50%);background:var(--accent);box-shadow:0 0 12px color-mix(in srgb, var(--accent) 72%, transparent),
    0 0 28px color-mix(in srgb, var(--blue) 24%, transparent);animation:clickCore 0.62s var(--ease) forwards}.fx-click-ray{width:var(--ray-length, 24px);height:1px;transform-origin:left center;background:linear-gradient(90deg, var(--accent), var(--ink), transparent);animation:clickRay 0.68s var(--ease) forwards}@keyframes clickCore{from{opacity:1;transform:translate(-50%, -50%) scale(0.4)}to{opacity:0;transform:translate(-50%, -50%) scale(2.4)}}@keyframes clickRay{from{opacity:0.9;transform:rotate(var(--ray-angle)) translateX(2px) scaleX(0.2)}to{opacity:0;transform:rotate(var(--ray-angle)) translateX(34px) scaleX(1.45)}}.site-header{position:fixed;top:var(--header-top);left:18px;right:18px;z-index:5000;height:var(--header-h);display:grid;grid-template-columns:minmax(220px, 340px) 1fr auto;align-items:center;gap:18px;padding:0 16px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 88%, transparent);backdrop-filter:blur(18px) saturate(1.08);-webkit-backdrop-filter:blur(18px) saturate(1.08);box-shadow:0 14px 54px rgba(0, 0, 0, 0.16)}html[data-theme="white"] .site-header{background:rgba(244, 239, 223, 0.88);box-shadow:0 14px 54px rgba(16, 16, 14, 0.08)}.brand{display:flex;align-items:center;min-width:0;font-size:0}.brand span{color:var(--ink);font-size:14px;line-height:1;font-weight:900;letter-spacing:-0.03em;white-space:nowrap}.site-nav{display:flex;justify-content:center;align-items:center;gap:clamp(12px, 2vw, 28px);min-width:0}.site-nav a{padding:8px 0;color:var(--muted);font-size:10px;line-height:1;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;transition:color 0.2s var(--ease),
    transform 0.2s var(--ease)}.site-nav a:hover{color:var(--accent);transform:translateY(-1px)}.header-right{display:flex;justify-content:flex-end;align-items:center;gap:8px;min-width:0;white-space:nowrap}.theme-mini,
.hamburger{position:relative;display:inline-flex;align-items:center;justify-content:center;height:34px;border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer}.theme-mini{min-width:124px;gap:8px;padding:0 12px}.theme-mini span{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent)}.theme-mini b{color:var(--ink);font-size:9px;line-height:1;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.theme-mini:hover,
.hamburger:hover{border-color:var(--accent)}.header-status{display:inline-flex;align-items:center;gap:8px;height:34px;padding:0 10px;border:1px solid var(--line);color:var(--muted);font-size:9px;line-height:1;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.header-status span + span::before{content:"/ ";opacity:0.55}.hamburger{display:none;width:38px;padding:0;flex-direction:column;gap:7px}.hamburger i{display:block;width:16px;height:1px;background:currentColor;transition:transform 0.22s var(--ease)}.hamburger.is-open i:first-child{transform:translateY(4px) rotate(45deg)}.hamburger.is-open i:last-child{transform:translateY(-4px) rotate(-45deg)}.mobile-panel{position:fixed;top:78px;left:18px;right:18px;z-index:4900;display:grid;max-height:calc(100dvh - 96px);overflow:auto;padding:10px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 94%, transparent);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px);transition:opacity 0.24s var(--ease),
    transform 0.24s var(--ease),
    visibility 0.24s}.mobile-panel.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:none}.mobile-panel a{display:block;padding:14px 10px;border-bottom:1px solid var(--line);color:var(--ink);font-size:12px;line-height:1;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.mobile-panel a:last-child{border-bottom:0}.page-section{width:min(100%, 1500px);margin:0 auto;padding:96px var(--page-x)}.section-label,
.section-head p{margin:0;color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.section-head{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:end;margin-bottom:24px;padding-top:12px;border-top:1px solid var(--line)}.section-head span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.hero{position:relative;isolation:isolate;display:grid;align-items:center;min-height:94vh;padding-top:108px;overflow:hidden}.hero::before{content:"";position:absolute;inset:76px 28px 26px;z-index:0;pointer-events:none;opacity:0.22;background:linear-gradient(90deg, color-mix(in srgb, var(--ink) 7%, transparent) 1px, transparent 1px),
    linear-gradient(0deg, color-mix(in srgb, var(--ink) 5%, transparent) 1px, transparent 1px);background-size:clamp(42px, 5vw, 78px) clamp(42px, 5vw, 78px);mask-image:radial-gradient(circle at 66% 42%, #000 0 40%, transparent 74%);-webkit-mask-image:radial-gradient(circle at 66% 42%, #000 0 40%, transparent 74%)}.hero::after{content:"PORTFOLIO\A VISUAL";white-space:pre;position:absolute;left:clamp(16px, 10vw, 180px);top:51%;z-index:0;pointer-events:none;transform:translateY(-40%);color:color-mix(in srgb, var(--ink) 8%, transparent);font-family:var(--display);font-size:clamp(72px, 12vw, 190px);line-height:0.76;font-weight:900;letter-spacing:-0.09em;opacity:0.42}.hero-visual-system{position:absolute;inset:54px 0 0;z-index:2;pointer-events:none}.kinetic-type{position:absolute;left:clamp(12px, 4vw, 64px);top:54%;transform:translateY(-50%);color:var(--ink);font-family:var(--display);font-size:clamp(62px, 12vw, 190px);line-height:0.75;font-weight:900;letter-spacing:-0.1em;text-transform:uppercase;opacity:0.045}.kinetic-type span{display:block;animation:typeFloat 9s ease-in-out infinite}.floating-stack{position:absolute;right:clamp(34px, 5.4vw, 96px);top:18vh;width:min(40vw, 590px);height:56vh;z-index:4;overflow:visible}.float-card,
.float-card[class*="f-"]{position:absolute;left:var(--x, 0);top:var(--y, 0);right:auto;bottom:auto;width:calc(var(--w, 35%) * 0.88);height:auto;aspect-ratio:16 / 10;margin:0;padding:1.5px;overflow:hidden;border:0.5px solid color-mix(in srgb, var(--ink) 14%, transparent);background:color-mix(in srgb, var(--ink) 74%, var(--bg) 26%);box-shadow:0 18px 54px rgba(0, 0, 0, 0.24);transform:rotate(var(--r, 0deg)) scale(var(--scale, 1));animation:screenFloat var(--duration, 11s) ease-in-out infinite;animation-delay:var(--delay, 0s);will-change:transform}.float-card img{width:100%;height:100%;object-fit:contain;object-position:center;background:color-mix(in srgb, var(--ink) 4%, var(--bg))}.float-card figcaption{display:none}.float-card.f-0{--x:46%;--y:2%;--w:50%;--r:-2deg;--z:7;--delay:-1s}.float-card.f-1{--x:8%;--y:14%;--w:36%;--r:2deg;--z:3;--delay:-3s}.float-card.f-2{--x:56%;--y:30%;--w:38%;--r:1deg;--z:6;--delay:-5s}.float-card.f-3{--x:18%;--y:43%;--w:34%;--r:-2deg;--z:5;--delay:-7s}.float-card.f-4{--x:62%;--y:58%;--w:31%;--r:2deg;--z:4;--delay:-2s}.float-card.f-5{--x:2%;--y:68%;--w:30%;--r:-1deg;--z:2;--delay:-6s}.float-card.f-6{--x:34%;--y:75%;--w:27%;--r:1deg;--z:3;--delay:-4s}.orbital-code{position:absolute;right:20px;bottom:24px;z-index:5;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.orbital-code span{padding:7px 9px;border:1px solid var(--line);color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.hero-grid{position:relative;z-index:6;display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(22px, 4vw, 64px);align-items:end}.hero-left{max-width:820px}.hero h1{max-width:900px;margin:16px 0 0;color:var(--ink);font-family:var(--display);font-size:clamp(58px, 9.4vw, 142px);line-height:0.82;font-weight:900;letter-spacing:-0.085em;text-transform:uppercase}.hero h1 span{display:block}.hero h1 span:nth-child(2){color:var(--accent);font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none}.hero-copy{max-width:520px;color:var(--muted);font-size:14px;line-height:1.65}.hero-right{display:grid;align-self:end;justify-self:end;width:min(360px, 100%)}.hero-ticker{position:relative;display:flex;align-items:center;gap:10px;overflow:hidden;margin-top:26px;padding:10px 12px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 76%, transparent);backdrop-filter:blur(10px);color:var(--faint);font-size:9px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.hero-ticker::after{content:"";position:absolute;top:0;bottom:0;left:-90px;width:90px;background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 24%, transparent), transparent);animation:tickerScan 3.8s var(--ease) infinite}.hero-ticker i{flex:1;height:1px;background:var(--line)}@keyframes typeFloat{50%{transform:translateX(3vw)}}@keyframes screenFloat{0%, 100%{translate:0 0}35%{translate:var(--dx1, 6px) var(--dy1, -8px)}70%{translate:var(--dx2, -5px) var(--dy2, 5px)}}@keyframes tickerScan{to{left:100%}}.about-grid{display:grid;grid-template-columns:minmax(360px, 430px) minmax(0, 1fr) minmax(220px, 260px);gap:24px;align-items:stretch}.profile-glitch{position:relative;min-height:620px;height:620px;margin:0;overflow:hidden;border:1px solid var(--line);background:var(--ink);box-shadow:0 32px 100px rgba(0, 0, 0, 0.24);cursor:pointer}.profile-glitch img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.55s var(--ease),
    filter 0.55s var(--ease),
    opacity 0.35s var(--ease)}.profile-glitch img:nth-child(2){opacity:0;mix-blend-mode:screen}.profile-glitch::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(
    120deg,
    transparent 0 38%,
    color-mix(in srgb, var(--accent) 16%, transparent) 47%,
    transparent 56%
  );transform:translateX(-120%);transition:transform 0.75s var(--ease);mix-blend-mode:screen}.profile-glitch:hover::after{transform:translateX(120%)}.profile-glitch:hover img:first-child{transform:scale(1.035);filter:contrast(1.08) saturate(1.05)}.profile-glitch:hover img:nth-child(2){opacity:0.18;transform:translateX(4px)}.profile-glitch figcaption{position:absolute;left:10px;bottom:10px;padding:6px 8px;background:var(--ink);color:var(--bg);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.about-copy{align-self:end}.about-copy h2{margin:12px 0 18px;color:var(--ink);font-family:var(--display);font-size:clamp(30px, 4vw, 62px);line-height:0.92;letter-spacing:-0.07em}.about-copy p:not(.section-label){max-width:680px;color:var(--muted)}.about-facts{display:grid;gap:8px;margin-top:24px}.about-facts div{display:grid;grid-template-columns:110px 1fr;gap:12px;padding-top:10px;border-top:1px solid var(--line)}.about-facts span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.13em;text-transform:uppercase}.about-facts strong{color:var(--ink);font-size:13px}.tool-lab{position:relative;min-height:620px;height:620px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg, color-mix(in srgb, var(--ink) 4%, transparent), transparent)}.lab-title{position:absolute;left:12px;top:12px;z-index:4;color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.tool-chip{position:absolute;left:0;top:0;z-index:2;display:grid;place-items:center;width:68px;height:68px;padding:10px;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 6%, transparent);color:var(--ink);cursor:pointer;will-change:transform}.tool-chip img{width:28px;height:28px;object-fit:contain}.tool-chip span{font-size:10px;font-weight:900}.tool-chip.is-active{border-color:var(--accent);background:var(--accent);color:#fff}.tool-lines{position:absolute;inset:0;pointer-events:none}.project-controls{display:grid;grid-template-columns:1fr 420px;gap:18px;margin-bottom:18px}.filter-row{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:8px 10px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer}.chip.is-active,
.chip:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}.sort-row{display:grid;grid-template-columns:1fr 130px;gap:8px}.sort-row label{display:grid;gap:4px;padding:7px 9px;border:1px solid var(--line)}.sort-row span{color:var(--faint);font-size:9px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.sort-row input,
.sort-row select{width:100%;border:0;outline:0;background:transparent;color:var(--ink)}.sort-row option{background:var(--bg);color:var(--ink)}.project-toolbar{display:grid;grid-template-columns:1fr 60px 1fr;gap:12px;padding:10px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.project-toolbar span:nth-child(2){color:var(--accent);text-align:center}.project-toolbar span:last-child{text-align:right}.projects .project-index,
.project-index{display:grid;gap:7px;border:0}.project-row{--mx:50%;--my:50%;position:relative;width:100%;min-height:96px;display:grid;grid-template-columns:46px 124px minmax(0, 1fr) minmax(160px, 220px) 90px;gap:14px;align-items:center;overflow:hidden;padding:10px 12px;border:1px solid var(--line);border-left:3px solid transparent;background:var(--project-surface);color:var(--ink);text-align:left;cursor:pointer;transition:background 0.22s var(--ease),
    border-color 0.22s var(--ease),
    transform 0.22s var(--ease)}.project-row::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at var(--mx) var(--my), color-mix(in srgb, var(--accent) 10%, transparent), transparent 38%),
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 48%);opacity:0;transition:opacity 0.28s var(--ease)}.project-row:hover{border-left-color:var(--accent);background:var(--project-hover);transform:translateX(4px)}.project-row:hover::before{opacity:1}.row-bg-text,
.row-type{display:none}.row-no{position:relative;z-index:2;align-self:stretch;display:grid;place-items:center;border-right:1px solid var(--line);color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.row-thumb{position:relative;z-index:2;display:block;width:124px;height:74px;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 74%, var(--ink) 7%)}.row-thumb img{width:100%;height:100%;padding:5px;object-fit:contain;object-position:center;background:transparent;transition:transform 0.24s var(--ease)}.row-thumb.fit-cover img{padding:0;object-fit:cover}.project-row:hover .row-thumb.fit-cover img{transform:scale(1.025)}.project-row:hover .row-thumb.fit-contain img{transform:scale(0.985)}.row-main{position:relative;z-index:2;min-width:0}.row-title{display:block;max-width:850px;color:var(--ink);font-family:var(--display);font-size:clamp(21px, 2.8vw, 40px);line-height:0.96;font-weight:900;letter-spacing:-0.055em;transition:color 0.24s var(--ease),
    transform 0.24s var(--ease)}.project-row:hover .row-title{color:var(--accent);transform:translateX(5px)}.row-sub{display:-webkit-box;max-width:620px;margin-top:6px;overflow:hidden;color:var(--muted);font-size:11px;line-height:1.35;-webkit-line-clamp:2;-webkit-box-orient:vertical}.row-tags{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:5px}.row-tags em{padding:5px 7px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 80%, transparent);color:var(--muted);font-size:9px;line-height:1;font-weight:900;font-style:normal;letter-spacing:0.08em;text-transform:uppercase}.row-year{position:relative;z-index:2;display:grid;gap:6px;color:var(--muted);text-align:right;font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.row-year b{color:var(--ink);font-size:13px}.row-year i{color:var(--accent);font-size:9px;font-style:normal;letter-spacing:0.1em}.stats-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:1px;margin-bottom:28px;border:1px solid var(--line);background:var(--line)}.stat-card{min-height:210px;padding:18px;background:var(--bg)}.stat-card span,
.archive-item > span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.13em;text-transform:uppercase}.stat-card h3{margin:42px 0 12px;color:var(--ink);font-size:21px;line-height:1;letter-spacing:-0.04em}.stat-card p{margin:0;color:var(--muted);font-size:13px}.recognition-list{border-top:1px solid var(--line)}.archive-item{position:relative;display:grid;grid-template-columns:90px 1fr 120px;gap:20px;overflow:hidden;padding:16px 0;border-bottom:1px solid var(--line)}.archive-item::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform 0.35s var(--ease)}.archive-item:hover::after{transform:scaleX(1)}.archive-item h3{margin:0 0 4px;color:var(--ink)}.archive-item p{margin:0;color:var(--muted);font-size:13px}.contact-grid{display:grid;grid-template-columns:1fr 0.9fr;gap:30px;align-items:start}.contact-statement > span{color:var(--accent);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.contact-statement h2{max-width:900px;margin:14px 0 26px;color:var(--ink);font-family:var(--display);font-size:clamp(40px, 7vw, 102px);line-height:0.86;letter-spacing:-0.08em}.contact-links{display:flex;flex-wrap:wrap;gap:8px}.contact-links a,
.send-button{position:relative;overflow:hidden;padding:10px 12px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer}.contact-links a:hover,
.send-button:hover{border-color:var(--accent);color:var(--accent)}.sentence-form{display:flex;flex-wrap:wrap;gap:8px;padding-top:16px;border-top:1px solid var(--line)}.sentence-form span,
.sentence-form input,
.sentence-form textarea{font-size:28px;line-height:1.1;letter-spacing:-0.05em}.sentence-form input,
.sentence-form textarea{min-width:180px;flex:1;border:0;border-bottom:1px solid var(--line);outline:0;background:transparent;color:var(--ink)}.sentence-form input:focus,
.sentence-form textarea:focus{color:var(--accent)}.sentence-form textarea{min-height:100px;flex-basis:100%;resize:vertical}.form-note{flex-basis:100%;color:var(--muted);font-size:12px}.site-footer{display:flex;justify-content:space-between;gap:18px;padding:22px 20px;border-top:1px solid var(--line);color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.modal{position:fixed;inset:0;z-index:7000;display:none;background:rgba(0, 0, 0, 0.76)}.modal.is-open{display:block}.modal-bg{position:absolute;inset:0;background:color-mix(in srgb, var(--bg) 72%, black 18%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.modal-panel{position:absolute;inset:0;width:100%;max-width:none;height:100%;margin:0;overflow:auto;outline:0;background:var(--bg);color:var(--ink);scrollbar-gutter:stable}.modal-close{position:fixed;right:22px;top:22px;z-index:50;min-width:74px;padding:12px 18px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 90%, transparent);color:var(--ink);backdrop-filter:blur(14px);font-size:11px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer}.modal-close:hover{border-color:var(--accent);background:var(--ink);color:var(--bg)}.modal-content{width:min(1240px, calc(100vw - 44px));margin:0 auto;padding:clamp(72px, 8vw, 104px) 0 118px;color:var(--ink)}.modal-nav{position:fixed;left:50%;bottom:22px;z-index:42;width:min(1080px, calc(100vw - 52px));display:flex;justify-content:space-between;align-items:center;gap:14px;transform:translateX(-50%);pointer-events:none}.modal-nav button{pointer-events:auto;min-width:148px;height:46px;display:inline-flex;align-items:center;justify-content:center;padding:0 16px;border:1px solid var(--line);background:color-mix(in srgb, var(--bg) 86%, transparent);color:var(--ink);backdrop-filter:blur(16px);box-shadow:0 18px 54px rgba(0, 0, 0, 0.16);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;transition:transform 0.24s var(--ease),
    border-color 0.24s var(--ease),
    background 0.24s var(--ease),
    color 0.24s var(--ease)}.modal-nav button:hover{transform:translateY(-4px);border-color:var(--accent);background:var(--ink);color:var(--bg)}.project-page{width:100%;color:var(--ink)}.project-page-hero,
.case-hero{display:grid;grid-template-columns:minmax(0, 0.86fr) minmax(360px, 1fr);gap:clamp(22px, 3vw, 42px);align-items:end;margin-bottom:clamp(24px, 4vw, 44px)}.project-hero-copy,
.case-title{align-self:end}.case-kicker,
.case-title > p:first-child{margin:0 0 18px;color:var(--faint);font-size:11px;font-weight:900;letter-spacing:0.15em;text-transform:uppercase}.project-hero-copy h2,
.case-title h2{max-width:650px;margin:0;color:var(--ink);font-family:var(--display);font-size:clamp(46px, 7vw, 104px);line-height:0.88;letter-spacing:-0.07em}.case-subtitle,
.case-title p:last-child{max-width:620px;margin:24px 0 0;color:var(--muted);font-size:clamp(14px, 1.5vw, 18px);line-height:1.45;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}.project-hero-cover,
.case-cover{min-height:0;aspect-ratio:16 / 10;margin:0;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 6%, var(--bg))}.project-hero-cover img,
.case-cover img{width:100%;height:100%;object-fit:contain;object-position:center}.project-page-meta,
.case-meta{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:10px;margin:0 0 clamp(26px, 4vw, 46px)}.project-page-meta div,
.case-meta div{min-height:auto;display:grid;align-content:start;gap:12px;padding:16px;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 4%, transparent)}.project-page-meta span,
.case-meta span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.13em;text-transform:uppercase}.project-page-meta strong,
.case-meta strong{color:var(--ink);font-size:13px;line-height:1.45}.project-page-intro,
.case-story{display:grid;grid-template-columns:minmax(230px, 0.42fr) minmax(0, 1fr);gap:clamp(22px, 4vw, 52px);padding:0 0 clamp(28px, 4vw, 46px)}.project-page-intro aside span,
.case-story aside span{display:block;margin-bottom:12px;color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.project-page-intro aside p,
.case-story aside p{margin:0;color:var(--muted);font-size:15px;line-height:1.7}.project-page-intro article{display:grid;gap:18px}.project-page-intro article p,
.case-story > div p{display:grid;grid-template-columns:42px minmax(0, 1fr);gap:18px;margin:0;color:var(--muted);font-size:clamp(14px, 1.55vw, 18px);line-height:1.65}.project-page-intro article b{color:var(--faint);font-size:11px;letter-spacing:0.12em}.project-page-deliverables,
.project-page-tools,
.deliverables{display:grid;grid-template-columns:180px 1fr;gap:26px;padding:22px 0;border-bottom:1px solid var(--line)}.project-page-deliverables > span,
.project-page-tools > span,
.deliverables > span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.13em;text-transform:uppercase}.project-page-deliverables ul,
.deliverables ul{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}.project-page-deliverables li,
.project-page-tools div span,
.deliverables li{padding:8px 10px;border:1px solid var(--line);color:var(--ink);font-size:12px;font-weight:800;letter-spacing:0.06em;text-transform:uppercase}.project-page-tools div{display:flex;flex-wrap:wrap;gap:8px}.project-section-title{display:flex;align-items:end;justify-content:space-between;gap:18px;margin:clamp(22px, 4vw, 56px) 0 clamp(22px, 3vw, 38px);padding-top:18px;border-top:2px solid var(--ink)}.project-section-title span,
.project-section-title em{color:var(--muted);font-size:10px;font-weight:900;font-style:normal;letter-spacing:0.13em;text-transform:uppercase}.project-page-process,
.case-blocks{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:14px}.project-page-process .project-section-title{grid-column:1 / -1}.case-process-card,
.case-blocks article{min-height:160px;padding:18px;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 5%, transparent)}.case-process-card span,
.case-blocks span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.case-process-card p,
.case-blocks p{margin:18px 0 0;color:var(--muted);font-size:14px;line-height:1.65}.project-page-custom{display:grid;gap:14px}.case-section{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:end;padding-top:18px;border-top:1px solid var(--line)}.case-section figure{margin:0;background:color-mix(in srgb, var(--ink) 6%, var(--bg))}.case-section figure img{width:100%;height:100%;min-height:330px;object-fit:cover}.case-section div,
.case-section-text{padding:18px 0}.case-section h3{margin:18px 0 12px;color:var(--ink);font-size:34px;line-height:0.95;letter-spacing:-0.05em}.case-section p{margin:0;color:var(--muted);line-height:1.6}.case-section-quote{margin:0;padding:36px 0;border-top:1px solid var(--line);color:var(--ink);font-size:clamp(28px, 4vw, 64px);line-height:0.98;letter-spacing:-0.05em}.case-section-quote p{margin:12px 0}.case-section-quote cite{color:var(--muted);font-size:12px;font-style:normal;letter-spacing:0.12em;text-transform:uppercase}.project-content-flow{display:grid;gap:clamp(42px, 6vw, 86px);margin-top:0}.content-block{min-width:0}.content-block-text,
.content-text-frame,
.content-grid-head,
.content-text-card,
.media-section-head.independent-head,
.media-item figcaption,
.project-video-note{border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 4%, transparent);color:var(--ink)}.content-block-text{width:100%;max-width:none;padding:clamp(20px, 3vw, 40px)}.content-block-text.is-narrow{max-width:760px}.content-block-text.align-center{margin-inline:auto;text-align:center}.content-block-text.align-right{margin-left:auto}.content-block-text.text-frame-plain{padding:0;border:0;background:transparent}.content-block-text.text-frame-boxed,
.content-text-frame.text-frame-boxed{padding:clamp(18px, 2.2vw, 30px);border:0.75px solid color-mix(in srgb, var(--ink) 18%, transparent);background:color-mix(in srgb, var(--paper) 6%, transparent)}.content-block-text span,
.content-block-quote span,
.content-text-frame b,
.content-grid-head span,
.content-text-card b,
.media-section-head.independent-head span,
.media-section-head.independent-head em{display:block;margin-bottom:12px;color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.content-block-text h3,
.content-text-frame h3,
.content-grid-head h3,
.media-section-head.independent-head h3{margin:0 0 14px;color:var(--ink);font-size:clamp(24px, 3.5vw, 48px);line-height:0.98;letter-spacing:-0.055em}.content-block-text p,
.content-text-frame p,
.content-grid-head p,
.content-text-card p,
.media-section-head.independent-head p{margin:0;color:var(--muted);font-size:15px;line-height:1.72}.content-text-copy{display:grid;grid-template-columns:1fr;gap:clamp(8px, 1.1vw, 14px);width:100%}.content-text-copy.text-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr));column-gap:clamp(18px, 3vw, 44px);row-gap:clamp(10px, 1.4vw, 18px)}.content-block-media{display:grid;grid-template-columns:minmax(0, 1fr) minmax(280px, 360px);gap:clamp(16px, 2.4vw, 32px);align-items:stretch}.content-block-media.display-text-left{grid-template-columns:minmax(280px, 360px) minmax(0, 1fr)}.content-block-media.display-text-left .content-text-frame{order:-1}.content-block-media.display-hero,
.content-block-media.display-full,
.content-block-media.display-center{grid-template-columns:1fr}.content-block-media.display-center{width:min(1120px, 100%);margin-inline:auto}.content-block-media.display-detail{width:min(980px, 100%);margin-inline:auto;grid-template-columns:minmax(0, 0.75fr) minmax(240px, 0.35fr)}.content-block-media .content-text-frame.text-width-full{grid-column:1 / -1}.content-media-frame{position:relative;min-height:340px;margin:0;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 5%, var(--bg));box-shadow:0 18px 50px rgba(0, 0, 0, 0.08)}.content-media-frame img,
.content-media-frame video,
.content-media-frame model-viewer,
.content-media-frame iframe{width:100%;height:100%;min-height:inherit;object-position:center;background:transparent}.content-media-frame img,
.content-media-frame video{object-fit:cover}.content-block-media.fit-contain .content-media-frame img,
.content-block-media.fit-contain .content-media-frame video{object-fit:contain}.content-block-media.ratio-wide .content-media-frame{aspect-ratio:16 / 9}.content-block-media.ratio-banner .content-media-frame{aspect-ratio:21 / 9}.content-block-media.ratio-square .content-media-frame{aspect-ratio:1 / 1}.content-block-media.ratio-medium .content-media-frame,
.content-block-media.ratio-detail .content-media-frame{aspect-ratio:4 / 3}.content-block-media.ratio-poster .content-media-frame{aspect-ratio:3 / 4}.content-block-media.ratio-tall .content-media-frame{aspect-ratio:4 / 5}.content-block-media.ratio-long .content-media-frame{min-height:0;aspect-ratio:auto;background:transparent}.content-block-media.ratio-long .content-media-frame img{width:100%;height:auto;min-height:0;object-fit:contain}.content-block-media.type-model.display-hero .content-media-frame,
.content-block-media.type-model.display-full .content-media-frame,
.content-block-media.type-embed.display-hero .content-media-frame,
.content-block-media.type-embed.display-full .content-media-frame{min-height:min(62dvh, 640px);aspect-ratio:16 / 9}.content-block-media.type-model model-viewer,
.content-block-media.type-embed iframe{width:100%;height:100%;min-height:inherit;background:transparent;border:0}.content-text-frame{width:100%;min-height:0;display:grid;align-content:start;padding:clamp(16px, 2vw, 24px)}.content-text-frame.text-frame-plain{padding:clamp(12px, 1.7vw, 18px) 0 0;border:0;background:transparent}.content-text-frame em{display:none}.content-block-quote{padding:clamp(26px, 4vw, 48px) 0 clamp(18px, 3vw, 36px)}.content-block-quote p{max-width:980px;margin:0 0 18px;color:var(--ink);font-size:clamp(36px, 6vw, 86px);line-height:0.92;letter-spacing:-0.065em}.content-block-quote cite{color:var(--muted);font-size:12px;font-weight:900;font-style:normal;letter-spacing:0.12em;text-transform:uppercase}.content-block-text-grid{display:grid;gap:14px}.content-grid-head{padding:clamp(18px, 2.4vw, 28px)}.content-text-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:14px}.content-text-card{min-height:190px;padding:clamp(16px, 2vw, 24px)}.content-text-card h4{margin:0 0 14px;color:var(--ink);font-size:22px;line-height:1;letter-spacing:-0.04em}.content-line{width:100%;display:flex;justify-content:var(--content-line-align, center);align-items:center;margin:var(--content-line-margin, 42px 0)}.content-line-inner{width:var(--content-line-width, 100%);max-width:100%;display:flex;align-items:center;gap:var(--content-line-gap, 18px)}.content-line-inner > span{flex:1 1 auto;min-width:28px;height:0;border-top:var(--content-line-thickness, 1px)
    var(--content-line-style, solid)
    currentColor;opacity:var(--content-line-opacity, 0.22)}.content-line b{flex:0 0 auto;color:var(--muted);opacity:var(--content-line-label-opacity, 0.58);font-size:10px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;white-space:nowrap}.content-block-media-grid,
.project-media-sections,
.project-page-gallery,
.project-page-videos{display:grid;gap:18px}.media-section-head.independent-head,
.media-section-head{display:grid;grid-template-columns:minmax(120px, 0.22fr) minmax(0, 1fr) auto;gap:clamp(14px, 2vw, 24px);align-items:start;padding:clamp(18px, 2.4vw, 30px)}.media-section-head p{grid-column:2 / 3;max-width:760px}.media-section-head em{justify-self:end}.media-items,
.content-block-media-grid .media-items,
.media-layout-model-grid .media-items{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:clamp(12px, 1.5vw, 18px);padding:0;background:transparent}.media-layout-mini-grid .media-items{grid-template-columns:repeat(6, minmax(0, 1fr))}.media-layout-mosaic .media-items{grid-template-columns:repeat(12, minmax(0, 1fr))}.media-layout-compare .media-items{grid-template-columns:1fr 1fr}.media-layout-sequence .media-items{grid-template-columns:1fr}.media-layout-filmstrip .media-items{display:flex;overflow-x:auto;gap:10px;scroll-snap-type:x mandatory}.media-item{min-width:0;display:grid;gap:10px;margin:0;overflow:visible;border:0;background:transparent}.media-layout-mosaic .media-item{grid-column:span 4}.media-layout-mosaic .media-item:nth-child(5n + 1){grid-column:span 6}.media-layout-mosaic .media-item:nth-child(7n + 2){grid-column:span 3}.media-layout-sequence .media-item{grid-template-columns:minmax(0, 1fr) minmax(250px, 360px)}.media-layout-filmstrip .media-item{flex:0 0 260px;scroll-snap-align:start}.media-frame,
.project-video-frame{position:relative;width:100%;min-height:240px;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 5%, var(--bg));box-shadow:0 18px 50px rgba(0, 0, 0, 0.08)}.media-frame img,
.media-frame video,
.media-frame model-viewer,
.project-video-frame video{width:100%;height:100%;min-height:240px;object-position:center}.media-frame img,
.media-frame video,
.project-video-frame video{object-fit:cover}.media-item.fit-contain .media-frame img,
.media-item.fit-contain .media-frame video{object-fit:contain}.media-item.ratio-square .media-frame{aspect-ratio:1 / 1}.media-item.ratio-wide .media-frame{aspect-ratio:16 / 9}.media-item.ratio-banner .media-frame{aspect-ratio:21 / 9}.media-item.ratio-medium .media-frame,
.media-item.ratio-detail .media-frame{aspect-ratio:4 / 3}.media-item.ratio-poster .media-frame{aspect-ratio:3 / 4}.media-item.ratio-tall .media-frame{aspect-ratio:4 / 5}.media-item figcaption{min-height:106px;padding:12px}.media-item figcaption{display:grid;grid-template-columns:34px 1fr;gap:6px 10px}.media-item figcaption b{color:var(--faint);font-size:9px;letter-spacing:0.12em}.media-item figcaption strong{color:var(--ink);font-size:13px;line-height:1.2}.media-item figcaption p{grid-column:2;margin:0;color:var(--muted);font-size:11px;line-height:1.45}.media-item.type-model{gap:0;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 4%, transparent)}.media-item.type-model .media-frame{min-height:260px;aspect-ratio:1 / 1.08;border:0;border-bottom:1px solid var(--line);box-shadow:none}.media-item.type-model model-viewer{width:100%;height:100%;min-height:260px;background:transparent}.media-item.type-model figcaption{min-height:auto;padding:12px 14px;border:0;background:color-mix(in srgb, var(--bg) 90%, var(--ink) 10%)}.media-item.type-model figcaption p,
.media-item.type-model figcaption small,
.media-item.type-model figcaption em,
.media-item.type-model figcaption code{display:none}.project-video-card{display:grid;grid-template-columns:minmax(0, 1fr) minmax(260px, 360px);gap:clamp(14px, 2vw, 26px);align-items:start}.project-video-frame{min-height:320px;aspect-ratio:16 / 9}.project-video-note{padding:clamp(14px, 1.8vw, 22px)}.project-video-note b,
.project-video-note em{display:block;color:var(--faint);font-size:10px;font-weight:900;font-style:normal;letter-spacing:0.12em;text-transform:uppercase}.project-video-note h3{margin:12px 0;color:var(--ink);font-size:18px;line-height:1.1}.project-video-note p{margin:0;color:var(--muted);line-height:1.6}.model-section{margin-top:52px;padding-top:12px;border-top:2px solid var(--ink)}.model-section > span{color:var(--faint);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.model-card{display:grid;grid-template-columns:1fr 320px;gap:18px;margin-top:16px}.model-card model-viewer,
.project-model-viewer{width:100%;height:480px;min-height:480px;background:color-mix(in srgb, var(--ink) 7%, transparent)}.model-card > div{padding:18px;border:1px solid var(--line)}.model-card code{display:block;margin-top:12px;color:var(--muted);font-size:11px;word-break:break-all}.has-model-loader{position:relative;overflow:hidden}.fx-model-loader{position:absolute;inset:0;z-index:20;display:grid;place-items:center;background:radial-gradient(circle at 50% 45%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 42%),
    color-mix(in srgb, var(--bg) 84%, transparent);backdrop-filter:blur(10px);transition:opacity 0.35s ease,
    visibility 0.35s ease}.fx-model-loader.is-done{opacity:0;visibility:hidden}.fx-model-loader__box{width:min(190px, calc(100% - 32px));display:grid;gap:14px;justify-items:center}.fx-model-loader__ring{width:58px;height:58px;border:1px solid var(--line);border-left-color:var(--accent);border-right-color:var(--blue);border-radius:50%;animation:modelSpin 1.3s linear infinite}.fx-model-loader__track{width:100%;height:3px;overflow:hidden;border-radius:999px;background:var(--line)}.fx-model-loader__track i{display:block;width:8%;height:100%;border-radius:inherit;background:linear-gradient(90deg, var(--accent), var(--ink));transition:width 0.16s linear}@keyframes modelSpin{to{transform:rotate(360deg)}}.project-page-an-ho-brand .content-block-media-grid .media-items,
.project-page-an-ho-brand .media-layout-model-grid .media-items{grid-template-columns:repeat(4, minmax(0, 1fr));gap:14px}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(-n + 4) .media-frame,
.project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(-n + 4) .media-frame{min-height:clamp(260px, 25vw, 360px)}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(n + 5),
.project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(n + 5){min-height:44px;height:44px;display:flex;align-items:center;overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb, var(--ink) 2.5%, transparent)}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(n + 5) .media-frame,
.project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(n + 5) .media-frame{display:none}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(n + 5) figcaption,
.project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(n + 5) figcaption{width:100%;min-height:44px;height:44px;display:flex;align-items:center;gap:12px;padding:0 14px;border:0;background:transparent}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(n + 5) figcaption p,
.project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(n + 5) figcaption p{display:none}.project-hero-cover.is-missing,
.row-thumb.is-missing,
.content-media-frame.is-missing,
.media-frame.is-missing{position:relative;display:grid;place-items:center;background:repeating-linear-gradient(
      -45deg,
      color-mix(in srgb, var(--ink) 5%, var(--bg)),
      color-mix(in srgb, var(--ink) 5%, var(--bg)) 12px,
      color-mix(in srgb, var(--ink) 9%, var(--bg)) 12px,
      color-mix(in srgb, var(--ink) 9%, var(--bg)) 24px
    )}.project-hero-cover.is-missing::before,
.row-thumb.is-missing::before,
.content-media-frame.is-missing::before,
.media-frame.is-missing::before{content:"Missing asset / check path";position:absolute;z-index:2;padding:8px 10px;border:1px solid var(--line);background:var(--bg);color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0.12em;text-transform:uppercase}.project-hero-cover.is-missing img,
.row-thumb.is-missing img,
.content-media-frame.is-missing img,
.media-frame.is-missing img{opacity:0}.reveal,
[data-scroll-reveal],
.fx-reveal{opacity:0;transform:translate3d(0, 24px, 0);filter:blur(6px);transition:opacity 0.72s var(--ease),
    transform 0.78s var(--ease),
    filter 0.78s var(--ease)}.reveal.is-visible,
[data-scroll-reveal].is-visible,
.fx-reveal.is-visible{opacity:1;transform:none;filter:none}.fx-card{--mx:50%;--my:50%;position:relative;transition:border-color 0.28s var(--ease),
    box-shadow 0.28s var(--ease),
    background-color 0.28s var(--ease)}.fx-card:hover{border-color:color-mix(in srgb, var(--accent) 46%, var(--line));box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 8%, transparent),
    0 18px 54px rgba(0, 0, 0, 0.16)}@media (max-width: 1180px){.hero-visual-system .floating-stack{right:-2vw;width:50vw;height:52vh;opacity:0.58}.project-page-hero,
  .case-hero{grid-template-columns:1fr}.project-hero-cover,
  .case-cover{aspect-ratio:16 / 9}.project-page-meta,
  .case-meta{grid-template-columns:repeat(2, minmax(0, 1fr))}.content-block-media-grid .media-items,
  .media-layout-model-grid .media-items{grid-template-columns:repeat(3, minmax(0, 1fr))}}@media (max-width: 1024px){:root{--header-top:12px}.site-header{left:12px;right:12px;height:52px;grid-template-columns:1fr auto;padding:0 12px}.site-nav{display:none}.hamburger{display:inline-flex}.theme-mini{min-width:86px}.theme-mini b{font-size:0}.theme-mini b::after{content:"MODE";font-size:9px}.header-status span:first-child{display:none}.mobile-panel{top:74px;left:12px;right:12px}.hero-grid,
  .about-grid,
  .contact-grid,
  .case-story,
  .project-page-intro,
  .case-section,
  .model-card{grid-template-columns:1fr}.hero-right{justify-self:start;width:100%}.about-grid{gap:18px}.profile-glitch{min-height:500px;height:500px}.tool-lab{min-height:300px;height:300px}.project-controls{grid-template-columns:1fr}.project-row{grid-template-columns:34px 100px minmax(0, 1fr) 72px;min-height:90px;gap:10px;padding:9px 10px}.row-thumb{width:100px;height:70px}.row-tags{display:none}.row-title{font-size:26px}.stats-grid{grid-template-columns:repeat(2, 1fr)}.project-page-process,
  .case-blocks{grid-template-columns:1fr}.content-block-media,
  .content-block-media.display-text-left,
  .content-block-media.display-detail,
  .project-video-card,
  .media-layout-sequence .media-item{grid-template-columns:1fr;width:100%}.content-block-media.display-text-left .content-text-frame{order:initial}.project-page-deliverables,
  .project-page-tools,
  .deliverables{grid-template-columns:1fr;gap:12px}.media-layout-mini-grid .media-items{grid-template-columns:repeat(4, minmax(0, 1fr))}.media-section-head,
  .media-section-head.independent-head{grid-template-columns:120px minmax(0, 1fr)}.media-section-head em{grid-column:2}}@media (max-width: 760px){:root{--page-x:13px}body{font-size:13px;line-height:1.55}.page-section{padding-top:74px;padding-bottom:74px}.site-header{top:calc(env(safe-area-inset-top, 0px) + 10px);left:10px;right:10px;height:50px;min-height:50px;padding:0 10px}.brand span{max-width:100%;overflow:hidden;font-size:12px;text-overflow:ellipsis}.header-status{display:none}.theme-mini{width:36px;min-width:36px;padding:0}.theme-mini b,
  .theme-mini b::after{display:none}.hamburger{width:36px;min-width:36px}.mobile-panel{top:calc(env(safe-area-inset-top, 0px) + 68px);left:10px;right:10px;max-height:calc(100dvh - 84px - env(safe-area-inset-top, 0px))}.section-head{grid-template-columns:1fr;gap:8px;margin-bottom:18px}.hero{min-height:auto;padding-top:calc(env(safe-area-inset-top, 0px) + 94px);padding-bottom:46px}.hero::before,
  .hero::after,
  .floating-stack,
  .hero-visual-system .floating-stack,
  .hover-preview,
  .cursor-dot,
  .cursor-ring{display:none}.hero-grid{grid-template-columns:1fr;gap:22px}.hero h1{max-width:100%;margin-top:12px;font-size:clamp(44px, 14vw, 68px);line-height:0.9}.hero-copy{max-width:100%;margin-top:14px;font-size:12px}.hero-ticker{display:none}.orbital-code{justify-content:flex-start}.kinetic-type{left:10px;top:52%;max-width:100%;overflow:hidden;opacity:0.12}.kinetic-type span{font-size:clamp(48px, 18vw, 92px)}.profile-glitch{width:100%;min-height:390px;height:auto;aspect-ratio:4 / 5}.tool-lab{width:100%;min-height:320px;height:320px}.about-copy h2,
  .contact-statement h2{font-size:clamp(34px, 11vw, 62px)}.about-facts div{grid-template-columns:88px minmax(0, 1fr);gap:10px}.filter-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.chip{flex:0 0 auto;white-space:nowrap;font-size:9px}.sort-row,
  .project-toolbar{grid-template-columns:1fr}.project-toolbar{gap:5px;font-size:9px}.project-toolbar span,
  .project-toolbar span:last-child{text-align:left}.project-index{gap:9px}.project-row{grid-template-columns:74px minmax(0, 1fr);grid-template-areas:"thumb main"
      "thumb meta";gap:8px 10px;min-height:0;align-items:start;padding:10px;border-left-width:1px;transform:none}.project-row:hover{transform:none}.row-no{position:absolute;left:13px;top:13px;z-index:4;width:auto;height:auto;padding:3px 5px;border:0;background:color-mix(in srgb, var(--bg) 82%, transparent);font-size:8px}.row-thumb{grid-area:thumb;width:74px;height:92px}.row-main{grid-area:main}.row-title{font-size:clamp(19px, 6.3vw, 25px);line-height:1}.project-row:hover .row-title{transform:none}.row-sub{margin-top:5px;font-size:10px;line-height:1.38}.row-year{grid-area:meta;display:flex;justify-content:flex-start;gap:8px;text-align:left}.row-year b,
  .row-year i{font-size:9px}.stats-grid,
  .project-page-meta,
  .case-meta,
  .content-text-grid{grid-template-columns:1fr}.archive-item{grid-template-columns:1fr;gap:6px}.contact-links,
  .sentence-form{display:grid;grid-template-columns:1fr}.contact-links a,
  .send-button{width:100%;text-align:center}.sentence-form span,
  .sentence-form input,
  .sentence-form textarea{width:100%;min-width:0;font-size:20px}.site-footer{grid-template-columns:1fr;display:grid;gap:8px;padding:18px 14px calc(18px + env(safe-area-inset-bottom, 0px))}.modal-panel{height:100dvh;max-height:100dvh;overflow-x:hidden;-webkit-overflow-scrolling:touch}.modal-close{position:sticky;top:calc(env(safe-area-inset-top, 0px) + 8px);right:auto;margin:calc(env(safe-area-inset-top, 0px) + 8px) 10px 0 auto;padding:9px 10px;font-size:9px}.modal-content{width:calc(100vw - 24px);padding:18px 0 96px;overflow-x:hidden}.modal-nav{position:sticky;left:auto;bottom:0;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 0 calc(10px + env(safe-area-inset-bottom, 0px));transform:none;background:color-mix(in srgb, var(--bg) 90%, transparent);backdrop-filter:blur(14px);pointer-events:auto}.modal-nav button{width:100%;min-width:0;height:42px;font-size:9px}.project-page-hero,
  .case-hero{gap:16px;margin-bottom:22px}.project-hero-copy h2,
  .case-title h2{font-size:clamp(34px, 11.5vw, 52px);line-height:0.94}.case-subtitle,
  .case-title p:last-child{margin-top:14px;font-size:13px;line-height:1.48}.project-hero-cover,
  .case-cover{min-height:clamp(240px, 64vw, 360px);max-height:380px;aspect-ratio:4 / 3}.project-page-meta div,
  .case-meta div{padding:12px}.project-page-intro,
  .case-story{grid-template-columns:1fr;gap:14px;padding-bottom:22px}.project-page-intro article p,
  .case-story > div p{grid-template-columns:1fr;gap:6px;font-size:13px}.project-section-title{display:grid;grid-template-columns:1fr;gap:6px;margin:34px 0 12px;padding-top:10px}.case-section{grid-template-columns:1fr}.case-section figure img{min-height:0;height:auto;object-fit:contain}.case-section h3{margin:10px 0 8px;font-size:clamp(24px, 8vw, 34px)}.content-block-media,
  .content-block-media.display-text-left,
  .content-block-media.display-detail,
  .content-block-media.display-center,
  .content-block-media.display-hero,
  .content-block-media.display-full{grid-template-columns:1fr;width:100%;gap:12px}.content-block-media.display-text-left .content-text-frame{order:initial}.content-media-frame{min-height:clamp(230px, 64vw, 360px);max-height:390px;aspect-ratio:4 / 3}.content-block-media.ratio-wide .content-media-frame,
  .content-block-media.ratio-banner .content-media-frame{min-height:clamp(220px, 58vw, 340px);aspect-ratio:16 / 10}.content-block-media.ratio-square .content-media-frame{min-height:0;max-height:none;aspect-ratio:1 / 1}.content-block-media.ratio-poster .content-media-frame,
  .content-block-media.ratio-tall .content-media-frame{min-height:0;max-height:72vh;aspect-ratio:3 / 4}.content-block-media.ratio-long .content-media-frame{min-height:0;max-height:none;aspect-ratio:auto}.content-block-media.ratio-long .content-media-frame img{height:auto;max-height:none}.content-block-media.type-model .content-media-frame,
  .media-item.type-model .media-frame,
  .content-block-media-grid .media-frame{min-height:clamp(250px, 70vw, 360px);max-height:380px}.content-text-frame,
  .content-block-text,
  .content-grid-head,
  .content-text-card,
  .media-section-head.independent-head{width:100%;max-width:100%}.content-text-frame h3,
  .content-block-text h3,
  .content-grid-head h3,
  .media-section-head.independent-head h3{font-size:clamp(24px, 8vw, 34px)}.content-text-frame p,
  .content-block-text p,
  .content-grid-head p,
  .content-text-card p,
  .media-section-head.independent-head p{font-size:12.5px;line-height:1.62}.content-text-copy.text-cols-2{grid-template-columns:1fr}.content-line{margin:var(--content-line-margin-mobile, 30px 0)}.media-section-head,
  .media-section-head.independent-head{grid-template-columns:1fr;padding:14px}.media-section-head p,
  .media-section-head em{grid-column:auto;justify-self:start}.media-items,
  .content-block-media-grid .media-items,
  .media-layout-model-grid .media-items,
  .media-layout-mini-grid .media-items,
  .media-layout-mosaic .media-items,
  .media-layout-compare .media-items,
  .media-layout-sequence .media-items{grid-template-columns:1fr;gap:12px}.media-layout-mosaic .media-item,
  .media-layout-mosaic .media-item:nth-child(n){grid-column:auto}.media-layout-sequence .media-item{grid-template-columns:1fr}.media-layout-filmstrip .media-item{flex:0 0 78vw;max-width:320px}.media-item figcaption{min-height:0}.project-video-card,
  .model-card{grid-template-columns:1fr}.project-video-frame{min-height:240px}.model-card model-viewer,
  .project-model-viewer{height:min(62dvh, 380px);min-height:280px;max-height:420px}.project-page-an-ho-brand .content-block-media-grid .media-items,
  .project-page-an-ho-brand .media-layout-model-grid .media-items{grid-template-columns:1fr}.project-page-an-ho-brand .content-block-media-grid .media-item:nth-child(n + 5),
  .project-page-an-ho-brand .media-layout-model-grid .media-item:nth-child(n + 5){min-height:42px;height:42px}.art-bg-canvas{opacity:0.42}.motion-orbs{opacity:0.5}.loader{padding:18px}.loader-portal{width:min(260px, 76vw);transform:scale(0.74)}.loader-orbit i:nth-child(1){transform:rotate(0deg) translateY(-100px)}.loader-orbit i:nth-child(2){transform:rotate(45deg) translateY(-100px)}.loader-orbit i:nth-child(3){transform:rotate(90deg) translateY(-100px)}.loader-orbit i:nth-child(4){transform:rotate(135deg) translateY(-100px)}.loader-orbit i:nth-child(5){transform:rotate(180deg) translateY(-100px)}.loader-orbit i:nth-child(6){transform:rotate(225deg) translateY(-100px)}.loader-orbit i:nth-child(7){transform:rotate(270deg) translateY(-100px)}.loader-orbit i:nth-child(8){transform:rotate(315deg) translateY(-100px)}.loader-meta{left:18px;right:18px;bottom:18px;font-size:9px}.loader-track{left:18px;right:18px;bottom:18px}}@media (max-width: 430px){:root{--page-x:12px}.site-header{left:8px;right:8px;height:48px;min-height:48px;padding:0 8px}.mobile-panel{top:calc(env(safe-area-inset-top, 0px) + 64px);left:8px;right:8px}.hero{padding-top:calc(env(safe-area-inset-top, 0px) + 86px)}.hero h1{font-size:clamp(42px, 15.4vw, 66px)}.project-row{grid-template-columns:68px minmax(0, 1fr);gap:8px;padding:9px}.row-thumb{width:68px;height:88px}.row-title{font-size:clamp(18px, 6.1vw, 23px)}.row-sub{font-size:9.7px}.project-hero-copy h2,
  .case-title h2{font-size:clamp(31px, 11vw, 46px)}.project-hero-cover,
  .case-cover{min-height:250px;max-height:330px}.content-media-frame{min-height:240px;max-height:340px}.content-block-media.type-model .content-media-frame,
  .media-item.type-model .media-frame,
  .content-block-media-grid .media-frame{min-height:270px}}@media (max-width: 360px){.brand span{font-size:11px}.theme-mini,
  .hamburger{width:34px;min-width:34px}.hero h1{font-size:clamp(38px, 15vw, 58px)}.project-row{grid-template-columns:62px minmax(0, 1fr);padding:8px}.row-thumb{width:62px;height:82px}.row-title{font-size:18px}.row-sub{font-size:9px}}@media (pointer: coarse){.hover-preview,
  .cursor-dot,
  .cursor-ring{display:none}.project-row:hover,
  .project-row:hover .row-title,
  .contact-links a:hover{transform:none}}@media (prefers-reduced-motion: reduce){*,
  *::before,
  *::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}.reveal,
  [data-scroll-reveal],
  .fx-reveal{opacity:1 !important;transform:none !important;filter:none !important}}.modal{display:block;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.26s var(--ease), visibility 0s linear 0.26s}.modal.is-open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity 0.26s var(--ease), visibility 0s linear 0s}.modal-bg{opacity:0;transition:opacity 0.26s var(--ease)}.modal.is-open .modal-bg{opacity:1}.modal-panel{height:100vh;height:100dvh;overscroll-behavior:contain;touch-action:pan-y;opacity:0;transform:translate3d(0, 14px, 0);transition:opacity 0.30s var(--ease), transform 0.34s var(--ease)}.modal.is-open .modal-panel{opacity:1;transform:translate3d(0, 0, 0)}html.modal-is-open,
html.modal-is-open body{overscroll-behavior:none}body.is-scroll-locked{position:fixed;top:calc(var(--locked-scroll-y, 0px) * -1);left:0;right:0;width:100%;overflow:hidden}[data-heavy-src]:not([src]){background:linear-gradient(110deg, transparent 22%, color-mix(in srgb, var(--ink) 6%, transparent) 42%, transparent 62%),
    color-mix(in srgb, var(--ink) 3%, var(--bg));background-size:220% 100%}model-viewer[data-heavy-src]:not([src]),
video[data-heavy-src]:not([src]),
iframe[data-heavy-src]:not([src]){min-height:inherit}.content-block,
.media-item{content-visibility:visible;contain-intrinsic-size:none}@media (min-width: 1181px) and (pointer: fine) and (prefers-reduced-motion: no-preference){.modal.is-open .project-hero-copy{animation:projectCopyEnter 0.54s 0.04s var(--ease) both}.modal.is-open .project-hero-cover{animation:projectCoverEnter 0.62s 0.08s var(--ease) both}.modal.is-open .project-page-meta,
  .modal.is-open .project-page-intro,
  .modal.is-open .project-page-deliverables{animation:projectMetaEnter 0.54s 0.12s var(--ease) both}}@keyframes projectCopyEnter{from{opacity:0;transform:translate3d(0, 18px, 0)}to{opacity:1;transform:none}}@keyframes projectCoverEnter{from{opacity:0;transform:translate3d(0, 12px, 0) scale(1.006)}to{opacity:1;transform:none}}@keyframes projectMetaEnter{from{opacity:0;transform:translate3d(0, 12px, 0)}to{opacity:1;transform:none}}@media (max-width: 1180px), (pointer: coarse){.site-header,
  .mobile-panel,
  .modal-bg,
  .modal-close,
  .modal-nav,
  .modal-nav button{backdrop-filter:none !important;-webkit-backdrop-filter:none !important}.site-header{background:color-mix(in srgb, var(--bg) 96%, var(--ink) 4%);box-shadow:0 8px 28px rgba(0, 0, 0, 0.12)}.mobile-panel{background:color-mix(in srgb, var(--bg) 97%, var(--ink) 3%)}.modal-bg{background:color-mix(in srgb, var(--bg) 94%, black 6%)}.modal-close,
  .modal-nav,
  .modal-nav button{background:color-mix(in srgb, var(--bg) 96%, var(--ink) 4%)}.hero::before{display:none}.kinetic-type span{animation:none !important}.float-card,
  .float-card[class*="f-"]{animation:none !important;will-change:auto;box-shadow:0 10px 30px rgba(0, 0, 0, 0.16)}.floating-stack.is-tablet-stack{display:none}.profile-glitch::after,
  .profile-glitch img:nth-child(2){display:none}.profile-glitch:hover img:first-child{transform:none;filter:none}.tool-lab.is-static{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));align-content:start;gap:10px;width:100%;height:auto;min-height:0;padding:52px 14px 14px}.tool-lab.is-static .tool-chip{position:relative;inset:auto;width:100%;height:auto;min-height:72px;aspect-ratio:1;transform:none !important;will-change:auto}.reveal,
  [data-scroll-reveal],
  .fx-reveal{filter:none;transform:translate3d(0, 12px, 0);transition:opacity 0.42s var(--ease), transform 0.46s var(--ease)}.fx-card:hover{box-shadow:none}.project-row:hover,
  .project-row:hover .row-title,
  .content-media-frame:hover img,
  .media-frame:hover img{transform:none !important}.content-media-frame img,
  .media-frame img,
  .project-hero-cover img{transition:opacity 0.24s var(--ease)}}@media (min-width: 761px) and (max-width: 1180px){.hero{min-height:max(720px, 92svh)}.hero-grid{position:relative;z-index:5}.hero-left{max-width:900px}.hero h1{font-size:clamp(70px, 12vw, 118px)}.about-grid,
  .contact-grid{grid-template-columns:1fr}.profile-glitch{width:min(100%, 680px);margin-inline:auto}.modal-content{width:calc(100vw - 36px)}.project-page-hero,
  .case-hero{grid-template-columns:1fr}.project-hero-cover,
  .case-cover{min-height:420px;max-height:68svh}.content-block-media-grid .media-items,
  .media-layout-model-grid .media-items{grid-template-columns:repeat(2, minmax(0, 1fr))}}@media (max-width: 760px){html,
  body{min-height:100%;min-height:-webkit-fill-available}.art-bg-canvas,
  .background-click-layer,
  .burst-layer{display:none !important}.hero::after{display:none}.loader-atmosphere,
  .loader-ring-c,
  .loader-orbit{display:none}.loader-portal{width:min(220px, 64vw)}.loader-ring-a{width:54%;height:54%}.loader-ring-b{width:82%;height:82%}.tool-lab.is-static{grid-template-columns:repeat(3, minmax(0, 1fr));gap:8px;padding:48px 10px 10px}.tool-lab.is-static .tool-chip{min-height:68px}.modal-panel{position:fixed;inset:0;width:100%;height:100vh;height:100dvh;max-height:none;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.modal-close{position:fixed;top:calc(env(safe-area-inset-top, 0px) + 8px);right:10px;left:auto;margin:0;z-index:90}.modal-content{width:calc(100vw - 22px);padding-top:calc(env(safe-area-inset-top, 0px) + 62px);padding-bottom:22px}.modal-nav{position:sticky;left:auto;bottom:0;z-index:85;width:100%;padding:9px 11px calc(9px + env(safe-area-inset-bottom, 0px));transform:none;border-top:1px solid var(--line)}.project-hero-cover,
  .case-cover,
  .content-media-frame,
  .media-frame,
  model-viewer,
  iframe,
  video{max-width:100%}iframe[data-heavy-src],
  model-viewer[data-heavy-src]{min-height:280px}.content-block,
  .media-item{contain-intrinsic-size:auto 380px}}@media (max-width: 430px){.modal-content{width:calc(100vw - 18px)}}@media (max-width: 350px){.tool-lab.is-static{grid-template-columns:repeat(2, minmax(0, 1fr))}}.project-page[data-project-id="resq-app"]{--resq-red:#ff2b2b;--resq-dark:#111111;--resq-soft:rgba(255, 43, 43, 0.08)}.project-page[data-project-id="resq-app"] .content-block{width:min(100%, 980px);margin-inline:auto}.project-page[data-project-id="resq-app"] img,
.project-page[data-project-id="resq-app"] video{display:block;max-width:100%;height:auto;margin-inline:auto;object-fit:contain !important;object-position:center !important}.project-page[data-project-id="3d-body"]{--body-project-max:1280px}.project-page[data-project-id="3d-body"] .content-block{width:min(100%, var(--body-project-max));margin-inline:auto}.project-page[data-project-id="3d-body"] .content-media-frame,
.project-page[data-project-id="3d-body"] .media-frame{width:min(100%, 1180px);margin-inline:auto}.project-page[data-project-id="3d-body"] img,
.project-page[data-project-id="3d-body"] video{display:block;width:100%;max-width:1180px;height:auto;margin-inline:auto;object-fit:contain !important;object-position:center !important}@supports (-webkit-touch-callout: none){.site-header,
  .mobile-panel,
  .modal-panel{transform:translateZ(0)}input,
  textarea,
  select{font-size:max(16px, 1em)}}@media (prefers-reduced-motion: reduce){.modal,
  .modal-bg,
  .modal-panel{transition:none !important}[data-heavy-src]:not([src]){background-image:none}}:root{--neon-acid:#cfff3c;--neon-cyan:#54f6ff;--neon-violet:#786cff;--neon-hot:#ff4b22;--neon-soft:rgba(207, 255, 60, 0.12)}.bg-field,
.meteor-layer,
.click-fx-layer{position:fixed;inset:0;pointer-events:none}.bg-field{z-index:0;overflow:hidden;contain:strict;background:radial-gradient(circle at 10% 10%, rgba(255, 75, 34, 0.105), transparent 31vw),
    radial-gradient(circle at 88% 12%, rgba(120, 108, 255, 0.115), transparent 34vw),
    radial-gradient(circle at 76% 84%, rgba(84, 246, 255, 0.032), transparent 33vw),
    linear-gradient(145deg, #020302 0%, var(--bg) 58%, #05050b 100%)}.bg-field::before{content:"";position:absolute;inset:0;opacity:0.075;background-image:linear-gradient(rgba(207, 255, 60, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(84, 246, 255, 0.038) 1px, transparent 1px);background-size:88px 88px;background-position:center center}.bg-field::after{content:"";position:absolute;inset:0;opacity:0.19;background-image:radial-gradient(circle, rgba(207, 255, 60, 0.58) 0 0.85px, transparent 1.35px),
    radial-gradient(circle, rgba(84, 246, 255, 0.42) 0 0.75px, transparent 1.25px),
    radial-gradient(circle, rgba(255, 255, 255, 0.24) 0 0.65px, transparent 1.1px);background-size:283px 283px, 367px 367px, 211px 211px;background-position:29px 43px, 117px 19px, 61px 149px}.bg-field span,
.motion-orbs,
.art-bg-canvas{display:none !important}html[data-theme="white"] .bg-field{background:radial-gradient(circle at 10% 10%, rgba(255, 75, 34, 0.075), transparent 32vw),
    radial-gradient(circle at 88% 12%, rgba(83, 100, 255, 0.075), transparent 35vw),
    radial-gradient(circle at 76% 84%, rgba(84, 246, 255, 0.024), transparent 34vw),
    linear-gradient(145deg, #f8f3e7 0%, var(--bg) 59%, #eee9dc 100%)}html[data-theme="white"] .bg-field::before{opacity:0.052}html[data-theme="white"] .bg-field::after{opacity:0.13}body.modal-open .bg-field::before,
body.modal-open .bg-field::after{opacity:0.012}.meteor-layer{z-index:4;overflow:hidden;contain:strict}.meteor-shot{position:absolute;left:0;top:0;width:var(--meteor-length, 168px);height:2px;border-radius:999px;opacity:0;transform-origin:0 50%;background:linear-gradient(90deg, transparent 0%, rgba(84,246,255,0.04) 26%, rgba(84,246,255,0.34) 70%, #faffee 100%);box-shadow:0 0 7px rgba(84,246,255,0.20);will-change:transform, opacity}.meteor-shot::after{content:"";position:absolute;right:-2px;top:50%;width:5px;height:5px;border-radius:50%;transform:translateY(-50%);background:#fff;box-shadow:0 0 7px var(--neon-cyan), 0 0 13px rgba(207,255,60,0.30)}body.modal-open .meteor-layer{display:none !important}.click-fx-layer{z-index:9997;overflow:hidden;contain:strict}.click-burst{position:absolute;left:0;top:0;width:1px;height:1px;transform:translate3d(-0.5px, -0.5px, 0)}.click-burst::before{content:"";position:absolute;left:-7px;top:-7px;width:14px;height:14px;border:1px solid rgba(207,255,60,0.72);border-radius:50%;opacity:0;animation:clickRing 480ms cubic-bezier(.16,.8,.24,1) forwards}.click-burst::after{content:"";position:absolute;left:-3px;top:-3px;width:6px;height:6px;transform:rotate(45deg);background:#fff;box-shadow:0 0 8px var(--neon-cyan), 0 0 15px rgba(207,255,60,0.48);animation:clickCore 420ms ease-out forwards}.click-burst > i{position:absolute;left:0;top:-1px;width:15px;height:2px;border-radius:999px;transform-origin:0 50%;background:linear-gradient(90deg, var(--spark-color), transparent);opacity:0;animation:clickSpark 500ms cubic-bezier(.16,.72,.2,1) var(--spark-delay,0ms) forwards}.click-burst > i::after{content:"";position:absolute;right:1px;top:50%;width:2px;height:2px;border-radius:50%;transform:translateY(-50%);background:currentColor}@keyframes clickRing{0%{opacity:0.8;transform:scale(0.45)}100%{opacity:0;transform:scale(2.6)}}@keyframes clickCore{0%{opacity:1;transform:rotate(45deg) scale(0.7)}100%{opacity:0;transform:rotate(105deg) scale(1.8)}}@keyframes clickSpark{0%{opacity:0;transform:rotate(var(--spark-angle)) translateX(0) scaleX(0.35)}16%{opacity:0.95}100%{opacity:0;transform:rotate(var(--spark-angle)) translateX(var(--spark-distance)) scaleX(1)}}@media (pointer: fine){html, body{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 17 17'%3E%3Ccircle cx='8.5' cy='8.5' r='2.2' fill='%23d9ff42'/%3E%3Cpath d='M8.5 1.5v3M8.5 12.5v3M1.5 8.5h3M12.5 8.5h3' stroke='%2354f6ff' stroke-width='1.1'/%3E%3C/svg%3E") 8 8, crosshair}a, button, select, label, [role="button"], .project-row, .archive-item, .tool-chip{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Ccircle cx='9' cy='9' r='6.2' fill='none' stroke='%23d9ff42' stroke-width='1.2'/%3E%3Ccircle cx='9' cy='9' r='2' fill='%2354f6ff'/%3E%3C/svg%3E") 9 9, pointer}input, textarea{cursor:text}}.cursor-dot,
.cursor-ring,
.hover-preview,
.background-click-layer,
.burst-layer{display:none !important}.tool-lab.has-floating-tools{position:relative;display:block;width:100%;min-height:620px;height:620px;overflow:hidden;contain:layout paint style;isolation:isolate;border-color:rgba(207,255,60,0.38);background:linear-gradient(rgba(207,255,60,0.027) 1px, transparent 1px),
    linear-gradient(90deg, rgba(84,246,255,0.024) 1px, transparent 1px),
    linear-gradient(145deg, rgba(207,255,60,0.025), rgba(120,108,255,0.045) 62%, transparent);background-size:52px 52px, 52px 52px, auto}.tool-lab.has-floating-tools::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 18% 26%, rgba(207,255,60,0.22) 0 1px, transparent 1.8px),
    radial-gradient(circle at 82% 18%, rgba(84,246,255,0.18) 0 1px, transparent 1.8px),
    radial-gradient(circle at 72% 78%, rgba(120,108,255,0.18) 0 1px, transparent 1.8px)}.tool-lab.has-floating-tools .lab-title{z-index:6;color:var(--neon-acid);text-shadow:0 0 12px rgba(207,255,60,0.16)}.tool-lab.has-floating-tools .tool-lines{z-index:1;opacity:0.22;background:linear-gradient(115deg, transparent 0 35%, rgba(84,246,255,0.16) 35.2% 35.35%, transparent 35.55% 100%),
    linear-gradient(25deg, transparent 0 62%, rgba(207,255,60,0.12) 62.15% 62.3%, transparent 62.5% 100%)}.tool-lab.has-floating-tools .tool-chip{position:absolute;left:0;top:0;z-index:3;margin:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;contain:layout paint style;will-change:auto;border-color:rgba(84,246,255,0.26);background:rgba(13,15,14,0.88);box-shadow:0 6px 18px rgba(0,0,0,0.16);transition:border-color 150ms linear, background-color 150ms linear, box-shadow 150ms linear, color 150ms linear}.tool-lab.has-floating-tools.is-motion-running .tool-chip{will-change:transform}.tool-lab.has-floating-tools .tool-chip.is-active,
.tool-lab.has-floating-tools .tool-chip:focus-visible{border-color:var(--neon-acid);background:rgba(207,255,60,0.11);color:var(--ink);box-shadow:0 0 0 1px rgba(207,255,60,0.24), 0 8px 24px rgba(0,0,0,0.20)}.fx-reveal{opacity:0;transform:translate3d(0, 12px, 0);filter:none !important;transition:opacity 360ms ease-out var(--reveal-delay,0ms), transform 430ms var(--ease) var(--reveal-delay,0ms);backface-visibility:hidden}.fx-reveal.fx-reveal-from-left{transform:translate3d(-12px, 9px, 0)}.fx-reveal.fx-reveal-from-right{transform:translate3d(12px, 9px, 0)}.fx-reveal.fx-reveal-soft-scale{transform:translate3d(0, 10px, 0) scale(0.994)}.fx-reveal.is-visible{opacity:1;transform:none}.project-row{isolation:isolate}.project-row::after{content:"";position:absolute;left:12px;top:12px;z-index:4;width:17px;height:17px;border-left:1px solid transparent;border-top:1px solid transparent;opacity:0;pointer-events:none;transition:opacity 140ms linear, border-color 140ms linear}.project-row:hover,
.project-row:focus-within{transform:none !important;border-color:rgba(207,255,60,0.54) !important;background:linear-gradient(90deg, rgba(255,75,34,0.075), transparent 34%),
    linear-gradient(180deg, rgba(207,255,60,0.024), transparent),
    var(--project-hover) !important;box-shadow:inset 3px 0 0 var(--neon-acid), inset 0 1px 0 rgba(207,255,60,0.48) !important}.project-row:hover::after,
.project-row:focus-within::after{opacity:1;border-color:var(--neon-acid)}.archive-item:hover,
.stat-card:hover,
.compact-product-card:hover{transform:none !important;border-color:rgba(207,255,60,0.34) !important;background:rgba(207,255,60,0.024) !important;box-shadow:none !important}.modal-panel{scroll-behavior:auto !important;contain:none !important;transform:none !important;will-change:auto !important}.project-page model-viewer,
.project-page video,
.project-page iframe,
.project-page img{will-change:auto !important}model-viewer,
iframe[data-heavy-src],
video[data-heavy-src]{width:100%;backface-visibility:hidden}model-viewer{touch-action:pan-y;--poster-color:transparent}.manual-media-load{display:none !important}.fx-model-loader{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;background:radial-gradient(circle at 50% 45%, rgba(207,255,60,0.07), transparent 43%),
    var(--bg) !important}.fx-model-loader.is-error{opacity:1;visibility:visible}.fx-model-loader__error{width:min(360px, calc(100% - 30px));display:grid;gap:9px;justify-items:center;padding:20px;border:1px solid rgba(255,75,34,0.52);background:var(--bg);text-align:center}.fx-model-loader__error strong{color:var(--accent);font-size:11px;letter-spacing:0.12em}.fx-model-loader__error span{max-width:31ch;color:var(--muted);font-size:11px}.fx-model-loader__error button{min-height:34px;padding:7px 13px;border:1px solid var(--line2);background:transparent;color:var(--ink);font-size:10px;font-weight:900;letter-spacing:0.12em}.compact-product-card{min-height:76px !important;display:grid !important;grid-template-columns:40px minmax(0,1fr) !important;grid-template-rows:auto !important;align-items:center !important;column-gap:12px !important;padding:15px 16px !important;border:1px solid var(--line) !important;background:rgba(255,255,255,0.018) !important;transition:border-color 140ms linear, background-color 140ms linear !important}.compact-product-card b{grid-row:auto !important;align-self:center !important}.compact-product-card strong{font-size:13px !important;line-height:1.3 !important}.compact-product-card span{display:none !important}.site-header,
.mobile-panel,
.hero-ticker,
.modal-bg,
.modal-close,
.modal-nav,
.fx-model-loader{backdrop-filter:none !important;-webkit-backdrop-filter:none !important}.site-header{background:color-mix(in srgb, var(--bg) 96%, var(--ink) 4%) !important}.loader{background:radial-gradient(circle at 50% 47%, rgba(207,255,60,0.075), transparent 24%),
    radial-gradient(circle at 75% 22%, rgba(120,108,255,0.045), transparent 32%),
    linear-gradient(145deg, #000, #050605 57%, #000) !important}.loader-atmosphere,
.loader-ring-c{display:none !important}.loader-portal-glow{filter:none !important;opacity:0.42}.loader-ring-a{border-color:rgba(207,255,60,0.38) !important;animation-duration:2.9s !important}.loader-ring-b{border-color:rgba(84,246,255,0.24) !important;animation-duration:4.5s !important}.loader-orbit{opacity:0.38;animation-duration:8.8s !important}.loader-core{background:var(--neon-acid) !important;box-shadow:0 0 14px rgba(207,255,60,0.72), 0 0 28px rgba(84,246,255,0.22) !important}.loader-track{height:6px !important;background:rgba(255,255,255,0.075) !important}.loader-track span{background:linear-gradient(90deg, var(--neon-acid), var(--neon-cyan), #fff) !important;box-shadow:0 0 9px rgba(207,255,60,0.65), 0 0 18px rgba(84,246,255,0.20) !important}html.is-low-power-device .meteor-layer,
html.is-low-power-device .click-fx-layer{display:none !important}html.is-low-power-device .bg-field::before{opacity:0.035}html.is-low-power-device .bg-field::after{opacity:0.09}html.is-low-power-device .tool-lab.has-floating-tools .tool-chip{box-shadow:none}@media (max-width: 1180px), (pointer: coarse){.meteor-layer, .click-fx-layer{display:none !important}.bg-field::before{opacity:0.045;background-size:96px 96px}.bg-field::after{opacity:0.11}.tool-lab.has-floating-tools{min-height:390px;height:390px}.tool-lab.has-floating-tools .tool-chip{width:64px;height:64px;padding:9px}.tool-lab.has-floating-tools .tool-chip img{width:27px;height:27px}.fx-reveal{transform:translate3d(0,9px,0);transition-duration:300ms, 360ms}}@media (max-width: 760px){.bg-field{background:radial-gradient(circle at 10% 12%, rgba(255,75,34,0.075), transparent 52vw),
      radial-gradient(circle at 90% 18%, rgba(120,108,255,0.075), transparent 58vw),
      linear-gradient(155deg, #020302, var(--bg) 65%, #05050a)}.bg-field::before{opacity:0.032;background-size:104px 104px}.bg-field::after{opacity:0.075}.tool-lab.has-floating-tools{min-height:330px;height:330px}.tool-lab.has-floating-tools .tool-chip{width:56px;height:56px;padding:7px;box-shadow:none}.tool-lab.has-floating-tools .tool-chip img{width:24px;height:24px}.tool-lab.has-floating-tools .tool-chip span{font-size:8px}.fx-reveal{transform:translate3d(0,7px,0);transition-duration:260ms, 320ms}.project-row:hover, .project-row:focus-within{box-shadow:none !important}}@media (max-width: 380px){.tool-lab.has-floating-tools{min-height:300px;height:300px}.tool-lab.has-floating-tools .tool-chip{width:52px;height:52px}}@media (prefers-reduced-motion: reduce){.meteor-layer, .click-fx-layer{display:none !important}.fx-reveal{opacity:1 !important;transform:none !important;transition:none !important}.tool-lab.has-floating-tools .tool-chip{will-change:auto !important}.loader-ring-a, .loader-ring-b, .loader-orbit, .loader-core{animation:none !important}}.compact-product-list{width:100%;display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:14px;margin-top:20px}.compact-product-card{min-width:0;min-height:84px !important}html{scrollbar-width:thin;scrollbar-color:rgba(246, 240, 223, 0.24) transparent;scroll-padding-top:calc(var(--header-h) + var(--header-top) + 18px)}html[data-theme="white"]{scrollbar-color:rgba(16, 16, 14, 0.26) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{min-height:42px;border:3px solid transparent;border-radius:999px;background:rgba(246, 240, 223, 0.24);background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:rgba(246, 240, 223, 0.42);background-clip:padding-box}html[data-theme="white"] *::-webkit-scrollbar-thumb{background:rgba(16, 16, 14, 0.25);background-clip:padding-box}html[data-theme="white"] *::-webkit-scrollbar-thumb:hover{background:rgba(16, 16, 14, 0.42);background-clip:padding-box}@media (pointer: fine){html[data-theme="white"],
  html[data-theme="white"] body{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='19' height='19' viewBox='0 0 19 19'%3E%3Ccircle cx='9.5' cy='9.5' r='2.5' fill='%23e43f28'/%3E%3Cpath d='M9.5 1.5v4M9.5 13.5v4M1.5 9.5h4M13.5 9.5h4' stroke='%23e43f28' stroke-width='1.45' stroke-linecap='round'/%3E%3C/svg%3E") 10 10, crosshair}html[data-theme="white"] a,
  html[data-theme="white"] button,
  html[data-theme="white"] select,
  html[data-theme="white"] label,
  html[data-theme="white"] [role="button"],
  html[data-theme="white"] .project-row,
  html[data-theme="white"] .archive-item,
  html[data-theme="white"] .tool-chip{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='7' fill='none' stroke='%23e43f28' stroke-width='1.5'/%3E%3Ccircle cx='10' cy='10' r='2.2' fill='%23e43f28'/%3E%3C/svg%3E") 10 10, pointer}html[data-theme="white"] input,
  html[data-theme="white"] textarea{cursor:text}}@media (max-width: 1100px){.compact-product-list{grid-template-columns:repeat(2, minmax(0, 1fr))}}@media (max-width: 640px){.compact-product-list{grid-template-columns:1fr;gap:10px}.compact-product-card{min-height:72px !important}}

/* ==========================================================================
   BACKGROUND + LOADER POLISH — 2026-06-22
   --------------------------------------------------------------------------
   Static layered gradients keep the page richer without adding a canvas loop.
   Loader motion exists for about one second only. Meteors remain desktop-only,
   capped at two elements and are cancelled while scrolling or in project view.
   ========================================================================== */

.bg-field {
  box-shadow: inset 0 0 180px rgba(0, 0, 0, 0.62);
  background:
    radial-gradient(ellipse at 48% -14%, rgba(207, 255, 60, 0.075), transparent 42%),
    radial-gradient(circle at 7% 18%, rgba(255, 75, 34, 0.13), transparent 30vw),
    radial-gradient(circle at 91% 14%, rgba(120, 108, 255, 0.145), transparent 34vw),
    radial-gradient(circle at 78% 82%, rgba(84, 246, 255, 0.05), transparent 32vw),
    linear-gradient(118deg, transparent 0 35%, rgba(84, 246, 255, 0.018) 48%, transparent 62%),
    linear-gradient(145deg, #010201 0%, var(--bg) 55%, #05050c 100%);
}

.bg-field::before {
  opacity: 0.105;
  background-image:
    linear-gradient(rgba(207, 255, 60, 0.042) 1px, transparent 1px),
    linear-gradient(90deg, rgba(84, 246, 255, 0.036) 1px, transparent 1px),
    linear-gradient(118deg, transparent 0 38%, rgba(255, 255, 255, 0.045) 49.8%, transparent 50.2% 100%);
  background-size: 84px 84px, 84px 84px, 100% 100%;
  background-position: center center;
  -webkit-mask-image: radial-gradient(ellipse at center, #000 18%, rgba(0, 0, 0, 0.8) 58%, transparent 100%);
  mask-image: radial-gradient(ellipse at center, #000 18%, rgba(0, 0, 0, 0.8) 58%, transparent 100%);
}

.bg-field::after {
  opacity: 0.25;
  background-image:
    radial-gradient(circle, rgba(207, 255, 60, 0.68) 0 0.8px, transparent 1.35px),
    radial-gradient(circle, rgba(84, 246, 255, 0.5) 0 0.72px, transparent 1.22px),
    radial-gradient(circle, rgba(255, 255, 255, 0.3) 0 0.64px, transparent 1.08px),
    radial-gradient(circle, rgba(255, 75, 34, 0.34) 0 0.68px, transparent 1.16px);
  background-size: 251px 251px, 337px 337px, 193px 193px, 421px 421px;
  background-position: 31px 47px, 129px 17px, 67px 151px, 213px 89px;
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, rgba(0, 0, 0, 0.82) 70%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, rgba(0, 0, 0, 0.82) 70%, transparent 100%);
}

html[data-theme="white"] .bg-field {
  box-shadow: inset 0 0 150px rgba(110, 84, 40, 0.07);
  background:
    radial-gradient(ellipse at 48% -14%, rgba(156, 184, 0, 0.07), transparent 43%),
    radial-gradient(circle at 7% 18%, rgba(236, 74, 37, 0.095), transparent 31vw),
    radial-gradient(circle at 91% 14%, rgba(38, 56, 200, 0.095), transparent 35vw),
    radial-gradient(circle at 78% 82%, rgba(54, 163, 176, 0.032), transparent 34vw),
    linear-gradient(118deg, transparent 0 36%, rgba(38, 56, 200, 0.018) 48%, transparent 62%),
    linear-gradient(145deg, #faf6eb 0%, var(--bg) 57%, #ece6d8 100%);
}

html[data-theme="white"] .bg-field::before { opacity: 0.064; }
html[data-theme="white"] .bg-field::after { opacity: 0.16; }

.loader {
  isolation: isolate;
  background:
    radial-gradient(circle at 50% 48%, rgba(207, 255, 60, 0.085), transparent 19%),
    radial-gradient(circle at 22% 16%, rgba(84, 246, 255, 0.052), transparent 31%),
    radial-gradient(circle at 82% 78%, rgba(120, 108, 255, 0.09), transparent 35%),
    linear-gradient(145deg, #000 0%, #030504 48%, #03030a 100%);
}

.loader::before {
  z-index: -1;
  background:
    radial-gradient(circle at 50% 48%, transparent 0 18%, rgba(0, 0, 0, 0.18) 38%, rgba(0, 0, 0, 0.72) 78%, #000 100%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    linear-gradient(rgba(255, 255, 255, 0.014) 1px, transparent 1px);
  background-size: auto, 96px 96px, 96px 96px;
}

.loader::after {
  content: "";
  position: absolute;
  z-index: -1;
  left: -12%;
  right: -12%;
  bottom: -46%;
  height: 72%;
  opacity: 0.18;
  transform: perspective(620px) rotateX(68deg);
  transform-origin: center bottom;
  background-image:
    linear-gradient(rgba(84, 246, 255, 0.16) 1px, transparent 1px),
    linear-gradient(90deg, rgba(207, 255, 60, 0.13) 1px, transparent 1px);
  background-size: 58px 58px;
  -webkit-mask-image: linear-gradient(to top, #000 4%, rgba(0, 0, 0, 0.65) 42%, transparent 86%);
  mask-image: linear-gradient(to top, #000 4%, rgba(0, 0, 0, 0.65) 42%, transparent 86%);
  animation: loaderFloorDrift 3.8s linear infinite;
  will-change: transform;
}

.loader-atmosphere i {
  mix-blend-mode: screen;
  opacity: 0.085;
  filter: blur(92px);
}

.loader-portal {
  width: min(300px, 68vw);
  transform: scale(0.86);
}

.loader-portal::before,
.loader-portal::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.loader-portal::before {
  inset: -8%;
  border-radius: 50%;
  background: conic-gradient(
    from 20deg,
    transparent 0 16%,
    rgba(84, 246, 255, 0.78) 22%,
    transparent 29% 48%,
    rgba(207, 255, 60, 0.72) 55%,
    transparent 63% 83%,
    rgba(120, 108, 255, 0.62) 89%,
    transparent 96% 100%
  );
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #000 calc(100% - 1.5px));
  mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #000 calc(100% - 1.5px));
  opacity: 0.72;
  animation: loaderHaloSpin 4.8s linear infinite;
}

.loader-portal::after {
  inset: 5%;
  border-radius: 50%;
  opacity: 0.19;
  background:
    linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(84, 246, 255, 0.55) 50%, transparent calc(50% + 0.5px)),
    linear-gradient(transparent calc(50% - 0.5px), rgba(207, 255, 60, 0.5) 50%, transparent calc(50% + 0.5px));
  -webkit-mask-image: radial-gradient(circle, transparent 0 22%, #000 23% 74%, transparent 75%);
  mask-image: radial-gradient(circle, transparent 0 22%, #000 23% 74%, transparent 75%);
}

.loader-portal-glow {
  inset: 14%;
  background:
    radial-gradient(circle, rgba(207, 255, 60, 0.22), transparent 34%),
    radial-gradient(circle, rgba(84, 246, 255, 0.11), transparent 62%);
  filter: blur(18px);
}

.loader-ring-a {
  border-color: rgba(207, 255, 60, 0.38);
  box-shadow: inset 0 0 32px rgba(207, 255, 60, 0.035), 0 0 25px rgba(207, 255, 60, 0.055);
}

.loader-ring-b {
  border-color: rgba(84, 246, 255, 0.28);
  box-shadow: inset 0 0 32px rgba(84, 246, 255, 0.03), 0 0 28px rgba(84, 246, 255, 0.05);
}

.loader-ring-c {
  border-color: rgba(120, 108, 255, 0.28);
}

.loader-core {
  position: relative;
  width: 15px;
  height: 15px;
  background: #f7ffe9;
  box-shadow:
    0 0 13px rgba(255, 255, 255, 0.92),
    0 0 30px rgba(207, 255, 60, 0.56),
    0 0 68px rgba(84, 246, 255, 0.28);
}

.loader-core::before,
.loader-core::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.loader-core::before {
  inset: -16px;
  border: 1px solid rgba(207, 255, 60, 0.34);
  animation: loaderCoreEcho 1.45s var(--ease) infinite;
}

.loader-core::after {
  inset: -42px;
  background: radial-gradient(circle, rgba(84, 246, 255, 0.11), transparent 62%);
}

.loader-track {
  left: 50%;
  right: auto;
  bottom: 30px;
  width: min(460px, calc(100vw - 48px));
  height: 4px;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.075);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.055), 0 0 24px rgba(84, 246, 255, 0.09);
}

.loader-track span {
  background: linear-gradient(90deg, #cfff3c, #f7ffe9, #54f6ff, #786cff, #cfff3c);
  background-size: 180% 100%;
  box-shadow: 0 0 9px rgba(207, 255, 60, 0.7), 0 0 25px rgba(84, 246, 255, 0.34);
  animation: loaderBarFlow 1.35s linear infinite;
}

.loader-track span::after {
  right: -5px;
  width: 10px;
  height: 10px;
  box-shadow: 0 0 12px rgba(255, 255, 255, 0.82), 0 0 26px rgba(84, 246, 255, 0.56);
}

.loader.is-accelerating .loader-portal::before {
  animation-duration: 0.58s;
}

.meteor-shot {
  height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, rgba(84, 246, 255, 0.035) 24%, rgba(84, 246, 255, 0.38) 72%, #faffee 100%);
  box-shadow: 0 0 8px rgba(84, 246, 255, 0.22);
}

.meteor-shot.is-companion {
  height: 1px;
  opacity: 0.84;
}

.meteor-shot.is-warm {
  background: linear-gradient(90deg, transparent 0%, rgba(255, 75, 34, 0.035) 24%, rgba(255, 104, 61, 0.38) 72%, #fff4e8 100%);
  box-shadow: 0 0 8px rgba(255, 75, 34, 0.2);
}

.meteor-shot.is-warm::after {
  box-shadow: 0 0 7px #ff6a3d, 0 0 13px rgba(255, 75, 34, 0.34);
}

.meteor-shot.is-acid {
  background: linear-gradient(90deg, transparent 0%, rgba(207, 255, 60, 0.03) 24%, rgba(207, 255, 60, 0.34) 72%, #faffee 100%);
  box-shadow: 0 0 8px rgba(207, 255, 60, 0.19);
}

.meteor-shot.is-acid::after {
  box-shadow: 0 0 7px #cfff3c, 0 0 13px rgba(207, 255, 60, 0.3);
}

@keyframes loaderFloorDrift {
  from { transform: perspective(620px) rotateX(68deg) translate3d(0, 0, 0); }
  to { transform: perspective(620px) rotateX(68deg) translate3d(0, 58px, 0); }
}

@keyframes loaderHaloSpin {
  to { transform: rotate(360deg); }
}

@keyframes loaderCoreEcho {
  0% { opacity: 0; transform: scale(0.55); }
  34% { opacity: 0.72; }
  100% { opacity: 0; transform: scale(1.45); }
}

@keyframes loaderBarFlow {
  to { background-position: 180% 0; }
}

@media (max-width: 760px), (pointer: coarse) {
  .loader-portal {
    width: min(220px, 64vw);
  }

  .bg-field {
    box-shadow: inset 0 0 90px rgba(0, 0, 0, 0.34);
  }

  .bg-field::before {
    opacity: 0.055;
    background-size: 72px 72px, 72px 72px, 100% 100%;
  }

  .bg-field::after {
    opacity: 0.14;
  }

  .loader::after,
  .loader-portal::before,
  .loader-portal::after,
  .loader-core::before {
    animation: none;
  }

  .loader::after {
    opacity: 0.08;
  }

  .loader-track {
    bottom: 22px;
    width: calc(100vw - 36px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .loader::after,
  .loader-portal::before,
  .loader-core::before,
  .loader-track span {
    animation: none !important;
  }
}
