@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/outfit-latin-ext-wght-normal-DdQaqQDo.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/outfit-latin-wght-normal-Bc-8i84L.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--ink:#3a2b3f;--ink-soft:#6b5a70;--paper:#fff8ec;--paper-2:#fbead3;--paper-3:#f4dcc0;--accent-warm:#ff9e6d;--accent-gold:#ffd98a;--accent-teal:#6fc3c9;--line:#3a2b3f29;--font-display:"Fraunces Variable", Georgia, "Times New Roman", serif;--font-body:"Outfit Variable", system-ui, -apple-system, sans-serif;--radius-lg:26px;--radius-md:16px;--radius-sm:10px;--shadow-panel:0 24px 80px #3a2b3f47;--shadow-soft:0 6px 24px #3a2b3f24;--ease-pop:cubic-bezier(.22, 1.2, .36, 1)}*{box-sizing:border-box}html,body{overscroll-behavior:none;height:100%;margin:0;padding:0;overflow:hidden}body{font-family:var(--font-body);color:var(--ink);background:var(--paper-2);-webkit-font-smoothing:antialiased}#root,.app{position:fixed;inset:0}.app>div:first-child{inset:0;position:absolute!important}canvas{touch-action:none;outline:none}button{color:inherit;font-family:inherit}:focus-visible{outline:3px solid var(--accent-warm);outline-offset:2px;border-radius:6px}.hud{pointer-events:none;z-index:20;position:absolute;inset:0}.hud>*{pointer-events:auto}.vignette{z-index:-1;background:radial-gradient(#0000 62%,#3a2b3f2e 100%);position:absolute;inset:0;pointer-events:none!important}.topbar{justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:absolute;top:0;left:0;right:0}.wordmark{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid var(--ink);font-family:var(--font-display);letter-spacing:.01em;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .25s var(--ease-pop);background:#fff8ecd1;border-radius:999px;align-items:center;gap:10px;padding:8px 18px 8px 12px;font-size:15px;font-weight:600;display:flex}.wordmark:hover{transform:translateY(-2px)}.wordmark em{color:var(--ink-soft);font-style:italic;font-weight:400}.wordmark__dot{border:2px solid var(--ink);background:radial-gradient(circle at 32% 30%,#a8e08f,#6dbb6b 70%);border-radius:50%;flex-shrink:0;width:16px;height:16px}.topbar__actions{gap:10px;display:flex}.icon-btn{border:2px solid var(--ink);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-soft);transition:transform .25s var(--ease-pop), background .2s;background:#fff8ecd1;border-radius:50%;place-items:center;display:grid}.icon-btn:hover{background:var(--paper);transform:translateY(-2px)}.icon-btn--active{background:var(--accent-gold)}.drawer-backdrop{background:#3a2b3f33;position:absolute;inset:0}.drawer{background:var(--paper);border:2px solid var(--ink);border-radius:var(--radius-lg);width:min(330px,100vw - 44px);max-height:calc(100dvh - 100px);box-shadow:var(--shadow-panel);opacity:0;pointer-events:none;transition:opacity .22s ease, transform .28s var(--ease-pop);flex-direction:column;gap:4px;padding:14px;display:flex;position:absolute;top:76px;right:22px;overflow-y:auto;transform:translateY(-12px)scale(.98)}.drawer--open{opacity:1;pointer-events:auto;transform:none}.drawer__hint{color:var(--ink-soft);margin:6px 10px 10px;font-size:13px;font-style:italic}.drawer__item{border-radius:var(--radius-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:9px 10px;transition:background .15s;display:flex}.drawer__item:hover{background:var(--paper-2)}.drawer__icon{background:color-mix(in srgb, var(--accent) 22%, white);width:38px;height:38px;color:var(--ink);border:2px solid color-mix(in srgb, var(--accent) 55%, var(--ink) 20%);border-radius:12px;flex-shrink:0;place-items:center;display:grid}.drawer__text{flex-direction:column;line-height:1.25;display:flex}.drawer__text strong{font-size:15px}.drawer__text small{color:var(--ink-soft);font-size:12.5px}.nearby-prompt{border:2px solid var(--ink);background:color-mix(in srgb, var(--accent) 30%, var(--paper));cursor:pointer;box-shadow:var(--shadow-soft);animation:prompt-in .35s var(--ease-pop);border-radius:999px;align-items:center;gap:10px;padding:12px 22px;font-size:15.5px;font-weight:600;display:flex;position:absolute;bottom:96px;left:50%;transform:translate(-50%)}.nearby-prompt:hover{background:color-mix(in srgb, var(--accent) 45%, var(--paper))}.nearby-prompt__key{border:2px solid var(--ink);background:var(--paper);border-radius:7px;place-items:center;width:26px;height:26px;display:grid}@keyframes prompt-in{0%{opacity:0;transform:translate(-50%)translateY(14px)}}.controls-hint{color:#fff8ecf2;letter-spacing:.04em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);white-space:nowrap;background:#3a2b3f80;border-radius:999px;padding:8px 18px;font-size:13px;position:absolute;bottom:26px;left:50%;transform:translate(-50%)}.joystick{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);touch-action:none;background:#fff8ec47;border:2px solid #3a2b3f8c;border-radius:50%;width:128px;height:128px;position:absolute;bottom:34px;left:30px}.joystick__knob{background:var(--paper);border:2px solid var(--ink);width:54px;height:54px;box-shadow:var(--shadow-soft);border-radius:50%;margin:-27px 0 0 -27px;position:absolute;top:50%;left:50%}.lm-label{border:3px solid var(--accent,var(--ink));white-space:nowrap;background:#fff8eceb;border-radius:999px;flex-direction:column;align-items:center;gap:1px;padding:10px 22px;transition:opacity .3s;display:flex;transform:translateZ(0);box-shadow:0 6px 18px #3a2b3f33}.lm-label__place{letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-size:13px}.lm-label__title{font-family:var(--font-display);font-size:22px;font-weight:600}body.section-open .lm-label,body.far-view .lm-label{opacity:0}.intro{z-index:30;opacity:0;pointer-events:none;background:linear-gradient(#3a2b3f1f 0%,#0000 30% 55%,#3a2b3f57 100%);justify-content:center;align-items:flex-end;padding:0 24px calc(6dvh + 12px);transition:opacity 1.2s .3s;display:flex;position:absolute;inset:0}.intro--ready{opacity:1}.intro__content{pointer-events:auto;text-align:center;max-width:660px}.intro__eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--paper);text-shadow:0 1px 10px #3a2b3f99;margin-bottom:10px;font-size:13px}.intro__title{font-family:var(--font-display);font-variation-settings:"SOFT" 60;color:var(--paper);text-shadow:0 2px 24px #3a2b3f8c;margin:0 0 14px;font-size:clamp(42px,7vw,74px);font-weight:620;line-height:1.02}.intro__sub{color:var(--paper);text-shadow:0 1px 12px #3a2b3fa6;max-width:560px;margin:0 auto 26px;font-size:clamp(15px,2vw,17.5px);line-height:1.55}.intro__actions{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:20px;display:flex}.intro__hint{letter-spacing:.05em;color:#fff8eceb;text-shadow:0 1px 8px #3a2b3f99;font-size:13px;line-height:1.7}.intro__hint-soft{opacity:.85;font-style:italic}.btn{border:2px solid var(--ink);background:var(--accent-gold);cursor:pointer;transition:transform .15s var(--ease-pop), box-shadow .15s, background .2s;color:var(--ink);border-radius:999px;align-items:center;gap:8px;padding:11px 22px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 4px #3a2b3fd9}.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px #3a2b3fd9}.btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #3a2b3fd9}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--large{padding:14px 28px;font-size:16.5px}.btn--small{padding:7px 14px;font-size:13px;box-shadow:0 3px #3a2b3fd9}.btn--ghost{background:#fff8ecd9}.overlay{z-index:40;justify-content:center;align-items:center;padding:clamp(10px,3vh,30px) clamp(10px,3vw,30px);display:flex;position:absolute;inset:0}.overlay__backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:linear-gradient(200deg,#78aede40,#3a2b3f73);animation:.3s fade-in;position:absolute;inset:0}.overlay--closing .overlay__backdrop{animation:.28s forwards fade-out}.panel{background:var(--paper);border:3px solid var(--ink);border-radius:var(--radius-lg);width:min(940px,100%);max-height:min(86dvh,900px);box-shadow:var(--shadow-panel);animation:panel-in .42s var(--ease-pop);flex-direction:column;display:flex;position:relative;overflow:hidden}.overlay--closing .panel{animation:.28s forwards panel-out}.panel:before{content:"";background:var(--accent,var(--accent-gold));height:7px;position:absolute;top:0;left:0;right:0}@keyframes panel-in{0%{opacity:0;transform:translateY(36px)scale(.97)}}@keyframes panel-out{to{opacity:0;transform:translateY(24px)scale(.98)}}@keyframes fade-in{0%{opacity:0}}@keyframes fade-out{to{opacity:0}}.panel__header{justify-content:space-between;align-items:flex-start;gap:16px;padding:26px 28px 16px;display:flex}.panel__eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);align-items:center;gap:8px;font-size:12.5px;display:inline-flex}.panel__icon{border:2px solid color-mix(in srgb, var(--accent) 60%, var(--ink) 15%);background:color-mix(in srgb, var(--accent) 25%, white);border-radius:9px;place-items:center;width:30px;height:30px;display:grid}.panel__title{font-family:var(--font-display);margin:8px 0 4px;font-size:clamp(30px,4.4vw,42px);font-weight:620;line-height:1.05}.panel__tagline{color:var(--ink-soft);margin:0;font-size:15px;font-style:italic}.panel__scroll{scrollbar-width:thin;scrollbar-color:var(--paper-3) transparent;padding:6px 28px 26px;overflow-y:auto}.panel__footer{border-top:2px solid var(--line);background:var(--paper-2);justify-content:space-between;align-items:center;gap:10px;padding:14px 20px;display:flex}.section-body{flex-direction:column;gap:18px;display:flex}.prose{margin:0;font-size:15.5px;line-height:1.65}.section-lede{color:var(--ink-soft);font-size:17px}.footnote{color:var(--ink-soft);margin:0;font-size:13px;font-style:italic}.about-header{align-items:center;gap:22px;display:flex}.about-portrait{flex-shrink:0;width:110px;height:110px}.about-name{font-family:var(--font-display);margin:0 0 2px;font-size:26px}.about-role{letter-spacing:.06em;color:var(--ink-soft);margin:0 0 8px;font-size:14px}.about-intro{margin:0;font-size:16.5px;font-style:italic}.about-highlights{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.about-highlight{border:2px solid var(--line);border-radius:var(--radius-md);background:var(--paper-2);flex-direction:column;gap:3px;padding:16px;display:flex}.about-highlight__value{font-family:var(--font-display);font-size:21px;font-weight:620}.about-highlight__label{color:var(--ink-soft);font-size:13px}.about-quote{border-left:4px solid var(--accent-warm);border-radius:0 var(--radius-md) var(--radius-md) 0;background:color-mix(in srgb, var(--accent-warm) 10%, white);margin:4px 0 0;padding:18px 22px}.about-quote p{font-family:var(--font-display);margin:0 0 6px;font-size:19px;font-style:italic}.about-quote cite{color:var(--ink-soft);font-size:13px;font-style:normal}.project-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;display:grid}.project-card{border:2px solid var(--ink);border-radius:var(--radius-md);transition:transform .25s var(--ease-pop), box-shadow .25s;background:#fff;flex-direction:column;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-soft);transform:translateY(-4px)}.project-card--featured{flex-direction:row;grid-column:1/-1}.project-card--featured .project-card__thumb{flex-shrink:0;width:42%}.project-card__thumb{aspect-ratio:4/3;border-bottom:2px solid var(--ink);overflow:hidden}.project-card--featured .project-card__thumb{aspect-ratio:auto;border-bottom:none;border-right:2px solid var(--ink)}.motif{object-fit:cover;width:100%;height:100%;display:block}.project-card__content{flex-direction:column;gap:8px;padding:16px;display:flex}.project-card__status{letter-spacing:.12em;text-transform:uppercase;color:color-mix(in srgb, var(--accent) 70%, var(--ink) 30%);font-size:11.5px;font-weight:600}.project-card__title{font-family:var(--font-display);margin:0;font-size:21px}.project-card__desc{color:var(--ink-soft);margin:0;font-size:14px;line-height:1.55}.project-card__links{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.tag-row{flex-wrap:wrap;gap:6px;display:flex}.tag{border:1.5px solid var(--line);background:var(--paper-2);border-radius:999px;padding:4px 11px;font-size:12px;font-weight:500}.tag-row--large{gap:8px}.tag--stack{border:2px solid var(--ink);background:#fff;padding:8px 16px;font-size:14px;box-shadow:0 3px #3a2b3f40}.area-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;display:grid}.area-card{border:2px solid var(--line);border-radius:var(--radius-md);background:var(--paper-2);padding:15px 16px}.area-card h4{margin:0 0 5px;font-size:15.5px}.area-card p{color:var(--ink-soft);margin:0;font-size:13.5px;line-height:1.45}.practice-list{flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;display:flex}.practice-list li{padding-left:26px;font-size:15px;line-height:1.5;position:relative}.practice-list li:before{content:"✦";color:var(--accent-teal);position:absolute;left:2px}.featured-banner{border:2px solid var(--ink);border-radius:var(--radius-md);background:color-mix(in srgb, var(--accent) 8%, white);gap:0;display:flex;overflow:hidden}.featured-banner__thumb{border-right:2px solid var(--ink);flex-shrink:0;width:34%;min-width:190px}.featured-banner>div:last-child{padding:20px 22px}.featured-banner__eyebrow{letter-spacing:.14em;text-transform:uppercase;color:color-mix(in srgb, var(--accent) 70%, var(--ink) 30%);font-size:12px;font-weight:600}.featured-banner h3{font-family:var(--font-display);margin:6px 0 8px;font-size:24px}.featured-banner p{color:var(--ink-soft);margin:0;font-size:14.5px;line-height:1.6}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;display:grid}.gallery-item{border:2px solid var(--ink);border-radius:var(--radius-md);aspect-ratio:4/3;margin:0;position:relative;overflow:hidden}.gallery-item--wide{aspect-ratio:8/3.2;grid-column:span 2}.gallery-item img,.gallery-item .motif{object-fit:cover;width:100%;height:100%;transition:transform .5s}.gallery-item:hover img,.gallery-item:hover .motif{transform:scale(1.045)}.gallery-item figcaption{inset-inline:0;color:var(--paper);opacity:0;background:linear-gradient(#0000,#3a2b3fb8);flex-direction:column;gap:1px;padding:26px 14px 11px;transition:opacity .3s,transform .3s;display:flex;position:absolute;bottom:0;transform:translateY(6px)}.gallery-item:hover figcaption,.gallery-item:focus-within figcaption{opacity:1;transform:none}.gallery-item figcaption strong{font-family:var(--font-display);font-size:16px}.gallery-item figcaption span{opacity:.9;font-size:12.5px}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.skill-group{border:2px solid color-mix(in srgb, var(--accent) 55%, var(--ink) 12%);border-radius:var(--radius-md);background:color-mix(in srgb, var(--accent) 7%, white);padding:16px 18px}.skill-group__title{font-family:var(--font-display);align-items:center;gap:10px;margin:0 0 12px;font-size:17.5px;display:flex}.skill-group__lantern{background:var(--accent);border:2px solid var(--ink);width:13px;height:13px;box-shadow:0 0 10px color-mix(in srgb, var(--accent) 70%, transparent);border-radius:50%}.skill-group ul{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.skill-group li{justify-content:space-between;align-items:center;gap:12px;font-size:14.5px;display:flex}.skill-dots{gap:4px;display:inline-flex}.skill-dot{border:1.5px solid var(--line);background:#fff;border-radius:50%;width:9px;height:9px}.skill-note{border:1.5px solid color-mix(in srgb, var(--accent) 60%, var(--ink) 12%);letter-spacing:.03em;white-space:nowrap;background:#fff;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.contact-headline{font-family:var(--font-display);margin:0;font-size:clamp(24px,3.4vw,32px);line-height:1.15}.contact-links{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.contact-card{border:2px solid var(--ink);border-radius:var(--radius-md);color:inherit;transition:transform .2s var(--ease-pop), box-shadow .2s;background:#fff;flex-direction:column;gap:3px;padding:16px 18px;text-decoration:none;display:flex}.contact-card:hover{box-shadow:var(--shadow-soft);transform:translateY(-3px)}.contact-card--primary{background:color-mix(in srgb, var(--accent-warm) 18%, white)}.contact-card__label{letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-size:12px;font-weight:600}.contact-card__value{overflow-wrap:anywhere;font-size:15.5px;font-weight:600}.contact-form{border:2px dashed var(--line);border-radius:var(--radius-md);background:var(--paper-2);flex-direction:column;gap:14px;padding:20px;display:flex}.contact-form__row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.contact-form label{letter-spacing:.04em;flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.contact-form input,.contact-form textarea{border:2px solid var(--line);border-radius:var(--radius-sm);color:inherit;resize:vertical;background:#fff;padding:10px 14px;font-family:inherit;font-size:14.5px}.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent-warm);border-color:#0000}.contact-form__footer{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.contact-closing{font-family:var(--font-display);color:var(--ink-soft);text-align:center;margin:0;padding-top:6px;font-size:16.5px;font-style:italic}@media (width<=720px){.topbar{padding:12px 14px}.wordmark em{display:none}.panel__header{padding:20px 18px 12px}.panel__scroll{padding:4px 18px 20px}.panel__footer{flex-wrap:wrap;justify-content:center}.panel__footer .btn--ghost{flex:1;justify-content:center;padding:9px 10px;font-size:13px}.panel__footer .btn:not(.btn--ghost){order:-1;justify-content:center;width:100%}.project-card--featured{flex-direction:column}.project-card--featured .project-card__thumb{aspect-ratio:4/3;border-right:none;border-bottom:2px solid var(--ink);width:100%}.featured-banner{flex-direction:column}.featured-banner__thumb{border-right:none;border-bottom:2px solid var(--ink);width:100%}.gallery-item--wide{aspect-ratio:4/3;grid-column:auto}.about-header{text-align:center;flex-direction:column}.contact-form__row{grid-template-columns:1fr}.nearby-prompt{bottom:170px}.controls-hint{white-space:normal;text-align:center;max-width:calc(100vw - 40px);font-size:12px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
