:root{
  --bg:#0a0f24;--bg-soft:#101736;--panel:rgba(255,255,255,.04);
  --border:rgba(255,255,255,.09);--border-strong:rgba(255,255,255,.18);
  --text:#eef2ff;--muted:#98a8d6;--muted-2:#6f7fb0;
  --accent:#7c9cff;--accent-2:#5eead4;--warn:#fbbf24;--danger:#ff6b81;--ok:#34d399;
  --shadow:0 18px 40px rgba(0,0,0,.32);--radius:16px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"Inter","Hiragino Sans","Noto Sans JP",system-ui,-apple-system,sans-serif;
  background:
    radial-gradient(1100px 600px at 80% -10%,rgba(124,156,255,.18),transparent 50%),
    radial-gradient(900px 500px at -10% 0%,rgba(94,234,212,.10),transparent 55%),
    var(--bg);
  color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
.app{max-width:2100px;margin:0 auto;padding:18px}
.hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,.9fr);gap:14px;margin-bottom:16px}
.hero-card,.panel{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)
}
.hero-main{padding:22px 24px}
.hero-main h1{margin:0 0 10px;font-size:clamp(22px,3.2vw,36px);letter-spacing:-.03em}
.hero-main p{margin:0;color:var(--muted);font-size:14px;line-height:1.7}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:14px}
.stat{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;padding:12px 14px}
.stat .k{color:var(--muted);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.stat .v{font-size:24px;font-weight:800;margin-top:6px}
.stat .s{color:var(--muted-2);font-size:12px;margin-top:2px}

.layout{display:grid;grid-template-columns:330px minmax(0,1fr) 390px;gap:14px;align-items:start}
.panel{display:flex;flex-direction:column;max-height:calc(100vh - 36px)}
.panel-head{
  padding:14px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  position:sticky;top:0;background:rgba(10,15,36,.85);backdrop-filter:blur(8px);z-index:5
}
.panel-head h2{margin:0;font-size:16px}
.panel-body{padding:14px 16px;overflow:auto}
.stack{display:grid;gap:14px}

.field-label{
  display:block;font-size:12px;color:var(--muted);margin-bottom:6px;
  font-weight:700;letter-spacing:.04em
}
.inline-label{margin:0;align-self:center}
input[type=text],textarea{
  width:100%;background:#0c1330;color:var(--text);border:1px solid var(--border-strong);
  border-radius:12px;padding:10px 12px;font-size:13px;outline:none
}
input:focus,textarea:focus{border-color:rgba(124,156,255,.7);box-shadow:0 0 0 4px rgba(124,156,255,.18)}
.chip-grid{display:flex;flex-wrap:wrap;gap:6px}
button.chip,button.btn{
  border:0;cursor:pointer;font-weight:700;transition:.14s;
  background:rgba(255,255,255,.05);color:var(--text);border-radius:10px;
  padding:7px 10px;font-size:12px;border:1px solid transparent
}
button.chip:hover,button.btn:hover{transform:translateY(-1px);filter:brightness(1.08)}
button.chip.active{background:linear-gradient(135deg,#7c9cff,#9c7cff)}
button.chip.tiny{padding:5px 8px;font-size:11px}
button.btn.primary{background:linear-gradient(135deg,#5eead4,#22c55e);color:#06231a}
button.btn.warn{background:linear-gradient(135deg,#fbbf24,#f97316);color:#2a1300}
button.btn.danger{background:linear-gradient(135deg,#ff6b81,#dc2626)}
button.btn.ghost{background:rgba(255,255,255,.04);border:1px solid var(--border)}
button[disabled]{opacity:.4;cursor:not-allowed;transform:none}

.helper{color:var(--muted);font-size:11px;line-height:1.6}
.section-title{font-size:12px;font-weight:800;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.collapsible{border-top:1px dashed var(--border);padding-top:12px;margin-top:4px}
.coll-head{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none}
.coll-head .arrow{color:var(--muted);transition:transform .2s}
.coll-head.open .arrow{transform:rotate(90deg)}
.coll-body{display:none;padding-top:10px}
.coll-body.open{display:block}
.range-row{display:grid;gap:8px}
.range-track{position:relative;height:28px}
.range-track input[type=range]{
  position:absolute;left:0;right:0;width:100%;background:transparent;
  -webkit-appearance:none;appearance:none;pointer-events:none;height:28px
}
.range-track input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,#7c9cff,#9c7cff);cursor:pointer;pointer-events:auto;
  box-shadow:0 2px 8px rgba(0,0,0,.35);border:2px solid #fff
}
.range-track input[type=range]::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,#7c9cff,#9c7cff);cursor:pointer;pointer-events:auto;border:2px solid #fff
}
.range-track .rail{position:absolute;top:12px;left:0;right:0;height:4px;background:rgba(255,255,255,.1);border-radius:2px}
.range-track .fill{position:absolute;top:12px;height:4px;background:linear-gradient(135deg,#7c9cff,#9c7cff);border-radius:2px}
.range-vals{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}
.range-vals .v{color:var(--text);font-weight:800}
.check-grid{display:grid;gap:8px;margin-top:10px}
.check-item{
  display:flex;align-items:center;gap:8px;color:var(--text);font-size:12px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;padding:8px 10px
}
.check-item input{width:16px;height:16px;accent-color:#7c9cff}

.inline-row{display:flex;gap:8px;align-items:center}
.result-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:space-between;margin-bottom:12px}
.pill{
  display:inline-flex;align-items:center;gap:6px;padding:6px 10px;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:999px;color:var(--muted);font-size:11px;font-weight:700
}

.card-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.card-tile{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--border);border-radius:16px;overflow:hidden;display:grid;gap:6px;position:relative
}
.card-tile.banned::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(135deg,rgba(255,107,129,0) 0 16px,rgba(255,107,129,.18) 16px 18px)
}
.card-tile.banned::after{
  content:"Genesys使用不可";position:absolute;top:8px;right:8px;background:rgba(220,38,38,.95);
  color:#fff;font-size:10px;font-weight:800;padding:4px 7px;border-radius:999px;z-index:2
}
.tile-image{position:relative;aspect-ratio:1/1.02;background:#0c1227;overflow:hidden;display:flex;align-items:center;justify-content:center}
.tile-image img{width:100%;height:100%;object-fit:cover;display:block}
.tile-image .ban-line,.tile-image .ban-line2{
  position:absolute;left:-10%;right:-10%;top:50%;height:4px;background:rgba(220,38,38,.95);transform:rotate(-15deg)
}
.tile-image .ban-line2{transform:rotate(15deg)}
.tile-body{padding:0 10px;display:grid;gap:5px}
.tile-name{font-size:13px;font-weight:800;line-height:1.32}
.tile-meta{display:flex;flex-wrap:wrap;gap:6px}
.badge{border-radius:999px;padding:3px 8px;font-size:10px;font-weight:800;letter-spacing:.04em;white-space:nowrap}
.b-monster{background:rgba(124,156,255,.16);color:#c4d1ff}
.b-spell{background:rgba(94,234,212,.16);color:#aff3e7}
.b-trap{background:rgba(244,114,182,.18);color:#ffc1e2}
.b-rar-UR{background:rgba(251,191,36,.18);color:#ffd86a}
.b-rar-SR{background:rgba(236,72,153,.18);color:#ff8fcb}
.b-rar-R{background:rgba(59,130,246,.18);color:#8ec3ff}
.b-rar-N{background:rgba(148,163,184,.2);color:#d2dae6}
.b-attr{background:rgba(255,255,255,.08);color:#d8e3ff}
.b-points{background:rgba(94,234,212,.14);color:#8df3e7}
.b-zone-extra{background:rgba(168,85,247,.18);color:#d8b4fe}
.b-zone-main{background:rgba(255,255,255,.06);color:#c4cfff}
.tile-text{
  font-size:10.5px;line-height:1.5;color:#c1cdf5;background:rgba(6,10,25,.4);
  border:1px solid rgba(255,255,255,.04);border-radius:10px;padding:7px 8px;margin:0 10px;
  max-height:64px;overflow:auto;white-space:pre-wrap
}
.tile-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px 10px 10px}
.tile-actions>:last-child{grid-column:1/-1}
.tile-actions button{font-size:11px;padding:7px 6px}
.tile-stats{
  display:flex;gap:8px;padding:0 10px;font-size:10.5px;color:var(--muted-2);
  font-family:ui-monospace,monospace;flex-wrap:wrap
}
.tile-stats span b{color:var(--text)}
img.broken{opacity:.25}

.summary{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}
.s-card{border-radius:12px;padding:10px 12px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.s-card .l{font-size:11px;color:var(--muted)}
.s-card .v{font-size:22px;font-weight:800;margin-top:2px}
.status-box{border:1px solid var(--border);border-radius:14px;padding:12px;margin-bottom:12px;font-size:12px;line-height:1.6}
.status-ok{background:rgba(52,211,153,.10);border-color:rgba(52,211,153,.3)}
.status-ng{background:rgba(255,107,129,.10);border-color:rgba(255,107,129,.3)}
.status-title{font-weight:800;font-size:13px;margin-bottom:4px}

.deck-section{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:12px}
.deck-head{padding:10px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.deck-head strong{font-size:13px}
.deck-rows{display:grid;gap:6px;padding:8px}
.deck-row{
  display:grid;grid-template-columns:36px 1fr auto;gap:8px;align-items:center;padding:6px;
  background:rgba(8,12,26,.5);border:1px solid rgba(255,255,255,.05);border-radius:10px
}
.deck-row img{width:36px;height:36px;object-fit:cover;border-radius:6px;background:#0c1227}
.deck-row .nm{font-size:12px;font-weight:700;line-height:1.3}
.deck-row .meta{font-size:10px;color:var(--muted-2);margin-top:2px}
.qty{display:inline-flex;align-items:center;gap:6px}
.qty button{width:28px;height:28px;padding:0;border-radius:8px}
.qty .v{min-width:16px;text-align:center;font-weight:800;font-size:13px}
.empty{color:var(--muted);padding:14px;text-align:center;border:1px dashed var(--border);border-radius:12px;font-size:12px}

.pagination-wrap{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 0 2px;flex-wrap:wrap}
.pagination-info{color:var(--muted);font-size:12px}
.pagination{display:flex;gap:6px;flex-wrap:wrap}
.page-btn{
  border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);
  border-radius:10px;min-width:38px;padding:7px 10px;font-size:12px;font-weight:700;cursor:pointer
}
.page-btn.active{background:linear-gradient(135deg,#7c9cff,#9c7cff);border-color:transparent}
.page-btn[disabled]{opacity:.35;cursor:not-allowed}
.page-ellipsis{color:var(--muted);padding:8px 2px;font-size:12px}

.modal-backdrop{
  position:fixed;inset:0;background:rgba(4,8,22,.78);display:none;align-items:center;justify-content:center;
  padding:16px;z-index:100;backdrop-filter:blur(6px)
}
.modal-backdrop.show{display:flex}
.modal{
  background:#0f1638;border:1px solid var(--border-strong);border-radius:18px;max-width:720px;width:100%;
  padding:18px;max-height:90vh;overflow:auto
}
.modal h3{margin:0 0 10px;font-size:18px}
.modal textarea{min-height:240px;font-family:ui-monospace,monospace;font-size:12px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px;flex-wrap:wrap}

.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:rgba(15,22,56,.96);border:1px solid var(--border-strong);padding:10px 18px;border-radius:999px;
  font-size:13px;font-weight:700;z-index:200;box-shadow:var(--shadow);display:none
}
.toast.show{display:block;animation:toastIn .2s ease}
@keyframes toastIn{
  from{opacity:0;transform:translate(-50%,8px)}
  to{opacity:1;transform:translate(-50%,0)}
}

footer{text-align:center;padding:20px;color:var(--muted);font-size:12px}
.mt8{margin-top:8px}
.mt10{margin-top:10px}
.mt14{margin-top:14px}

@media (max-width:1700px){
  .layout{grid-template-columns:320px minmax(0,1fr)}
  .deck-panel{grid-column:1/-1;max-height:none}
}
@media (max-width:1024px){
  .hero{grid-template-columns:1fr}
  .layout{grid-template-columns:1fr}
  .panel{max-height:none}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:720px){
  .app{padding:10px}
  .hero-stats{grid-template-columns:1fr}
  .summary{grid-template-columns:1fr 1fr}
  .card-grid{grid-template-columns:1fr}
  .pagination-wrap{justify-content:center}
}
@media (max-width:420px){
  .app{padding:8px}
  .hero-main{padding:16px 14px}
  .panel-body{padding:12px}
  button.chip{padding:6px 8px;font-size:11px}
}
