:root{--radius-none:0;--radius-sm:2px;--radius-md:4px;--radius-lg:4px;--radius-full:4px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--bp-sm:480px;--bp-md:768px;--bp-lg:1024px;--bp-xl:1280px;--touch-min:44px;--font-sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "SF Mono", Consolas, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.35rem;--text-2xl:1.75rem;--shadow-sm:0 1px 2px #00000042;--shadow-md:0 8px 24px #00000047;--lightningcss-light: ;--lightningcss-dark:initial;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-bg:#151515;--color-bg-2:#1f211f;--color-surface:#ffffff0b;--color-surface-2:#ffffff13;--color-surface-3:#ffffff1c;--color-border:#ffffff1c;--color-border-strong:#ffffff38;--color-text:#f2f2f5;--color-text-2:#c7c9d3;--color-text-3:#8e93a6;--color-accent:#d58c72;--color-accent-2:#80b59b;--color-accent-soft:#80b59b29;--color-good:#7fcf9e;--color-warn:#f0c674;--color-danger:#e89299}*{box-sizing:border-box}html,body,#root{min-height:100%}body{font-family:var(--font-sans);color:var(--color-text);background:linear-gradient(160deg, var(--color-bg), var(--color-bg-2));letter-spacing:0;-webkit-font-smoothing:antialiased;margin:0;font-size:14px;line-height:1.5}a{color:inherit}button,input,select{font:inherit}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.app-shell,.page-shell{width:min(1480px, calc(100vw - var(--space-6)));min-height:100vh;padding:var(--space-4) 0 var(--space-8);margin:0 auto}.topbar{align-items:center;gap:var(--space-4);border-bottom:1px solid var(--color-border);min-height:56px;display:flex}.page-frame,.content-stack{gap:var(--space-5);display:grid}.page-heading{justify-content:space-between;align-items:flex-end;gap:var(--space-4);padding:var(--space-8) 0 var(--space-2);display:flex}.page-heading h1{font-size:var(--text-2xl);letter-spacing:0;margin:0;font-weight:650;line-height:1.1}.brand{min-height:var(--touch-min);align-items:center;gap:var(--space-2);color:var(--color-text);white-space:nowrap;font-weight:700;text-decoration:none;display:inline-flex}.project-nav{align-items:center;gap:var(--space-2);padding:var(--space-2) 0;display:flex;overflow-x:auto}.gallery-heading,.detail-header{justify-content:space-between;align-items:flex-end;gap:var(--space-4);padding:var(--space-8) 0 var(--space-5);display:flex}.gallery-heading h1,.detail-header h1{font-size:var(--text-2xl);letter-spacing:0;margin:0;font-weight:650;line-height:1.1}.detail-header p{margin:var(--space-2) 0 0;color:var(--color-text-3);font-family:var(--font-mono);font-size:var(--text-xs);overflow-wrap:anywhere}.stats-row{gap:var(--space-2);display:flex}.toolbar{z-index:10;gap:var(--space-2);padding:var(--space-3) 0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--color-border);background:#111424e0;grid-template-columns:minmax(220px,1fr) auto minmax(180px,240px);display:grid;position:sticky;top:0}.gallery-grid{gap:var(--space-3);padding-top:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(230px,1fr));display:grid}.project-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.section-block{min-width:0}.detail-shell{width:min(1280px, calc(100vw - var(--space-6)))}.detail-preview{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);min-height:62vh;overflow:hidden}.version-list{gap:var(--space-2);padding:var(--space-4) 0 0;flex-wrap:wrap;display:flex}@media (width<=860px){.page-shell,.app-shell,.detail-shell{width:min(100vw - var(--space-4), 100%)}.topbar,.gallery-heading,.detail-header,.page-heading{flex-direction:column;align-items:stretch}.toolbar{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}}.nav-chip,.version-chip{align-items:center;gap:var(--space-1);min-height:32px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);background:var(--color-surface);white-space:nowrap;text-decoration:none;display:inline-flex}.nav-chip.active,.version-chip.active{color:var(--color-text);background:var(--color-accent-soft);border-color:#d98a9b6b}.eyebrow{margin:0 0 var(--space-2);color:var(--color-accent);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;font-weight:700}.stat{min-width:86px;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.stat strong,.stat span{display:block}.stat strong{font-size:var(--text-lg)}.stat span{color:var(--color-text-3);font-size:var(--text-xs)}.search-field,.select-field{min-height:var(--touch-min);align-items:center;gap:var(--space-2);padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-2);display:flex}.search-field input,.select-field select{width:100%;color:var(--color-text);background:0 0;border:0;outline:0}.select-field select{appearance:none}.segmented{min-height:var(--touch-min);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);align-items:center;padding:3px;display:inline-flex}.segmented button{min-height:36px;padding:0 var(--space-3);border-radius:var(--radius-md);color:var(--color-text-2);cursor:pointer;background:0 0;border:0}.segmented button.active{color:var(--color-text);background:var(--color-surface-3)}.gallery-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);min-width:0;box-shadow:var(--shadow-sm);overflow:hidden}.preview-link{aspect-ratio:4/3;background:#0000002e;display:block;overflow:hidden}.preview-media,.preview-frame{object-fit:cover;background:#fff;border:0;width:100%;height:100%;display:block}.text-preview{place-items:center;gap:var(--space-2);height:100%;color:var(--color-text-3);display:grid}.card-body{padding:var(--space-3)}.card-title-row,.meta-line,.badge-row{align-items:center;gap:var(--space-2);min-width:0;display:flex}.card-title{min-width:0;color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:700;text-decoration:none;overflow:hidden}.favorite-icon{color:var(--color-warn);flex-shrink:0}.meta-line{margin-top:var(--space-1);color:var(--color-text-3);font-size:var(--text-xs);justify-content:space-between}.badge-row{margin-top:var(--space-3);flex-wrap:wrap}.kind-badge,.type-badge{align-items:center;gap:var(--space-1);min-height:22px;padding:0 var(--space-2);border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text-2);font-size:var(--text-xs);display:inline-flex}.kind-badge.image{color:var(--color-good)}.kind-badge.artifact{color:var(--color-accent)}.hint{margin-top:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);background:var(--color-surface)}.hint.error{color:var(--color-danger);border-color:#e8929973}.primary-action{min-height:var(--touch-min);padding:0 var(--space-4);border-radius:var(--radius-md);color:var(--color-text);background:var(--color-accent-soft);border:1px solid #d98a9b6b;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.brand-mark{border:1px solid var(--color-border);border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-accent-2);background:var(--color-surface);place-items:center;display:inline-grid}.brand span:last-child{gap:1px;display:grid}.brand small{color:var(--color-text-3);font-size:var(--text-xs);font-weight:500}.topnav{align-items:center;gap:var(--space-1);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:3px;display:inline-flex}.topnav a{min-height:32px;padding:0 var(--space-3);border-radius:var(--radius-md);color:var(--color-text-2);align-items:center;text-decoration:none;display:inline-flex}.topnav a.active{color:var(--color-text);background:var(--color-surface-3)}.quick-search{align-items:center;gap:var(--space-2);min-height:36px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-3);background:var(--color-surface);margin-left:auto;display:inline-flex}.lead{max-width:720px;margin:var(--space-2) 0 0;color:var(--color-text-2)}.metric-strip{gap:var(--space-2);flex-wrap:wrap;display:flex}.metric-strip span{align-items:center;gap:var(--space-2);min-height:34px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);background:var(--color-surface);display:inline-flex}.section-title{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.section-title h2{align-items:center;gap:var(--space-2);font-size:var(--text-lg);margin:0;line-height:1.2;display:inline-flex}.section-title a,.back-link,.button-link{align-items:center;gap:var(--space-2);min-height:34px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);background:var(--color-surface);text-decoration:none;display:inline-flex}.project-card,.item-card{border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:0;color:var(--color-text);background:var(--color-surface);box-shadow:var(--shadow-sm);flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.item-card-link{min-width:0;color:inherit;flex-direction:column;text-decoration:none;display:flex}.project-card:hover,.item-card:hover,.button-link:hover,.back-link:hover{border-color:var(--color-border-strong);background:var(--color-surface-2)}.project-card .card-body,.item-card .card-body{gap:var(--space-1);display:grid}.project-card strong,.item-card strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.project-card .card-body>span:last-child,.item-card .card-body>span:last-child{color:var(--color-text-3);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.card-kicker{color:var(--color-accent-2);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase}.tag-row{gap:var(--space-2);padding:0 var(--space-3) var(--space-3);flex-wrap:wrap;display:flex}.badge{min-height:24px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);font-size:var(--text-xs);background:var(--color-surface);align-items:center;display:inline-flex}.badge-muted{color:var(--color-text-3)}.badge-public,.is-public{color:var(--color-good)}.publish-toggle{top:var(--space-2);right:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);width:34px;height:34px;color:var(--color-text-2);cursor:pointer;background:#151515d1;place-items:center;display:inline-grid;position:absolute}.publish-toggle:hover{border-color:var(--color-border-strong);background:var(--color-surface-3)}.publish-toggle.is-public{color:var(--color-good)}.button-link{cursor:pointer}.media-preview{aspect-ratio:4/3;background:#ffffff09;display:block;overflow:hidden}.media-preview img{object-fit:cover;width:100%;height:100%;display:block}.preview-frame{background:#f6f3ed;border:0;width:100%;height:100%;display:block}.media-preview-large{aspect-ratio:auto;height:100%;min-height:52vh}.media-preview-large img{object-fit:contain;background:#f6f3ed}.media-empty{color:var(--color-text-3);place-items:center;display:grid}.chart-preview{padding:var(--space-2);background:#202221;place-items:center;display:grid}.chart-preview>div,.chart-preview svg,.chart-preview canvas{max-width:100%;max-height:100%}.text-artifact-preview{padding:var(--space-3);color:var(--color-text-2);background:#202221;display:block}.text-artifact-preview pre{max-height:100%;color:inherit;font-family:var(--font-mono);font-size:var(--text-xs);white-space:pre-wrap;overflow-wrap:anywhere;margin:0;line-height:1.55;overflow:hidden}.text-artifact-preview:not(:has(pre)){place-items:center;display:grid}.render-page{background:#181a19;width:100vw;height:100vh;margin:0;overflow:hidden}.render-page .media-preview-large{border:0;border-radius:0;width:100vw;height:100vh;min-height:100vh}.detail-hero{gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);grid-template-columns:minmax(220px,360px) minmax(0,1fr);align-items:stretch;display:grid}.detail-copy h1,.item-aside h1{font-size:var(--text-2xl);margin:0;line-height:1.12}.item-layout{gap:var(--space-4);grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:start;display:grid}.media-panel,.item-aside{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.item-aside{gap:var(--space-3);padding:var(--space-4);display:grid}.meta-list{gap:var(--space-2);margin:0;display:grid}.meta-list div{gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);grid-template-columns:96px minmax(0,1fr);display:grid}.meta-list dt{color:var(--color-text-3)}.meta-list dd{overflow-wrap:anywhere;min-width:0;margin:0}.version-row{align-items:center;gap:var(--space-2);min-width:220px;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-2);background:var(--color-surface);text-decoration:none;display:inline-flex}.version-row.is-active{color:var(--color-text);border-color:var(--color-border-strong);background:var(--color-accent-soft)}.version-row span{gap:2px;display:grid}.version-row small{color:var(--color-text-3)}.skeleton-card,.notice,.empty-state{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.skeleton-card{min-height:260px;animation:1.2s ease-in-out infinite alternate pulse}.notice{align-items:center;gap:var(--space-3);padding:var(--space-3);color:var(--color-warn);display:flex}.notice span,.empty-state{gap:var(--space-1);display:grid}.notice small,.empty-state span{color:var(--color-text-3)}.empty-state{min-height:180px;padding:var(--space-5);text-align:center;place-items:center}.empty-state-compact{min-height:96px}@keyframes pulse{0%{opacity:.55}to{opacity:1}}@media (width<=860px){.quick-search{display:none}.detail-hero,.item-layout{grid-template-columns:1fr}.media-preview-large{min-height:46vh}}
