:root{color:#1e2937;background:#eef3f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;margin:0}a{color:inherit}svg{width:1.1em;height:1.1em;flex:0 0 auto}.site-shell{min-height:100vh}.index-page,.tutorial-page,.not-found{width:min(1180px,calc(100% - 40px));margin:0 auto}.index-page{padding:40px 0 72px}.index-header{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;padding-bottom:32px;border-bottom:1px solid #d6e0ea}.brand{display:flex;align-items:center;gap:14px}.brand-mark{display:grid;width:52px;height:52px;place-items:center;border-radius:8px;color:#f7fbff;background:#16324f;font-size:14px;font-weight:800}.brand h1,.brand p,.index-summary,.category-heading p,.step-header p,.not-found p{margin:0}.brand h1{color:#152235;font-size:30px;line-height:1.15}.eyebrow,.category-kicker,.step-count{color:#ad3838;font-size:12px;font-weight:800;text-transform:uppercase}.index-summary{max-width:520px;color:#506070;font-size:16px;line-height:1.65}.category-list{display:grid;gap:18px;padding-top:18px}.category-section{display:grid;grid-template-columns:260px minmax(0,1fr);gap:32px;padding:30px 0;border-bottom:1px solid #d6e0ea}.category-heading{display:flex;flex-direction:column;gap:10px}.category-heading h2{margin:0;color:#16324f;font-size:24px;line-height:1.25}.category-heading p:not(.category-kicker){color:#5b6876;font-size:15px;line-height:1.65}.tutorial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.tutorial-card{display:flex;align-items:center;gap:14px;min-height:84px;padding:16px;border:1px solid #d4dde7;border-radius:8px;background:#fff;text-decoration:none;transition:border-color .16s ease,transform .16s ease,box-shadow .16s ease}.tutorial-card:hover,.tutorial-card:focus-visible{border-color:#b94040;box-shadow:0 8px 22px #16324f1f;transform:translateY(-1px);outline:none}.tutorial-card svg{width:24px;height:24px;color:#1d7f78}.tutorial-card span{display:grid;gap:4px}.tutorial-card strong{color:#162538;font-size:16px;line-height:1.25}.tutorial-card small{color:#657486;font-size:13px}.tutorial-page{padding:26px 0 72px}.step-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 14px;border:1px solid #cdd8e3;border-radius:8px;color:#24364a;background:#fff;font-size:14px;font-weight:800;text-decoration:none}.step-button:hover,.step-button:focus-visible{border-color:#16324f;outline:none}.step-layout{display:grid;grid-template-columns:290px minmax(0,1fr);gap:28px;align-items:start;min-width:0;margin-top:0}.step-sidebar{position:sticky;top:26px;min-width:0;max-height:calc(100vh - 52px);overflow:auto;padding:20px;border:1px solid #d4dde7;border-radius:8px;background:#fff}.toc-link{display:flex;align-items:center;justify-content:center;gap:8px;min-height:42px;margin-bottom:18px;padding:0 12px;border:1px solid #cdd8e3;border-radius:8px;color:#24364a;background:#f8fafc;font-size:14px;font-weight:800;text-decoration:none}.toc-link:hover,.toc-link:focus-visible{border-color:#16324f;outline:none}.step-sidebar h1{margin:8px 0 18px;color:#16324f;font-size:24px;line-height:1.25}.step-list{display:grid;gap:8px;max-width:100%;margin:0;padding:0;list-style:none}.step-link{display:flex;align-items:center;gap:10px;min-height:42px;padding:8px 10px;border-radius:8px;color:#47576a;font-size:14px;font-weight:750;text-decoration:none}.step-link span{display:grid;width:24px;height:24px;place-items:center;border-radius:999px;color:#fff;background:#69788c;font-size:12px}.step-link.active,.step-link:hover,.step-link:focus-visible{color:#162538;background:#eaf2f2;outline:none}.step-link.active span{background:#ad3838}.step-panel{min-width:0;padding:34px;border:1px solid #d4dde7;border-radius:8px;background:#fff}.step-header{padding-bottom:24px;border-bottom:1px solid #e0e7ee}.step-header h2{margin:8px 0 12px;color:#152235;font-size:34px;line-height:1.18}.step-header p:not(.step-count){color:#536373;font-size:16px;line-height:1.65}.guide-content{min-width:0;padding:26px 0 8px}.guide-content p,.guide-content li{color:#334155;font-size:17px;line-height:1.8;overflow-wrap:anywhere}.guide-content code{padding:2px 6px;border-radius:6px;background:#eef3f7;color:#ad3838;font-size:.92em}.guide-content table{width:100%;margin:26px 0;border-collapse:collapse;overflow:hidden;border:1px solid #d4dde7;border-radius:8px;font-size:16px}.guide-content th,.guide-content td{padding:12px 14px;border-bottom:1px solid #d4dde7;text-align:left}.guide-content th{color:#152235;background:#eef3f7;font-weight:800}.guide-content tr:last-child td{border-bottom:0}.notice{margin:26px 0;padding:16px 18px;border-left:4px solid #1d7f78;border-radius:8px;background:#e7f6f4;color:#214b4a}.notice p{margin:0}.notice-warning{border-left-color:#b47a1b;background:#fff7e3;color:#67490f}.step-image{margin:28px 0}.step-image img{display:block;width:100%;border:1px solid #d9e1ea;border-radius:8px;background:#fff}.step-image figcaption{margin-top:10px;color:#5a6878;font-size:14px}.step-actions{display:flex;justify-content:space-between;gap:12px;padding-top:24px;border-top:1px solid #e0e7ee}.step-button.primary{border-color:#16324f;color:#fff;background:#16324f}.not-found{display:grid;min-height:100vh;place-content:center;justify-items:center;gap:14px;text-align:center}.not-found h1{margin:0;color:#152235}.job-role-row{display:grid;grid-template-columns:72px minmax(0,1fr);gap:18px;align-items:center;margin:24px 0;padding:14px 16px;border:1px solid #d4dde7;border-radius:8px;background:#f8fbfd;box-shadow:0 6px 16px #16324f12}.job-role-badge{display:grid;justify-items:center;gap:6px}.job-role-badge img{width:56px;height:56px}.job-role-badge span{color:#47576a;font-size:13px;font-weight:800}.job-role-copy{display:flex;flex-direction:column;gap:0;margin:0}.job-role-copy span{color:#334155;font-size:17px;line-height:1.25}.job-role-copy span+span{color:#64748b;font-size:14px;line-height:1.35}.job-profile{display:grid;grid-template-columns:minmax(0,1fr);gap:18px;align-items:stretch;min-width:0;margin:30px 0;overflow:hidden;border:1px solid #d4dde7;border-radius:8px;background:#f8fbfd;box-shadow:0 6px 16px #16324f12}.job-profile.has-illustration{grid-template-columns:minmax(0,1fr) minmax(190px,260px)}.job-profile-main{display:grid;align-content:start;gap:16px;min-width:0;padding:16px}.job-profile-heading{display:grid;grid-template-columns:58px minmax(0,1fr);gap:16px;align-items:center;min-width:0}.job-profile-icon{width:54px;height:54px}.job-profile-body{display:grid;min-width:0;gap:8px}.job-profile-title{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px}.job-profile-title strong{color:#152235;font-size:22px;line-height:1.15}.job-profile-title span{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border:1px solid #b7c4d1;border-radius:999px;color:#16324f;background:#fff;font-size:12px;font-weight:850;line-height:1}.job-profile-meta{display:flex;flex-wrap:wrap;gap:7px 14px;margin:0}.job-profile-meta div{display:inline-flex;min-width:0;align-items:baseline;gap:6px}.job-profile-meta dt{flex:0 0 auto;color:#ad3838;font-size:11px;font-weight:850;line-height:1;white-space:nowrap}.job-profile-weapon-label{display:inline-flex;align-items:center}.job-profile-weapon-label svg{width:14px;height:14px;stroke-width:2.4;transform:translateY(3px)}.job-profile-meta dd{min-width:0;margin:0;color:#64748b;font-size:14px;line-height:1.25}.job-profile-content{min-width:0}.job-profile-content>:first-child{margin-top:0}.job-profile-content>:last-child{margin-bottom:0}.job-profile-content ul{margin:0;padding-left:20px}.job-profile-figure{display:flex;align-items:center;justify-content:center;min-width:0;min-height:250px;margin:0;overflow:hidden;padding:24px 20px 18px;border-left:1px solid #d4dde7;background:#eef3f7}.job-profile-figure img{display:block;width:var(--job-profile-illustration-width, min(100%, 230px));max-width:none;max-height:300px;object-fit:contain;object-position:center}@media(max-width:925px){.index-page,.tutorial-page,.not-found{width:min(100% - 28px,1180px)}.index-header,.category-section,.step-layout{grid-template-columns:1fr}.index-header{display:grid;align-items:start;gap:18px}.tutorial-grid{grid-template-columns:1fr}.step-sidebar{position:static;max-height:none;overflow:hidden}.step-sidebar h1{margin-bottom:12px}.step-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x proximity}.step-list li{flex:0 0 auto;scroll-snap-align:start}.step-link{min-width:max-content;padding-right:14px}.step-panel{padding:22px}.step-header h2{font-size:28px}.job-profile.has-illustration{grid-template-columns:1fr}.job-profile-main{gap:14px;padding:14px}.job-profile-heading{grid-template-columns:52px minmax(0,1fr);gap:14px}.job-profile-icon{width:50px;height:50px}.job-profile-figure{min-height:260px;padding:20px 18px 18px;border-top:1px solid #d4dde7;border-left:0}.job-profile-figure img{width:var(--job-profile-illustration-width, min(74%, 230px));max-height:300px}}@media(max-width:520px){.brand h1{font-size:25px}.brand-mark{width:46px;height:46px}.step-actions{display:grid;grid-template-columns:1fr;justify-content:stretch}.step-button{width:100%}.job-profile-heading{grid-template-columns:46px minmax(0,1fr)}.job-profile-icon{width:44px;height:44px}.job-profile-title strong{font-size:20px}.job-profile-figure{min-height:240px}.job-profile-figure img{width:var(--job-profile-illustration-width, min(80%, 220px));max-height:280px}}
