*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f4ea;--surface:#fff;--surface-soft:#fbf7eb;--ink:#1f160d;--ink-2:#4a3a26;--ink-3:#8e7d62;--ink-4:#c4b496;--line:#1f160d1a;--line-strong:#1f160d33;--vermilion:#c44a3a;--matcha:#7a8b56;--gold:#a47b35;--shadow:0 1px 2px #1f160d0a, 0 4px 16px #1f160d0f;--r:8px;--r-lg:12px;--mono:"JetBrains Mono", "SF Mono", Menlo, ui-monospace, monospace;--serif:"Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;--sans:"Zen Kaku Gothic New", "Hiragino Sans", system-ui, sans-serif}html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;min-height:100vh}button{font:inherit;color:inherit;cursor:pointer}.app{flex-direction:column;gap:28px;max-width:880px;margin:0 auto;padding:48px 24px 56px;display:flex}.header{justify-content:space-between;align-items:baseline;gap:24px;display:flex}.title{color:var(--ink);align-items:baseline;gap:14px;display:flex}.logo{padding:22px 4px 10px 18px;display:inline-block;position:relative}.logo-art{pointer-events:none;width:calc(100% - 18px);height:22px;position:absolute;top:0;left:14px}.logo-text{font-family:var(--serif);letter-spacing:.08em;z-index:1;font-size:25px;font-weight:700;display:block;position:relative}.logo-pot{pointer-events:none;width:22px;height:10px;position:absolute;bottom:-2px;left:0}.title-en{font-family:var(--mono);color:var(--ink-3);letter-spacing:.16em;font-size:11px;font-weight:400}.overall{font-family:var(--mono);align-items:baseline;gap:6px;display:inline-flex}.overall-label{font-family:var(--serif);color:var(--ink-3);letter-spacing:.18em;margin-right:2px;font-size:11px}.overall-value{color:var(--matcha);font-size:18px;font-weight:700}.overall-of{color:var(--ink-3);font-size:11px}.home{flex-direction:column;gap:24px;max-width:640px;padding:8px 0 24px;display:flex}.home-tagline{font-family:var(--serif);letter-spacing:.04em;color:var(--ink);font-size:22px;font-weight:700;line-height:1.4}.home-desc{font-family:var(--serif);color:var(--ink-2);letter-spacing:.02em;font-size:15px;line-height:1.85}.home-howto{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);flex-direction:column;gap:10px;padding:18px 22px;display:flex}.home-howto-title{font-family:var(--serif);letter-spacing:.18em;color:var(--vermilion);margin-bottom:2px;font-size:13px;font-weight:700}.home-howto-list{counter-reset:howto;flex-direction:column;gap:8px;padding:0;list-style:none;display:flex}.home-howto-list li{counter-increment:howto;font-family:var(--serif);color:var(--ink-2);letter-spacing:.01em;padding-left:32px;font-size:14.5px;line-height:1.7;position:relative}.home-howto-list li:before{content:counter(howto);background:var(--matcha);color:#fff;width:22px;height:22px;font-family:var(--mono);letter-spacing:0;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:2px;left:0}.home-cta{flex-wrap:wrap;align-items:center;gap:12px;margin-top:4px;display:flex}.home-start{letter-spacing:.06em;padding:11px 22px;font-size:14px}.home-start-from-zero{font-size:12px}.logo-btn{cursor:pointer;text-align:left;background:0 0;border:none}.logo-btn:disabled{cursor:default}.rail{align-items:center;gap:12px;display:flex}.rail-btn{border:1px solid var(--line);background:var(--surface);width:26px;height:26px;color:var(--ink-2);font-family:var(--mono);border-radius:var(--r);justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:inline-flex}.rail-btn:hover:not(:disabled){border-color:var(--ink-3);color:var(--ink)}.rail-btn:disabled{visibility:hidden}.dots{flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.dot{background:var(--ink-4);border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:all .15s}.dot:hover{background:var(--ink-3);transform:scale(1.2)}.dot.done{background:var(--matcha)}.dot.current{background:var(--vermilion);border-radius:999px;width:22px}.dot.locked{border:1px dashed var(--ink-4);cursor:not-allowed;background:0 0}.dot.locked:hover{background:0 0;transform:none}.prompt{flex-direction:column;gap:8px;display:flex}.meta{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:10px;font-size:10px;display:flex}.meta-num{color:var(--vermilion);font-weight:700}.meta-chapter{color:var(--ink-3)}.t{font-family:var(--serif);color:var(--ink);letter-spacing:.04em;min-height:59.4px;font-size:22px;font-weight:700;line-height:1.35}.d{font-family:var(--serif);color:var(--ink-2);letter-spacing:.01em;max-width:720px;min-height:52.5px;font-size:15px;font-weight:400;line-height:1.75}.actions{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-top:4px;display:flex}.modes{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.hint-link{color:var(--ink-3);font-family:var(--mono);letter-spacing:.06em;background:0 0;border:none;align-items:center;gap:6px;padding:6px 4px;font-size:11px;transition:color .15s;display:inline-flex}.hint-link:hover{color:var(--vermilion)}.hint-icon{width:18px;height:18px;font-family:var(--serif);border:1px solid;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.mode{background:var(--surface);border:1px solid var(--line);border-radius:999px;align-items:center;gap:4px;width:fit-content;padding:3px 3px 3px 10px;display:inline-flex}.mode-group-label{font-family:var(--serif);letter-spacing:.18em;color:var(--ink-3);margin-right:4px;font-size:10px}.mode-btn{color:var(--ink-3);font-family:var(--mono);letter-spacing:.04em;background:0 0;border:none;border-radius:999px;align-items:center;gap:6px;padding:5px 11px;font-size:11px;transition:all .15s;display:inline-flex}.mode-btn.on{background:var(--ink);color:#fff}.mode-btn:not(.on):hover{color:var(--ink)}.mode-btn:disabled{opacity:.5;cursor:default}.mdot{border-radius:50%;width:6px;height:6px}.mdot-merge{background:var(--vermilion)}.mdot-rebase{background:var(--matcha)}.mdot-cherry-pick{background:#d97a91}.mdot-squash{background:var(--gold)}.mdot-revert{background:#6b8aa8}.mdot-reset{background:#4a3a26}.boards{grid-template-columns:1fr 1fr;gap:16px;display:grid}.board{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);transition:box-shadow .4s;position:relative;overflow:hidden}.board.cleared{box-shadow:0 0 0 1px var(--matcha), 0 0 24px #7a8b5647, var(--shadow)}.bh{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:10px 14px;display:flex}.lbl{font-family:var(--serif);color:#fff;letter-spacing:.1em;border-radius:3px;padding:2px 9px;font-size:11px;font-weight:600}.lbl.your{background:var(--vermilion)}.lbl.goal{background:var(--matcha)}.bb{background:var(--surface-soft);flex-direction:column;min-height:560px;padding:16px;display:flex;position:relative}.bb-inner,.bb-inner>div{flex:1;min-height:0;display:flex}.bb-inner svg{width:100%;height:100%;display:block}.check{pointer-events:none;color:#7a8b5673;font-size:140px;font-family:var(--serif);z-index:2;justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute;inset:0}.mask{border:2px dashed var(--line-strong);text-align:center;background-image:repeating-linear-gradient(45deg,#0000 0 12px,#1f160d08 12px 24px);border-radius:8px;flex-direction:column;flex:1;justify-content:center;align-self:stretch;align-items:center;gap:10px;width:100%;padding:24px;display:flex}.mask-icon{font-family:var(--serif);color:var(--ink-4);font-size:48px;font-weight:700;line-height:1}.mask-text{font-family:var(--serif);color:var(--ink-2);letter-spacing:.04em;font-size:14px}.mask-sub{font-family:var(--mono);color:var(--ink-3);letter-spacing:.06em;font-size:11px}.reveal-btn{border:1px solid var(--line);color:var(--ink-3);font-family:var(--mono);letter-spacing:.04em;background:0 0;border-radius:999px;margin-left:auto;padding:4px 12px;font-size:11px;transition:all .15s}.reveal-btn:hover{border-color:var(--vermilion);color:var(--vermilion)}.foot{justify-content:center;gap:8px;display:flex}.btn{background:var(--surface);color:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);font-family:var(--mono);letter-spacing:.04em;padding:8px 16px;font-size:12px;transition:all .15s}.btn:hover:not(:disabled){border-color:var(--ink-3);color:var(--ink)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn.primary{background:var(--matcha);color:#fff;border-color:var(--matcha)}.btn.primary:hover{background:#94a86a;border-color:#94a86a}.hint-wrap{display:inline-flex;position:relative}.hint-tooltip{background:var(--surface);border:1px solid var(--line-strong);border-left:3px solid var(--vermilion);border-radius:var(--r);z-index:50;opacity:0;visibility:hidden;pointer-events:none;width:max-content;max-width:320px;padding:12px 16px;transition:opacity .15s,visibility .15s,transform .15s;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(-2px);box-shadow:0 12px 32px #1f160d29,0 2px 6px #1f160d14}.hint-wrap:hover .hint-tooltip,.hint-wrap:focus-within .hint-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.hint-tooltip strong{font-family:var(--serif);color:var(--vermilion);letter-spacing:.18em;margin-bottom:6px;font-size:11px;display:block}.hint-tooltip p{font-family:var(--serif);color:var(--ink);font-size:13px;line-height:1.65}.banner{background:var(--matcha);color:#fff;font-family:var(--serif);letter-spacing:.06em;z-index:60;border-radius:999px;align-items:center;gap:12px;padding:10px 18px;font-size:13px;font-weight:600;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 32px #5e6f3e52}.banner-next{color:#fff;font-family:var(--mono);letter-spacing:.04em;background:#fff3;border:1px solid #fff6;border-radius:999px;padding:4px 12px;font-size:11px;transition:background .15s}.banner-next:hover{background:#ffffff52}.cmd-line{justify-content:center;align-items:center;min-height:40px;margin-top:4px;display:flex;position:relative}.cmd{color:#ede4c9;font-family:var(--mono);letter-spacing:.02em;background:linear-gradient(#2a1f12 0%,#1a1208 100%);border-radius:8px;align-items:center;gap:10px;max-width:100%;padding:8px 16px 8px 14px;font-size:12.5px;line-height:1;display:inline-flex;overflow:hidden;box-shadow:inset 0 1px #ffffff0a,0 6px 18px #1f160d2e,0 0 0 1px #1f160d73}.cmd-prompt{color:#9bcf8a;flex:none;font-weight:700}.cmd-text{color:inherit;white-space:nowrap;text-overflow:ellipsis;background:0 0;min-width:0;font-weight:500;overflow:hidden}.solved{background:var(--surface);border:1px solid #7a8b5666;border-left:3px solid var(--matcha);border-radius:var(--r);flex-direction:column;gap:10px;width:100%;max-width:720px;padding:14px 18px 14px 16px;display:flex;box-shadow:0 1px 2px #1f160d0a,0 8px 24px #7a8b561f}.solved-head{align-items:center;gap:10px;display:flex}.solved-badge{font-family:var(--serif);letter-spacing:.18em;color:#fff;background:var(--matcha);border-radius:3px;flex:none;padding:3px 10px;font-size:11px;font-weight:700}.solved-step-count{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;font-size:11px}.solved-cmds{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.solved-cmd-row{align-items:center;gap:10px;min-width:0;display:flex}.solved-step-num{background:var(--matcha);color:#fff;width:18px;height:18px;font-family:var(--mono);border-radius:50%;flex:none;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.solved-cmd{font-family:var(--mono);color:var(--ink);background:var(--surface-soft);border:1px solid var(--line);border-radius:6px;flex:auto;align-items:center;gap:8px;min-width:0;padding:6px 12px;font-size:12.5px;display:inline-flex;overflow:hidden}.solved-cmd .cmd-prompt{color:var(--matcha);flex:none;font-weight:700}.solved-cmd .cmd-text{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.solved-lesson{font-family:var(--serif);color:var(--ink-2);letter-spacing:.02em;margin:0;font-size:13.5px;line-height:1.7}.solved-badge.final{background:linear-gradient(135deg, var(--gold), var(--vermilion));letter-spacing:.22em;padding:4px 14px;font-size:12px}.solved .final-lesson{color:var(--ink);font-size:14px;line-height:1.85}.home-allcleared{border-radius:var(--r);background:linear-gradient(135deg,#a47b351f,#c44a3a1a);border:1px solid #a47b354d;align-items:center;gap:12px;width:fit-content;padding:12px 16px;display:flex}.home-allcleared-badge{font-family:var(--serif);letter-spacing:.22em;color:#fff;background:linear-gradient(135deg, var(--gold), var(--vermilion));border-radius:3px;flex:none;padding:4px 12px;font-size:11px;font-weight:700}.home-allcleared-text{font-family:var(--serif);color:var(--ink-2);letter-spacing:.02em;margin:0;font-size:13px}@media (width<=720px){.app{gap:20px;padding:28px 16px 40px}.boards{grid-template-columns:1fr}.header{flex-direction:column;align-items:flex-start;gap:8px}.title{font-size:20px}.t{font-size:16px}.d{font-size:15px}}
