*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,Segoe UI,Roboto,Hiragino Sans,Noto Sans JP,sans-serif;font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0}button,input,select,textarea{font-family:inherit;font-size:inherit}:root{--bg:#0a0908;--surface:#161412;--surface2:#1e1b18;--surface3:#252220;--border:#3a3530;--border-dim:#2a2522;--accent:#c5a56e;--accent-dim:#7d6640;--accent-glow:#c5a56e26;--text:#e0d4be;--text-muted:#7a6e60;--text-head:#f0e6cc;--danger:#c55;--success:#6a9955;--radius:4px;--radius-lg:8px;--shadow:0 2px 8px #0009}.app{background:var(--bg);min-height:100vh;color:var(--text);flex-direction:column;display:flex}.app-header{border-bottom:1px solid var(--border);background:var(--surface);padding:16px 24px 12px}.app-title{color:var(--accent);letter-spacing:.05em;margin:0;font-size:22px;font-weight:600}.app-subtitle{color:var(--text-muted);margin:2px 0 0;font-size:12px}.app-body{flex:1;display:flex;overflow:hidden}.status-form{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:12px;width:280px;min-width:260px;padding:16px;display:flex;overflow-y:auto}.form-title{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin:0 0 4px;font-size:13px;font-weight:600}.origin-row{align-items:flex-end;gap:10px;display:flex}.origin-field{flex:1;min-width:0}.level-badge{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;flex-shrink:0;align-items:center;padding:4px 10px 5px;line-height:1;display:flex}.level-label{color:var(--accent-dim);text-transform:uppercase;letter-spacing:.1em;font-size:9px;font-weight:600}.level-value{color:var(--accent);letter-spacing:-.02em;font-size:20px;font-weight:700}.stat-grid{flex-direction:column;gap:6px;display:flex}.stat-row{grid-template-columns:52px 1fr 44px;align-items:center;gap:8px;display:grid}.stat-label{color:var(--accent-dim);text-align:right;letter-spacing:.02em;-webkit-user-select:none;user-select:none;white-space:nowrap;font-size:12px;font-weight:600}.stat-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;height:4px}.stat-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:background .15s}.stat-slider::-webkit-slider-thumb:hover{background:#d4b87e}.stat-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.stat-number{text-align:center;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:44px;color:var(--text);outline:none;padding:3px 4px;font-size:13px}.stat-number:focus{border-color:var(--accent-dim)}.form-field{flex-direction:column;gap:4px;display:flex}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:11px;font-weight:600}.field-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;outline:none;padding:6px 8px;font-size:13px}.field-select:focus{border-color:var(--accent-dim)}.form-actions{gap:8px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0a0908;flex:1}.btn-primary:hover:not(:disabled){background:#d4b87e}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface3)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border-dim);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border)}.build-save-row{align-items:center;gap:6px;display:flex}.build-name-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);min-width:0;color:var(--text);outline:none;flex:1;padding:6px 8px;font-size:13px}.build-name-input:focus{border-color:var(--accent-dim)}.load-wrapper{position:relative}.load-menu{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow);z-index:100;margin:0;padding:4px 0;list-style:none;position:absolute;top:calc(100% + 4px);right:0}.load-menu-item{align-items:center;display:flex}.load-menu-name{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:none;flex:1;padding:8px 12px;font-size:13px}.load-menu-name:hover{background:var(--surface3);color:var(--accent)}.load-menu-del{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:8px 10px;font-size:14px}.load-menu-del:hover{color:var(--danger)}.save-msg{color:var(--success);text-align:center;margin:0;font-size:12px}.app-main{flex:1;padding:16px;overflow:auto}.table-placeholder{height:200px;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.table-placeholder.table-error{color:var(--danger)}.table-wrapper{flex-direction:column;gap:8px;display:flex}.result-count{color:var(--text-muted);margin:0;font-size:12px}.table-scroll{overflow-x:auto}.weapon-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:13px}.weapon-table th{text-align:left;color:var(--accent-dim);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--surface);z-index:1;padding:8px 10px;font-size:11px;font-weight:600;position:sticky;top:0}.weapon-table td{border-bottom:1px solid var(--border-dim);vertical-align:middle;padding:7px 10px}.weapon-table tbody tr:hover{background:var(--surface2)}.weapon-name-btn{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-size:13px}.weapon-name-btn:hover{color:#d4b87e;text-decoration:underline}.mono-cell{font-family:ui-monospace,Consolas,monospace;font-size:12px}.small-cell{color:var(--text-muted);font-size:12px}.skill-cell{text-overflow:ellipsis;max-width:160px;font-size:12px;overflow:hidden}.detail-overlay{z-index:200;background:#0009;position:fixed;inset:0}.detail-panel{background:var(--surface);border-left:1px solid var(--border);z-index:201;width:min(480px,100vw);position:fixed;top:0;bottom:0;right:0;overflow-y:auto;box-shadow:-4px 0 20px #00000080}.detail-close{float:right;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:32px;height:32px;color:var(--text-muted);cursor:pointer;z-index:1;justify-content:center;align-items:center;margin:12px 12px 0 0;font-size:18px;line-height:1;display:flex;position:sticky;top:0}.detail-close:hover{color:var(--text);background:var(--surface3)}.detail-content{clear:both;padding:16px 20px 32px}.detail-loading,.detail-error{text-align:center;color:var(--text-muted);padding:40px 20px}.detail-error{color:var(--danger)}.detail-name{color:var(--text-head);margin:0 0 4px;font-size:20px;font-weight:700}.detail-name-en{color:var(--text-muted);margin:0 0 8px;font-size:13px}.detail-meta{color:var(--text-muted);margin:0 0 4px;font-size:13px}.detail-effect{color:var(--text);background:var(--surface2);border-left:3px solid var(--accent-dim);border-radius:0 var(--radius) var(--radius) 0;margin:8px 0 0;padding:8px 12px;font-size:13px}.detail-section{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-dim);border-bottom:1px solid var(--border-dim);margin:20px 0 8px;padding-bottom:4px;font-size:11px;font-weight:600}.detail-table{border-collapse:collapse;width:100%;font-size:13px}.stat-table td{padding:4px 8px}.stat-table td:first-child{width:60px;color:var(--text-muted)}.infusion-table th{color:var(--accent-dim);text-align:left;border-bottom:1px solid var(--border);background:var(--surface2);padding:6px 8px;font-size:11px;font-weight:600}.infusion-table td{border-bottom:1px solid var(--border-dim);padding:5px 8px;font-size:12px}.infusion-table tr:hover td{background:var(--surface2)}.detail-skill{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.skill-name{color:var(--text-head);margin:0;font-size:14px;font-weight:600}.skill-fp{color:#6ba8c8;margin-left:6px;font-size:12px;font-weight:400}.skill-replaceable{color:var(--text-muted);margin-left:6px;font-size:11px;font-weight:400}.detail-text{color:var(--text);margin:4px 0;font-size:13px}.detail-acquisition{color:var(--text-muted)}.detail-description{color:var(--text-muted);white-space:pre-wrap;font-size:13px;line-height:1.6}.accordion-filter{border:1px solid var(--border-dim);border-radius:var(--radius);overflow:hidden}.accordion-header{background:var(--surface2);cursor:pointer;width:100%;color:var(--text-muted);border:none;justify-content:space-between;align-items:center;padding:6px 10px;font-size:12px;transition:background .1s;display:flex}.accordion-header:hover{background:var(--surface3);color:var(--text)}.accordion-label{align-items:center;gap:6px;font-weight:500;display:flex}.accordion-badge{background:var(--accent-dim);min-width:18px;height:18px;color:var(--text-head);border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.accordion-arrow{color:var(--text-muted);font-size:9px}.accordion-body{background:var(--surface);flex-direction:column;gap:4px;padding:6px;display:flex}.wt-filter{flex-direction:column;gap:4px;display:flex}.wt-chips{background:var(--surface2);border:1px solid var(--border-dim);border-radius:var(--radius);flex-wrap:wrap;gap:3px;max-height:116px;padding:4px;display:flex;overflow-y:auto}.wt-chips::-webkit-scrollbar{width:4px}.wt-chips::-webkit-scrollbar-track{background:0 0}.wt-chips::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.wt-chip{background:var(--surface3);border:1px solid var(--border-dim);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:10px;padding:2px 7px;font-size:11px;transition:background .1s,color .1s,border-color .1s}.wt-chip:hover{color:var(--text);border-color:var(--accent-dim)}.wt-chip-active{background:var(--accent-dim);border-color:var(--accent-dim);color:var(--text-head)}.wt-chip-all{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:10px;align-self:flex-start;padding:3px 10px;font-size:11px;font-weight:600}.wt-chip-all:hover{color:var(--text);border-color:var(--border)}.wt-chip-all-active{background:var(--accent-dim);border:1px solid var(--accent-dim);color:var(--text-head);cursor:pointer;border-radius:10px;align-self:flex-start;padding:3px 10px;font-size:11px;font-weight:600}.aow-section{margin-top:8px}.aow-toggle{color:var(--accent-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.aow-toggle:hover{color:var(--accent)}.aow-body{background:var(--surface3);border-radius:var(--radius);margin-top:6px;padding:8px 10px;font-size:12px}.aow-row{color:var(--text);margin:3px 0}.aow-key{min-width:80px;color:var(--text-muted);margin-right:6px;display:inline-block}.aow-desc{color:var(--text-muted);margin:6px 0 2px;line-height:1.5}.aow-acq{color:var(--text-muted)}.aow-loading,.aow-error{color:var(--text-muted);margin:0;font-size:12px}.aow-error{color:var(--danger)}.smithing-section{margin-top:4px}.smithing-toggle{border:1px solid var(--border-dim);border-radius:var(--radius);color:var(--accent-dim);cursor:pointer;text-align:left;background:0 0;width:100%;padding:5px 10px;font-size:12px;font-weight:600}.smithing-toggle:hover{color:var(--accent);border-color:var(--border)}.smithing-body{flex-direction:column;gap:8px;margin-top:8px;display:flex}.smithing-inputs{flex-direction:column;gap:6px;display:flex}.smithing-field{flex-direction:column;gap:2px;display:flex}.smithing-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.smithing-slider-row{align-items:center;gap:8px;display:flex}.smithing-slider-row .stat-slider{flex:1}.smithing-number{text-align:center;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:44px;color:var(--text);outline:none;padding:3px 4px;font-size:13px}.smithing-number:focus{border-color:var(--accent-dim)}.smithing-loading,.smithing-none{color:var(--text-muted);margin:0;font-size:12px}.smithing-error{color:var(--danger);margin:0;font-size:12px}.smithing-results{flex-direction:column;gap:4px;display:flex}.stone-row{border:1px solid var(--border-dim);border-radius:var(--radius);overflow:hidden}.stone-row.stone-insufficient{border-color:#c556}.stone-header{background:var(--surface2);cursor:pointer;text-align:left;width:100%;color:var(--text);border:none;align-items:center;gap:8px;padding:6px 10px;font-size:12px;display:flex}.stone-header:hover{background:var(--surface3)}.stone-name{flex:1;font-weight:600}.stone-qty{color:var(--text-muted);white-space:nowrap;font-size:12px}.stone-avail.ok{color:var(--success)}.stone-avail.ng{color:var(--danger)}.stone-arrow{color:var(--text-muted);font-size:10px}.stone-locations{background:var(--surface);margin:0;padding:0;list-style:none}.stone-loc-item{border-top:1px solid var(--border-dim);color:var(--text-muted);padding:5px 12px;font-size:12px}.stone-loc-region{color:var(--accent-dim);font-weight:600}.stone-loc-name{color:var(--text)}.stone-loc-text{color:var(--text-muted)}.stone-loc-qty{color:var(--accent-dim);font-weight:600}.replaceable-ash-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.replaceable-ash-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.replaceable-ash-header{background:var(--surface2);cursor:pointer;text-align:left;width:100%;color:var(--text);border:none;align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:flex}.replaceable-ash-header:hover{background:var(--surface3)}.replaceable-ash-name{flex:1;font-weight:600}.replaceable-ash-meta{color:var(--text-muted);white-space:nowrap;font-size:12px}.replaceable-ash-detail{background:var(--surface);border-top:1px solid var(--border);padding:8px 12px}@media (width<=768px){.app-body{flex-direction:column;overflow:visible}.status-form{border-right:none;border-bottom:1px solid var(--border);width:100%;overflow-y:visible}.app-main{padding:12px}.detail-panel{border-top:none;border-left:none;border-radius:0;width:100vw;height:100vh;top:0;bottom:0}}
