:root{color-scheme:light dark;--bg: #fffaf7;--surface: #ffffff;--surface-2: #fff4ee;--surface-3: #fdece3;--fg: #1c1422;--fg-soft: #463d4f;--muted: #756c7e;--line: #efe7ee;--line-strong: #e0d6e0;--brand: #ff5722;--brand-strong: #c0380c;--brand-2: #ff2e7e;--brand-grad: linear-gradient(135deg, #ff7a18 0%, #ff2e7e 100%);--brand-grad-cta: linear-gradient(135deg, #d8400f 0%, #cc0f57 100%);--brand-grad-soft: linear-gradient(135deg, #fff1e6 0%, #ffeaf2 100%);--brand-tint: #ffe9df;--ring: #c0380c;--shadow-sm: 0 1px 2px rgba(28, 20, 34, .06), 0 1px 3px rgba(28, 20, 34, .05);--shadow-md: 0 4px 14px rgba(28, 20, 34, .08), 0 2px 6px rgba(28, 20, 34, .05);--shadow-lg: 0 16px 40px rgba(255, 87, 34, .18), 0 6px 18px rgba(28, 20, 34, .1);--radius: 18px;--radius-md: 14px;--radius-cover: 10px;--radius-pill: 999px;--maxw: 1060px}@media(prefers-color-scheme:dark){:root{--bg: #130f19;--surface: #1c1626;--surface-2: #221b2e;--surface-3: #281f37;--fg: #f5f1f8;--fg-soft: #d3cbdb;--muted: #a79db2;--line: #2e2740;--line-strong: #3b3251;--brand: #ff6a3d;--brand-strong: #ff8a5c;--brand-2: #ff5a9e;--brand-grad: linear-gradient(135deg, #ff8a3d 0%, #ff5a9e 100%);--brand-grad-cta: linear-gradient(135deg, #c2390c 0%, #c20f52 100%);--brand-grad-soft: linear-gradient(135deg, #2a1c22 0%, #281a2c 100%);--brand-tint: #36232a;--ring: #ff9a6f;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .45);--shadow-md: 0 6px 18px rgba(0, 0, 0, .5);--shadow-lg: 0 18px 46px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 106, 61, .12)}}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,Hiragino Sans,Yu Gothic UI,Meiryo,system-ui,sans-serif;color:var(--fg);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;display:flex;flex-direction:column;min-height:100vh}img{max-width:100%}a{color:var(--brand-strong)}:focus-visible{outline:3px solid var(--ring);outline-offset:2px;border-radius:8px}.skip-link{position:absolute;left:12px;top:-56px;background:var(--fg);color:var(--bg);padding:.55rem 1rem;border-radius:10px;font-size:.875rem;font-weight:600;text-decoration:none;z-index:100;transition:top .15s ease}.skip-link:focus{top:12px}main{flex:1 0 auto}.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:1.25rem}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}.header-inner{max-width:var(--maxw);margin-inline:auto;padding:.6rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.logo{display:inline-flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--fg);font-weight:800;font-size:1.2rem;letter-spacing:.01em}.logo-mark{display:inline-grid;place-items:center;width:31px;height:31px;border-radius:10px;background:var(--brand-grad);box-shadow:var(--shadow-sm);flex:none}.logo-mark svg{width:19px;height:19px}.logo-text{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.header-nav{display:flex;align-items:center;gap:.25rem}.nav-search{display:inline-flex;align-items:center;gap:.42rem;text-decoration:none;color:var(--fg);font-size:.92rem;font-weight:700;padding:.5rem 1.05rem;border-radius:var(--radius-pill);border:1px solid var(--line-strong);background:var(--surface);transition:border-color .15s,color .15s,box-shadow .15s,transform .15s}.nav-search svg{width:16px;height:16px}.nav-search:hover{border-color:var(--brand);color:var(--brand-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font:inherit;font-weight:700;line-height:1.2;text-decoration:none;cursor:pointer;border:0;border-radius:var(--radius-pill);padding:.8rem 1.6rem;transition:transform .15s,box-shadow .15s,filter .15s,border-color .15s,color .15s}.btn-primary{background:var(--brand-grad-cta);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);filter:saturate(1.06)}.btn-ghost{background:var(--surface);color:var(--fg);border:1px solid var(--line-strong)}.btn-ghost:hover{border-color:var(--brand);color:var(--brand-strong);transform:translateY(-1px)}.pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:700;padding:.3rem .75rem;border-radius:var(--radius-pill);background:var(--surface-2);color:var(--fg-soft);border:1px solid var(--line);white-space:nowrap}.pill-brand{background:var(--brand-tint);color:var(--brand-strong);border-color:color-mix(in srgb,var(--brand) 32%,transparent)}.section-head{margin-bottom:1.1rem}.kicker{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-strong);margin:0 0 .35rem}.section-title{font-size:clamp(1.4rem,1rem + 1.8vw,1.85rem);font-weight:800;margin:0 0 .2rem;letter-spacing:.01em;line-height:1.3}.section-note{margin:0;color:var(--muted);font-size:.9rem}.cover img{display:block;width:100%;height:auto;border-radius:var(--radius-cover);background:var(--surface-2);box-shadow:var(--shadow-md)}.cover-placeholder{display:grid;place-items:center;width:100%;aspect-ratio:5 / 7;border-radius:var(--radius-cover);background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 10px,var(--surface-3) 10px,var(--surface-3) 20px);color:var(--muted);font-size:.8rem;font-weight:600}.breadcrumb{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;font-size:.85rem;color:var(--muted)}.breadcrumb a{color:var(--brand-strong);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .sep{color:var(--line-strong)}.breadcrumb [aria-current]{color:var(--fg-soft)}.prose-page{padding:2.5rem 0 1rem}.prose{max-width:760px;margin-inline:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:clamp(1.5rem,1rem + 2vw,2.75rem)}.prose>h1{font-size:clamp(1.7rem,1.2rem + 2vw,2.2rem);font-weight:800;margin:0 0 1.5rem;line-height:1.25}.prose h2{font-size:1.2rem;font-weight:800;margin:2.2rem 0 .7rem;padding-left:.7rem;border-left:4px solid var(--brand);border-radius:2px;line-height:1.4}.prose p,.prose ul,.prose ol{line-height:1.9;color:var(--fg-soft)}.prose ul,.prose ol{padding-left:1.3rem}.prose li{margin:.25rem 0}.prose a{color:var(--brand-strong);text-underline-offset:2px}.prose .updated,.prose .note{color:var(--muted);font-size:.85rem;margin-top:1.5rem}.site-footer{flex-shrink:0;margin-top:4rem;background:var(--surface-2);border-top:1px solid var(--line)}.footer-inner{max-width:var(--maxw);margin-inline:auto;padding:2.5rem 1.25rem;text-align:center}.footer-brand{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;font-weight:800;font-size:1.1rem}.footer-tagline{color:var(--muted);font-size:.9rem;margin:.6rem 0 1.4rem}.footer-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem 1.4rem;margin-bottom:1.4rem;font-size:.875rem}.footer-nav a{color:var(--fg-soft);text-decoration:none}.footer-nav a:hover{color:var(--brand-strong)}.copy{color:var(--muted);font-size:.8rem}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
