.project-detail{max-width:85rem;margin:0 auto;padding:var(--space-l);box-sizing:border-box}.project-grid{display:grid;grid-template-columns:1fr 20rem;gap:var(--space-l);align-items:start;position:relative}.project-content{min-width:0}.project-toc{width:100%}.project-hero{position:relative;border-radius:var(--space-s);overflow:hidden;box-shadow:0 var(--space-xs) var(--space-xl) color-mix(in oklab,black 8%,transparent);margin-bottom:var(--space-l)}.project-hero-figure{width:100%;height:26.25rem;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-hero-title{position:absolute;left:var(--space-m);bottom:var(--space-s);right:var(--space-s);color:#fff;text-shadow:0 var(--space-xs) var(--space-xl) rgba(0,0,0,.65);padding:var(--space-xs) var(--space-s);background:linear-gradient(180deg,#0000,#00000047 35%,#00000085);border-radius:var(--space-xs);backdrop-filter:blur(var(--space-xs))}.project-hero-title h1,.project-hero-title .project-title{margin:0;font-family:var(--font-heading);font-weight:700;color:#fff;font-size:var(--step-3);line-height:1.05}.project-summary{margin:var(--space-xs) 0 var(--space-l);color:var(--color-text-secondary);font-size:var(--step-1);max-width:84%}.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);box-shadow:0 var(--space-xs) var(--space-xl) color-mix(in oklab,black 6%,transparent);border:1px solid color-mix(in oklab,var(--color-border) 14%,transparent)}.role-heading{margin:0 0 var(--space-s);font-weight:700;font-size:var(--step-1)}.role-body{color:var(--color-text-secondary);font-size:var(--step-1);line-height:1.65}.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--1);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-3xs) var(--space-xs);background:color-mix(in oklab,var(--color-accent) 9%,transparent);border-radius:999px;font-size:var(--step--1);color:var(--text-color);line-height:1}.project-section{margin:var(--space-l) 0}.project-section h2{margin-top:0;margin-bottom:var(--space-s);color:var(--text-color);font-size:var(--step-2)}.section-content{font-size:var(--step-1);line-height:1.6}p{font-size:var(--step-1);line-height:1.6;margin-bottom:var(--space-m)}.process-list{list-style:disc;margin-left:var(--space-m);color:var(--color-text-secondary);font-size:var(--step-1)}.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-1)}.cta-row{display:flex;gap:var(--space-m);margin:var(--space-l) 0 0;align-items:center;flex-wrap:nowrap;overflow-x:auto}.cta-row .btn{inline-size:auto!important;block-size:auto!important;width:auto!important;height:auto!important;padding:var(--space-xs) var(--space-m)!important;min-width:var(--space-xl);white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 var(--space-xs) var(--space-xl) color-mix(in oklab,var(--accent-color) 18%,transparent);border:1px solid transparent;background-clip:padding-box;transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,border-color .18s ease,color .18s ease;font-weight:600;letter-spacing:.01em}.cta-row .btn.btn-secondary{background:color-mix(in oklab,var(--color-accent) 8%,var(--color-card) 92%);color:var(--text-color);border:1px solid color-mix(in oklab,var(--color-border) 36%,transparent);box-shadow:0 var(--space-xs) var(--space-xl) color-mix(in oklab,black 6%,transparent)}.cta-row .btn:hover,.cta-row .btn:focus{transform:translateY(calc(var(--space-3xs) * -1));box-shadow:0 var(--space-m) var(--space-3xl) color-mix(in oklab,var(--accent-color) 20%,transparent)}.project-detail .btn:focus{outline:3px solid color-mix(in oklab,var(--color-accent) 55%,transparent 45%);outline-offset:var(--space-3xs)}.cta-row .btn.btn-secondary:hover,.cta-row .btn.btn-secondary:focus{background:color-mix(in oklab,var(--color-accent) 14%,var(--color-card) 86%);border-color:color-mix(in oklab,var(--color-border) 50%,transparent);color:var(--text-color)}.project-detail .btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-s);padding:var(--space-xs) var(--space-m);border-radius:10px;font-size:var(--step--1);cursor:pointer;text-decoration:none;border:1px solid transparent;transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease;white-space:nowrap;min-width:var( --space-xl );word-break:normal;-webkit-font-smoothing:antialiased}.project-detail .btn:focus{outline:3px solid var(--color-focus);outline-offset:var(--space-3xs)}.project-detail .btn-primary{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) 22%,transparent);border:1px solid color-mix(in oklab,var(--accent-color) 60%,transparent);transform:translateZ(0)}.project-detail .btn-primary:hover,.project-detail .btn-primary:focus{transform:translateY(calc(var(--space-3xs) * -1));background:var(--color-accent-hover)}.project-detail .btn-secondary{background:transparent;color:var(--text-color);border:1px solid color-mix(in oklab,var(--color-border) 26%,transparent)}.project-detail .btn-secondary:hover,.project-detail .btn-secondary:focus{background:color-mix(in oklab,var(--color-accent) 6%,transparent);transform:translateY(calc(var(--space-3xs) * -1))}.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-s));right:clamp(1.125rem,6vw,3.5rem);width:20rem;z-index:120;pointer-events:auto}.toc-card{position:relative;padding:var(--space-m);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-s)));overflow:auto}.toc-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-s)}.toc-toggle{appearance:none;border:none;background:color-mix(in oklab,var(--color-border) 8%,transparent);color:var(--text-color);width:var(--space-xl);height:var(--space-xl);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--step--1)}.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 0 var(--space-s);font-size:var(--step-1)}.toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-s)}.toc-list a{color:var(--color-text-tertiary);text-decoration:none;padding:var(--space-2xs) var(--space-s);border-radius:8px;display:block;font-size:var(--step-0)}.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-hero-figure{height:220px}.project-hero-title h1{font-size:var(--step-2)}.project-detail .btn{font-size:var(--step--1);padding:var(--space-xs) var(--space-s)}}@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))}}
