.qs-hero{border-bottom:1px solid var(--line);padding:56px 0 0;position:relative;overflow:hidden}.qs-hero:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,rgba(148,163,184,.05) 1px,transparent 1px),linear-gradient(rgba(148,163,184,.05) 1px,transparent 1px);background-size:64px 64px;position:absolute;top:0;bottom:0;left:0;right:0;-webkit-mask-image:radial-gradient(70% 70% at 20% 30%,#000 30%,transparent 80%);mask-image:radial-gradient(70% 70% at 20% 30%,#000 30%,transparent 80%)}.qs-hero:after{content:"";filter:blur(60px);pointer-events:none;background:radial-gradient(closest-side,rgba(124,92,255,.22),transparent 70%);border-radius:50%;width:560px;height:480px;position:absolute;top:-160px;right:-100px}.qs-hero .wrap{position:relative}.qs-hero .row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:32px;display:flex}.qs-hero h1{font-family:var(--display);letter-spacing:-.02em;margin:18px 0 0;font-size:max(32px,min(4.2vw,52px));font-weight:600;line-height:1.05}.qs-hero h1 .accent{background:linear-gradient(#fff,#cfd9ea 70%);color:transparent;-webkit-background-clip:text;background-clip:text}.qs-hero h1 .pop{color:#a892ff}.qs-hero .deck{color:var(--muted);max-width:54ch;margin:18px 0 0;font-size:17px}.qs-hero .meta{flex-wrap:wrap;gap:8px;margin-top:22px;display:flex}.qs-stat-card{background:var(--card);border:1px solid var(--line);border-radius:14px;flex-direction:column;align-self:flex-start;gap:6px;min-width:220px;margin-top:6px;padding:18px 20px;display:flex}.qs-stat-card .lbl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-size:10.5px}.qs-stat-card .v{font-family:var(--display);letter-spacing:-.01em;align-items:baseline;gap:8px;font-size:28px;font-weight:600;display:flex}.qs-stat-card .v small{font-family:var(--mono);color:var(--muted-2);letter-spacing:.05em;font-size:11px;font-weight:400}.qs-stat-card .sub{color:var(--muted);margin:0;font-size:13px;line-height:1.5}.progress-strip{z-index:30;-webkit-backdrop-filter:blur(12px)saturate(160%);border-bottom:1px solid var(--line);background:rgba(15,23,42,.86);padding:14px 0;position:-webkit-sticky;position:sticky;top:68px}.ps-row{flex-wrap:wrap;align-items:center;gap:18px;display:flex}.ps-row .lbl{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-size:11px}.ps-bar{background:rgba(148,163,184,.16);border-radius:3px;flex:1;min-width:160px;height:5px;position:relative;overflow:hidden}.ps-bar div{background:linear-gradient(90deg,#7c5cff,var(--blue-2),var(--green));border-radius:3px;width:0%;height:100%;transition:width .35s}.ps-pct{font-family:var(--mono);color:var(--text);letter-spacing:.04em;text-align:right;min-width:48px;font-size:12px}.ps-reset{font-family:var(--mono);color:var(--muted-2);border:1px solid var(--line-2);letter-spacing:.04em;background:0 0;border-radius:5px;padding:4px 9px;font-size:11px;transition:color .15s,border-color .15s}.ps-reset:hover{color:var(--text);border-color:#4b5b73}.qs-cards{padding:48px 0 24px}.qs-section-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:22px;display:flex}.qs-section-head h2{font-family:var(--display);letter-spacing:-.015em;margin:0;font-size:24px;font-weight:600}.qs-section-head .sub{font-family:var(--mono);color:var(--muted-2);letter-spacing:.04em;font-size:12px}.qs-grid{grid-template-columns:repeat(5,1fr);gap:14px;display:grid}@media (max-width:1100px){.qs-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:680px){.qs-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:460px){.qs-grid{grid-template-columns:1fr}}.qs-card{background:var(--card);border:1px solid var(--line);cursor:pointer;text-align:left;border-radius:14px;flex-direction:column;gap:12px;min-height:180px;padding:18px;transition:transform .2s,border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.qs-card:hover{border-color:#34435c;transform:translateY(-3px)}.qs-card .top{justify-content:space-between;align-items:center;gap:10px;display:flex}.qs-card .n{font-family:var(--mono);letter-spacing:.1em;color:var(--muted-2);font-size:11.5px}.qs-card .time{font-family:var(--mono);color:var(--muted-2);border:1px solid var(--line);letter-spacing:.04em;background:rgba(255,255,255,.03);border-radius:5px;padding:3px 7px;font-size:10.5px}.qs-card h3{font-family:var(--display);letter-spacing:-.005em;margin:0;font-size:16px;font-weight:600;line-height:1.22}.qs-card p{color:var(--muted);flex:1;margin:0;font-size:13px;line-height:1.5}.qs-card .check{border:1.5px solid var(--line-2);color:transparent;background:rgba(255,255,255,.02);border-radius:50%;flex:0 0 22px;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex}.qs-card.done{background:linear-gradient(180deg,rgba(0,204,136,.06),transparent),var(--card);border-color:rgba(0,204,136,.3)}.qs-card.done .check{background:var(--green);border-color:var(--green);color:#0f172a}.qs-card.done .n{color:var(--green-2)}.qs-card .ico{color:rgba(148,163,184,.05);font-family:var(--display);letter-spacing:-.04em;pointer-events:none;font-size:64px;font-weight:700;line-height:1;position:absolute;bottom:-8px;right:-8px}.qs-card.done .ico{color:rgba(0,204,136,.06)}.modules{padding:36px 0 96px}.mod{background:var(--card);border:1px solid var(--line);border-radius:16px;margin-bottom:20px;overflow:hidden}.mod-head{border-bottom:1px solid var(--line);background:linear-gradient(rgba(255,255,255,.02),transparent);justify-content:space-between;align-items:center;gap:18px;padding:18px 24px;display:flex}.mod-head .lhs{align-items:center;gap:14px;display:flex}.mod-head .n{font-family:var(--mono);letter-spacing:.1em;color:var(--muted-2);border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:6px;padding:5px 10px;font-size:11.5px}.mod-head h2{font-family:var(--display);letter-spacing:-.01em;margin:0;font-size:20px;font-weight:600}.mod-head .est{font-family:var(--mono);color:var(--muted-2);letter-spacing:.05em;font-size:11px}.mod-body{padding:24px}.mod-body p{color:#cbd5e1;margin:8px 0;font-size:15px;line-height:1.65}.mod-body p strong{color:var(--text);font-weight:600}.mod-body code.inline{font-family:var(--mono);color:var(--blue-3);background:rgba(123,174,255,.1);border:1px solid rgba(123,174,255,.18);border-radius:4px;padding:1px 6px;font-size:12.5px}.wiring-layout{grid-template-columns:1.4fr .9fr;align-items:start;gap:28px;display:grid}@media (max-width:880px){.wiring-layout{grid-template-columns:1fr}}.pinout-stage{border:1px solid var(--line);background:#0a101c;border-radius:14px;min-height:420px;padding:18px;position:relative}.pinout-stage svg{width:100%;height:auto;display:block}.pin-tooltip{pointer-events:none;border:1px solid var(--line-2);font-family:var(--mono);color:var(--text);letter-spacing:.04em;opacity:0;white-space:nowrap;z-index:5;background:rgba(11,19,34,.96);border-radius:8px;padding:8px 12px;font-size:11px;transition:opacity .15s,transform .15s;position:absolute;transform:translate(-50%,-110%)}.pin-tooltip.show{opacity:1;transform:translate(-50%,-120%)}.pin-tooltip .role{color:var(--blue-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px;font-size:10.5px;display:block}.pin-tooltip:after{content:"";border:5px solid transparent;border-top-color:rgba(11,19,34,.96);position:absolute;top:100%;left:50%;transform:translate(-50%)}.wiring-side h4{font-family:var(--display);letter-spacing:-.005em;margin:0 0 10px;font-size:15px;font-weight:600}.pin-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.pin-list li{border:1px solid var(--line);cursor:pointer;background:rgba(255,255,255,.02);border-radius:9px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 12px;font-size:13px;transition:border-color .15s,background .15s;display:grid}.pin-list li:hover{background:rgba(124,92,255,.04);border-color:rgba(124,92,255,.3)}.pin-list li .swatch{border:1px solid var(--line-2);border-radius:4px;width:14px;height:14px}.pin-list li .nm{font-family:var(--mono);color:var(--text);letter-spacing:.04em;font-size:12px}.pin-list li .desc{color:var(--muted);font-size:13px}.pin-list li.active{background:rgba(124,92,255,.08);border-color:rgba(124,92,255,.5)}.pin-list li .unit{font-family:var(--mono);color:var(--muted-2);font-size:11px}.pin-callout{background:rgba(124,92,255,.06);border:1px solid rgba(124,92,255,.25);border-radius:10px;align-items:flex-start;gap:10px;margin-top:14px;padding:12px 14px;display:flex}.pin-callout .txt{color:#cbd5e1;font-size:13px;line-height:1.55}.pin-callout .txt strong{color:var(--text)}.vid-grid{grid-template-columns:1fr 1fr;gap:14px;margin:20px 0 0;display:grid}@media (max-width:720px){.vid-grid{grid-template-columns:1fr}}.vid{border:1px solid var(--line);cursor:pointer;background:#0a101c;border-radius:12px;transition:border-color .2s,transform .2s;display:block;overflow:hidden}.vid:hover{border-color:#34435c;transform:translateY(-2px)}.vid .thumb{aspect-ratio:16/9;background:#0b1322;position:relative;overflow:hidden}.vid .thumb svg{width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.vid .play{border:1px solid var(--line-2);color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:rgba(15,23,42,.85);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .2s,background .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vid:hover .play{background:var(--blue);transform:translate(-50%,-50%)scale(1.08)}.vid .dur{font-family:var(--mono);color:var(--text);border:1px solid var(--line-2);letter-spacing:.04em;background:rgba(11,19,34,.85);border-radius:4px;padding:3px 6px;font-size:10.5px;position:absolute;bottom:10px;right:10px}.vid .src{font-family:var(--mono);color:var(--muted);border:1px solid var(--line-2);letter-spacing:.06em;text-transform:uppercase;background:rgba(11,19,34,.85);border-radius:4px;padding:3px 6px;font-size:10.5px;position:absolute;top:10px;left:10px}.vid .body{padding:14px 16px 16px}.vid .body h4{font-family:var(--display);letter-spacing:-.005em;margin:0;font-size:15px;font-weight:600;line-height:1.25}.vid .body p{color:var(--muted);font-size:12.5px;font-family:var(--mono);letter-spacing:.04em;margin:6px 0 0}.code-tabs{border-bottom:1px solid var(--line);flex-wrap:wrap;gap:0;margin-bottom:0;display:flex}.code-tabs button{font-family:var(--mono);letter-spacing:.04em;color:var(--muted);border-bottom:2px solid transparent;align-items:center;gap:8px;padding:11px 18px;font-size:12px;transition:color .15s,border-color .15s;display:flex}.code-tabs button .ext{color:var(--muted-2);font-size:10px}.code-tabs button:hover{color:var(--text)}.code-tabs button.active{color:var(--text);border-bottom-color:var(--blue)}.code-tabs button.active .ext{color:var(--blue-2)}.codepane{display:none}.codepane.active{display:block}.code-actions{border-bottom:1px solid var(--line);font-family:var(--mono);color:var(--muted-2);letter-spacing:.04em;background:rgba(255,255,255,.02);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;font-size:11.5px;display:flex}.code-actions .file{flex:1}.code-actions button{font-family:var(--mono);color:var(--muted);border:1px solid var(--line-2);letter-spacing:.04em;background:0 0;border-radius:5px;align-items:center;gap:6px;padding:5px 10px;font-size:11px;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.code-actions button:hover{color:var(--text);border-color:#4b5b73}.code-actions button.primary{color:var(--blue-3);background:rgba(0,102,255,.1);border-color:rgba(0,102,255,.3)}.code-actions button.primary:hover{color:#fff;background:rgba(0,102,255,.16)}pre.codeblock{font-family:var(--mono);color:#d6deea;background:#0b1322;border-radius:0 0 12px 12px;margin:0;padding:18px 20px;font-size:13px;line-height:1.65;overflow-x:auto}pre.codeblock .c-key{color:#f0a6ca}pre.codeblock .c-typ{color:#7baeff}pre.codeblock .c-fn{color:#fbd38d}pre.codeblock .c-str{color:#5be3b1}pre.codeblock .c-num{color:#fbd38d}pre.codeblock .c-com{color:#64748b;font-style:italic}pre.codeblock .c-pre{color:#a892ff}pre.codeblock .c-pun{color:#94a3b8}.code-wrap{border:1px solid var(--line);background:#0b1322;border-radius:12px;margin-top:14px;overflow:hidden}.pair-flow{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px;display:grid;position:relative}@media (max-width:900px){.pair-flow{grid-template-columns:repeat(2,1fr)}}.pf{border:1px solid var(--line);z-index:1;cursor:pointer;text-align:left;background:rgba(255,255,255,.02);border-radius:12px;flex-direction:column;gap:10px;padding:18px;transition:border-color .25s,background .25s;display:flex;position:relative}.pf.on{background:linear-gradient(rgba(124,92,255,.06),transparent);border-color:rgba(124,92,255,.4)}.pf .pf-n{font-family:var(--mono);color:var(--muted-2);letter-spacing:.1em;font-size:11px}.pf.on .pf-n{color:#a892ff}.pf h4{font-family:var(--display);letter-spacing:-.005em;margin:0;font-size:14px;font-weight:600}.pf p{color:var(--muted);margin:0;font-size:12.5px;line-height:1.5}.pf .viz{border:1px solid var(--line);background:#0b1322;border-radius:8px;height:90px;margin-top:auto;position:relative;overflow:hidden}.pf .viz svg{width:100%;height:100%}@media (min-width:901px){.pair-flow:before{content:"";pointer-events:none;z-index:0;background:repeating-linear-gradient(90deg,rgba(148,163,184,.25) 0,rgba(148,163,184,.25) 4px,transparent 4px,transparent 8px);height:1px;position:absolute;top:55%;left:0;right:0}}.test-grid{grid-template-columns:1.1fr .9fr;align-items:stretch;gap:18px;margin-top:8px;display:grid}@media (max-width:900px){.test-grid{grid-template-columns:1fr}}.terminal{border:1px solid var(--line);background:#070b14;border-radius:12px;flex-direction:column;min-height:280px;display:flex;overflow:hidden}.terminal .head{border-bottom:1px solid var(--line);background:rgba(255,255,255,.02);align-items:center;gap:10px;padding:10px 14px;display:flex}.terminal .head .dots{gap:6px;display:flex}.terminal .head .dots span{background:#334155;border-radius:50%;width:9px;height:9px}.terminal .head .dots span.r{background:#f87171}.terminal .head .dots span.y{background:#fbbf24}.terminal .head .dots span.g{background:#34d399}.terminal .head .ttl{font-family:var(--mono);color:var(--muted);letter-spacing:.04em;margin-left:6px;font-size:11.5px}.terminal .head .status{font-family:var(--mono);color:var(--green);letter-spacing:.06em;align-items:center;gap:6px;margin-left:auto;font-size:10.5px;display:flex}.terminal .head .status .dot{background:currentColor;border-radius:50%;width:7px;height:7px;animation:1.8s ease-in-out infinite blink;box-shadow:0 0 8px}.terminal .body{font-family:var(--mono);color:#cbd5e1;white-space:pre-wrap;flex:1;padding:16px 18px;font-size:12.5px;line-height:1.7;overflow:auto}.terminal .body .gray{color:#64748b}.terminal .body .blue{color:#7baeff}.terminal .body .green{color:#5be3b1}.terminal .body .yel{color:#fbd38d}.terminal .body .pink{color:#f0a6ca}.terminal .body .caret{background:var(--blue-2);vertical-align:-2px;width:7px;height:14px;margin-left:1px;animation:1s steps(2,end) infinite caret;display:inline-block}.device-card{background:var(--card);border:1px solid var(--line);border-radius:12px;flex-direction:column;gap:14px;padding:18px;display:flex}.device-card .lbl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-size:10.5px}.phone-mockup{border:1px solid var(--line);background:#0a101c;border-radius:12px;flex-direction:column;gap:10px;padding:16px;display:flex;position:relative}.phone-mockup .ph-top{font-family:var(--mono);color:var(--muted-2);letter-spacing:.04em;border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;padding-bottom:8px;font-size:10.5px;display:flex}.phone-mockup .ph-row{border:1px solid var(--line);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:13px;transition:border-color .25s,background .25s;display:flex}.phone-mockup .ph-row .name{color:var(--text);font-weight:600}.phone-mockup .ph-row .mac{font-family:var(--mono);color:var(--muted-2);letter-spacing:.04em;font-size:10.5px}.phone-mockup .ph-row.connected{background:linear-gradient(rgba(0,204,136,.06),transparent);border-color:rgba(0,204,136,.4)}.phone-mockup .ph-row .pill{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted-2);border:1px solid var(--line-2);border-radius:5px;margin-left:auto;padding:3px 7px;font-size:10px}.phone-mockup .ph-row.connected .pill{color:var(--green);background:rgba(0,204,136,.08);border-color:rgba(0,204,136,.4)}.run-row{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.ts{border:1px solid var(--line);background:var(--card);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}.ts details{border-bottom:1px solid var(--line)}.ts details:last-child{border-bottom:0}.ts summary{cursor:pointer;color:var(--text);justify-content:space-between;align-items:center;gap:14px;padding:14px 18px;font-size:14px;font-weight:500;list-style:none;display:flex}.ts summary::-webkit-details-marker{display:none}.ts summary:hover{background:rgba(255,255,255,.02)}.ts summary .left{align-items:center;gap:12px;display:flex}.ts summary .left .ico{color:#fbd38d;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);border-radius:6px;flex:0 0 24px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.ts summary .chev{color:var(--muted-2);flex:none;transition:transform .2s}.ts details[open] summary .chev{color:var(--text);transform:rotate(90deg)}.ts .ans{color:var(--muted);padding:0 18px 16px 56px;font-size:13.5px;line-height:1.6}.ts .ans code{font-family:var(--mono);color:var(--blue-3);background:rgba(123,174,255,.1);border:1px solid rgba(123,174,255,.18);border-radius:4px;padding:1px 6px;font-size:12px}.finish{border:1px solid var(--line);background:linear-gradient(180deg,rgba(124,92,255,.06),transparent),var(--card);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;margin-top:36px;padding:28px;display:flex}.finish .h3{font-family:var(--display);margin:0;font-size:20px;font-weight:600}.finish p{color:var(--muted);max-width:50ch;margin:6px 0 0;font-size:14px}.finish .cta{flex-wrap:wrap;gap:10px;display:flex}.finish a.inline{color:var(--blue-2);text-underline-offset:3px;-webkit-text-decoration:underline rgba(123,174,255,.4);text-decoration:underline rgba(123,174,255,.4)}.breadcrumb{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;flex-wrap:wrap;align-items:center;gap:8px;font-size:11.5px;display:flex}.breadcrumb a{color:var(--muted);transition:color .15s}.breadcrumb a:hover{color:var(--text)}.breadcrumb .sep{opacity:.5}
