.project-detail{max-width:var( --container-blog );max-width:110rem;margin:0 auto;padding:var(--space-xl) var(--space-m);box-sizing:border-box}.project-grid{display:grid;grid-template-columns:1fr 22rem;gap:var(--space-xl);align-items:start;position:relative;transition:all var(--m3-motion-duration-medium) var(--m3-motion-easing-standard)}.project-content{min-width:0}.project-toc{width:100%}.project-hero{position:relative;border-radius:var(--space-s);overflow:hidden;box-shadow:var(--m3-elevation-2);margin-bottom:var(--space-l);transition:box-shadow var(--m3-motion-duration-medium) var(--m3-motion-easing-standard)}.project-hero:hover{box-shadow:var(--m3-elevation-4)}.project-hero-figure{width:100%;height:clamp(30rem,50vh,45rem);overflow:hidden;display:block;background:linear-gradient(180deg,#0000000a,#00000005);background-size:cover;background-position:center}.project-hero-figure:after{content:"";position:absolute;left:0;right:0;bottom:0;height:40%;pointer-events:none;background:linear-gradient(180deg,#0000,#00000059 70%,#0009)}.project-hero-figure img{width:100%;height:100%;object-fit:cover;display:block;transform-origin:center;transition:transform .6s ease}.project-hero:hover .project-hero-figure img,.project-hero:focus-within .project-hero-figure img{transform:scale(1.03)}.project-intro-card{background:var(--color-surface);border-radius:2rem;box-shadow:0 4px 6px -1px #0000000d,0 10px 15px -3px #0000001a;border:1px solid color-mix(in oklab,var(--color-border) 8%,transparent);overflow:hidden;margin-bottom:var(--space-xl)}.project-hero{position:relative;margin:0;display:block}.project-hero-figure{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#f3f4f8}.project-hero-figure img{width:100%;height:100%;object-fit:cover;display:block;opacity:.95}.project-hero-title{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-l) var(--space-xl);background:linear-gradient(180deg,#0000 0% 60%,#0006 80%,#000c);color:#fff;pointer-events:none}.project-hero-title h1{margin:0;font-size:var(--step-5);font-weight:780;letter-spacing:-.025em;text-shadow:0 2px 8px rgba(0,0,0,.2)}.project-version{margin:var(--space-3xs) 0 0;font-size:var(--step-0);font-weight:350;color:#fffc}.project-hero-title h1,.project-hero-title .project-title{margin:0;font-family:var(--font-heading);font-weight:780;color:#fff;font-size:var(--step-5);line-height:var(--font-line-height-heading-tight);letter-spacing:-.025em;text-shadow:var(--m3-elevation-2)}.project-summary{margin:var(--space-m) 0 var(--space-xl);color:var(--color-text-secondary);font-size:var(--step-3);line-height:var(--font-line-height-body);max-width:85ch}.info-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--grid-gap-md);margin:var(--space-l) 0;align-items:start}.card{padding:var(--space-m);background:var(--color-card);border-radius:var(--space-s);border:1px solid color-mix(in oklab,var(--m3-color-outline) 15%,transparent);box-shadow:var(--m3-elevation-1);transition:transform var(--m3-motion-duration-short) var(--m3-motion-easing-standard),box-shadow var(--m3-motion-duration-short) var(--m3-motion-easing-standard)}.card:hover{transform:translateY(-4px);box-shadow:var(--m3-elevation-3);background:color-mix(in oklab,var(--color-card) 95%,var(--m3-color-primary) 5%)}.role-heading{margin:0 0 var(--space-s);font-weight:780;font-size:var(--step-1);letter-spacing:.02em;text-transform:uppercase;color:var(--m3-color-primary)}.role-body{color:var(--color-text-secondary);font-size:var(--step-2);line-height:var(--font-line-height-body)}.tt-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs);align-items:start;margin-top:var(--space-3xs)}.tt-column{min-width:0;padding:0}.tt-subheading{margin:0 0 var(--space-xs);font-size:var(--step-0);font-weight:600;color:var(--text-color)}.tt-column .tech-list,.tt-column .tech-list li{margin:0;padding:0}@media(min-width:981px){.tt-column+.tt-column{padding-left:var(--space-m);border-left:1px solid color-mix(in oklab,var(--color-border) 12%,transparent);margin-left:0}.tt-subheading{margin-left:0}}@media(max-width:560px){.tt-grid{grid-template-columns:1fr;gap:var(--space-s)}.tt-column+.tt-column{border-left:none;padding-left:0}.tech-pill{font-size:var(--step--1);padding:var(--space-3xs) var(--space-xs)}}.tech-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:var(--space-xs)}.tech-list li{display:inline-flex;align-items:center;gap:var(--space-s);color:var(--color-text-secondary);margin:0;padding:0}.tech-pill{display:inline-block;padding:var(--space-2xs) var(--space-s);background:color-mix(in oklab,var(--m3-color-primary) 8%,transparent);border:1px solid color-mix(in oklab,var(--m3-color-primary) 12%,transparent);border-radius:999px;font-size:var(--step-0);color:var(--m3-color-on-surface);line-height:1;font-weight:500;transition:all var(--m3-motion-duration-short) var(--m3-motion-easing-standard)}.tech-pill:hover{background:var(--m3-color-primary);color:var(--m3-color-on-primary);transform:scale(1.05)}.project-section{margin:var(--space-l) 0}.project-section h2{margin-top:0;margin-bottom:var(--space-m);color:var(--text-color);font-size:var(--step-3);font-weight:650}.section-content{font-size:var(--step-2);line-height:1.6}p{font-size:var(--step-2);line-height:var(--font-line-height-body);margin-bottom:var(--space-l);color:var(--color-text-secondary);max-width:85ch}.process-list{list-style:disc;margin-left:var(--space-m);color:var(--color-text-secondary);font-size:var(--step-2);line-height:var(--font-line-height-body)}.final-figure{margin:var(--space-l) 0;border-radius:var(--space-s);overflow:hidden;box-shadow:0 var(--space-s) var(--space-xl) color-mix(in oklab,black 8%,transparent);border:1px solid color-mix(in oklab,var(--color-border) 10%,transparent)}.final-figure img{max-width:100%;width:auto;height:auto;display:block;margin:0 auto}.simple-list{list-style:disc;margin-left:var(--space-m);color:var(--color-text-secondary);font-size:var(--step-2);line-height:var(--font-line-height-body)}.overview-layout{display:grid;grid-template-columns:1fr auto;gap:var(--space-xl);align-items:start;margin-bottom:var(--space-xl)}.project-summary{margin-bottom:0;max-width:65ch}.cta-aside .btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:.5rem 1.75rem;border-radius:var(--space-s);text-decoration:none;font-weight:600;font-size:var(--step-0);background-color:var(--m3-color-surface-container-low, #f3f4f8);color:var(--m3-color-on-surface);border:1px solid var(--m3-color-outline-variant, var(--m3-color-outline));transition:all var(--m3-motion-duration-short) var(--m3-motion-easing-standard);width:100%;max-width:220px;line-height:1.2}.cta-aside .btn:hover{background-color:var(--m3-color-surface-container-high);border-color:var(--m3-color-primary);box-shadow:var(--m3-elevation-2);transform:translateY(-2px)}.overview-layout{display:grid;grid-template-columns:1fr auto;gap:var(--space-xl);align-items:center;padding:var(--space-l) var(--space-xl);border-top:1px solid var(--color-border)}.project-summary{margin-bottom:0;max-width:70ch;line-height:var(--font-line-height-body);font-size:var(--step-1);color:var(--color-text-secondary)}.project-summary strong{font-weight:700;color:var(--m3-color-on-surface)}.cta-aside.primary-actions{display:flex;flex-direction:column;gap:var(--space-xs);align-items:stretch;min-width:14rem}.cta-aside-group{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);width:100%}.cta-aside .btn-icon{width:20px;height:20px;color:#111827}.btn-arrow-icon{display:none}.license-tag{font-family:var(--font-mono);font-size:.75rem;color:#9ca3af;text-transform:none;letter-spacing:normal;margin-right:.25rem}@media(max-width:900px){.overview-layout{grid-template-columns:1fr;gap:var(--space-m)}.cta-aside.primary-actions{align-items:stretch;width:100%}}.project-detail .btn strong,.project-detail .btn span{white-space:nowrap;word-break:keep-all}.project-toc{position:fixed;top:calc(var(--nav-height) + var(--space-l));right:clamp(1.5rem,5vw,4.5rem);width:24rem;z-index:120;pointer-events:auto}.toc-card{position:relative;padding:var(--space-l) 0;background:var(--color-card);border-radius:var(--radius-md, var(--space-s));border:1px solid color-mix(in oklab,var(--color-border) 10%,transparent);box-shadow:0 var(--space-s) var(--space-2xl) color-mix(in oklab,black 8%,transparent);max-height:calc(100vh - calc(var(--nav-height) + var(--space-l)));overflow:auto}.toc-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-s);padding:0 var(--space-l)}.toc-toggle{appearance:none;border:none;background:color-mix(in oklab,var(--color-border) 8%,transparent);color:var(--text-color);width:var(--space-2xl);height:var(--space-2xl);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--step-0)}.toc-toggle:focus{outline:2px solid var(--color-focus);outline-offset:var(--space-3xs)}.project-toc.toc-collapsed{width:var(--space-xl)}.project-toc.toc-collapsed .toc-card{padding:var(--space-3xs);width:var(--space-xl);overflow:visible}.project-toc.toc-collapsed .toc-list,.project-toc.toc-collapsed h4{display:none}.project-toc.toc-collapsed .toc-toggle{width:var(--space-xl);height:var(--space-xl)}.toc-card h4{margin:0;font-size:var(--step-2);font-weight:700;color:var(--m3-color-primary)}.toc-list{list-style:none;padding:0;margin:var(--space-l) 0 0;display:flex;flex-direction:column;gap:var(--space-xs)}.toc-list a{color:var(--color-text-tertiary);text-decoration:none;padding:var(--space-s) var(--space-l);border-radius:4px;display:block;font-size:var(--step-1);transition:all var(--m3-motion-duration-short) var(--m3-motion-easing-standard);margin:0 4px}.toc-list a.link-active{color:var(--text-color);background:color-mix(in oklab,var(--color-accent) 10%,transparent);font-weight:700;box-shadow:0 var(--space-3xs) var(--space-2xs) color-mix(in oklab,var(--color-accent) 6%,transparent)}.toc-list a:hover,.toc-list a:focus{color:var(--color-text-tertiary);background:color-mix(in oklab,var(--color-accent) 4%,transparent);font-weight:600}.kv{display:flex;flex-direction:column;gap:var(--space-xs)}.kv dt{font-weight:700;font-size:var(--step--1)}.kv dd{margin:0;color:var(--color-text-secondary);font-size:var(--step-1)}@media(max-width:980px){.project-grid{grid-template-columns:1fr}.project-toc{order:2}.project-hero-figure{height:320px}.info-row{grid-template-columns:1fr}.project-toc{position:fixed;top:auto;right:var(--space-s-m);bottom:calc(env(safe-area-inset-bottom,0px) + var(--space-m-l));left:auto;width:auto;z-index:200;max-height:none;box-shadow:none;pointer-events:auto}.toc-card{padding:var(--space-s);max-width:min(86vw,360px);max-height:min(70vh,520px);overflow:auto;box-shadow:0 var(--space-s) var(--space-2xl) color-mix(in oklab,black 12%,transparent)}.project-toc.toc-collapsed{width:var(--space-2xl)}.project-toc.toc-collapsed .toc-card{width:var(--space-2xl);height:var(--space-2xl);padding:var(--space-3xs);border-radius:var(--space-3xl);background:var(--accent-color);box-shadow:0 var(--space-s) var(--space-2xl) color-mix(in oklab,var(--accent-color) 28%,transparent);overflow:visible}.project-toc.toc-collapsed .toc-toggle{width:var(--space-xl);height:var(--space-xl);border-radius:var(--space-3xl);background:transparent;color:var(--color-on-accent);font-size:var(--step-0)}.project-toc:not(.toc-collapsed) .toc-toggle{width:var(--space-xl);height:var(--space-xl);border-radius:10px;background:color-mix(in oklab,var(--color-border) 8%,transparent);color:var(--text-color)}.project-toc:not(.toc-collapsed) h4{display:block}.toc-list a{font-size:var(--step-1)}}@media(max-width:560px){.project-detail{padding:var(--space-m) var(--space-s)}.project-hero-figure{height:200px;aspect-ratio:16 / 10}.project-hero-title{padding:var(--space-m)}.project-hero-title h1{font-size:var(--step-3)}.project-intro-card{border-radius:var(--space-m);margin-bottom:var(--space-l)}.overview-layout{padding:var(--space-m);gap:var(--space-s)}.project-summary{font-size:var(--step-0)}.card{padding:var(--space-s);border-radius:var(--space-xs)}.role-heading{font-size:var(--step-0);margin-bottom:var(--space-2xs)}.role-body{font-size:var(--step-1)}.project-section h2{font-size:var(--step-2);margin-bottom:var(--space-s)}.section-content,p{font-size:var(--step-0)}.tech-pill{font-size:var(--step--1);padding:var(--space-3xs) var(--space-xs)}.project-detail .btn{font-size:var(--step--1);padding:var(--space-xs) var(--space-s);max-width:none;width:100%}.final-figure,.project-section{margin:var(--space-m) 0}}@media(prefers-reduced-motion:reduce){.project-hero-figure img,.project-detail .btn,.project-hero{transition:none}}section[id]{scroll-margin-top:calc(var(--nav-height) + var(--space-s))}.scroll-top{position:fixed;right:var(--space-s-m);bottom:calc(env(safe-area-inset-bottom,0px) + var(--space-m));width:var(--space-xl);height:var(--space-xl);display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:var(--accent-color);color:var(--color-on-accent);box-shadow:0 var(--space-s) var(--space-2xl) color-mix(in oklab,var(--accent-color) 20%,transparent);border:1px solid color-mix(in oklab,var(--color-border) 14%,transparent);opacity:0;transform:translateY(var(--space-xs));pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:220;font-size:var(--step-1);line-height:1}.scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top:focus{outline:3px solid var(--color-focus);outline-offset:var(--space-3xs)}@media(max-width:980px){.scroll-top{right:auto;left:var(--space-s-m);bottom:calc(env(safe-area-inset-bottom,0px) + var(--space-m-l))}}
