:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{margin:0;font-family:Cinzel,serif;color:#d5b378;background:#8d4a32;background:linear-gradient(90deg,#fff0,#101a24 15%,#1d2a36 30% 70%,#101a24 85%,#fff0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:flex;align-items:center;justify-content:center}.container{margin:0 auto;padding:2rem;text-align:center;box-sizing:border-box}.app-layout{display:flex;align-items:flex-start;gap:18px}.sidebar{position:fixed;left:0;top:0;width:220px;height:100vh;background:linear-gradient(180deg,#0000001f,#0000000f);border-right:1px solid rgba(213,179,120,.06);padding:12px;box-sizing:border-box;z-index:40;overflow:auto;transition:width .16s ease}.sidebar.collapsed{width:64px}.sidebar .sidebar-inner{display:flex;flex-direction:column;gap:12px;height:100%}.sidebar-footer{margin-top:auto;font-size:12px;color:#d5b378;opacity:.9;padding:8px 6px;text-align:center}.sidebar.collapsed .sidebar-footer{font-size:11px;padding:6px 4px}.sidebar-collapse{align-self:flex-end}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px;background:transparent;border:none;color:inherit;cursor:pointer}.nav-icon{font-size:16px}.nav-label{font-weight:600}.container.sidebar-open{margin-left:220px}.container.sidebar-collapsed{margin-left:64px}.title{font-size:3rem;margin:0 0 1.5rem;letter-spacing:.08em;color:#d5b378}legend{margin-bottom:1rem}.controls{display:flex;flex-direction:column;gap:1rem;align-items:center;margin-bottom:1.5rem}.weights-row{width:100%;display:flex;flex-direction:column;gap:.5rem;align-items:center;min-width:120px;flex:1 1 120px}.weights-row .justify-center,.weights-row .weights-row{justify-content:center}.weights-row .weights-title{font-size:.95rem;opacity:.95}.weights-row .weights-row{width:100%;display:flex;flex-direction:column;gap:.5rem;align-items:center;justify-content:center}.weight-label{font-size:.8rem;margin-bottom:.25rem;margin:0 10px}.weight-input{width:2rem;padding:.35rem .5rem;border-radius:6px;border:1px solid rgba(213,179,120,.12);background:#ffffff05;color:#d5b378}.multi{min-width:220px;max-width:420px;height:6rem;padding:.35rem;border-radius:6px;border:1px solid rgba(213,179,120,.12);background:#ffffff05;color:#d5b378}.weight-bonus{width:120px;padding:.35rem .5rem;border-radius:6px;border:1px solid rgba(213,179,120,.12);background:#ffffff05;color:#d5b378}.excluded{display:flex;gap:1rem;border:none;padding:0;flex-wrap:wrap;justify-content:center;align-items:center}.checkbox-label{display:inline-flex;gap:.35rem;align-items:center;color:#d5b378;flex:1 1 180px;justify-content:center}@media(max-width:880px){.weights{justify-content:center}.weight{flex:1 1 140px}.multi{max-width:100%;width:100%;height:auto}.weight-input{width:100%;box-sizing:border-box}.weight-bonus{width:100%;max-width:240px}.excluded{gap:.5rem}.checkbox-label{flex:1 1 45%}}@media(max-width:560px){.controls{align-items:stretch}.weights{flex-direction:column;align-items:stretch}.weight{flex-direction:row;justify-content:space-between;padding:.25rem 0}.weight-label{margin-bottom:0}.weight-input{width:6rem}.multi{height:5rem}.excluded{flex-direction:column}.checkbox-label{width:100%}}.label{font-size:.9rem;opacity:.9}.select{padding:.5rem 1.75rem .5rem .75rem;font-size:1rem;border-radius:6px;border:1px solid rgba(213,179,120,.2);background:#ffffff05;color:#d5b378;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23D5B378' d='M0 0l5 6 5-6z'/></svg>");background-repeat:no-repeat;background-position:right .75rem center;background-size:10px 6px}.buttons{display:flex;gap:.75rem;margin-top:.5rem}.btn{padding:.6rem 1rem;font-size:1rem;border-radius:6px;border:1px solid rgba(213,179,120,.15);background:linear-gradient(180deg,#d5b3781f,#d5b3780f);color:#d5b378;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.ghost{background:transparent;border:1px solid rgba(213,179,120,.08)}.log{text-align:center;margin-top:1.25rem;display:flex;flex-direction:column;align-items:center}.log h2{margin:1rem 0;font-size:1.1rem}.log-window{min-height:8rem;max-height:200px;overflow:auto;padding:1rem;border-radius:8px;background:#ffffff05;border:1px solid rgba(213,179,120,.06);display:flex;flex-direction:column;align-items:center;width:100%;max-width:1000px}.empty{opacity:.7}.log-line{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:.9rem;color:#f6e7d0;padding:.12rem 0;border-bottom:1px dashed rgba(255,255,255,.02);text-align:center;width:100%}.log-line.info{color:#f6e7d0}.result-window{max-width:1200px;margin:18px auto;padding:12px;box-sizing:border-box}.result-title{margin-bottom:12px}.slot-group{margin-bottom:14px}.slot-name{margin:8px 0;font-size:16px;color:#1b2b40}.items-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.inventory-window .inventory-wrapper{display:grid;grid-template-columns:1fr 140px 1fr;gap:18px;align-items:start;justify-items:center}.inventory-window .column{display:flex;flex-direction:column;gap:12px;width:100%;max-width:260px}.slot-tile{background:linear-gradient(180deg,#ffffff08,#0000000f);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:8px;min-height:64px;display:flex;align-items:center}.empty-tile{opacity:1;justify-content:center}.slot-label{font-size:12px;color:#cfcfcf}.hero-column{display:flex;align-items:center;justify-content:center}.hero-face{font-weight:700;color:#fffffff2}.mini-item{display:flex;flex-direction:column;gap:6px;width:100%}.mini-header{display:flex;justify-content:space-between;align-items:baseline}.mini-name{font-size:13px;font-weight:600}.mini-slot{font-size:12px;color:#f3f4f6;background:#0000002e;padding:2px 6px;border-radius:6px}.mini-meta{font-size:11px;color:#d1d5db}.mini-stats{display:flex;justify-content:center;gap:6px}.mini-dungeon{font-size:11px;color:#9ca3af;background:#101a2499;padding:2px 6px;border-radius:6px}.inventory-window .stat-pill{background:linear-gradient(180deg,#fff,#eaf4ff);padding:4px 8px;border-radius:999px;font-size:12px}@media(max-width:880px){.inventory-window .inventory-wrapper{grid-template-columns:1fr;gap:12px}.hero-sprite{margin:6px 0}}.item-card{border-radius:12px;padding:12px;background:linear-gradient(135deg,#fff,#f0f7ff);box-shadow:0 6px 18px #141e320f;transition:transform .14s ease,box-shadow .14s ease;border:1px solid rgba(10,30,60,.04)}.item-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px #0a1e3c1f}.card-header{display:flex;justify-content:space-between;align-items:center}.item-name{font-size:14px;color:#07203a}.item-score{font-size:12px;color:#3b4b63}.meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:#264155}.stats-row{display:flex;gap:8px;margin-top:10px;justify-content:center}.stat-pill{padding:6px 10px;border-radius:999px;background:linear-gradient(180deg,#fff,#eaf4ff);border:1px solid rgba(20,60,100,.06);font-weight:600;color:#073257;min-width:84px;text-align:center}@media(max-width:520px){.items-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-pill{min-width:68px;padding:6px 8px}}.section-sep{display:flex;align-items:center;justify-content:center;gap:.75rem;margin:1.25rem 0;width:20%}.section-sep .diamond{width:12px;height:12px;background:#d5b378;transform:rotate(45deg);border-radius:2px;box-shadow:0 0 6px #d5b3781f}.section-sep .bar{height:3px;flex:1 1 40%;max-width:720px;background:linear-gradient(90deg,#d5b3781f,#d5b37859,#d5b3781f);border-radius:2px}.log-line.progress{color:#fff3d9;background:linear-gradient(90deg,#d5b37805,#ffffff03);padding:.6rem;border-radius:6px;text-align:center}.log-line.progress div{margin:.12rem 0}.log-line.done{color:#d0ffd9;background:#00000014;padding:.5rem;border-radius:6px}@media(max-width:560px){.title{font-size:2rem}.container{margin:2rem 1rem}}.featured-page{display:flex;justify-content:center;padding:1rem 0 3rem}.twitch-card{display:grid;grid-template-columns:1fr 320px;gap:18px;width:100%;max-width:1200px;align-items:start}.twitch-player{background:#000;border-radius:12px;overflow:hidden;min-height:360px;grid-column:1 / -1}.twitch-player iframe{width:100%;height:600px;border:0;display:block}.twitch-meta{background:linear-gradient(180deg,#0d1217f2,#1d242eeb);padding:18px;border-radius:12px;color:#fff;display:flex;flex-direction:column;gap:12px}.twitch-badge{background:linear-gradient(90deg,#ff004c,#ff8a00);padding:6px 12px;border-radius:999px;color:#fff;font-weight:700}.channel-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#6dd3ff,#7b61ff);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;color:#02182b;box-shadow:0 8px 20px #02061780}.channel-name{font-size:20px;margin:0;color:#d5b378}.channel-desc{font-size:13px;color:#ffffffd1;text-align:center}.twitch-actions{display:flex;gap:8px;margin-top:6px}.follow-btn,.watch-btn{text-decoration:none;padding:8px 12px;border-radius:8px;font-weight:700}.follow-btn{background:#9146ff;color:#fff}.watch-btn{background:transparent;border:1px solid rgba(255,255,255,.12);color:#fff}@media(max-width:920px){.twitch-card{grid-template-columns:1fr}.twitch-player iframe{height:320px}}.twitch-card-stacked{grid-template-columns:1fr;max-width:1100px}.twitch-meta-top{background:linear-gradient(90deg,#0f141cf5,#222b3cf0);padding:18px;border-radius:12px;margin-bottom:12px}.twitch-meta-top .meta-row{display:flex;gap:12px;align-items:center;justify-content:space-between}.meta-left{display:flex;gap:12px;align-items:center}.meta-center{flex:1;text-align:left}.meta-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.viewer-count{font-weight:800;color:#ffd7d2}.twitch-meta-top .channel-desc{text-align:left;margin:6px 0 0}.twitch-meta-top .channel-name{margin:0}.channel-avatar{width:64px;height:64px;font-size:20px}.channel-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}@media(max-width:920px){.twitch-meta-top .meta-row{flex-direction:column;align-items:center;text-align:center}.meta-center,.meta-right{align-items:center}}
