:root{--ink:#17223b;--muted:#66728b;--blue:#4169e1;--deep:#243b8d;--pale:#eef3ff;--line:#dfe6f3;--white:#fff;--yellow:#fff7d6;--red:#fff0ef;--green:#eaf9f1}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:24px}body{color:var(--ink);background:#f8faff;margin:0;font-family:Noto Sans JP,Yu Gothic UI,Hiragino Sans,sans-serif;line-height:1.8}button,a{font:inherit}a{color:inherit}.hero{color:#fff;background:radial-gradient(circle at 73% 35%,#637ff0 0,#304dc1 36%,#17296d 75%,#101d50 100%);min-height:720px;position:relative;overflow:hidden}.topbar{z-index:4;justify-content:space-between;align-items:center;max-width:1240px;height:76px;margin:auto;padding:0 28px;display:flex;position:relative}.brand{color:#fff;letter-spacing:.03em;align-items:center;gap:10px;font-weight:800;text-decoration:none;display:flex}.brand-mark{color:#304dc1;background:#fff;border-radius:11px;place-items:center;width:34px;height:34px;display:grid}.os-switch{background:#10215a80;border:1px solid #ffffff4a;border-radius:999px;padding:4px;display:flex}.os-switch button{color:#cdd7ff;cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 17px}.os-switch button.active{color:#19337f;background:#fff;font-weight:800}.hero-content{z-index:2;max-width:1180px;margin:0 auto;padding:105px 28px;position:relative}.eyebrow,.section-kicker{letter-spacing:.22em;font-size:.75rem;font-weight:900}.eyebrow{color:#b9c7ff}.hero h1{letter-spacing:-.06em;margin:10px 0 22px;font-size:clamp(3.2rem,7vw,6.7rem);line-height:1.06}.hero h1 span{color:#bad0ff}.lead{color:#dce4ff;font-size:1.1rem}.start-button,.link-button{border-radius:12px;justify-content:center;align-items:center;gap:14px;font-weight:800;text-decoration:none;display:inline-flex}.start-button{color:#243e9c;background:#fff;margin-top:25px;padding:14px 23px;box-shadow:0 12px 30px #08164f66}.hero-tags{gap:9px;margin-top:32px;display:flex}.hero-tags span{color:#dce5ff;border:1px solid #ffffff3b;border-radius:99px;padding:5px 12px;font-size:.78rem}.hero-art{pointer-events:none;position:absolute;inset:0 0 0 47%}.orb{filter:blur(1px);background:#ffffff16;border-radius:50%;position:absolute}.orb-one{width:520px;height:520px;top:80px;right:-100px}.orb-two{width:220px;height:220px;bottom:-50px;left:30px}.code-window{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#101a43c9;border:1px solid #ffffff38;border-radius:22px;width:390px;padding:25px;position:absolute;top:28%;right:10%;transform:rotate(3deg);box-shadow:0 35px 80px #06103d88}.code-window .dots{color:#91a5ff;letter-spacing:8px;font-size:.55rem}.code-window strong{margin:35px 0 7px;font-size:2rem;display:block}.code-window p{color:#b7c4ed}.typing{color:#e4eaff;background:#ffffff0d;border:1px solid #ffffff21;border-radius:10px;margin-top:35px;padding:15px}main{max-width:1200px;margin:auto;padding:85px 24px}.intro-section{justify-content:space-between;align-items:end;margin-bottom:30px;display:flex}.section-kicker{color:var(--blue);margin:0}.intro-section h2{letter-spacing:-.04em;margin:4px 0;font-size:2.25rem}.intro-section p:last-child{color:var(--muted);margin:0}.progress-card{border:1px solid var(--line);background:#fff;border-radius:15px;width:300px;padding:18px 20px;box-shadow:0 12px 30px #26345b0d}.progress-card>div:first-child{display:inline}.progress-card strong{font-size:1.8rem}.progress-card>span{float:right;color:var(--blue);margin-top:9px;font-weight:800}.progress-track{background:#e9edfa;border-radius:99px;height:7px;margin-top:8px;overflow:hidden}.progress-track div{background:linear-gradient(90deg,#4a6ee3,#7f66dc);border-radius:99px;height:100%;transition:width .3s}.chapter-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:30px;display:grid}.chapter-link{border:1px solid var(--line);background:#fff;border-radius:15px;grid-template-columns:48px 1fr 20px;align-items:center;gap:14px;padding:18px;text-decoration:none;transition:all .2s;display:grid;box-shadow:0 7px 20px #20315c09}.chapter-link:hover{border-color:#9eb1ec;transform:translateY(-2px)}.chapter-link.done{background:var(--green);border-color:#a5dfbf}.chapter-icon{color:#fff;background:linear-gradient(135deg,#496ee2,#755ac7);border-radius:13px;place-items:center;width:45px;height:45px;font-size:1.25rem;font-weight:800;display:grid}.chapter-link small{color:var(--blue);letter-spacing:.1em;font-size:.68rem;font-weight:900;display:block}.chapter-link strong{line-height:1.35;display:block}.arrow{color:#7c89a5}.notice{border:1px solid #cbd8fb;border-left:5px solid var(--blue);background:var(--pale);border-radius:12px;margin:26px 0;padding:18px 20px}.notice.warning{background:var(--yellow);border-color:#f3d77c #f3d77c #f3d77c #e3ad11}.notice.danger{background:var(--red);border-color:#f0b1ac #f0b1ac #f0b1ac #df544a}.notice strong{margin-bottom:2px;display:block}.notice p{color:#59657c;margin:0}.content-layout{grid-template-columns:210px 1fr;gap:38px;margin-top:70px;display:grid}.side-nav{height:max-content;padding:18px 0;position:sticky;top:20px}.side-nav>strong{margin-bottom:12px;display:block}.side-nav>a{color:#66738e;gap:10px;padding:8px 0;font-size:.78rem;line-height:1.4;text-decoration:none;display:flex}.side-nav>a:hover{color:var(--blue)}.side-nav>a span{color:#9aa6bd;font-weight:800}.mini-progress{background:#eef2fb;border-radius:12px;margin-top:22px;padding:14px;font-size:.7rem}.mini-progress strong{float:right;color:var(--blue)}.mini-progress div{background:#dce3f2;border-radius:9px;height:5px;margin-top:8px}.mini-progress i{background:var(--blue);border-radius:9px;height:100%;display:block}.sections{min-width:0}.workshop-section{border:1px solid var(--line);background:#fff;border-radius:20px;margin-bottom:38px;overflow:hidden;box-shadow:0 16px 40px #26345b0b}.section-heading{color:#fff;background:linear-gradient(120deg,#243e98,#5273df);gap:20px;padding:32px 35px;display:flex}.section-heading>span{color:#ffffff35;font-size:3.3rem;font-weight:900;line-height:1}.section-heading p{color:#c9d6ff;letter-spacing:.16em;margin:0;font-size:.7rem;font-weight:900}.section-heading h2{margin:0;font-size:1.7rem;line-height:1.4}.section-heading em{color:#dce4ff;font-size:.9rem;font-style:normal}.section-body{padding:35px}.section-body h3{margin:32px 0 10px}.section-body>p{color:#536079}.steps{gap:14px;margin-bottom:20px;display:grid}.step{border:1px solid var(--line);border-radius:13px;gap:16px;padding:17px;display:flex}.step>span,.card-num{color:#fff;background:var(--blue);border-radius:50%;flex:none;place-items:center;width:30px;height:30px;font-size:.8rem;font-weight:900;display:grid}.step strong{display:block}.step p{color:#66728b;margin:2px 0 0;font-size:.9rem}.link-button{color:#fff;background:var(--blue);margin:12px 0;padding:10px 17px;font-size:.88rem}.link-button:hover{background:#2e50bd}.os-panel{background:#f3f6ff;border:1px solid #cdd9f8;border-radius:16px;padding:24px}.os-label{color:#fff;background:var(--blue);border-radius:99px;padding:4px 10px;font-size:.68rem;font-weight:900}.os-panel h3{margin:12px 0}.keys{align-items:center;gap:9px;margin:16px 0;display:flex}kbd{color:#293650;background:#fff;border:1px solid #b5bfd4;border-bottom-width:3px;border-radius:7px;place-items:center;min-width:34px;padding:5px 8px;font-family:inherit;font-weight:800;display:inline-grid;box-shadow:0 2px #dce2ef}.tip{background:#e2e9fc;border-radius:8px;padding:9px 12px;font-size:.84rem}.shortcut-list p{border-bottom:1px solid #dfe6f5;justify-content:space-between;align-items:center;gap:15px;padding:11px 0;display:flex}.shortcut-list p:last-child{border:0}.two-cards{grid-template-columns:1fr 1fr;gap:13px;display:grid}.small-card{border:1px solid var(--line);background:#fbfcff;border-radius:14px;padding:20px}.small-card strong{font-size:1rem;display:block}.small-card p{color:#68738a;margin:5px 0 0;font-size:.87rem}.route{flex-wrap:wrap;align-items:center;gap:9px;margin:12px 0 18px;display:flex}.route span{background:#f2f5fd;border:1px solid #cdd8f4;border-radius:8px;padding:7px 12px;font-size:.84rem;font-weight:800}.route b{color:#9aa7bf}.copy-box{margin:12px 0 22px;position:relative}.copy-box pre{color:#e3eaff;white-space:pre-wrap;background:#142044;border-radius:14px;max-height:420px;margin:0;padding:22px 22px 70px;font-family:Yu Gothic UI,sans-serif;font-size:.78rem;line-height:1.7;overflow:auto}.copy-button{color:#fff;cursor:pointer;background:#ffffff18;border:1px solid #ffffff40;border-radius:8px;padding:8px 14px;position:absolute;bottom:12px;right:12px}.copy-button:hover{background:#ffffff2c}.number-list{padding-left:25px}.number-list li{color:#536079;padding:7px}.done-button{color:#64718a;cursor:pointer;background:#f8faff;border:1px dashed #aebbd2;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:32px;padding:13px;font-weight:800;display:flex}.done-button span{border:2px solid #aebbd2;border-radius:50%;place-items:center;width:23px;height:23px;display:grid}.done-button.completed{color:#187b49;background:var(--green);border-style:solid;border-color:#9bd4b5}.done-button.completed span{color:#fff;background:#25965d;border-color:#25965d}.finish{text-align:center;background:linear-gradient(135deg,#eef2ff,#f6efff);border-radius:16px;margin-top:30px;padding:30px}.finish span{color:#fff;background:var(--blue);border-radius:99px;padding:4px 14px;font-weight:900;display:inline-block}.finish h3{margin:12px 0 3px}.finish p{color:#66728b;margin:0}footer{color:#d5defb;background:#15265f;align-items:center;gap:20px;padding:28px max(24px,50% - 575px);display:flex}footer span{color:#99a8d4;font-size:.8rem}footer a{color:#fff;margin-left:auto;font-size:.8rem;font-weight:800;text-decoration:none}@media (max-width:950px){.hero{min-height:670px}.hero-art{opacity:.25;inset:0}.code-window{right:-80px}.content-layout{display:block}.side-nav{display:none}.chapter-grid{grid-template-columns:1fr}.intro-section{align-items:start;gap:20px}.progress-card{flex:0 0 250px}}@media (max-width:650px){.topbar{padding:0 16px}.brand{font-size:.85rem}.brand-mark{width:29px;height:29px}.os-switch button{padding:6px 11px;font-size:.72rem}.hero{min-height:620px}.hero-content{padding:80px 20px}.hero h1{font-size:3.25rem}.lead{font-size:.94rem}.desktop-only{display:none}.hero-tags{flex-wrap:wrap}.hero-art{display:none}main{padding:60px 14px}.intro-section{display:block}.intro-section h2{font-size:1.8rem}.progress-card{width:100%;margin-top:20px}.chapter-link{grid-template-columns:42px 1fr 15px;padding:14px}.chapter-icon{width:40px;height:40px}.workshop-section{border-radius:15px}.section-heading{gap:12px;padding:23px 20px}.section-heading>span{font-size:2.4rem}.section-heading h2{font-size:1.3rem}.section-heading em{font-size:.78rem}.section-body{padding:21px 17px}.two-cards{grid-template-columns:1fr}.keys{flex-wrap:wrap}.shortcut-list p{flex-direction:column;align-items:start}.copy-box pre{font-size:.7rem}.link-button{width:100%;font-size:.78rem}.route{gap:5px}.route span{font-size:.72rem}.route b{font-size:.7rem}footer{flex-direction:column;align-items:start;gap:4px}footer a{margin:12px 0 0}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.chapter-link{transition:none}}
