.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--paper: #f8f7f4;--paper-deep: #f0eee9;--surface: #fdfdfb;--ink: #1c1917;--ink-soft: #44403c;--muted: #78716c;--faint: #a8a29e;--line: rgba(28, 25, 23, .08);--line-strong: rgba(28, 25, 23, .14);--red: #c45549;--green: #4d8b5a;--blue-pill: #d4e9ed;--sand-pill: #ebdacb;--shadow-sm: 0 2px 8px rgba(120, 90, 50, .04);--shadow-md: 0 12px 32px rgba(120, 90, 50, .06);--shadow-lg: 0 20px 48px rgba(120, 90, 50, .08);--mono: "IBM Plex Mono", "SFMono-Regular", "Menlo", monospace;--typewriter: "IBM Plex Mono", "Courier Prime", "Courier New", monospace;--display: "Instrument Serif", "Playfair Display", Georgia, serif;--editorial: "Instrument Serif", "Playfair Display", Georgia, serif;--sans: "Inter", "LXGW WenKai", "PingFang SC", system-ui, sans-serif;--zh-sans: "Inter", "LXGW WenKai", "PingFang SC", system-ui, sans-serif;--zh-kai: "LXGW WenKai", "Kaiti SC", "STKaiti", serif;--hand: "Caveat", "Segoe Script", cursive;--max: 1200px;--ease-out: cubic-bezier(.32, .72, 0, 1)}*{box-sizing:border-box}html{background:var(--paper);color:var(--ink);font-family:var(--sans);scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;font-variant-numeric:tabular-nums}body{margin:0;min-height:100dvh;background:radial-gradient(circle at 8% 8%,rgba(255,255,255,.7),transparent 30%),var(--paper)}body:before{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.07;background-image:repeating-linear-gradient(0deg,rgba(28,25,23,.03) 0 1px,transparent 1px 4px),repeating-linear-gradient(90deg,rgba(28,25,23,.02) 0 1px,transparent 1px 6px);mix-blend-mode:multiply}a{color:inherit;text-decoration:none}a,button,.light-btn,.dark-btn,.filter-pill,.rail-item,.tool-nav-item{-webkit-tap-highlight-color:transparent}:focus-visible{outline:2px solid rgba(196,85,73,.6);outline-offset:4px;border-radius:6px}button{font:inherit}img{max-width:100%;display:block}::view-transition-old(root),::view-transition-new(root){animation-duration:.26s;animation-timing-function:cubic-bezier(.32,.72,0,1)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:1ms!important;transition-duration:1ms!important}}.page-shell{max-width:var(--max);margin:0 auto;padding:36px 42px 34px;min-height:100dvh;position:relative;overflow:hidden}.page-shell:after{content:"";position:absolute;left:-6vw;bottom:-86px;width:520px;height:210px;background:linear-gradient(165deg,#ece5d724,#ffffff80 52%,#d0c2ac26),var(--paper-deep);clip-path:polygon(0 31%,42% 8%,100% 50%,100% 100%,0 100%);border-top:1px solid var(--line);transform:rotate(-2deg);opacity:.9;z-index:0}.site-header,main,.closing{position:relative;z-index:1}.site-header{display:grid;grid-template-columns:78px 1fr auto;align-items:center;gap:28px;min-height:46px;margin-bottom:42px}.home-wordmark{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--ink-soft);letter-spacing:.02em;border-bottom:1px solid var(--line-strong);width:max-content;padding-bottom:4px;transition:color .36s var(--ease-out),border-color .36s var(--ease-out),transform .36s var(--ease-out)}.home-wordmark:hover{color:var(--red);border-color:var(--red);transform:translateY(-1px)}.nav-links{display:flex;align-items:center;justify-content:center;gap:clamp(22px,4vw,52px);font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.01em;color:var(--muted)}.nav-links a{padding-bottom:7px;border-bottom:2px solid transparent;transition:color .32s var(--ease-out),border-color .32s var(--ease-out),transform .32s var(--ease-out)}.nav-links a:hover{color:var(--ink);transform:translateY(-1px)}.nav-links a:active{transform:scale(.97)}.nav-links a[aria-current=page]{color:var(--ink);border-color:var(--ink)}.contact-btn{background:var(--ink);color:#fff;height:45px;padding:0 16px 0 18px;border-radius:999px;display:inline-flex;align-items:center;gap:14px;font-family:var(--zh-sans);font-size:11px;font-weight:600;box-shadow:var(--shadow-md);transition:transform .36s var(--ease-out),box-shadow .36s var(--ease-out),background .36s var(--ease-out)}.contact-btn:hover{background:var(--ink-soft);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.contact-btn:active{transform:translateY(0) scale(.98)}.contact-btn span{width:24px;height:24px;border-radius:50%;display:inline-grid;place-items:center;background:#ffffff17}.section-label{font-family:var(--mono);color:var(--red);font-size:11px;font-weight:600;letter-spacing:.12em;margin-bottom:25px;text-transform:uppercase}.micro-link{display:inline-flex;align-items:center;gap:12px;margin-top:18px;font-family:var(--mono);font-size:11px;font-weight:600;border-bottom:1px solid var(--ink);padding-bottom:3px;transition:color .32s var(--ease-out),border-color .32s var(--ease-out),transform .32s var(--ease-out)}.micro-link:hover{color:var(--red);border-color:var(--red);transform:translate(2px)}.hero{display:grid;grid-template-columns:minmax(290px,.78fr) minmax(520px,1.22fr);gap:38px;min-height:372px;margin-bottom:50px}.hero h1,.page-title{margin:0;font-family:var(--display);font-size:clamp(2.18rem,3.55vw,3.68rem);line-height:1.03;letter-spacing:-.04em;font-weight:700;text-wrap:balance}.hero h1 .line{display:block}.under{text-decoration:underline;text-decoration-thickness:.055em;text-underline-offset:.11em}.intro-copy,.detail-summary,.about-copy{max-width:620px;color:var(--ink-soft);font-family:var(--zh-sans);font-size:13px;line-height:1.82;letter-spacing:.015em;font-weight:400;text-wrap:pretty}.intro-copy{margin:30px 0 0;max-width:292px}.currently{margin-top:29px;display:flex;align-items:center;flex-wrap:wrap;gap:11px;width:min(570px,calc(100vw - 84px));font-family:var(--mono);color:var(--muted);font-size:11px;font-weight:500}.current-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px #4d8b5a1f}.chip{display:inline-flex;align-items:center;min-height:25px;border-radius:6px;padding:0 12px;background:var(--sand-pill);color:var(--ink-soft);border:1px solid rgba(28,25,23,.06);font-family:var(--zh-sans);font-weight:500;letter-spacing:.02em}.chip.blue{background:var(--blue-pill);color:var(--ink-soft)}.collage{position:relative;min-height:360px;transform:translateY(-12px)}.photo{position:absolute;overflow:hidden;border-radius:2px;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow-md);filter:saturate(1.03) contrast(1.02)}.flower{left:4%;top:50px;width:128px;height:115px}.blur{left:18%;top:123px;width:164px;height:166px}.sky{left:38%;top:0;width:150px;height:210px}.land{right:17%;top:150px;width:102px;height:77px}.bag{right:2%;top:94px;width:102px;height:88px}.coffee{right:25%;bottom:18px;width:94px;height:86px}.texture{right:8%;bottom:18px;width:98px;height:86px}.hand-note{position:absolute;right:8.5%;top:46px;font-family:var(--hand);font-size:17px;line-height:1.04;font-weight:700;color:var(--ink-soft);transform:rotate(-4deg)}.hand-note:after{content:"";position:absolute;width:58px;height:28px;left:-68px;top:34px;border-bottom:2px solid rgba(28,25,23,.5);border-left:2px solid rgba(28,25,23,.5);border-radius:0 0 0 42px;transform:rotate(-16deg)}.works,.builds{margin-bottom:48px}.works-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;align-items:end}.work-card{min-width:0;display:block;transition:transform .62s var(--ease-out)}.work-image{width:100%;height:126px;border-radius:3px;overflow:hidden;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow-sm);filter:saturate(1.02) contrast(1.02);transition:transform .7s var(--ease-out),box-shadow .7s var(--ease-out),filter .7s var(--ease-out)}.work-card:hover .work-image{transform:translateY(-4px) rotate(-.3deg);box-shadow:var(--shadow-lg);filter:saturate(1.08) contrast(1.04)}.work-title{margin:13px 0 2px;font-size:13px;line-height:1.25;font-family:var(--zh-sans);font-weight:600;letter-spacing:.01em}.work-meta{margin:0;color:var(--muted);font-size:11.5px;line-height:1.35;font-weight:400}.scribble-link,.more-projects{font-family:var(--hand);font-size:18px;line-height:1.05;font-weight:700;color:var(--ink-soft);transform:rotate(-5deg)}.scribble-link{padding-bottom:18px;justify-self:end;position:relative}.scribble-link:after{content:"";position:absolute;left:-15px;bottom:0;width:48px;height:18px;border-bottom:2px solid rgba(28,25,23,.4);border-left:2px solid rgba(28,25,23,.4);border-radius:0 0 0 28px;transform:rotate(-14deg)}.build-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.build-card{height:118px;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:14px 15px 12px;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:45px 1fr;gap:12px;align-items:start;transition:transform .65s var(--ease-out),background .65s var(--ease-out),box-shadow .65s var(--ease-out)}.build-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.build-card:active{transform:translateY(-1px) scale(.99)}.icon-box{width:39px;height:39px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}.icon-box img{width:100%;height:100%;object-fit:cover}.build-copy h3{margin:1px 0 6px;font-size:13px;line-height:1.2;letter-spacing:-.02em;text-wrap:balance}.build-copy p{margin:0;color:var(--muted);font-size:11px;line-height:1.42;font-family:var(--zh-sans);letter-spacing:.01em;font-weight:400}.build-foot{grid-column:2;align-self:end;margin-top:8px;display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted)}.status{min-height:20px;display:inline-flex;align-items:center;padding:0 9px;border-radius:4px;background:#4d8b5a1f;color:var(--green);font-size:10px;letter-spacing:.02em}.status.beta,.status.draft{background:#1c19170d;color:var(--muted)}.more-projects{display:flex;justify-content:flex-end;margin-top:18px;padding-right:36px;transform:rotate(-2deg)}.closing{min-height:154px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:24px;padding-top:10px}.motto{font-family:var(--mono);font-weight:700;font-size:clamp(1.35rem,2.3vw,2.05rem);line-height:1.06;letter-spacing:-.06em;align-self:center}.motto .mark-line{display:inline-block;border-bottom:2px solid var(--ink);padding-bottom:3px}.footer-links{display:flex;gap:14px;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--ink)}.listing-head{display:flex;justify-content:space-between;align-items:start;margin-bottom:22px}.filter-row{display:flex;gap:10px;margin:16px 0 24px;flex-wrap:wrap}.filter-pill{padding:8px 18px;border:1px solid var(--line);border-radius:999px;font-size:11px;font-weight:600;background:var(--surface);transition:transform .32s var(--ease-out),background .32s var(--ease-out),border-color .32s var(--ease-out)}.filter-pill:hover{transform:translateY(-1px);border-color:var(--line-strong)}.filter-pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}.project-list,.visual-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.project-tile{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .62s var(--ease-out),box-shadow .62s var(--ease-out)}.project-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.project-tile img{width:100%;height:150px;object-fit:cover;filter:saturate(1.04) contrast(1.02)}.project-tile-body{padding:16px}.project-tile h2{margin:0 0 6px;font-size:16px;line-height:1.2;letter-spacing:-.025em}.project-tile p{margin:0 0 14px;color:var(--muted);font-size:13px;line-height:1.55}.detail-shell{margin-top:10px}.case-grid{display:grid;grid-template-columns:240px minmax(0,1fr);gap:44px}.case-side{border-right:1px solid var(--line);padding-right:24px;color:var(--muted);font-size:12px;line-height:1.65}.case-body,.research-body,.visual-body{max-width:760px}.case-body h2,.research-body h2,.visual-body h2{margin:34px 0 10px;font-size:20px;letter-spacing:-.03em}.case-body p,.research-body p,.visual-body p{color:var(--ink-soft);font-family:var(--zh-sans);line-height:1.82;font-size:14px;text-wrap:pretty}.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:24px 0}.metric-card,.note-card{border:1px solid var(--line);border-radius:10px;background:var(--surface);padding:16px}.metric-card strong{display:block;font-family:var(--mono);font-size:18px;margin-bottom:6px}.tool-layout{display:grid;grid-template-columns:150px minmax(0,1fr);border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface);min-height:560px;box-shadow:var(--shadow-md)}.tool-rail{border-right:1px solid var(--line);padding:24px 16px;background:var(--paper)}.tool-nav-item{height:34px;border-radius:7px;display:flex;align-items:center;padding:0 10px;font-size:12px;font-weight:600;color:var(--muted);margin-top:9px;transition:transform .32s var(--ease-out),background .32s var(--ease-out),color .32s var(--ease-out)}.tool-nav-item:hover{transform:translate(2px);background:#1c191708}.tool-nav-item.active{background:var(--paper-deep);color:var(--ink)}.tool-main{padding:30px}.tool-top{display:flex;justify-content:space-between;gap:24px;margin-bottom:24px}.tool-actions{display:flex;gap:10px}.light-btn,.dark-btn{height:38px;border-radius:999px;padding:0 17px;font-size:11px;font-weight:600;border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;transition:transform .32s var(--ease-out),background .32s var(--ease-out),box-shadow .32s var(--ease-out);white-space:nowrap}.light-btn:hover,.dark-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.light-btn:active,.dark-btn:active{transform:translateY(0) scale(.98)}.dark-btn{background:var(--ink);color:#fff;border:0}.workspace-grid{display:grid;grid-template-columns:1.35fr .9fr;gap:18px}.process-panel,.result-panel{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:20px}.fake-field{min-height:118px;border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:18px;font-size:13px;color:var(--ink-soft);line-height:1.45;margin:12px 0 20px}.style-row,.size-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:12px}.style-chip{height:68px;border-radius:5px;border:1px solid var(--line);background-size:cover;background-position:center}.size-row{display:flex;margin-top:20px}.size-box{width:62px;height:42px;border:1px solid var(--line);border-radius:6px;display:grid;place-items:center;font-size:12px;font-weight:600}.result-preview{height:280px;border-radius:5px;object-fit:cover;width:100%;border:1px solid var(--line);box-shadow:var(--shadow-md);filter:saturate(1.03) contrast(1.02)}.research-page{max-width:780px;margin:0 auto;padding-top:26px}.research-body{margin-top:42px}.visual-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:34px;align-items:start}.visual-hero-image{width:100%;border-radius:6px;border:1px solid var(--line);box-shadow:var(--shadow-md)}.file-screen{min-height:620px;display:grid;grid-template-columns:168px minmax(0,1fr);border:1px solid var(--line-strong);border-radius:14px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-lg)}.file-rail{border-right:1px solid var(--line-strong);padding:25px 18px;background:var(--paper)}.file-rail .section-label{margin-bottom:20px;color:var(--ink);font-size:10px}.rail-item{min-height:34px;display:flex;align-items:center;border-radius:6px;padding:0 10px;margin-bottom:7px;color:var(--muted);font-size:11px;font-weight:600;transition:transform .32s var(--ease-out),background .32s var(--ease-out),color .32s var(--ease-out)}.rail-item:hover{transform:translate(2px);background:#1c191708}.rail-item.active{background:var(--paper-deep);color:var(--ink)}.rail-note,.research-margin-note{margin-top:92px;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:13px;color:var(--muted);font-size:11px;line-height:1.5}.rail-note strong,.rail-note span{display:block}.rail-note strong{margin-bottom:10px;font-family:var(--mono);color:var(--ink)}.rail-button{margin-top:230px;justify-content:center}.file-main{min-width:0;padding:31px 34px 34px}.file-topline{display:flex;align-items:start;justify-content:space-between;gap:24px;margin-bottom:24px}.file-title{margin:0;font-family:var(--editorial);font-size:clamp(1.55rem,2.4vw,2.25rem);line-height:1.05;font-weight:500;letter-spacing:-.035em;text-wrap:balance}.file-subtitle{margin:9px 0 0;color:var(--muted);font-size:12px;line-height:1.5}.file-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.ui-panel{border:1px solid var(--line);border-radius:9px;background:var(--surface);box-shadow:var(--shadow-sm);padding:17px;position:relative;min-width:0}.panel-index{display:block;margin-bottom:11px;color:var(--ink);font-size:11px;font-weight:600;font-family:var(--mono);letter-spacing:.01em}.ui-panel h2{margin:0 0 10px;font-size:15px;line-height:1.36;letter-spacing:-.02em;text-wrap:balance}.ui-panel p,.ui-panel li,.ui-panel td,.ui-panel th{color:var(--ink-soft);font-size:11.5px;line-height:1.55}.ui-panel table{width:100%;border-collapse:collapse}.ui-panel th,.ui-panel td{border-bottom:1px solid var(--line);padding:8px 7px;text-align:left}.ui-panel th{background:var(--paper-deep);font-weight:600}.case-dashboard{display:grid;grid-template-columns:1.18fr 1.18fr .78fr;gap:14px;grid-template-areas:"goal metrics metrics" "friction friction hypothesis" "flow flow evidence" "iteration result evidence"}.goal-panel{grid-area:goal}.metrics-panel{grid-area:metrics}.table-panel{overflow-x:auto}.friction-panel{grid-area:friction}.hypothesis-panel{grid-area:hypothesis}.flow-panel{grid-area:flow}.iteration-panel{grid-area:iteration}.result-panel-card{grid-area:result}.evidence-panel{grid-area:evidence}.metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric-strip div{min-height:76px;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--paper)}.metric-strip strong{display:block;margin-bottom:7px;font-size:20px;letter-spacing:-.05em}.metric-strip span{color:var(--muted);font-size:10.5px;line-height:1.35}.paper-sticky{width:126px;margin:18px 0 0 auto;padding:16px 14px;background:var(--sand-pill);box-shadow:var(--shadow-md);transform:rotate(-4deg);font-family:var(--hand);font-size:15px;line-height:1.1}.flow-steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;align-items:center}.flow-steps span{min-height:58px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;padding:8px;text-align:center;font-size:11px;font-weight:600;background:var(--paper)}.flow-steps i{display:none}.mini-chart{height:78px;display:flex;align-items:end;gap:12px;margin:9px 0 14px;padding:12px;border-bottom:1px solid var(--line-strong)}.mini-chart span{width:28px;background:#4d8b5a40;border:1px solid rgba(77,139,90,.15)}.evidence-panel ul,.ai-assist ul{margin:0;padding-left:18px}.workbench-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:16px;grid-template-areas:"prompt result" "style result" "settings result" "mood recent"}.prompt-panel{grid-area:prompt}.style-panel{grid-area:style}.settings-panel{grid-area:settings}.generation-panel{grid-area:result}.moodboard-panel{grid-area:mood}.recent-panel{grid-area:recent}.prompt-box{min-height:110px;border:1px solid var(--line);border-radius:8px;padding:15px;background:var(--paper);color:var(--ink-soft);font-size:13px;line-height:1.55}.counter{display:block;margin-top:8px;color:var(--faint);font-family:var(--mono);font-size:10px}.style-picker{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.style-card{border:1px solid var(--line);border-radius:8px;padding:5px;background:var(--surface);transition:transform .36s var(--ease-out),border-color .36s var(--ease-out),box-shadow .36s var(--ease-out)}.style-card:hover{transform:translateY(-2px);border-color:var(--line-strong)}.style-card.selected{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink)}.style-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;filter:saturate(1.04) contrast(1.02)}.style-card span{display:block;margin-top:6px;font-size:10px;text-align:center;color:var(--muted)}.setting-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.setting-grid label{display:block;border:1px solid var(--line);border-radius:8px;padding:10px;background:var(--surface)}.setting-grid span,.setting-grid strong{display:block}.setting-grid span{margin-bottom:7px;color:var(--faint);font-size:10px}.setting-grid strong{font-size:12px}.slider-line{margin-top:17px;height:1px;background:var(--line-strong)}.slider-line span{display:block;width:58%;height:1px;background:var(--ink)}.generation-preview{width:100%;height:390px;object-fit:cover;border-radius:5px;border:1px solid var(--line);box-shadow:var(--shadow-md);filter:saturate(1.04) contrast(1.02)}.result-actions{display:flex;justify-content:space-between;margin-top:13px}.thumb-strip{display:flex;gap:10px;align-items:center;overflow-x:auto}.thumb-strip img,.add-tile{flex:0 0 76px;width:76px;height:56px;border-radius:4px;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow-sm)}.add-tile{display:grid;place-items:center;color:var(--faint);font-size:11px;background:var(--paper)}.image-map-grid{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);gap:16px;grid-template-areas:"map collection" "map collection" "series notes"}.image-map-panel{grid-area:map}.collection-panel{grid-area:collection}.series-panel{grid-area:series}.notes-panel{grid-area:notes}.image-map-canvas{position:relative;min-height:560px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:radial-gradient(circle at 50% 43%,rgba(255,255,255,.6),transparent 28%),var(--paper)}.map-fragment{position:absolute;margin:0;width:78px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}.map-fragment img{width:100%;aspect-ratio:1;object-fit:cover;filter:saturate(1.04) contrast(1.02)}.fragment-1{left:8%;top:8%;width:126px}.fragment-2{left:37%;top:6%;width:74px}.fragment-3{right:10%;top:12%;width:96px}.fragment-4{left:18%;top:28%;width:88px}.fragment-5{right:31%;top:29%;width:82px}.fragment-6{left:7%;bottom:25%;width:106px}.fragment-7{left:39%;bottom:31%;width:130px}.fragment-8{right:8%;bottom:27%;width:86px}.fragment-9{left:23%;bottom:8%;width:98px}.fragment-10{right:24%;bottom:7%;width:128px}.fragment-11{right:8%;top:46%;width:72px}.map-type{position:absolute;font-family:var(--typewriter);color:var(--ink-soft);font-size:15px;line-height:1.2;font-weight:500;letter-spacing:-.02em}.type-one{left:33%;top:42%}.type-two{right:11%;bottom:16%;max-width:170px}.collection-masonry{columns:2 140px;column-gap:12px}.collection-item{break-inside:avoid;margin:0 0 12px;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm)}.collection-item img{width:100%;object-fit:cover;filter:saturate(1.04) contrast(1.02)}.collection-item.square img{aspect-ratio:1}.collection-item.tall img{aspect-ratio:.75}.collection-item.wide img{aspect-ratio:1.45}.collection-item figcaption{padding:7px 8px 8px;color:var(--muted);font-family:var(--mono);font-size:10px;line-height:1.2}.series-list{display:flex;flex-wrap:wrap;gap:9px}.series-list span{border:1px solid var(--line);border-radius:999px;padding:8px 11px;background:var(--surface);color:var(--muted);font-family:var(--mono);font-size:10px;font-weight:600}.notes-panel p{margin:0;color:var(--ink-soft);font-size:12px;line-height:1.8;text-wrap:pretty}.dossier-screen{background:var(--surface)}.quiet-rail{background:var(--paper)}.research-margin-note{transform:rotate(-4deg);font-family:var(--typewriter);background:var(--sand-pill);box-shadow:var(--shadow-sm)}.dossier-grid{display:grid;grid-template-columns:.9fr 1.1fr 1fr;gap:16px;grid-template-areas:"question assist assist" "notes validation validation" "outputs outputs evidence"}.research-question{grid-area:question;min-height:160px}.ai-assist{grid-area:assist}.iteration-notes{grid-area:notes}.validation-panel{grid-area:validation}.outputs-panel{grid-area:outputs}.evidence-tags{grid-area:evidence}.research-question p{font-family:var(--typewriter);color:var(--ink);line-height:1.7}.research-question strong{position:absolute;right:20px;bottom:20px;color:var(--red);font-family:var(--hand);font-size:38px;font-weight:500}.validation-columns{display:grid;grid-template-columns:.8fr 1fr 150px;gap:14px;align-items:stretch}.validation-columns div:not(.radar){border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--paper)}.validation-columns strong,.validation-columns span{display:block}.validation-columns strong{margin-bottom:9px;font-size:12px}.validation-columns span{margin-top:7px;color:var(--muted);font-size:11px}.radar{display:grid;place-items:center}.radar i{width:112px;height:112px;display:block;background:linear-gradient(45deg,transparent 49%,var(--line-strong) 50%,transparent 51%),linear-gradient(-45deg,transparent 49%,var(--line-strong) 50%,transparent 51%),radial-gradient(circle,rgba(77,139,90,.06) 0 36%,transparent 37%),radial-gradient(circle,transparent 0 54%,var(--line-strong) 55% 56%,transparent 57%);border:1px solid var(--line-strong);transform:rotate(45deg)}.download-list{display:grid;gap:9px}.download-list span{display:flex;justify-content:space-between;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:var(--paper);font-size:12px}.download-list em{color:var(--faint);font-style:normal;font-family:var(--mono)}.tag-cloud{display:flex;flex-wrap:wrap;gap:9px}.tag-cloud span{padding:8px 11px;border-radius:6px;background:var(--paper-deep);color:var(--muted);font-size:11px}.project-gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.gallery-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .65s var(--ease-out),box-shadow .65s var(--ease-out)}.gallery-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.gallery-card img{width:100%;height:165px;object-fit:cover;filter:saturate(1.04) contrast(1.02)}.gallery-card-body{padding:17px}.gallery-card-title{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:9px}.gallery-card h2{margin:0;font-size:15px;line-height:1.25;letter-spacing:-.02em;text-wrap:balance}.gallery-card-title span{border:1px solid var(--line);border-radius:4px;padding:3px 7px;color:var(--muted);font-size:10px;white-space:nowrap}.gallery-card p{min-height:55px;margin:0 0 15px;color:var(--muted);font-size:12px;line-height:1.55;text-wrap:pretty}.gallery-card strong{font-size:11px}.gallery-page{padding-top:8px}.gallery-head{margin-bottom:32px}.gallery-subtitle{margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.5}.masonry-wall{columns:4 220px;column-gap:16px}.masonry-item{break-inside:avoid;margin:0 0 16px;border-radius:8px;overflow:hidden;position:relative;background:var(--surface);cursor:pointer;transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out)}.masonry-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.masonry-item img{width:100%;display:block;filter:saturate(1.03) contrast(1.02)}.masonry-item.square img{aspect-ratio:1;object-fit:cover}.masonry-item.tall img{aspect-ratio:.7;object-fit:cover}.masonry-item.wide img{aspect-ratio:1.5;object-fit:cover}.masonry-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:24px 12px 10px;background:linear-gradient(to top,rgba(28,25,23,.5),transparent);color:#fff;font-family:var(--mono);font-size:11px;font-weight:500;opacity:0;transition:opacity .4s var(--ease-out)}.masonry-item:hover figcaption{opacity:1}.gallery-note{margin:40px 0 0;max-width:560px;color:var(--muted);font-family:var(--zh-kai);font-size:13px;line-height:1.8;font-style:italic}.research-page-new{padding-top:8px;max-width:900px}.research-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.research-wide{grid-column:1 / -1}.research-question-text{font-family:var(--zh-kai);font-size:15px;line-height:1.7;color:var(--ink);margin:0}.research-list{margin:0;padding-left:18px}.research-validation{display:grid;grid-template-columns:1fr 1fr;gap:14px}.research-validation div{border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--paper)}.research-validation strong,.research-validation span{display:block}.research-validation strong{margin-bottom:9px;font-size:12px}.research-validation span{margin-top:7px;color:var(--muted);font-size:11px}.research-aside{margin-top:36px;padding:16px 20px;background:var(--sand-pill);border-radius:8px;max-width:380px;transform:rotate(-1deg)}.research-aside p{margin:0;font-family:var(--typewriter);font-size:13px;color:var(--ink-soft)}.experience-detail{padding-top:8px;max-width:960px}.experience-detail-head{margin-bottom:32px}.experience-detail-head h1{margin:12px 0 0;font-family:var(--display);font-size:clamp(1.5rem,2.4vw,2.2rem);font-weight:500;letter-spacing:-.03em}.experience-meta{display:flex;gap:16px;margin-top:10px;font-family:var(--mono);font-size:12px;color:var(--muted)}.experience-meta span{display:flex;align-items:center}.experience-meta span+span:before{content:"·";margin-right:16px}.back-link{font-family:var(--mono);font-size:12px;color:var(--muted);transition:color .3s var(--ease-out)}.back-link:hover{color:var(--ink)}.experience-content{margin-top:32px;max-width:700px}.experience-content p{color:var(--ink-soft);font-size:14px;line-height:1.82}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-up .6s cubic-bezier(.16,1,.3,1) both}.works-grid>*,.build-grid>*,.projects-grid>*,.masonry-item,.research-block,.research-method,.ui-panel,.project-card{opacity:0;animation:fade-up .6s cubic-bezier(.16,1,.3,1) both}.works-grid>*:nth-child(1),.build-grid>*:nth-child(1),.projects-grid>*:nth-child(1){animation-delay:80ms}.works-grid>*:nth-child(2),.build-grid>*:nth-child(2),.projects-grid>*:nth-child(2){animation-delay:.16s}.works-grid>*:nth-child(3),.build-grid>*:nth-child(3),.projects-grid>*:nth-child(3){animation-delay:.24s}.works-grid>*:nth-child(4),.build-grid>*:nth-child(4),.projects-grid>*:nth-child(4){animation-delay:.32s}.works-grid>*:nth-child(5),.build-grid>*:nth-child(5),.projects-grid>*:nth-child(5){animation-delay:.4s}.masonry-item:nth-child(1){animation-delay:60ms}.masonry-item:nth-child(2){animation-delay:.12s}.masonry-item:nth-child(3){animation-delay:.18s}.masonry-item:nth-child(4){animation-delay:.24s}.masonry-item:nth-child(5){animation-delay:.3s}.masonry-item:nth-child(6){animation-delay:.36s}.masonry-item:nth-child(7){animation-delay:.42s}.masonry-item:nth-child(8){animation-delay:.48s}.masonry-item:nth-child(9){animation-delay:.54s}.masonry-item:nth-child(10){animation-delay:.6s}.masonry-item:nth-child(11){animation-delay:.66s}.research-block:nth-child(1){animation-delay:.1s}.research-block:nth-child(2){animation-delay:.2s}.research-block:nth-child(3){animation-delay:.3s}.research-method:nth-child(1){animation-delay:.15s}.research-method:nth-child(2){animation-delay:.25s}.research-method:nth-child(3){animation-delay:.35s}.research-method:nth-child(4){animation-delay:.45s}.ui-panel:nth-child(1){animation-delay:80ms}.ui-panel:nth-child(2){animation-delay:.16s}.ui-panel:nth-child(3){animation-delay:.24s}.ui-panel:nth-child(4){animation-delay:.32s}.ui-panel:nth-child(5){animation-delay:.4s}.ui-panel:nth-child(6){animation-delay:.48s}.ui-panel:nth-child(7){animation-delay:.56s}.ui-panel:nth-child(8){animation-delay:.64s}.build-card:active,.project-card:active,.project-tile:active,.masonry-item:active,.gallery-card:active{transform:translateY(-1px) scale(.98)}.rail-item:active,.filter-pill:active,.light-btn:active,.dark-btn:active,.micro-link:active,.projects-archive-link:active,.about-link:active{transform:scale(.97)}.works-grid{grid-template-columns:1.15fr .85fr 1fr 1fr}.research-story{max-width:680px}.research-block{margin-bottom:40px}.research-block h2{font-family:var(--display);font-size:20px;font-weight:400;letter-spacing:-.02em;margin:0 0 14px}.research-block p{color:var(--ink-soft);font-size:14px;line-height:1.82;margin:0 0 12px}.research-block strong{color:var(--ink)}.research-method-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.research-method{border:1px solid var(--line);border-radius:10px;padding:16px;background:var(--surface)}.research-method strong{display:block;font-size:13px;margin-bottom:8px}.research-method p{margin:0;font-size:12px;line-height:1.65;color:var(--muted)}.about-links{display:flex;gap:16px;margin-top:24px}.about-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink);padding-bottom:2px;border-bottom:1px solid var(--line-strong);transition:color .3s var(--ease-out),border-color .3s var(--ease-out)}.about-link:hover{color:var(--red);border-color:var(--red)}.projects-page{padding-top:8px}.projects-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}.projects-title{margin:0;font-family:var(--display);font-size:clamp(1.75rem,2.8vw,2.5rem);font-weight:600;letter-spacing:-.03em}.projects-archive-link{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--muted);transition:color .3s var(--ease-out)}.projects-archive-link:hover{color:var(--ink)}.projects-filters{display:flex;gap:10px;margin-bottom:28px}.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.project-card{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .6s var(--ease-out),box-shadow .6s var(--ease-out);display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.project-card-image{overflow:hidden}.project-card-image img{width:100%;height:180px;object-fit:cover;filter:saturate(1.03) contrast(1.02);transition:transform .6s var(--ease-out)}.project-card:hover .project-card-image img{transform:scale(1.03)}.project-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}.project-card-body h2{margin:0 0 4px;font-size:16px;font-weight:600;letter-spacing:-.02em;line-height:1.25}.project-card-category{font-family:var(--mono);font-size:11px;color:var(--muted);margin-bottom:10px}.project-card-body p{margin:0;color:var(--ink-soft);font-size:13px;line-height:1.55;flex:1}.project-card-action{margin-top:16px;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--ink);transition:color .3s var(--ease-out)}.project-card:hover .project-card-action{color:var(--red)}@media(max-width:980px){.page-shell{padding:26px 22px 28px}.site-header{grid-template-columns:auto 1fr;gap:16px}.nav-links{justify-content:flex-end;gap:18px}.contact-btn{grid-column:2;justify-self:end;height:40px}.hero,.case-grid,.tool-layout,.visual-detail-grid,.file-screen{grid-template-columns:1fr}.file-rail{border-right:0;border-bottom:1px solid var(--line-strong);display:flex;align-items:center;gap:8px;overflow-x:auto}.file-rail .section-label,.rail-note,.research-margin-note,.rail-button{display:none}.rail-item{flex:0 0 auto;margin:0}.case-dashboard,.workbench-grid,.image-map-grid,.dossier-grid{grid-template-columns:1fr 1fr;grid-template-areas:none}.case-dashboard>*,.workbench-grid>*,.image-map-grid>*,.dossier-grid>*{grid-area:auto}.collage{min-height:360px}.works-grid,.build-grid,.project-list,.visual-grid,.project-gallery-grid,.projects-grid,.research-grid,.research-method-list{grid-template-columns:repeat(2,minmax(0,1fr))}.research-wide{grid-column:1 / -1}.tool-rail{display:none}}@media(max-width:640px){.page-shell{padding:22px 16px 26px}.site-header{grid-template-columns:1fr auto}.nav-links{order:3;grid-column:1 / -1;justify-content:space-between;gap:8px;overflow-x:auto;padding-bottom:4px}.contact-btn{grid-column:auto;height:38px;padding:0 14px}.collage{min-height:300px;transform:none}.photo.flower{left:0;top:32px;width:96px;height:88px}.photo.blur{left:18%;top:108px;width:124px;height:124px}.photo.sky{left:44%;top:0;width:104px;height:152px}.photo.land{right:15%;top:150px;width:80px;height:58px}.photo.bag{right:0;top:78px;width:82px;height:70px}.photo.coffee{right:28%;bottom:18px;width:74px;height:68px}.photo.texture{right:0;bottom:18px;width:78px;height:68px}.hand-note{right:2%;top:16px;font-size:15px}.works-grid,.build-grid,.project-list,.visual-grid,.workspace-grid,.metric-grid,.case-dashboard,.workbench-grid,.image-map-grid,.dossier-grid,.project-gallery-grid,.projects-grid,.research-grid,.research-validation,.research-method-list,.metric-strip,.style-picker,.setting-grid,.validation-columns{grid-template-columns:1fr}.research-wide{grid-column:auto}.masonry-wall{columns:2}.file-main{padding:24px 18px}.file-topline{display:block}.file-actions{justify-content:flex-start;margin-top:16px}.flow-steps{grid-template-columns:1fr}.generation-preview{height:300px}.image-map-canvas{min-height:460px}.map-fragment{width:64px}.fragment-1{width:100px}.fragment-7,.fragment-10{width:108px}.collection-masonry{columns:1}.work-image{height:190px}.build-card{height:auto;min-height:118px}.more-projects,.scribble-link{justify-content:flex-start;justify-self:start;padding-right:0}}
