:root{--bg: #0b0b10;--bg-elev: #13131b;--fg: #e9e9f2;--fg-muted: #9a9ab0;--accent: #9b7cff;--accent-2: #5ec8c6;--border: color-mix(in srgb, var(--fg) 12%, transparent);--radius: 14px;--maxw: 1120px;--font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "Hiragino Sans", "Noto Sans JP", "Meiryo", sans-serif;--font-mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html{color-scheme:dark;background:var(--bg);color:var(--fg);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{margin:0;min-height:100dvh;line-height:1.65}a{color:inherit;text-decoration-color:color-mix(in srgb,var(--accent) 60%,transparent);text-underline-offset:3px}a:hover{text-decoration-color:var(--accent)}img,svg,video{max-width:100%;height:auto;display:block}.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}.site-header{position:sticky;top:0;z-index:10;backdrop-filter:saturate(140%) blur(12px);background:color-mix(in srgb,var(--bg) 72%,transparent);border-bottom:1px solid var(--border)}.site-header .inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.9rem}.brand{display:inline-flex;align-items:baseline;gap:.5rem;font-weight:800;font-size:1.1rem;letter-spacing:.02em;text-decoration:none}.brand .dot{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:inline-block;transform:translateY(1px)}.brand .tag{color:var(--fg-muted);font-weight:500;font-size:.85rem}main{padding-block:clamp(2rem,6vw,4rem)}footer.site-footer{border-top:1px solid var(--border);padding-block:2rem;color:var(--fg-muted);font-size:.9rem}.hero{padding-block:clamp(2.5rem,8vw,5rem);text-align:left}.hero h1{font-size:clamp(2rem,5vw,3.25rem);line-height:1.15;margin:0 0 .75rem;background:linear-gradient(135deg,var(--fg),color-mix(in srgb,var(--accent) 80%,var(--fg)));-webkit-background-clip:text;background-clip:text;color:transparent}.hero p.sub{margin:0;color:var(--fg-muted);font-size:clamp(1rem,1.6vw,1.15rem);max-width:60ch}.grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr))}.card{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:transform .15s,border-color .15s,background .15s}.card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.card h3{margin:0;font-size:1.05rem}.card p{margin:0;color:var(--fg-muted);font-size:.92rem}.card .meta{margin-top:auto;display:flex;gap:.5rem;flex-wrap:wrap;font-size:.75rem}.chip{padding:.15rem .5rem;border:1px solid var(--border);border-radius:999px;color:var(--fg-muted)}.article-title{font-size:clamp(1.6rem,3.5vw,2.5rem);line-height:1.2;margin:0 0 .5rem}.article-tagline{color:var(--fg-muted);margin-top:0}.section{margin-block:2.5rem}.section h2{font-size:1.35rem;margin:0 0 .75rem;scroll-margin-top:6rem}.prompt-box{position:relative;background:#07070c;border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1rem 1rem 1.1rem;overflow:auto}.prompt-box pre{margin:0;font-family:var(--font-mono);font-size:.9rem;line-height:1.55;white-space:pre-wrap;word-break:break-word}.prompt-copy{position:absolute;top:.6rem;right:.6rem;padding:.3rem .65rem;font-size:.78rem;background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--fg);border:1px solid color-mix(in srgb,var(--accent) 50%,var(--border));border-radius:8px;cursor:pointer;font-family:inherit}.prompt-copy:hover{background:color-mix(in srgb,var(--accent) 45%,transparent)}.preview-frame{margin-block:1.5rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;aspect-ratio:16 / 10;width:100%}.preview-frame iframe{width:100%;height:100%;border:0;display:block}.preview-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .9rem;border-radius:10px;background:var(--bg-elev);border:1px solid var(--border);text-decoration:none;font-size:.9rem;transition:border-color .15s,background .15s}.btn:hover{border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0b10;border-color:transparent;font-weight:700}dl.stack-list{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;margin:0}dl.stack-list dt{color:var(--fg-muted);font-size:.88rem}dl.stack-list dd{margin:0}ul.bullet{padding-left:1.2rem;margin:0}ul.bullet li+li{margin-top:.35rem}details.faq-item{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;background:var(--bg-elev)}details.faq-item+details.faq-item{margin-top:.5rem}details.faq-item summary{cursor:pointer;font-weight:600}details.faq-item[open] summary{margin-bottom:.5rem}.lang-banner{display:flex;justify-content:center;gap:.5rem;font-size:.85rem;padding:.5rem 1rem;background:color-mix(in srgb,var(--accent) 10%,transparent);border-bottom:1px solid var(--border);color:var(--fg-muted)}.lang-banner a{color:var(--fg);font-weight:600}@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.lang-switcher[data-astro-cid-su6xvggn]{display:inline-flex;gap:.25rem;padding:.25rem;background:color-mix(in srgb,currentColor 6%,transparent);border-radius:999px}.lang-link[data-astro-cid-su6xvggn]{padding:.25rem .75rem;font-size:.85rem;border-radius:999px;color:inherit;text-decoration:none;opacity:.7;transition:opacity .15s,background .15s}.lang-link[data-astro-cid-su6xvggn]:hover{opacity:1}.lang-link[data-astro-cid-su6xvggn].active{background:color-mix(in srgb,currentColor 12%,transparent);opacity:1;font-weight:600}
