@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Serif:ital,wght@0,400;0,500;1,400&display=swap";:root{--surface: oklch(98.5% .005 95);--surface-2: oklch(96.5% .008 95);--surface-3: oklch(93% .01 95);--line: oklch(88% .01 95);--line-2: oklch(82% .012 95);--ink: oklch(22% .015 95);--ink-2: oklch(38% .012 95);--ink-3: oklch(55% .01 95);--ink-4: oklch(68% .01 95);--accent: oklch(48% .1 145);--accent-soft: oklch(92% .04 145);--accent-ink: oklch(30% .08 145);--warn: oklch(60% .13 50);--good: oklch(55% .12 145);--serif: "IBM Plex Serif", "Iowan Old Style", Georgia, serif;--sans: "IBM Plex Sans", -apple-system, system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;--row-h: 44px;--pad-x: 14px;--radius: 6px}[data-density=compact]{--row-h: 32px;--pad-x: 10px}*,*:before,*:after{box-sizing:border-box}body,html{margin:0;font-family:var(--sans);color:var(--ink);background:var(--surface);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}.item-icon{display:inline-flex;align-items:center;justify-content:center;border-radius:4px;border:1px solid var(--line);flex-shrink:0}.rarity-dot{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);white-space:nowrap}.rarity-dot__swatch{width:8px;height:8px;border-radius:50%;box-shadow:0 0 0 1px color-mix(in oklch,currentColor 20%,transparent)}.biome-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px 4px 8px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);transition:.12s ease;font-family:inherit}.biome-chip__swatch{width:8px;height:8px;border-radius:2px;background:var(--biome-color, var(--ink-3))}.biome-chip:hover{border-color:var(--line-2);color:var(--ink)}.biome-chip.is-active{background:var(--surface-3);border-color:var(--ink-3);color:var(--ink)}.tag-chip{font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:4px;border:1px solid var(--line);background:var(--surface);color:var(--ink-3);font-family:var(--mono);transition:.12s ease}.tag-chip:hover{color:var(--ink);border-color:var(--line-2)}.tag-chip.is-active{background:var(--ink);color:var(--surface);border-color:var(--ink)}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:13px;transition:.12s ease}.btn:hover{background:var(--surface-2);border-color:var(--line-2)}.btn--primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}.btn--primary:hover{background:oklch(from var(--ink) calc(l + .06) c h)}.btn--ghost{border-color:transparent;background:transparent;color:var(--ink-2)}.btn--ghost:hover{background:var(--surface-2);color:var(--ink)}.btn--sm{padding:3px 8px;font-size:12px}.input{display:block;width:100%;padding:8px 12px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);font-size:14px;font-family:inherit;color:var(--ink);transition:.12s ease}.input:focus{outline:none;border-color:var(--ink-3);box-shadow:0 0 0 3px color-mix(in oklch,var(--ink) 8%,transparent)}.input::placeholder{color:var(--ink-4)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px;border:2px solid var(--surface)}::-webkit-scrollbar-track{background:transparent}.topbar{position:sticky;top:0;background:color-mix(in oklch,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);z-index:30}.topbar__inner{max-width:1280px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;gap:24px}.topbar__brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--ink)}.topbar__mark{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;background:var(--ink);color:var(--surface)}.topbar__logo{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.topbar__name-stack{display:flex;flex-direction:column;gap:0;line-height:1.15}.topbar__name{font-family:var(--serif);font-size:15px;font-weight:500;letter-spacing:-.01em}.topbar__name-sub{color:var(--ink-3);font-style:italic;font-weight:400}.topbar__name-game{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}.topbar__nav{display:flex;gap:4px;margin-left:8px}.topbar__link{padding:6px 10px;border-radius:4px;white-space:nowrap;font-size:13px;color:var(--ink-2);text-decoration:none;transition:.12s ease}.topbar__link:hover{background:var(--surface-2);color:var(--ink)}.topbar__link.is-active{color:var(--ink);background:var(--surface-3)}.topbar__list{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);font-size:12px;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:.12s ease}.topbar__list:hover{border-color:var(--line-2);color:var(--ink)}.topbar__list-star{color:var(--accent);display:flex}.topbar__list-count{font-family:var(--mono);font-weight:600;color:var(--ink)}.page{max-width:1280px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:252px 1fr;gap:44px;align-items:start}.page__main{padding:32px 0 96px;min-width:0}.page__main--wide{grid-column:1 / -1}.rail{position:sticky;top:72px;align-self:start;max-height:calc(100vh - 88px);overflow-y:auto;padding:28px 8px 28px 0;margin-right:-8px}.rail__inner{display:flex;flex-direction:column;gap:18px}.rail__search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:0 10px;transition:.12s ease}.rail__search:focus-within{border-color:var(--ink-3);box-shadow:0 0 0 3px color-mix(in oklch,var(--ink) 8%,transparent)}.rail__search-icon{color:var(--ink-3);display:flex}.rail__search-input{flex:1;min-width:0;border:none;outline:none;background:transparent;padding:10px 2px;font-family:inherit;font-size:14px;color:var(--ink)}.rail__search-input::placeholder{color:var(--ink-4)}.rail__search-clear{border:none;background:none;color:var(--ink-3);font-size:17px;line-height:1;padding:2px 4px;border-radius:4px}.rail__search-clear:hover{background:var(--surface-3);color:var(--ink)}.rail__count{display:flex;align-items:baseline;gap:6px;font-size:12px;color:var(--ink-3)}.rail__count-num{font-family:var(--serif);font-size:20px;color:var(--ink);line-height:1}.rail__count-of{font-family:var(--mono)}.rail__clear{margin-left:auto;border:none;background:none;color:var(--accent-ink);font-size:12px;padding:2px 4px;border-radius:4px}.rail__clear:hover{text-decoration:underline}.rail__group{display:flex;flex-direction:column;gap:8px}.rail__group-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500}.rail__chips{display:flex;flex-wrap:wrap;gap:6px}.rail__listbtn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);font-family:inherit;font-size:13px;white-space:nowrap;transition:.12s ease}.rail__listbtn:hover{border-color:var(--line-2);color:var(--ink)}.rail__listbtn.is-active{background:var(--accent-soft);border-color:color-mix(in oklch,var(--accent) 45%,var(--line));color:var(--accent-ink)}.rail__listbtn-star{display:flex;color:var(--accent)}.rail__listbtn.is-active .rail__listbtn-star{color:var(--accent-ink)}.rail__listbtn-count{margin-left:auto;font-family:var(--mono);font-size:11px;background:var(--surface-3);color:var(--ink-2);padding:0 7px;border-radius:999px}.rail__listbtn.is-active .rail__listbtn-count{background:color-mix(in oklch,var(--accent) 22%,var(--surface));color:var(--accent-ink)}.rail__seg{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.rail__seg-btn{flex:1;border:none;background:var(--surface);color:var(--ink-3);font-family:inherit;font-size:12px;padding:7px 4px;border-right:1px solid var(--line)}.rail__seg-btn:last-child{border-right:none}.rail__seg-btn:hover{color:var(--ink);background:var(--surface-2)}.rail__seg-btn.is-active{background:var(--ink);color:var(--surface)}.rail__bigstat{display:flex;flex-direction:column;gap:6px;padding:14px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px}.rail__bigstat-row{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-2)}.rail__bigstat-row span:first-child{color:var(--ink-3)}.rail__note{font-size:12px;color:var(--ink-3);line-height:1.5;font-style:italic;margin:0}.rail__danger{padding:8px 12px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--warn);font-family:inherit;font-size:13px}.rail__danger:hover{background:color-mix(in oklch,var(--warn) 8%,var(--surface));border-color:color-mix(in oklch,var(--warn) 40%,var(--line))}.ring-stat{position:relative;align-self:center;width:80px;height:80px}.ring-stat__center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ring-stat__pct{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);line-height:1}.ring-stat__sub{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-top:2px}.page-head{margin-bottom:24px;padding-bottom:22px;border-bottom:1px solid var(--line)}.page-head__kicker{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:8px}.page-head__title{font-family:var(--serif);font-size:40px;line-height:1.05;font-weight:500;letter-spacing:-.015em;margin:0 0 12px;color:var(--ink)}.page-head__lede{font-family:var(--serif);font-size:16px;line-height:1.55;color:var(--ink-2);max-width:62ch;margin:0}.page-head__lede em{color:var(--ink);font-style:italic}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.toolbar__count{font-size:13px;color:var(--ink-3)}.toolbar__count strong{color:var(--ink);font-weight:600}.toolbar__right{display:flex;align-items:center;gap:8px}.seg{display:inline-flex;border:1px solid var(--line);border-radius:6px;background:var(--surface);padding:2px}.seg__btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px;border-radius:4px;border:none;background:transparent;color:var(--ink-3);font-family:inherit}.seg__btn:hover{color:var(--ink)}.seg__btn.is-active{background:var(--ink);color:var(--surface)}.item-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}.item-card{position:relative;display:flex;flex-direction:column;gap:8px;text-align:left;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);font-family:inherit;transition:.14s ease}.item-card:hover{border-color:var(--ink-3);transform:translateY(-1px);box-shadow:0 2px 0 var(--line)}.item-card__have{position:absolute;top:10px;right:10px;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border:1px solid color-mix(in oklch,var(--accent) 35%,var(--line));padding:1px 7px;border-radius:999px}.item-card__name{font-weight:600;font-size:14px;color:var(--ink);line-height:1.25}.item-card__meta{display:flex}.item-card__foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto;padding-top:4px}.item-card__biomes{display:flex;gap:3px}.item-card__biome{width:12px;height:12px;border-radius:3px}.item-card__tag{font-family:var(--mono);font-size:10px;text-transform:lowercase;color:var(--ink-3);background:var(--surface-3);padding:1px 6px;border-radius:3px}.item-card__used{font-family:var(--mono);font-size:10px;color:var(--ink-4)}.block-h{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);margin:36px 0 6px;display:flex;align-items:baseline;gap:10px}.block-h:first-child{margin-top:8px}.block-h__count{font-family:var(--mono);font-size:12px;color:var(--ink-3);background:var(--surface-3);padding:1px 8px;border-radius:999px}.block-sub{font-size:13px;color:var(--ink-3);margin:0 0 16px}.mylist-recipes{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;margin-bottom:8px}.mylist-row{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:8px 10px}.mylist-row:hover{border-color:var(--line-2)}.mylist-row__main{flex:1;display:flex;align-items:center;gap:10px;background:none;border:none;padding:0;font-family:inherit;text-align:left;min-width:0}.mylist-row__name{font-weight:500;color:var(--ink)}.mylist-row__sub{display:flex;align-items:center;gap:6px;margin-top:2px;font-size:12px;color:var(--ink-3)}.mylist-row__star{flex-shrink:0}.tracker{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:8px;overflow:hidden}.tracker-row{display:grid;grid-template-columns:minmax(180px,1.4fr) 1fr auto;align-items:center;gap:16px;padding:8px 14px;border-bottom:1px solid var(--line)}.tracker-row:last-child{border-bottom:none}.tracker-row.is-ok{background:color-mix(in oklch,var(--accent-soft) 50%,var(--surface))}.tracker-row__item{display:flex;align-items:center;gap:10px;background:none;border:none;padding:0;font-family:inherit;text-align:left;min-width:0}.tracker-row__name{font-weight:500;color:var(--ink)}.tracker-row__biome{font-family:var(--mono);font-size:11px;color:var(--ink-3);background:var(--surface-3);padding:1px 6px;border-radius:3px;white-space:nowrap}.tracker-row__bar{height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden}.tracker-row__bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .2s ease}.empty-list{text-align:center;padding:64px 24px;border:1px dashed var(--line-2);border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.empty-list__star{color:var(--line-2)}.empty-list__title{font-family:var(--serif);font-size:22px;color:var(--ink)}.empty-list__sub{font-size:14px;color:var(--ink-3);max-width:40ch;margin-bottom:8px}.star-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--ink-4);border-radius:6px;transition:.12s ease}.star-btn:hover{background:var(--surface-3);color:var(--accent-ink)}.star-btn.is-on{color:var(--accent)}.star-btn.is-on:hover{color:var(--accent-ink)}.list-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 12px;border-radius:6px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);font-family:inherit;white-space:nowrap;flex-shrink:0;transition:.12s ease}.list-toggle:hover{border-color:var(--line-2);color:var(--ink)}.list-toggle.is-active{background:var(--accent-soft);border-color:color-mix(in oklch,var(--accent) 45%,var(--line));color:var(--accent-ink)}.list-toggle__star{display:flex}.list-toggle__count{font-family:var(--mono);font-size:11px;background:var(--surface-3);color:var(--ink-2);padding:0 6px;border-radius:999px}.list-toggle.is-active .list-toggle__count{background:color-mix(in oklch,var(--accent) 22%,var(--surface));color:var(--accent-ink)}.gameselect{min-height:100vh;display:flex;flex-direction:column}.gameselect__header{display:flex;align-items:center;gap:8px;padding:0 24px;height:56px;border-bottom:1px solid var(--line)}.gameselect__header .topbar__logo{width:38px;height:38px}.gameselect__main{flex:1;max-width:720px;margin:0 auto;padding:64px 24px}.gameselect__heading{font-family:var(--serif);font-size:32px;font-weight:500;letter-spacing:-.015em;color:var(--ink);margin:0 0 32px}.gameselect__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.gameselect__card{display:flex;flex-direction:column;gap:4px;padding:24px 20px;border:1px solid var(--line);border-radius:10px;background:var(--surface);text-decoration:none;transition:.14s ease}.gameselect__card:hover{border-color:var(--ink-3);transform:translateY(-2px);box-shadow:0 4px 0 var(--line)}.gameselect__card-name{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink)}.gameselect__card-sub{font-family:var(--mono);font-size:12px;color:var(--ink-3)}@media (max-width: 880px){.page{grid-template-columns:1fr;gap:0}.rail{position:static;max-height:none;overflow:visible;padding:20px 0 0;border-bottom:1px solid var(--line)}.tracker-row{grid-template-columns:1fr auto}.tracker-row__bar,.topbar__list{display:none}}.recipe-table-wrap{border:1px solid var(--line);border-radius:8px;background:var(--surface);overflow:hidden}.recipe-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.recipe-table__th{text-align:left;font-weight:500;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);padding:12px var(--pad-x);border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap;position:sticky;top:0;z-index:1}.recipe-table__th.is-right{text-align:right}.recipe-table__th--icon{width:48px;padding-right:0}.recipe-table__th--actions{width:36px}.recipe-table__th--sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.recipe-table__th--sortable:hover{color:var(--ink)}.sort-caret{margin-left:6px;color:var(--ink-4);font-size:11px}.sort-caret.is-active{color:var(--ink)}.recipe-table__row{transition:background .1s ease;cursor:pointer}.recipe-table__row:hover{background:var(--surface-2)}.recipe-table__row:hover .open-arrow{color:var(--ink);transform:translate(2px)}.recipe-table__td{padding:0 var(--pad-x);height:var(--row-h);border-bottom:1px solid var(--line);vertical-align:middle;color:var(--ink-2)}.recipe-table__row:last-child .recipe-table__td{border-bottom:none}.recipe-table__td--icon{padding-right:0}.recipe-table__td--name{color:var(--ink)}.recipe-table__td--num{font-family:var(--mono);text-align:right;font-size:13px;color:var(--ink-2)}.recipe-table__td--actions{color:var(--ink-4);text-align:right;font-family:var(--mono)}.recipe-table__td--ings{padding-top:6px;padding-bottom:6px;min-width:280px}.recipe-table__name{font-weight:500;color:var(--ink)}.recipe-table__yield{font-size:11px;color:var(--ink-3);font-family:var(--mono)}[data-density=compact] .recipe-table__yield{display:none}.station-tag{font-family:var(--mono);font-size:11px;text-transform:lowercase;letter-spacing:.02em;color:var(--ink-2);padding:2px 6px;border-radius:3px;background:var(--surface-3)}.open-arrow{color:var(--ink-4);transition:.12s ease;display:inline-block}.ing-stack{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0}.ing-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 8px 3px 4px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-size:12px;color:var(--ink-2);font-family:inherit;transition:.12s ease;white-space:nowrap;max-width:100%}.ing-pill__name{overflow:hidden;text-overflow:ellipsis}.ing-pill:hover{background:var(--surface-2);border-color:var(--line-2);color:var(--ink)}.ing-pill.is-ok{border-color:color-mix(in oklch,var(--accent) 50%,var(--line));background:var(--accent-soft);color:var(--accent-ink)}.ing-pill__qty{font-family:var(--mono);font-size:11px;color:var(--ink-3)}.ing-pill.is-ok .ing-pill__qty{color:var(--accent-ink)}.ing-pill__note{font-style:italic;color:var(--ink-4);font-size:11px}[data-density=compact] .ing-pill{padding:1px 6px 1px 3px;font-size:11px}[data-density=compact] .ing-stack{gap:3px}.recipe-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.recipe-card{position:relative;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:14px;transition:.14s ease;font-family:inherit;display:flex;flex-direction:column;gap:12px}.recipe-card:hover{border-color:var(--ink-3);box-shadow:0 2px 0 var(--line);transform:translateY(-1px)}.recipe-card__head{display:flex;align-items:center;gap:12px;padding-right:28px}.recipe-card__title{flex:1;min-width:0}.recipe-card__name{font-weight:600;color:var(--ink);font-size:15px}.recipe-card__sub{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3);margin-top:2px;flex-wrap:wrap}.dot-sep{color:var(--ink-4)}.recipe-card__time{font-family:var(--mono)}.recipe-card__body{display:flex;flex-wrap:wrap;gap:6px}.recipe-card__ing{display:inline-flex;align-items:center;gap:6px;padding:3px 8px 3px 4px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);font-size:12px;color:var(--ink-2)}.recipe-card__ing:hover{background:var(--surface-3)}.recipe-card__ing-qty{font-family:var(--mono);font-size:11px;color:var(--ink-3)}.recipe-card__star{position:absolute;top:10px;right:10px}[data-density=compact] .recipe-card{padding:10px;gap:8px}[data-density=compact] .recipe-card__name{font-size:14px}.empty-state{padding:48px 24px;text-align:center;background:var(--surface)}.empty-state__title{font-size:15px;color:var(--ink);margin-bottom:4px}.empty-state__sub{font-size:13px;color:var(--ink-3)}.detail-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#17161100;pointer-events:none;transition:.2s ease;z-index:50}.detail-scrim.is-open{background:#1716114d;pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:min(560px,100vw);background:var(--surface);border-left:1px solid var(--line);z-index:60;transform:translate(100%);transition:transform .22s cubic-bezier(.32,.72,0,1);overflow-y:auto;box-shadow:-16px 0 40px -20px #00000026}.detail-panel.is-open{transform:translate(0)}.detail-panel__close{position:sticky;top:12px;left:100%;margin-left:-42px;margin-right:12px;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;z-index:2;transition:.12s ease}.detail-panel__close:hover{background:var(--ink);color:var(--surface);border-color:var(--ink)}.rd{padding:4px 32px 48px;margin-top:-42px}.rd__head{display:flex;gap:16px;align-items:flex-start;padding-top:20px}.rd__kicker{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px}.rd__title{font-family:var(--serif);font-weight:500;font-size:28px;margin:0;line-height:1.15;color:var(--ink)}.rd__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px;font-size:13px;color:var(--ink-3)}.rd__num{font-family:var(--mono);font-size:12px}.rd__type{font-family:var(--mono);font-size:12px;text-transform:lowercase;padding:2px 6px;border-radius:3px;background:var(--surface-3);color:var(--ink-2)}.rd__desc{margin:18px 0 8px;font-family:var(--serif);font-size:15px;color:var(--ink-2);line-height:1.55;font-style:italic}.rd__section{margin-top:28px}.rd__h{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 12px;font-weight:500;padding-bottom:6px;border-bottom:1px solid var(--line);display:flex;align-items:baseline;gap:8px}.rd__h-sub{font-family:var(--serif);font-style:italic;text-transform:none;letter-spacing:0;color:var(--ink-4);font-size:12px}.rd__h-count{font-family:var(--mono);font-size:11px;background:var(--surface-3);color:var(--ink-2);padding:1px 6px;border-radius:999px;letter-spacing:0}.rd__ings{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.rd__ing{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:8px 10px;border-radius:6px;border:1px solid transparent}.rd__ing:hover{background:var(--surface-2)}.rd__ing.is-ok{border-color:color-mix(in oklch,var(--accent) 30%,var(--line));background:color-mix(in oklch,var(--accent-soft) 60%,var(--surface))}.rd__ing-main{display:flex;align-items:center;gap:10px;background:none;border:none;padding:0;text-align:left;font-family:inherit;color:inherit;min-width:0}.rd__ing-name{font-weight:500;color:var(--ink)}.rd__ing-meta{display:flex;align-items:center;gap:8px;margin-top:2px}.rd__tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);padding:1px 5px;background:var(--surface-3);border-radius:3px}.rd__ing-note{grid-column:1 / -1;font-size:12px;color:var(--ink-3);font-style:italic;padding-left:42px}.counter{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:6px;background:var(--surface);overflow:hidden}.counter__btn{width:26px;height:26px;background:none;border:none;color:var(--ink-2);font-size:14px;line-height:1;font-family:var(--mono)}.counter__btn:hover{background:var(--surface-3);color:var(--ink)}.counter__val{font-family:var(--mono);font-size:12px;padding:0 8px;min-width:50px;text-align:center}.counter__have{color:var(--ink);font-weight:500}.counter__sep{color:var(--ink-4);margin:0 1px}.counter__need{color:var(--ink-3)}.is-ok .counter__have{color:var(--accent-ink)}.counter__divider{width:1px;height:18px;background:var(--line);flex-shrink:0}.counter__btn--multi{width:auto;padding:0 6px;font-size:11px}.counter__input{width:3.5rem;text-align:center;font-family:var(--mono);font-size:12px;font-weight:500;background:transparent;border:none;color:var(--ink);padding:0 4px;-webkit-appearance:none;-moz-appearance:textfield}.counter__input::-webkit-outer-spin-button,.counter__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.craft-tree{list-style:none;margin:0;padding:0 0 0 14px;border-left:1px dashed var(--line-2)}.craft-tree--root{padding-left:0;border-left:none}.craft-tree__node{padding:2px 0}.craft-tree__row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px}.craft-tree__row:hover{background:var(--surface-2)}.craft-tree__row.is-ok{color:var(--accent-ink)}.craft-tree__bullet{width:12px;height:1px;background:var(--line-2);flex-shrink:0}.craft-tree--root .craft-tree__bullet{display:none}.craft-tree__item{display:inline-flex;align-items:center;gap:8px;background:none;border:none;padding:0;font-family:inherit;font-size:13px;color:inherit;text-align:left}.craft-tree__item:hover{color:var(--ink)}.craft-tree__qty{font-family:var(--mono);font-size:12px;color:var(--ink-3)}.craft-tree__open{margin-left:auto;font-size:11px;font-family:var(--mono);color:var(--ink-3);background:none;border:none;padding:2px 6px;border-radius:3px}.craft-tree__open:hover{background:var(--ink);color:var(--surface)}.rd__totals{display:flex;flex-wrap:wrap;gap:6px}.rd__total{display:inline-flex;align-items:center;gap:8px;padding:6px 10px 6px 6px;border-radius:6px;border:1px solid var(--line);background:var(--surface);font-family:inherit;font-size:12px;color:var(--ink-2)}.rd__total:hover{border-color:var(--line-2);color:var(--ink);background:var(--surface-2)}.rd__total-name{color:var(--ink);font-size:13px}.rd__total-qty{font-family:var(--mono);color:var(--ink-3)}.rd__total-sep{color:var(--ink-4);margin:0 2px}.rd__total.is-ok{border-color:color-mix(in oklch,var(--accent) 40%,var(--line));background:var(--accent-soft);color:var(--accent-ink)}.rd__total.is-ok .rd__total-qty{color:var(--accent-ink)}.stockpile{display:flex;align-items:center;gap:12px}.stockpile__hint{font-size:12px;color:var(--ink-3);font-style:italic}.rd__biomes{display:flex;flex-direction:column;gap:6px}.biome-card{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;border:1px solid var(--line);background:var(--surface)}.biome-card__swatch{width:28px;height:28px;border-radius:4px}.biome-card__name{font-weight:500;color:var(--ink)}.biome-card__sub{font-size:11px;color:var(--ink-3);font-family:var(--mono)}.recipe-link{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;border-radius:6px;border:1px solid var(--line);background:var(--surface);font-family:inherit;text-align:left}.recipe-link:hover{border-color:var(--ink-3);background:var(--surface-2)}.recipe-link__main{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-2)}.recipe-link__arrow{color:var(--ink-3)}.rd__used{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.rd__used-row{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:none;border:none;border-radius:4px;font-family:inherit;text-align:left}.rd__used-row:hover{background:var(--surface-2)}.rd__used-name{color:var(--ink);flex:1}.rd__used-qty{font-family:var(--mono);font-size:12px;color:var(--ink-3)}.rd__used-arrow{color:var(--ink-4)}.rd__list-btn{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:8px 14px;border-radius:6px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit;font-size:13px;transition:.12s ease}.rd__list-btn:hover{border-color:var(--ink-3);background:var(--surface-2)}.rd__list-btn.is-on{background:var(--accent-soft);border-color:color-mix(in oklch,var(--accent) 45%,var(--line));color:var(--accent-ink)}.ach{display:flex;flex-direction:column;gap:16px}.ach__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.ach-card{display:flex;gap:14px;align-items:flex-start;text-align:left;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);font-family:inherit;transition:.14s ease}.ach-card.is-auto{cursor:default}.ach-card:not(.is-auto):hover{border-color:var(--ink-3);background:var(--surface-2)}.ach-card.is-done{background:color-mix(in oklch,var(--accent-soft) 50%,var(--surface));border-color:color-mix(in oklch,var(--accent) 35%,var(--line))}.ach-card__badge{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:color-mix(in oklch,var(--tier-color) 14%,var(--surface));color:color-mix(in oklch,var(--tier-color) 70%,var(--ink));border:1px solid color-mix(in oklch,var(--tier-color) 40%,var(--line))}.ach-card.is-done .ach-card__badge{background:var(--accent);color:var(--surface);border-color:var(--accent)}.ach-card__body{flex:1;min-width:0}.ach-card__name{display:block;font-weight:600;font-size:14px;color:var(--ink);line-height:1.25}.ach-card__desc{font-size:12.5px;color:var(--ink-2);margin-top:3px;line-height:1.45}.ach-card__foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px}.ach-card__track{font-family:var(--mono);font-size:11px;color:var(--ink-3);display:inline-flex;align-items:center;gap:5px}.ach-card__auto-dot{width:6px;height:6px;border-radius:50%;background:var(--good);flex-shrink:0}.ach-card.is-done .ach-card__track{color:var(--accent-ink)}.ach-card__bar{height:4px;background:var(--surface-3);border-radius:999px;overflow:hidden;margin-top:8px}.ach-card__bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.ach__note{font-size:12px;color:var(--ink-3);font-style:italic}@media (max-width: 900px){.ach__grid{grid-template-columns:1fr}}
