:root{--paper: #eef0e4;--paper-2: #e3e7d3;--paper-edge: #cfd6b9;--moss: #dde5c8;--ink: #15170f;--ink-soft: #3b4232;--ink-mute: #7e8670;--rule: #c7d0ad;--shu: oklch(.56 .18 30);--moss-green: oklch(.52 .09 135);--highlight: oklch(.9 .11 125);--status-active: var(--moss-green);--status-shipped: var(--shu);--status-sunset: oklch(.55 .04 60);--f-display: "Shippori Mincho", "Newsreader", Georgia, serif;--f-body: "Newsreader", Georgia, serif;--f-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--f-jp: "Shippori Mincho", "Yu Mincho", serif;--pad-section: 9rem;--pad-inline: clamp(1.5rem, 6vw, 6rem);--max: 82.5rem;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--color-bg: var(--paper);--color-bg-subtle: var(--paper-2);--color-bg-muted: var(--moss);--color-border: var(--rule);--color-text: var(--ink);--color-text-secondary: var(--ink-soft);--color-text-tertiary: var(--ink-mute);--color-accent: var(--shu);--radius-sm: .25rem;--radius-lg: .5rem;--shadow-md: 0 .75rem 2rem rgba(21, 23, 15, .08);--shadow-lg: 0 1.25rem 3rem rgba(21, 23, 15, .12);--p: .56 .18 30;--s: .52 .09 135;--a: .56 .18 30;--b1: .94 .02 115;--b2: .9 .04 115;--b3: .84 .04 115;--bc: .18 .03 120}[data-theme=dark]{--paper: #11140e;--paper-2: #181c14;--paper-edge: #222719;--moss: #1c2017;--ink: #ebefd8;--ink-soft: #c8d1ac;--ink-mute: #888f73;--rule: #2c3322;--shu: oklch(.68 .16 30);--moss-green: oklch(.65 .08 135);--highlight: oklch(.55 .1 125);--status-sunset: oklch(.62 .04 60);--p: .68 .16 30;--s: .65 .08 135;--a: .68 .16 30;--b1: .18 .03 120;--b2: .22 .03 120;--b3: .26 .03 120;--bc: .9 .04 115}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1,"liga" 1}body{font-family:var(--f-body);color:var(--ink);background:var(--paper);font-size:18px;line-height:1.65;overflow-x:hidden;transition:background .5s ease,color .5s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;opacity:.14;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='320' height='320'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.20 0 0 0 0 0.16 0 0 0 0 0.10 0 0 0 0.10 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}[data-theme=dark] body:before{mix-blend-mode:screen;opacity:.08}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{color:inherit}img{display:block;max-width:100%;height:auto}::selection{background:var(--highlight);color:var(--ink)}:focus-visible{outline:2px solid var(--shu);outline-offset:3px;border-radius:.25rem}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--paper)}main{flex:1;position:relative;z-index:2}.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.375rem var(--pad-inline);background:linear-gradient(to bottom,color-mix(in oklch,var(--paper) 94%,transparent) 0%,color-mix(in oklch,var(--paper) 68%,transparent) 74%,transparent 100%);pointer-events:none}.nav>*{pointer-events:auto}.wordmark{display:inline-flex;align-items:baseline;gap:.5rem;font-family:var(--f-display);font-size:1.125rem;white-space:nowrap}.wordmark .kanji{font-family:var(--f-jp);font-size:1.375rem;color:var(--shu);line-height:1}.wordmark .name{color:var(--ink);font-weight:500}.wordmark em{font-family:var(--f-body);font-size:.875rem;font-style:italic;font-weight:400;color:var(--ink-mute)}.nav-right{display:flex;align-items:center;gap:clamp(.625rem,1.35vw,1.45rem)}.nav-right>a:not(.icon-link){min-height:2.25rem;display:inline-flex;align-items:center;font-family:var(--f-mono);font-size:.6875rem;text-transform:uppercase;color:var(--ink-soft);position:relative;padding:0 .625rem;border:1px solid transparent;border-radius:999px;transition:background .2s,border-color .2s,color .2s,transform .2s}.nav-right>a:not(.icon-link):hover{background:color-mix(in oklch,var(--paper-2) 52%,transparent);border-color:color-mix(in oklch,var(--rule) 84%,transparent);color:var(--ink);transform:translateY(-1px)}.nav-right>a:not(.icon-link):after{display:none}.nav-right>a:not(.icon-link):hover:after{display:none}.icon-link{min-width:2.75rem;min-height:2.75rem;width:2.75rem;height:2.75rem;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft);border:1px solid transparent;border-radius:999px;transition:background .2s,border-color .2s,color .2s,transform .2s}.icon-link:hover{background:color-mix(in oklch,var(--paper-2) 52%,transparent);border-color:color-mix(in oklch,var(--rule) 84%,transparent);color:var(--ink);transform:translateY(-1px)}.icon-link svg{width:1rem;height:1rem}.theme-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;border-radius:999px;background:transparent;min-width:2.75rem;min-height:2.75rem;width:2.75rem;height:2.75rem;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft);cursor:pointer;font-size:.875rem;transition:background .2s,border-color .2s,color .2s,transform .3s}.theme-toggle:hover{background:color-mix(in oklch,var(--paper-2) 52%,transparent);border-color:color-mix(in oklch,var(--rule) 84%,transparent);color:var(--ink);transform:translateY(-1px) rotate(15deg)}.lang-toggle{display:inline-flex;align-items:center;gap:.375rem;min-height:2.75rem;font-family:var(--f-mono);font-size:.6875rem;color:var(--ink-mute);padding:.25rem .625rem;border:1px solid var(--rule);border-radius:999px;transition:border-color .25s,color .25s,background .25s}.lang-toggle:hover{border-color:var(--moss-green);background:color-mix(in oklch,var(--paper-2) 46%,transparent);color:var(--ink)}.lang-toggle a{color:var(--ink-mute);padding:.625rem .25rem;border-radius:999px;transition:background .2s,color .2s}.lang-toggle a:hover{background:color-mix(in oklch,var(--paper) 72%,transparent)}.lang-toggle a.active{color:var(--ink);font-weight:500}.lang-toggle span{color:var(--rule)}.hero{position:relative;min-height:100vh;padding:6.25rem var(--pad-inline) 6rem;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(18rem,1fr);grid-template-rows:1fr auto;gap:3rem 5rem;max-width:var(--max);margin:0 auto;overflow:hidden}.hero-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;cursor:crosshair}.hero-content{position:relative;z-index:2;align-self:end;padding:.75rem 1rem;margin-left:-1rem;pointer-events:none;background:radial-gradient(ellipse at 30% 70%,color-mix(in oklch,var(--paper) 92%,transparent) 0%,color-mix(in oklch,var(--paper) 80%,transparent) 55%,transparent 100%)}.hero-content>*{pointer-events:auto}.hero-side{position:relative;z-index:2;align-self:end;display:flex;flex-direction:column;gap:1.75rem;max-width:38ch;padding:1rem 1.125rem;font-size:1rem;color:var(--ink-soft);line-height:1.7;background:radial-gradient(ellipse at 70% 50%,color-mix(in oklch,var(--paper) 92%,transparent) 0%,color-mix(in oklch,var(--paper) 78%,transparent) 60%,transparent 100%)}.season-mark{position:absolute;top:6.875rem;left:var(--pad-inline);z-index:3;font-family:var(--f-jp);font-size:.875rem;color:var(--ink-mute);pointer-events:none}.season-mark .stamp{display:inline-block;margin-right:.5rem;padding:.1875rem .375rem .25rem;background:var(--shu);color:var(--paper);font-size:.6875rem;font-family:var(--f-jp)}.vert-mark{position:absolute;top:6.875rem;right:var(--pad-inline);z-index:3;writing-mode:vertical-rl;font-family:var(--f-jp);font-size:.8125rem;color:var(--ink-mute);pointer-events:none}.hero h1{max-width:16ch;margin:0 0 .4em;font-family:var(--f-display);font-size:6rem;font-weight:400;line-height:1.05;color:var(--ink)}.hero h1 .ital{font-style:italic;color:var(--ink-soft)}.hero h1 .seal{display:inline-block;margin-left:.15em;padding:.2em .35em;background:var(--shu);color:var(--paper);font-family:var(--f-jp);font-size:.32em;vertical-align:.4em;border-radius:1px}.hero h1.h1-ja{max-width:14ch;font-family:var(--f-jp);font-size:5.375rem;line-height:1.18}.hero-tagline{max-width:38ch;margin:0;font-family:var(--f-body);font-size:1.25rem;line-height:1.6;color:var(--ink-soft);text-wrap:pretty}.hero-side p{margin:0;text-wrap:pretty}.hero-side p strong{color:var(--ink);font-weight:inherit;background:linear-gradient(180deg,transparent 65%,color-mix(in oklch,var(--moss-green) 35%,var(--highlight)) 65%);padding:0 .125rem}.now-pill{display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;font-family:var(--f-mono);font-size:.6875rem;text-transform:uppercase;color:var(--shu);border:1px solid var(--shu);padding:.375rem .75rem;border-radius:999px}.now-pill:before{content:"";width:.375rem;height:.375rem;border-radius:50%;background:var(--shu);animation:pulse 2.4s infinite}.hero-meta{display:grid;grid-template-columns:auto 1fr;gap:.25rem 1rem;border-top:1px solid var(--rule);padding-top:1.125rem;font-family:var(--f-mono);font-size:.6875rem;text-transform:uppercase;color:var(--ink-mute)}.hero-meta dt{color:var(--ink);font-weight:500}.hero-meta dd{margin:0;color:var(--ink-soft)}.scroll-cue{position:absolute;bottom:2rem;left:50%;z-index:3;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-family:var(--f-jp);font-size:.6875rem;color:var(--ink-mute);pointer-events:none}.scroll-cue .line{width:1px;height:2rem;background:var(--ink-mute);animation:lineDraw 2.4s ease-in-out infinite;transform-origin:top}.section{position:relative;max-width:var(--max);margin:0 auto;padding:var(--pad-section) var(--pad-inline)}.sec-head{position:relative;display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:baseline;margin-bottom:4rem}.sec-head:after{content:"";position:absolute;left:0;right:0;bottom:-1.5rem;height:1px;background:linear-gradient(to right,transparent,color-mix(in oklch,var(--moss-green) 50%,transparent),transparent);opacity:.35}.sec-head .num-vert{font-family:var(--f-jp);font-size:.8125rem;color:var(--ink-mute)}.sec-head h2{margin:0;font-family:var(--f-display);font-size:3rem;font-weight:400;line-height:1.08;color:var(--ink)}.sec-head h2 em{font-style:italic;color:var(--ink-mute)}.proj-filter{position:relative;z-index:4;display:flex;flex-wrap:wrap;gap:.5rem;margin:-2.25rem 0 3rem}.proj-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;min-height:2.75rem;font-family:var(--f-mono);font-size:.6875rem;text-transform:uppercase;color:var(--ink-mute);padding:.4375rem .75rem .4375rem .625rem;border:1px solid var(--rule);border-radius:999px;background:color-mix(in oklch,var(--paper-2) 50%,transparent);transition:border-color .2s,color .2s,background .2s}.proj-chip:hover{color:var(--ink);border-color:var(--ink-mute)}.proj-chip .dot{width:.4375rem;height:.4375rem;border-radius:50%;background:var(--ink-mute)}.proj-chip.status-active .dot{background:var(--status-active)}.proj-chip.status-shipped .dot{background:var(--status-shipped)}.proj-chip.status-sunset .dot{background:var(--status-sunset)}.proj-chip .count{font-size:.625rem;color:var(--ink-mute);background:color-mix(in oklch,var(--paper) 60%,transparent);padding:.0625rem .375rem;border-radius:999px}.proj-chip.is-on{background:var(--paper);color:var(--ink);border-color:var(--ink)}.proj-chip.is-on .count{color:var(--ink)}.scrap{position:relative;min-height:75rem}.scrap-piece{position:absolute;display:block;transition:transform .5s cubic-bezier(.2,.8,.3,1.05)}.scrap-piece:hover{transform:rotate(0) translateY(-4px)!important;z-index:12!important}.scrap-piece .frame{position:relative;background:var(--paper-2);border:1px solid var(--rule);padding:1rem 1rem 1.375rem;box-shadow:0 .75rem 2rem #15170f0d}[data-theme=dark] .scrap-piece .frame{box-shadow:0 .75rem 2rem #00000073}.scrap-piece .thumb{aspect-ratio:4 / 3;background:repeating-linear-gradient(135deg,var(--paper-edge) 0 5px,var(--paper-2) 5px 10px);border:1px solid var(--rule);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;position:relative;overflow:hidden}.project-logo{width:clamp(6.25rem,34%,9.25rem);height:clamp(6.25rem,34%,9.25rem);object-fit:contain;filter:drop-shadow(0 .5rem 1rem rgba(21,23,15,.1))}.scrap-piece .thumb-label{font-family:var(--f-mono);font-size:.625rem;color:var(--ink-mute);text-transform:uppercase}.status-pill{position:absolute;top:.625rem;left:.625rem;display:inline-flex;align-items:center;gap:.375rem;font-family:var(--f-mono);font-size:.5625rem;text-transform:uppercase;background:color-mix(in oklch,var(--paper) 88%,transparent);border:1px solid var(--rule);padding:.1875rem .5rem .1875rem .375rem;border-radius:999px;color:var(--ink-soft);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.status-pill .dot{width:.375rem;height:.375rem;border-radius:50%}.status-pill.status-active .dot{background:var(--status-active);animation:pulseDot 2.4s infinite}.status-pill.status-shipped .dot{background:var(--status-shipped)}.status-pill.status-sunset .dot{background:var(--status-sunset)}.scrap-piece h3{margin:1rem 0 .375rem;font-family:var(--f-display);font-weight:400;font-size:1.375rem;line-height:1.2}.scrap-piece h3 em{font-style:italic;color:var(--ink-mute);font-size:.82em}.scrap-piece p.summary{margin:0;font-size:.875rem;color:var(--ink-soft);line-height:1.55}.scrap-piece .meta{display:flex;justify-content:space-between;gap:1rem;margin-top:.875rem;padding-top:.625rem;border-top:1px dashed var(--rule);font-family:var(--f-mono);font-size:.625rem;color:var(--ink-mute);text-transform:uppercase}.scrap-piece .read-more{display:inline-flex;margin-top:.875rem;font-family:var(--f-mono);font-size:.6875rem;color:var(--shu);text-transform:uppercase}.scrap-piece.status-sunset .frame{background:color-mix(in oklch,var(--paper-2) 80%,oklch(.85 .05 70))}.scrap-piece.status-sunset h3,.scrap-piece.status-sunset h3 em,.scrap-piece.status-sunset .summary{color:var(--ink-mute)}.scrap-piece.status-sunset .thumb{filter:saturate(.6);opacity:.8}.writing-head{padding-bottom:3rem}.dual-blog{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}.dual-blog>div{position:relative;padding:4rem var(--pad-inline)}.dual-blog>div+div{border-left:1px solid var(--rule)}.blog-col-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:2.25rem;padding-bottom:1rem;border-bottom:1px solid var(--rule)}.blog-col-head h3{margin:0;font-size:1.75rem;font-weight:400}.blog-col-head .col-jp{font-family:var(--f-jp);font-size:.8125rem;color:var(--ink-mute)}.col-guides .blog-col-head h3{font-family:var(--f-mono);font-size:.875rem}.col-guides .post{display:block;border-bottom:1px dashed var(--rule);padding:1.125rem 0;cursor:pointer;transition:padding .3s ease,background .25s}.col-guides .post:last-child{border-bottom:0}.col-guides .post:hover{background:color-mix(in oklch,var(--paper-2) 60%,transparent);padding-left:.875rem;padding-right:.875rem}.col-guides .post-meta{display:flex;flex-wrap:wrap;gap:.875rem;margin-bottom:.5rem;font-family:var(--f-mono);font-size:.625rem;color:var(--ink-mute);text-transform:uppercase}.col-guides .post-meta .tag{background:var(--paper-2);padding:.125rem .5rem;border-radius:2px;border:1px solid var(--rule);color:var(--shu)}.col-guides .post h4{margin:0 0 .375rem;font-family:var(--f-mono);font-weight:500;font-size:.9375rem;line-height:1.4;color:var(--ink)}.col-guides .post p{margin:0;font-family:var(--f-mono);font-size:.75rem;color:var(--ink-soft);line-height:1.6}.col-guides .prompt-snippet{margin-top:.625rem;padding:.375rem .625rem;background:var(--paper-2);border-left:2px solid var(--shu);font-family:var(--f-mono);font-size:.6875rem;color:var(--ink-soft);white-space:pre-wrap}.col-philo .post-list{display:flex;flex-direction:column;gap:2.25rem}[data-philo=journal] .col-philo .post{position:relative;padding-left:1.75rem;cursor:pointer}[data-philo=journal] .col-philo .post:before{content:"";position:absolute;left:0;top:.875rem;width:.75rem;height:1px;background:var(--shu)}[data-philo=journal] .col-philo .post-meta{margin-bottom:.375rem;font-family:var(--f-body);font-style:italic;font-size:.8125rem;color:var(--ink-mute)}[data-philo=journal] .col-philo h4{margin:0 0 .5rem;font-family:var(--f-display);font-weight:400;font-size:1.5rem;line-height:1.2;color:var(--ink)}[data-philo=journal] .col-philo .post p{margin:0;font-family:var(--f-body);font-size:1rem;color:var(--ink-soft);line-height:1.55}.contact-sec{padding-bottom:10rem}.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}.contact-aside{font-size:1.0625rem;line-height:1.6;color:var(--ink-soft)}.contact-aside p{margin:0 0 1em;text-wrap:pretty}.contact-email{display:inline-block;margin:.5rem 0 1.5rem;padding-bottom:.25rem;border-bottom:2px solid var(--shu);font-family:var(--f-display);font-size:1.75rem;transition:color .25s,transform .25s}.contact-email:hover{color:var(--shu);transform:translateY(-1px)}.contact-links{display:flex;flex-wrap:wrap;gap:1.125rem;font-family:var(--f-mono);font-size:.6875rem;text-transform:uppercase;color:var(--ink-mute)}.contact-links a:hover{color:var(--ink)}.contact-stack{display:flex;flex-direction:column;gap:1.5rem}.contact-tabs{display:inline-flex;align-items:stretch;align-self:flex-start;background:color-mix(in oklch,var(--paper-2) 60%,transparent);border:1px solid var(--rule);border-radius:4px;padding:4px}.contact-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background:transparent;border:0;min-height:2.75rem;padding:.5625rem 1rem;display:inline-flex;align-items:center;gap:.625rem;font-family:var(--f-display);font-size:.9375rem;color:var(--ink-mute);border-radius:2px;transition:background .25s,color .25s}.contact-tab:hover{color:var(--ink)}.contact-tab.is-active{background:var(--paper);color:var(--ink);box-shadow:0 1px 0 var(--rule),0 4px 12px #15170f0a}.contact-tab .tab-num{width:1.375rem;height:1.375rem;display:inline-flex;align-items:center;justify-content:center;border-radius:2px;font-family:var(--f-jp);font-size:.75rem;color:var(--shu);background:color-mix(in oklch,var(--shu) 14%,transparent)}.contact-tab.is-active .tab-num{background:var(--shu);color:var(--paper)}.contact-form{display:flex;flex-direction:column;gap:1.125rem}.contact-lead{margin:0 0 .25rem;font-family:var(--f-body);font-size:.9375rem;font-style:italic;color:var(--ink-soft);line-height:1.6;text-wrap:pretty}.field{display:flex;flex-direction:column;gap:.375rem}.field-label{font-family:var(--f-mono);font-size:.625rem;text-transform:uppercase;color:var(--ink-mute)}.field input,.field textarea{font-family:var(--f-body);font-size:1.0625rem;color:var(--ink);background:color-mix(in oklch,var(--paper-2) 60%,transparent);border:0;border-bottom:1px solid var(--rule);padding:.5rem .125rem;outline:none;transition:border-color .25s,background .25s}.field textarea{min-height:7.5rem;resize:vertical;background:color-mix(in oklch,var(--paper-2) 80%,transparent);border:1px solid var(--rule);padding:.75rem;border-radius:2px;line-height:1.55}.field input:focus,.field textarea:focus{border-color:var(--shu);background:var(--paper-2)}.field input::placeholder,.field textarea::placeholder{color:var(--ink-mute);opacity:.6}.contact-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-top:.5rem}.contact-note{max-width:36ch;font-family:var(--f-body);font-style:italic;font-size:.875rem;color:var(--ink-mute)}.contact-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:0;border-radius:2px;min-height:2.75rem;background:var(--ink);color:var(--paper);padding:.75rem 1.375rem;font-family:var(--f-display);font-size:1rem;transition:transform .2s,background .25s,opacity .2s}.contact-btn:hover{transform:translateY(-1px);background:var(--shu)}.contact-btn:disabled{opacity:.5;cursor:default;transform:none}.contact-btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}.contact-btn.ghost:hover{background:var(--paper-2);border-color:var(--ink)}.contact-thanks{position:relative;padding:2.25rem;background:color-mix(in oklch,var(--paper-2) 70%,transparent);border:1px solid var(--rule);border-radius:2px}.thanks-stamp{position:absolute;top:-1rem;right:2rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--shu);color:var(--paper);font-family:var(--f-jp);font-size:1.75rem;border-radius:2px;transform:rotate(-4deg);box-shadow:0 .25rem .875rem #15170f1f}.subscribe-thanks .thanks-stamp{background:var(--moss-green)}.contact-thanks h3{margin:0 0 1rem;font-family:var(--f-display);font-weight:400;font-size:2rem;line-height:1.15}.contact-thanks h3 em{font-style:italic;color:var(--ink-mute)}.contact-thanks .ack{margin:0 0 .875rem;font-size:1.0625rem;line-height:1.65;color:var(--ink-soft);text-wrap:pretty}.contact-thanks .ack-note{margin:0 0 1.25rem;font-family:var(--f-body);font-style:italic;font-size:.875rem;color:var(--ink-mute)}.sub-choice{border:0;padding:0;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.625rem}.sub-choice legend{padding:0}.sub-choice-row{display:flex;gap:.5rem;flex-wrap:wrap}.sub-chip{display:inline-flex;align-items:center;gap:.5rem;min-height:2.75rem;font-family:var(--f-mono);font-size:.75rem;color:var(--ink-soft);padding:.5rem .875rem;border:1px solid var(--rule);border-radius:999px;background:color-mix(in oklch,var(--paper-2) 50%,transparent);cursor:pointer;transition:border-color .2s,background .2s,color .2s}.sub-chip input{position:absolute;opacity:0;pointer-events:none}.sub-chip:hover{border-color:var(--moss-green);color:var(--ink)}.sub-chip.is-on{background:color-mix(in oklch,var(--moss-green) 18%,var(--paper));border-color:var(--moss-green);color:var(--ink)}.sub-chip.is-on:before{content:"";width:.375rem;height:.375rem;border-radius:50%;background:var(--moss-green)}.site-footer{position:relative;z-index:2;border-top:1px solid var(--rule);padding:3rem var(--pad-inline);display:grid;grid-template-columns:1fr auto 1fr;gap:1.5rem;align-items:center;max-width:var(--max);width:100%;margin:0 auto;font-family:var(--f-mono);font-size:.6875rem;color:var(--ink-mute)}.site-footer .center{font-family:var(--f-jp);font-size:1rem;color:var(--shu);text-align:center}.site-footer .right{text-align:right}.reveal{opacity:0;transform:translateY(1.5rem);transition:opacity 1s ease,transform 1s ease}.reveal.in{opacity:1;transform:none}html[lang=ja] body,html[lang=ja] .hero-tagline,html[lang=ja] .hero-side{font-family:var(--f-jp);line-height:1.85}html[lang=ja] .sec-head h2,html[lang=ja] .scrap-piece h3,html[lang=ja] [data-philo=journal] .col-philo h4{font-family:var(--f-jp);line-height:1.35}html[lang=ja] .sec-head h2 em,html[lang=ja] .scrap-piece h3 em{font-style:normal}html[lang=ja] .col-guides .post h4{font-family:var(--f-jp);line-height:1.5}@keyframes pulse{0%,to{opacity:.35;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}@keyframes lineDraw{0%,to{transform:scaleY(.3);opacity:.3}50%{transform:scaleY(1);opacity:1}}@keyframes pulseDot{0%,to{box-shadow:0 0 color-mix(in oklch,var(--status-active) 60%,transparent)}50%{box-shadow:0 0 0 .375rem color-mix(in oklch,var(--status-active) 0%,transparent)}}@media(max-width:980px){.hero{grid-template-columns:1fr;padding-top:5.625rem}.hero h1{font-size:4.5rem}.hero h1.h1-ja{font-size:4.125rem}.hero-side{max-width:42rem}.scrap{min-height:0;display:flex;flex-direction:column;gap:3.5rem}.scrap-piece{position:relative!important;inset:auto!important;width:100%!important;transform:none!important}.dual-blog,.contact-grid{grid-template-columns:1fr}.dual-blog>div+div{border-left:0;border-top:1px solid var(--rule)}}@media(max-width:760px){:root{--pad-section: 5rem;--pad-inline: clamp(1.125rem, 5vw, 2rem)}body{font-size:16px}.nav{display:grid;grid-template-columns:1fr;align-items:start;gap:.625rem;padding:.875rem var(--pad-inline) .75rem;background:linear-gradient(to bottom,color-mix(in oklch,var(--paper) 98%,transparent),color-mix(in oklch,var(--paper) 92%,transparent) 74%,color-mix(in oklch,var(--paper) 0%,transparent))}.nav-right{justify-content:flex-start;flex-wrap:wrap;gap:.375rem}.nav-right>a:not(.icon-link){min-height:2.75rem;display:inline-flex;align-items:center;padding:0 .625rem;border:1px solid color-mix(in oklch,var(--rule) 72%,transparent);border-radius:999px;background:color-mix(in oklch,var(--paper-2) 44%,transparent)}.nav-right>a:not(.icon-link):after{display:none}.social-link{display:none}.hero{min-height:auto;padding-top:10.25rem;padding-bottom:4rem;gap:2rem}.hero h1,.hero h1.h1-ja{font-size:clamp(2.625rem,13vw,4rem)}.hero-tagline{font-size:1.0625rem}.hero-content{margin-left:0;padding:0;background:none}.hero-side{padding:0;background:none;gap:1.25rem}.season-mark{top:7.5rem}.vert-mark,.scroll-cue{display:none}.sec-head{grid-template-columns:1fr;gap:.5rem}.sec-head h2{font-size:2.25rem}.proj-filter{margin-top:-1.5rem;gap:.625rem}.scrap{gap:2rem}.scrap-piece .frame{padding:.875rem .875rem 1.125rem}.scrap-piece .meta{flex-direction:column;gap:.25rem}.dual-blog>div{padding:3rem var(--pad-inline)}.contact-tabs{width:100%}.contact-tab{flex:1;justify-content:center;padding-inline:.75rem}.contact-row{align-items:stretch}.contact-note,.contact-btn{width:100%}.site-footer{grid-template-columns:1fr;text-align:center}.site-footer .right{text-align:center}}@media(max-width:420px){.wordmark{font-size:1rem}.wordmark .kanji{font-size:1.25rem}.wordmark em{display:none}.nav-right{gap:.25rem}.nav-right>a:not(.icon-link),.lang-toggle,.icon-link,.theme-toggle{font-size:.625rem}.lang-toggle{gap:.25rem;padding-inline:.5rem}.hero-meta{grid-template-columns:1fr;gap:.125rem}}@media(hover:none){.scrap-piece:hover,.contact-email:hover,.contact-btn:hover,.icon-link:hover,.theme-toggle:hover{transform:none!important}}@media print{:root,[data-theme=dark]{--paper: #ffffff;--paper-2: #ffffff;--ink: #111111;--ink-soft: #333333;--ink-mute: #666666;--rule: #cccccc;--shu: #111111;--highlight: #eeeeee}body{background:#fff;font-size:12pt}body:before,.nav,.hero-canvas,.scroll-cue,.contact-tabs,.contact-form,.site-footer{display:none!important}main,.hero,.section{max-width:none;padding:0;margin:0}.hero,.dual-blog,.contact-grid{display:block}.hero h1{font-size:36pt}.scrap{min-height:0;display:block}.scrap-piece{position:static!important;width:auto!important;transform:none!important;page-break-inside:avoid;margin-bottom:18pt}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
