*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,sans-serif;background:#0c0d0e;color:#d1d5db;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shell{max-width:1160px;margin:0 auto;padding:32px 28px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:10px}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-left h1{font-size:18px;font-weight:700;color:#f3f4f6;letter-spacing:-.02em}.topbar-count{font-size:10px;font-weight:600;color:#fb23c2;background:#fb23c21a;border:1px solid rgba(251,35,194,.18);padding:2px 7px;border-radius:4px}.topbar-pills{display:flex;gap:5px;flex-wrap:wrap}.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:5px;font-size:11px;text-decoration:none;color:#ffffff73;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:all .12s}.pill:hover{color:#f3f4f6;background:#ffffff14;border-color:#ffffff24}.pill-active{color:#f3f4f6!important;background:#fb23c21f!important;border-color:#fb23c252!important}.pill-active b{color:#ffffff8c}.pill-active code{color:#ff82db}a,a:visited,a:active{color:inherit;text-decoration:none}.pill b{font-weight:600;color:#ffffff4d;font-size:10px;text-transform:uppercase;letter-spacing:.03em}.pill code{font-family:ui-monospace,SF Mono,monospace;font-size:11px;color:#fb23c2}.dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.dot-g{background:#22c55e}.dot-y{background:#f59e0b}.dot-p{background:#818cf8}.dot-d{background:#555}.cols{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start;transition:grid-template-columns .18s ease}@media(max-width:720px){.cols{grid-template-columns:1fr}}@media(min-width:721px){#hub-cols:not([data-hub-active-tab=all]){grid-template-columns:1fr}}#hub-cols:not([data-hub-active-tab=all]) .hub-preview-panel{display:none!important}.env-hint{font-size:11px;color:#ffffff52;margin-top:6px;width:100%;flex-basis:100%}.env-hint code{font-family:ui-monospace,SF Mono,monospace;font-size:10px;color:#ffffff73}.hub-left{display:grid;grid-template-columns:minmax(168px,200px) minmax(0,1fr);gap:22px;align-items:start}@media(max-width:900px){.hub-left{grid-template-columns:1fr;gap:14px}}.hub-toc{position:sticky;top:12px;z-index:1;padding:12px 12px 14px;border-radius:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.06)}@media(max-width:900px){.hub-toc{position:static;padding:10px 10px 12px}.hub-toc-nav{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.hub-toc-link{flex:0 0 auto;white-space:nowrap}}.hub-toc-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;line-height:1.25;color:#ffffff47;margin-bottom:10px;padding-left:2px}.hub-toc-nav{display:flex;flex-direction:column;gap:3px}@media(max-width:900px){.hub-toc-nav{flex-direction:row}}.hub-toc-link{display:flex;align-items:baseline;justify-content:space-between;gap:10px 12px;padding:8px 10px;border-radius:7px;font-size:13px;font-weight:600;line-height:1.3;letter-spacing:0;color:#e5e7eb8c;text-decoration:none;border:1px solid transparent;transition:color .12s,background .12s,border-color .12s}@media(max-width:900px){.hub-toc-link{align-items:center}}.hub-toc-link-main{display:inline-flex;align-items:baseline;gap:6px;min-width:0;flex-wrap:wrap}.hub-toc-cms-badge{flex-shrink:0;align-self:center;font-size:8px;font-weight:600;padding:2px 5px;letter-spacing:.04em;line-height:1}button.hub-toc-link{width:100%;margin:0;text-align:left;cursor:pointer;background:transparent;color:inherit;font-family:inherit;font-size:13px;font-weight:600;line-height:1.3;letter-spacing:0}.hub-toc-link:hover{color:#e5e7eb;background:#ffffff0d;border-color:#ffffff1a}.hub-toc-link:focus-visible{outline:2px solid rgba(251,35,194,.45);outline-offset:2px}.hub-toc-link[aria-selected=true],.hub-toc-link.hub-toc-link--active{color:#e5e7eb;background:#fb23c21a;border-color:#fb23c247}.hub-toc-link[aria-selected=true] .hub-toc-n,.hub-toc-link.hub-toc-link--active .hub-toc-n{color:#fff6}.hub-tab-panel.hub-tab-panel--hidden,.hub-main.hub-main--hidden{display:none!important}.hub-toc-link-text{min-width:0;font-weight:inherit}.hub-toc-n{font-size:11px;font-weight:600;line-height:1.3;letter-spacing:0;color:#ffffff52;font-variant-numeric:tabular-nums;flex-shrink:0}[id^=hub-]{scroll-margin-top:24px}.label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff47;margin-bottom:6px;padding-left:2px}.sep{height:1px;background:#ffffff0f;margin:16px 0}.plist{display:flex;flex-direction:column;gap:1px}.prow{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;text-decoration:none;color:inherit;transition:background .12s;min-width:0}.prow:hover{background:#ffffff0a}.prow-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1 1 auto}.prow-name{font-size:13px;font-weight:600;min-width:0;flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#e5e7eb}.prow-path{font-size:10px;font-family:ui-monospace,SF Mono,monospace;color:#ffffff47;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0;max-width:100%}.prow:hover .prow-path{color:#ffffff7a}.prow-actions{display:flex;align-items:center;gap:8px;flex:0 1 42%;max-width:min(42%,260px);min-width:0;justify-content:flex-end}@media(max-width:520px){.prow-actions{flex-basis:36%;max-width:min(36%,200px)}}a.prow .prow-path{flex:0 1 38%;max-width:min(38%,220px)}@media(max-width:520px){a.prow .prow-path{max-width:min(34%,160px)}}.prow-btn{font-size:10px;color:#ffffff40;text-decoration:none;padding:2px 7px;border-radius:4px;border:1px solid rgba(255,255,255,.07);transition:all .12s}.prow-btn:hover{color:#fb23c2;border-color:#fb23c240;background:#fb23c20f}.badge{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:1px 5px;border-radius:3px;white-space:nowrap}.b-live{color:#22c55e;background:#22c55e1a}.b-draft{color:#f59e0b;background:#f59e0b1a}.b-hard{color:#fff3;background:#ffffff0a}.b-cms{color:#818cf8;background:#818cf814}.scard{padding:12px;border-radius:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);margin-bottom:8px}.scard-top{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.scard-title{font-size:12px;font-weight:600;color:#e5e7eb;display:flex;align-items:center;gap:6px}.scard-arrow{font-size:9px;color:#ffffff40;transition:transform .12s}.scard.open .scard-arrow{transform:rotate(90deg)}.scard-link{font-size:11px;color:#fb23c2;text-decoration:none;font-weight:500}.scard-link:visited{color:#fb23c2}.scard-link:hover{text-decoration:underline}.scard-sub{font-size:11px;color:#ffffff4d;margin-top:4px}.scard-sections{display:none;flex-wrap:wrap;gap:3px;margin-top:8px}.scard.open .scard-sections{display:flex}.scard-sec{font-size:10px;padding:3px 8px;border-radius:4px;color:#fff6;background:#ffffff08;text-decoration:none;transition:all .12s}.scard-sec:visited{color:#fff6}.scard-sec:hover{color:#fff;background:#ffffff0f}.hub-preview-panel{min-width:0}.hub-preview-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:5px 6px;margin-bottom:8px;padding:2px}.hub-preview-group-label{flex:0 0 100%;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff38;margin-top:6px;margin-bottom:2px;padding-left:2px}.hub-preview-group-label:first-child{margin-top:0}.hub-preview-tab{margin:0;padding:5px 9px;border-radius:6px;cursor:pointer;font:inherit;font-size:11px;font-weight:500;color:#ffffff73;background:#ffffff08;border:1px solid rgba(255,255,255,.08);max-width:100%;text-align:left;transition:color .12s,border-color .12s,background .12s}.hub-preview-tab:hover{color:#e5e7eb;background:#ffffff0f;border-color:#ffffff1f}.hub-preview-tab[aria-selected=true]{color:#f3f4f6;background:#fb23c21a;border-color:#fb23c259}.hub-preview-tab--all{font-weight:600}.hub-preview-tab:focus-visible{outline:2px solid rgba(251,35,194,.45);outline-offset:2px}.hub-preview-sections{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px;min-height:26px;align-items:center}.hub-preview-sec{margin:0;padding:3px 8px;border-radius:4px;cursor:pointer;font:inherit;font-size:10px;color:#ffffff61;background:#ffffff08;border:1px solid rgba(255,255,255,.07)}.hub-preview-sec:hover{color:#ff82db;border-color:#fb23c240;background:#fb23c20f}.hub-preview-dialog{margin:0;border:none;background:transparent;box-sizing:border-box}.hub-preview-dialog:not([open]){display:none!important}.hub-preview-dialog[open]{display:flex;align-items:center;justify-content:center;width:100vw;max-width:100vw;height:100vh;max-height:100vh;padding:clamp(12px,3vw,24px);z-index:1000}.hub-preview-dialog::backdrop{background:#060708d1;backdrop-filter:blur(4px)}.hub-preview-dialog-panel{position:relative;z-index:0;isolation:isolate;display:flex;flex-direction:column;width:min(1180px,100%);max-height:min(92vh,880px);background:#121314;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;box-shadow:0 24px 80px #0000008c}.hub-preview-dialog-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.hub-preview-dialog-title{font-size:13px;font-weight:700;color:#f3f4f6;opacity:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hub-preview-dialog-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.hub-preview-dialog-close{margin:0;padding:5px 12px;border-radius:6px;font:inherit;font-size:11px;font-weight:600;cursor:pointer;color:#ffffffd9;background:#ffffff14;border:1px solid rgba(255,255,255,.12)}.hub-preview-dialog-close:hover{background:#ffffff1f}.hub-preview-dialog-body{padding:10px 12px 14px}.hub-preview-dialog-frame{display:block;position:relative;z-index:1;width:100%;height:min(72vh,760px);min-height:440px;max-height:78vh;border:0;border-radius:8px;background:#080808}.pipe{display:flex;flex-direction:column;align-items:center;gap:0;padding:4px 0}.pipe-row{display:flex;gap:12px;width:100%;justify-content:center}.pipe-track{display:flex;flex-direction:column;align-items:center;gap:0;flex:1;max-width:120px}.pipe-role{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.pipe-role-cw{color:#f59e0b}.pipe-role-dev{color:#818cf8}.pipe-node{font-size:10px;padding:5px 10px;border-radius:5px;text-align:center;width:100%;text-decoration:none;color:#ffffff8c;transition:all .12s}.pipe-node-cw{background:#f59e0b0f;border:1px solid rgba(245,158,11,.15)}.pipe-node-cw:hover{background:#f59e0b1f;color:#fbbf24}.pipe-node-dev{background:#818cf80f;border:1px solid rgba(129,140,248,.15)}.pipe-node-dev:hover{background:#818cf81f;color:#a5b4fc}.pipe-node-shared{background:#fb23c20f;border:1px solid rgba(251,35,194,.15)}.pipe-node-shared:hover{background:#fb23c21f;color:#ff82db}.pipe-node-prod{background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:#4ade80}.pipe-vline,.pipe-vline-merge{width:1px;height:10px;background:#ffffff1a}.pipe-merge-line{display:flex;align-items:center;width:100%;max-width:252px}.pipe-merge-arm{flex:1;height:1px;background:#ffffff1a}.pipe-merge-dot{width:5px;height:5px;border-radius:50%;background:#ffffff26;flex-shrink:0}.pipe-note{font-size:9px;color:#fff3;margin-top:2px}a.pipe-node{cursor:pointer}.guide-details{margin-top:4px}.guide-summary{font-size:11px;font-weight:500;color:#ffffff4d;cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:5px}.guide-summary::-webkit-details-marker{display:none}.guide-summary:before{content:"▸";font-size:9px;transition:transform .12s}.guide-details[open] .guide-summary:before{transform:rotate(90deg)}.guide-summary:hover{color:#ffffff80}.cms-notice{font-size:11px;color:#ffffff4d;padding:8px 12px;border-radius:6px;background:#ffffff05;border:1px dashed rgba(255,255,255,.07)}.cms-notice code{font-family:ui-monospace,SF Mono,monospace;font-size:11px;color:#fb23c2}.cms-group .cms-group-body{display:none}.cms-group.is-open .cms-group-body{display:flex;flex-direction:column;gap:1px}.cms-group-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;padding-left:2px}.cms-group-toggle{display:flex;align-items:center;gap:8px;flex:1;min-width:0;margin:0;padding:2px 4px 2px 0;border:none;border-radius:6px;background:transparent;color:inherit;font:inherit;cursor:pointer;text-align:left}.cms-group-toggle:hover{background:#ffffff08}.cms-group-toggle:focus-visible{outline:2px solid rgba(251,35,194,.45);outline-offset:2px}.cms-group-chevron{font-size:9px;color:#ffffff52;width:12px;flex-shrink:0;line-height:1;transition:transform .12s}.cms-group.is-open .cms-group-chevron{transform:rotate(0)}.cms-group:not(.is-open) .cms-group-chevron{transform:rotate(-90deg)}.cms-group-title{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff47}.cms-group-title .cms-group-count{font-weight:600;color:#ffffff61;letter-spacing:.02em;text-transform:none}.cms-group-toggle:hover .cms-group-title{color:#ffffff6b}
