:root{
  --blue:#2f7df0; --blue-d:#1c5fc4; --bg:#eef4ff; --surface:#ffffff;
  --ink:#16223a; --muted:#6b7a93; --line:#e3ebf7;
  --yellow:#ffcb05; --red:#ee1515; --green:#1eae5a; --green-d:#138a45;
  --shadow:0 2px 10px rgba(28,60,120,.08); --shadow-lg:0 10px 30px rgba(28,60,120,.16);
  --radius:16px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:linear-gradient(180deg,#f6f9ff,#eaf1ff 240px);color:var(--ink);
  font:16px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
h1{font-size:1.7rem;margin:.2em 0 .4em}
h2{font-size:1.25rem;margin:1.6em 0 .6em;display:flex;align-items:baseline;gap:.6em}
h3{font-size:1rem;margin:.2em 0 .4em}
.muted{color:var(--muted)} .small{font-size:.85rem} .pos{color:var(--green-d)} .neg{color:var(--red)}

/* top bar */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:8px 16px;background:rgba(255,255,255,.85);backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line)}
.topbar-inner{width:min(1180px,100%);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:14px;min-width:0}
.brand{display:flex;align-items:center;gap:9px;font-weight:600;font-size:1rem}
.brand-name b{color:var(--blue)}
.ball{width:22px;height:22px;border-radius:50%;flex:0 0 auto;
  background:linear-gradient(180deg,#ee1515 0 49%,#222 49% 51%,#fff 51% 100%);
  box-shadow:inset 0 0 0 2px #222, 0 0 0 2px #fff; position:relative}
.ball::after{content:"";position:absolute;inset:0;margin:auto;width:7px;height:7px;border-radius:50%;
  background:#fff;box-shadow:inset 0 0 0 2px #222}
.nav{display:flex;align-items:center;justify-content:flex-end;gap:4px;font-size:.9rem;flex:1;min-width:0;flex-wrap:wrap}
.nav > *{flex:0 0 auto}
.nav a{padding:6px 10px;border-radius:10px;color:var(--muted)}
.nav a{white-space:nowrap}
.nav a:hover{background:var(--bg);color:var(--ink)}
.nav a.cta{background:var(--blue);color:#fff;font-weight:600}
.nav a.cta:hover{background:var(--blue-d)}
.nav a.admin-link{border:1px solid var(--line);background:var(--surface)}
.nav-form{margin:0}
.nav-button{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--muted);
  padding:6px 10px;border-radius:10px;font:inherit;cursor:pointer}
.nav-button:hover{background:var(--bg);color:var(--ink)}
.gear{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--muted);
  width:38px;height:38px;border-radius:11px;font-size:1.15rem;cursor:pointer;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;transition:transform .3s}
.gear:hover{background:var(--bg);color:var(--ink);transform:rotate(40deg)}
.nav-check{position:absolute;opacity:0;pointer-events:none}
.menu-toggle{display:none;align-items:center;justify-content:center;gap:8px;min-width:42px;height:42px;
  padding:0 12px;border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--ink);
  font-weight:700;cursor:pointer;box-shadow:var(--shadow)}
.menu-toggle-bars{width:18px;height:14px;display:flex;flex-direction:column;justify-content:space-between}
.menu-toggle-bars span{display:block;height:2px;border-radius:999px;background:currentColor;transition:transform .18s ease,opacity .18s ease}
.menu-toggle-text{font-size:.82rem}
.nav-check:focus-visible + .menu-toggle{outline:2px solid var(--blue);outline-offset:2px}
.nav-check:checked + .menu-toggle .menu-toggle-bars span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-check:checked + .menu-toggle .menu-toggle-bars span:nth-child(2){opacity:0}
.nav-check:checked + .menu-toggle .menu-toggle-bars span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* settings modal */
.modal{position:fixed;inset:0;z-index:70;background:rgba(13,30,60,.45);backdrop-filter:blur(4px);
  display:none;align-items:flex-start;justify-content:center;padding:10vh 16px 16px}
.modal.show{display:flex}
.modal-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;
  width:min(380px,92vw);max-height:min(78vh,720px);padding:16px 16px 14px;overflow:auto;
  box-shadow:var(--shadow-lg);animation:pop .16s ease}
.settings-card{width:min(920px,94vw)}
@keyframes pop{from{transform:translateY(8px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.modal-head h3{margin:0;font-size:.94rem;letter-spacing:-.01em}
.modal-close{appearance:none;border:0;background:var(--bg);width:28px;height:28px;border-radius:9px;
  cursor:pointer;color:var(--muted);font-size:.92rem;flex:0 0 auto}
.modal-close:hover{background:#e6edf9;color:var(--ink)}
.settings-intro{margin:8px 0 0;font-size:.64rem;line-height:1.35}
.modal-note{display:flex;flex-direction:column;gap:3px;margin-top:10px;padding:8px 10px;border-radius:12px;
  background:linear-gradient(180deg,#f8fbff,#eef4ff);border:1px solid #d7e5fb;color:#284066}
.modal-note strong{font-size:.7rem}
.modal-note span{font-size:.64rem;line-height:1.35}
.modal-tabs{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px;padding:4px;background:#f5f8ff;border:1px solid var(--line);border-radius:12px}
.modal-tab{appearance:none;border:0;background:transparent;color:var(--muted);border-radius:9px;
  padding:6px 8px;font-size:.68rem;font-weight:700;cursor:pointer;flex:1 1 78px;line-height:1.1}
.modal-tab:hover{background:#edf3ff;color:var(--ink)}
.modal-tab.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.modal-panels{margin-top:10px}
.modal-panel{display:none}
.modal-panel.is-active{display:block}
.modal-actions{display:flex;flex-direction:column;gap:8px}
.modal-actions form{margin:0}
.modal-action{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;
  border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff)}
.modal-action-copy{flex:1;min-width:0}
.modal-action-title{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.modal-action-copy strong{display:block;font-size:.72rem;line-height:1.15}
.modal-action-meta{display:inline-flex;align-items:center;padding:3px 7px;border-radius:999px;background:#eef4ff;
  color:#355582;font-size:.56rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.modal-action-copy p{margin:4px 0 0;color:var(--muted);font-size:.64rem;line-height:1.35}
.modal-run-btn{flex:0 0 auto;min-width:58px;padding:7px 10px;font-size:.72rem;text-align:center}
.modal-panel-note{margin:8px 2px 0;color:var(--muted);font-size:.62rem;line-height:1.35}
.repair-next-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;padding:12px;
  border:1px solid #bad3ff;border-radius:14px;background:linear-gradient(180deg,#f7fbff,#eef5ff);box-shadow:var(--shadow)}
.repair-next-copy{min-width:0}
.repair-step-label{display:block;color:#315587;font-size:.56rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.repair-next-copy strong{display:block;font-size:.82rem;line-height:1.2}
.repair-next-copy p{margin:4px 0 0;color:#506985;font-size:.65rem;line-height:1.35}
.repair-status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:8px}
.repair-status-grid span{display:flex;flex-direction:column;gap:1px;min-width:0;padding:7px 8px;border:1px solid var(--line);
  border-radius:10px;background:#fff;color:var(--muted);font-size:.55rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.repair-status-grid b{color:var(--ink);font-size:.78rem;line-height:1}
.repair-ready-list{display:grid;gap:5px;margin-bottom:8px;padding:9px;border:1px solid #d7e5fb;border-radius:12px;background:#fbfdff}
.repair-ready-list strong{font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:#355582}
.repair-ready-list a{display:block;padding:7px 8px;border-radius:9px;background:#fff;border:1px solid var(--line);
  color:var(--ink);font-size:.65rem;font-weight:800;line-height:1.25}
.repair-ready-list a:hover{background:#f1f6ff}
.repair-steps{margin-top:8px}
.repair-step{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-right:6px;border-radius:999px;
  background:#e8f1ff;color:#315587;font-size:.6rem;font-weight:900}
.repair-advanced{margin-top:8px;border:1px solid var(--line);border-radius:12px;background:#fff}
.repair-advanced summary{cursor:pointer;padding:9px 10px;font-size:.65rem;font-weight:900;color:#355582;text-transform:uppercase;letter-spacing:.05em}
.repair-advanced .modal-actions{padding:0 8px 8px}
.uploader.modal-uploader{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:stretch;margin:0}
.drop.modal-drop{min-width:0;padding:16px;display:flex;align-items:center;justify-content:center}
.modal-upload-btn{align-self:stretch;white-space:nowrap}
.ai-settings-form{display:flex;flex-direction:column;gap:10px}
.ai-settings-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.ai-provider-list{display:flex;flex-direction:column;gap:8px}
.ai-provider-option{display:flex;gap:10px;align-items:flex-start;padding:10px;border:1px solid var(--line);
  border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);cursor:pointer}
.ai-provider-option.disabled{opacity:.55;cursor:default}
.ai-provider-option input{margin-top:2px}
.ai-provider-copy{display:flex;flex-direction:column;gap:2px}
.ai-provider-copy strong{font-size:.72rem;line-height:1.15}
.ai-provider-copy span{font-size:.64rem;color:#33507e}
.ai-provider-copy small{font-size:.6rem;color:var(--muted);line-height:1.3}
.ai-settings-actions{display:flex;justify-content:flex-start}
.release-preview-list{display:grid;gap:8px;margin-top:10px}
.release-preview-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:8px 10px;
  border:1px solid var(--line);border-radius:12px;background:#fbfdff}
.release-preview-row strong{font-size:.72rem;line-height:1.2}
.release-preview-row span{font-size:.63rem;color:var(--muted);text-align:right}
.release-editor-form{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.release-editor-label{font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#486181}
.release-editor-json{width:100%;min-height:240px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;
  background:#f8fbff;color:var(--ink);font:12px/1.45 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  resize:vertical}
.log-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px;
  padding:10px 12px;border:1px solid #d7e5fb;border-radius:14px;background:linear-gradient(180deg,#fff,#f7fbff)}
.log-panel-head strong,.log-panel-head span{display:block}
.log-panel-head strong{font-size:.82rem;line-height:1.2}
.log-panel-head span{margin-top:2px;color:var(--muted);font-size:.64rem;line-height:1.35}
.activity-log-list,.version-log-list{display:grid;gap:8px;max-height:420px;overflow:auto;padding-right:3px}
.activity-log-row,.version-log-row{border:1px solid var(--line);border-radius:13px;background:#fff}
.activity-log-row summary{display:flex;align-items:flex-start;gap:9px;padding:10px;cursor:pointer;list-style:none}
.activity-log-row summary::-webkit-details-marker{display:none}
.log-type{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:4px 7px;border-radius:999px;
  background:#eef4ff;color:#355582;font-size:.55rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em;line-height:1}
.log-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.log-copy strong,.version-log-row strong{font-size:.72rem;line-height:1.2;overflow-wrap:anywhere}
.log-copy small,.version-log-row small{color:var(--muted);font-size:.58rem;line-height:1.25;overflow-wrap:anywhere}
.activity-log-row p,.version-log-row p{margin:0 10px 10px;color:#435a79;font-size:.65rem;line-height:1.35}
.log-detail-grid{display:grid;grid-template-columns:74px minmax(0,1fr);gap:5px 8px;margin:0 10px 10px;padding:9px;
  border-radius:10px;background:#f8fbff;font-size:.62rem}
.log-detail-grid dt{color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.05em}
.log-detail-grid dd{margin:0;min-width:0;overflow-wrap:anywhere}
.log-detail-grid code{white-space:pre-wrap;word-break:break-word;font-size:.6rem;color:#263b5d}
.version-log-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:9px;padding:10px}

.wrap{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:18px 0 60px}
.foot{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:20px 0;display:flex;justify-content:space-between;
  gap:12px;color:var(--muted);font-size:.78rem;flex-wrap:wrap}

.login-shell{min-height:calc(100vh - 180px);display:grid;place-items:center;padding:34px 0}
.login-card{width:min(520px,100%);padding:28px;border:1px solid var(--line);border-radius:24px;
  background:linear-gradient(155deg,#ffffff,#f2f7ff);box-shadow:var(--shadow-lg)}
.login-kicker{display:inline-flex;margin-bottom:8px;padding:5px 9px;border-radius:999px;background:#eaf2ff;
  color:var(--blue-d);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.login-card h1{margin:0 0 8px;font-size:1.55rem;letter-spacing:-.03em}
.login-form{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.login-form label{display:flex;flex-direction:column;gap:5px;font-size:.72rem;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;color:#486181}
.login-form input{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:13px;
  background:#fff;color:var(--ink);font:inherit;text-transform:none;letter-spacing:0}
.login-error{padding:10px 12px;border:1px solid #f1c1c1;border-radius:12px;background:#fff0f0;color:#a11616}

/* hero + stats */
.hero h1{margin-top:.2em}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:6px 0 16px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:12px;
  padding:9px 12px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:0}
.stat .num{font-size:1.15rem;font-weight:800;letter-spacing:-.4px}
.stat .lab{color:var(--muted);font-size:.7rem}
.lang-split{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 4px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);font-size:.85rem;cursor:pointer}
.chip.lang-en{border-color:#bcd4ff} .chip.lang-ja{border-color:#ffc9c9}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 4px}
.actions form{margin:0}

.seeall{font-size:.85rem;color:var(--blue);font-weight:500;margin-left:auto}

/* buttons */
.btn{appearance:none;border:0;border-radius:12px;background:var(--blue);color:#fff;font-weight:600;
  padding:10px 16px;font-size:.92rem;cursor:pointer;box-shadow:var(--shadow)}
.btn:hover{background:var(--blue-d)} .btn:disabled{opacity:.6;cursor:default}
.btn.ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--bg)}
.button-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.compact-select{appearance:none;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);
  font:inherit;font-size:.78rem;font-weight:700;padding:5px 28px 5px 9px;margin-left:8px}

/* card grid */
.grid{display:grid;gap:12px}
.grid.cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
.grid.sets{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.card-tile{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;display:flex;flex-direction:column}
.card-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.thumb{position:relative;aspect-ratio:5/7;background:#dfe8f6;display:flex;align-items:center;justify-content:center}
.thumb img{width:100%;height:100%;object-fit:contain}
.card-tile.missing .thumb img{filter:grayscale(.9) opacity(.5)}
.card-tile.missing{background:#f4f7fc}
.badge{position:absolute;top:7px;left:7px;font-size:.72rem;font-weight:700;padding:3px 7px;border-radius:999px;
  background:var(--green);color:#fff;box-shadow:var(--shadow)}
.badge.miss-badge{background:#9aa7bd;left:auto;right:7px}
.badge.big{font-size:.9rem;padding:6px 12px}
.name-stack{display:flex;flex-direction:column;min-width:0}
.meta{padding:8px 10px;display:flex;flex-direction:column;gap:1px}
.meta .num{color:var(--muted);font-size:.72rem;line-height:1.2;white-space:normal;overflow-wrap:anywhere}
.meta .nm{display:block;font-weight:600;font-size:.9rem;line-height:1.24;white-space:normal;overflow-wrap:anywhere}
.meta .ja-sub{display:block;color:#33507e;font-size:.8rem;line-height:1.18;white-space:normal;overflow-wrap:anywhere}
.meta .en-sub{display:block;color:var(--muted);font-size:.76rem;line-height:1.15;white-space:normal;overflow-wrap:anywhere}
.meta .sub{color:var(--muted);font-size:.76rem;line-height:1.2;white-space:normal;overflow-wrap:anywhere}
.meta .val{font-weight:700;font-size:.86rem;margin-top:2px}

/* set tiles */
.set-tile{position:relative;display:flex;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}
.set-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.set-tile.missing{background:#f4f7fc}
.set-tile.missing .set-logo img{filter:grayscale(.95) opacity(.5)}
.set-tile.missing .set-logo-text,.set-tile.missing .set-name,.set-tile.missing .set-stats .val{color:#60708b}
.set-logo{width:74px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,#fdfefe 0%,#eef4ff 100%);border:1px solid #d9e5fb;
  border-radius:10px;padding:6px;text-align:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.set-logo img{max-width:100%;max-height:54px;object-fit:contain;filter:drop-shadow(0 3px 10px rgba(30,50,90,.16))}
.set-logo-text{font-size:.72rem;font-weight:700;color:var(--muted)}
.set-info{flex:1;min-width:0;padding-right:34px}
.set-name{font-weight:700}
.set-name-main{font-weight:700}
.set-name-sub{color:var(--muted);font-size:.82rem;font-weight:500;line-height:1.2;margin-top:1px}
.set-lang-flag{position:absolute;top:12px;right:12px;font-size:1.2rem;line-height:1}
.set-status-pill{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;padding:4px 8px;
  border-radius:999px;background:#fff3d5;border:1px solid #f2d48b;color:#8b6411;font-size:.58rem;font-weight:800;
  letter-spacing:.05em;text-transform:uppercase}
.set-lang-text{font-size:.66rem;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:.04em;
  background:#eef3fb;color:#4c6285}
.set-series{color:#33507e;font-size:.8rem;line-height:1.15;margin-top:2px}
.set-ja{color:var(--muted);font-size:.82rem;margin-top:1px}
.set-meta{color:var(--muted);font-size:.41rem;margin-top:2px}
.set-counts{display:flex;flex-wrap:wrap;gap:8px;color:#51698e;font-size:.36rem;font-weight:700;margin-top:6px}
.set-counts span{padding:1px 4px;border-radius:999px;background:#eef3fb}
.set-ja.big{font-size:1rem;margin:.1em 0 .3em}
.set-name-sub.big{font-size:1rem;margin:.1em 0 .3em}
.set-stats{display:flex;justify-content:space-between;color:var(--muted);font-size:.82rem;margin:6px 0 5px}
.set-stats.solo{justify-content:flex-start}
.set-stats .val{font-weight:700;color:var(--ink)}
.bar{height:8px;background:#e6edf9;border-radius:999px;overflow:hidden}
.bar.wide{height:12px;margin:10px 0 4px;max-width:520px}
.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),#56b0ff);border-radius:999px}
.bar-lab{font-size:.76rem;color:var(--muted);margin-top:4px}
.bar-lab.muted{font-style:italic}
.series-block{margin-top:22px}
.browse-grid{margin-top:14px}

/* flags / tags */
.flag{font-size:.66rem;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:.04em}
.flag-en{background:#e3efff;color:var(--blue-d)} .flag-ja{background:#ffe4e4;color:#c01515}
.tag{font-size:.76rem;background:var(--bg);border:1px solid var(--line);padding:3px 9px;border-radius:999px}
.tagrow{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}

/* set page */
.set-page{display:flex;flex-direction:column;gap:12px;--set-accent:#2f7df0;--set-ink:#1d2943;--set-soft:#6d7c98}
.set-hero{position:relative;padding:14px;border-radius:22px;overflow:hidden;
  background:linear-gradient(155deg,#edf4ff,#ffffff 74%);border:1px solid #d8e4f8;box-shadow:var(--shadow)}
.set-hero-glow{position:absolute;top:-42%;right:-8%;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(47,125,240,.15),transparent 68%);filter:blur(8px);pointer-events:none}
.set-hero-top{position:relative;display:grid;grid-template-columns:minmax(0,1.3fr) minmax(260px,.9fr);gap:12px;align-items:start}
.set-identity{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;align-items:center;min-width:0}
.set-identity-logo{display:flex;align-items:center;justify-content:center;width:110px;min-height:86px;padding:12px;border-radius:16px;
  background:rgba(255,255,255,.9);border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.96)}
.set-identity-logo img{max-width:100%;max-height:60px;object-fit:contain;filter:drop-shadow(0 5px 14px rgba(30,50,90,.12))}
.set-identity-copy{min-width:0}
.set-identity-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:7px}
.set-mini-pill{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.88);
  border:1px solid #d7e4f6;font-size:.67rem;font-weight:800;letter-spacing:.03em;color:#486181}
.set-hero-title{margin:0;font-size:1.35rem;line-height:1.02;letter-spacing:-.025em;color:var(--set-ink)}
.set-hero-subtitle{margin-top:4px;font-size:.88rem;font-weight:600;line-height:1.2;color:#536888}
.set-hero-caption{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px;font-size:.73rem;font-weight:700;letter-spacing:.03em;color:var(--set-soft)}
.set-hero-summary{margin:9px 0 0;font-size:.85rem;line-height:1.45;color:#223252;max-width:62ch}
.set-hero-artists{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap;margin-top:10px}
.set-micro-label,.sheet-k{font-size:.63rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.set-artist-row{display:flex;gap:6px;flex-wrap:wrap}
.set-artist-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:999px;
  background:rgba(255,255,255,.92);border:1px solid var(--line);font-size:.71rem;font-weight:700;color:#294269}
.set-artist-chip b{font-size:.67rem;color:var(--set-accent)}
.set-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.set-kpi-card{display:flex;flex-direction:column;gap:3px;padding:11px 12px;border-radius:16px;
  background:linear-gradient(180deg,#ffffff,#f6f9ff);border:1px solid #dce7f8;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.set-kpi-card strong{font-size:1.1rem;line-height:1.05;letter-spacing:-.04em;color:var(--set-ink)}
.set-kpi-card span:last-child{font-size:.72rem;color:#5e7290}
.set-kpi-label{font-size:.61rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.set-hero-panels{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}
.set-hero-panel{padding:12px;background:rgba(255,255,255,.78)}
.set-hero-panel .fg-head{margin-bottom:8px}
.set-hero-panel .fg-head h3{font-size:.92rem}
.set-hero-panel .fg-tag{font-size:.56rem;padding:3px 8px}
.set-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}
.set-hero-grid .fact,.set-collection-row{border-bottom:1px dashed var(--line);padding-bottom:7px}
.set-hero-grid .fk{font-size:.61rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.set-hero-grid .fv{font-size:.83rem;font-weight:700;line-height:1.28;color:var(--set-ink);overflow-wrap:anywhere}
.set-collection-list{display:grid;gap:8px}
.set-collection-row{display:grid;grid-template-columns:1fr auto;gap:1px 10px;align-items:center}
.set-collection-key{font-size:.61rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.set-collection-row strong{font-size:.95rem;line-height:1.1;color:var(--set-ink)}
.set-collection-row span:last-child{grid-column:1/-1;font-size:.74rem;line-height:1.28;color:#5e7290}
.set-hero-note{margin:10px 0 0;padding:9px 11px;border-radius:12px;background:rgba(255,247,224,.88);
  border:1px solid #ffe3a3;font-size:.8rem;line-height:1.42;color:#715711}

.set-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px 12px;
  background:rgba(255,255,255,.84);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.set-toolbar-progress{min-width:0}
.set-toolbar-head{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:6px}
.set-toolbar-title{font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.set-toolbar-meta{font-size:.76rem;font-weight:700;color:#536888}
.set-progress-track{height:7px;border-radius:999px;background:#e8eef9;overflow:hidden;max-width:460px}
.set-progress-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--set-accent),#7fc0ff)}
.filters{display:flex;gap:8px;margin:0;flex-wrap:wrap}
.filters .chip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.filters .chip.danger{border-color:#ffd7d7;color:#a04545;font-weight:700}
.filters .chip.danger.on{background:#e98f8f;color:#fff;border-color:#e98f8f}
.set-filters{justify-content:flex-end}
.set-filters .chip{padding:5px 10px;font-size:.78rem;font-weight:700;background:#fbfdff}
.set-filters .chip span{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:2px 6px;
  border-radius:999px;background:#eef3fb;color:#506887;font-size:.68rem;font-weight:800}
.set-filters .chip.on span{background:rgba(255,255,255,.2);color:#fff}
.set-filters .chip.danger.on span{background:rgba(255,255,255,.22);color:#fff}

.set-page-note,.note{background:#fff7e0;border:1px solid #ffe7a3;border-radius:12px;padding:12px 14px;font-size:.86rem}

.set-card-grid{gap:10px}
.set-page .grid.cards{grid-template-columns:repeat(auto-fill,minmax(136px,1fr))}
.set-page .card-tile{border-radius:13px;box-shadow:0 1px 8px rgba(28,60,120,.08);transition:transform .12s,box-shadow .12s}
.set-page .card-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.set-page .thumb{aspect-ratio:5/7.05;background:linear-gradient(180deg,#dfe8f6,#edf3fb)}
.set-page .meta{padding:7px 9px 9px;gap:2px}
.set-page .meta .num{font-size:.68rem}
.set-page .meta .nm{font-size:.86rem;line-height:1.2}
.set-page .meta .ja-sub{font-size:.74rem}
.set-page .meta .sub{font-size:.72rem}
.set-page .meta .val{font-size:.8rem}
.set-page .badge{top:6px;left:6px;font-size:.62rem;padding:2px 6px}
.set-page .badge.miss-badge{right:6px;left:auto;background:#b6c1d2}
.set-page .card-tile.missing{background:#f7faff;outline:1px solid #e4ebf7;outline-offset:-1px}
.set-page .card-tile.missing .thumb img{filter:grayscale(.72) opacity(.56)}
.set-page .card-tile.missing .miss-badge{background:#b0bccf}
.set-page .findot{font-size:.55rem;padding:1px 4px}

/* ============ card detail (type-themed) ============ */
.cd{--type:#7c9cc0;--type-soft:#eef3fb}
.cd.t-grass{--type:#4fae54;--type-soft:#e9f7e7}
.cd.t-fire{--type:#ff7a3d;--type-soft:#ffeadf}
.cd.t-water{--type:#3f8fe0;--type-soft:#e4f0fc}
.cd.t-lightning{--type:#e7b30a;--type-soft:#fff6cf}
.cd.t-psychic{--type:#b25cc9;--type-soft:#f5e7fa}
.cd.t-fighting{--type:#d96a3c;--type-soft:#fbe7dd}
.cd.t-darkness{--type:#574f6b;--type-soft:#e8e6ef}
.cd.t-metal{--type:#7f8a9c;--type-soft:#eef1f5}
.cd.t-fairy{--type:#e978c4;--type-soft:#fde7f4}
.cd.t-dragon{--type:#6a6fc0;--type-soft:#e9eafa}
.cd.t-colorless{--type:#9aa6b5;--type-soft:#eef1f5}

.cd-nav{display:flex;justify-content:space-between;align-items:center;margin:0 0 10px;font-size:.85rem}
.cd-nav a{color:var(--blue);font-weight:600;padding:4px 8px;border-radius:8px}
.cd-nav a:hover{background:#e6eefb}
.cd-nav .pager{display:flex;gap:6px}

.hero{position:relative;display:grid;grid-template-columns:1fr;gap:14px;align-items:start;
  background:linear-gradient(160deg,var(--type-soft),#fff 80%);border:1px solid var(--line);
  border-radius:18px;padding:15px;overflow:hidden;box-shadow:var(--shadow)}
.hero-glow{position:absolute;top:-45%;left:-12%;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,var(--type),transparent 62%);opacity:.28;filter:blur(14px);pointer-events:none}
.hero-card{position:relative;justify-self:center;width:min(214px,54vw)}
.hero-img{position:relative;border-radius:12px;overflow:hidden;
  box-shadow:0 22px 44px -20px var(--type),0 8px 18px rgba(20,40,80,.18);transition:transform .25s ease}
.hero-card:hover .hero-img{transform:translateY(-4px) rotate(-.5deg)}
.hero-img img{width:100%;display:block}
.status-pill{position:absolute;top:10px;left:10px;z-index:2;font-weight:800;font-size:.7rem;
  padding:4px 10px;border-radius:999px;box-shadow:var(--shadow)}
.status-pill.owned{background:var(--green);color:#fff}
.status-pill.missing{background:rgba(255,255,255,.9);color:#6b7a93;border:1px solid var(--line)}
.hero-card .proxy-note{position:relative;margin:8px auto 0;display:block;text-align:center;width:fit-content;font-size:.66rem}

.hero-info{position:relative;min-width:0;align-self:center}
.hero-eyebrow{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:.78rem;font-weight:600;flex-wrap:wrap}
.hero-eyebrow span:last-child{overflow-wrap:anywhere}
.hero-name{font-size:1.55rem;line-height:1.06;margin:5px 0 3px;letter-spacing:-.01em}
.hero-sub{display:flex;gap:10px;align-items:baseline;flex-wrap:wrap;margin-bottom:10px}
.hero-sub .ja{font-size:1.05rem;font-weight:700}
.hero-sub .en{font-size:1rem;font-weight:600;color:#33507e}
.hero-sub .romaji,.hero-sub .genus{color:var(--muted);font-size:.85rem}
.badge-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.type-chip{font-size:.7rem;font-weight:800;color:#fff;padding:4px 10px;border-radius:999px;
  background:var(--type);box-shadow:var(--shadow);text-transform:uppercase;letter-spacing:.03em}
.type-chip.t-grass{background:#4fae54}.type-chip.t-fire{background:#ff7a3d}
.type-chip.t-water{background:#3f8fe0}.type-chip.t-lightning{background:#e7b30a}
.type-chip.t-psychic{background:#b25cc9}.type-chip.t-fighting{background:#d96a3c}
.type-chip.t-darkness{background:#574f6b}.type-chip.t-metal{background:#7f8a9c}
.type-chip.t-fairy{background:#e978c4}.type-chip.t-dragon{background:#6a6fc0}
.type-chip.t-colorless{background:#9aa6b5}
.pill{font-size:.74rem;padding:4px 10px;border-radius:999px}
.pill.ghost{background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:600}
.hero-metrics{display:flex;gap:20px;flex-wrap:wrap}
.metric{display:flex;flex-direction:column}
.m-num{font-size:1.4rem;font-weight:800;letter-spacing:-.5px;line-height:1}
.m-num.hp{color:var(--type)}
.m-lab{color:var(--muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.hero-collection{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.hero-collection-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.85);border:1px solid var(--line);font-size:.78rem;font-weight:700;color:#33507e}
.hero-note{margin:14px 0 0;padding:10px 12px;border-radius:12px;border:1px solid rgba(63,143,224,.15);
  background:rgba(255,255,255,.72);color:#33507e;font-size:.85rem}
.ai-review-box{margin-top:12px;padding:12px;border:1px dashed #bfd3f5;border-radius:14px;background:#f8fbff}
.ai-review-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ai-review-actions{display:flex;gap:8px;flex-wrap:wrap}
.ai-review-note{margin:6px 0 0;color:var(--muted);font-size:.82rem}
.ai-draft-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}
.ai-draft-card{border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px;box-shadow:var(--shadow)}
.ai-draft-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}
.ai-draft-top strong{font-size:.95rem}
.ai-draft-meta{display:flex;flex-direction:column;gap:1px;color:var(--muted);font-size:.76rem}
.ai-draft-title{font-size:1.02rem;font-weight:700;line-height:1.2;margin:10px 0 4px}
.ai-draft-note{margin:0 0 8px;color:#33507e;font-size:.84rem}
.ai-draft-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ai-draft-empty{font-size:.84rem;color:var(--muted)}
.ai-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#eef3fb;color:#446086;font-size:.72rem;font-weight:700}

.hero-side{display:grid;gap:10px;align-content:start;min-width:0}
.hero-side-group{position:relative;background:rgba(255,255,255,.82);border:1px solid var(--line);
  border-radius:14px;padding:12px;backdrop-filter:blur(6px);box-shadow:var(--shadow)}
.hero-side-group.accent-purple{border-color:#ddd5ff}
.hero-side .fg-head{margin-bottom:10px}
.hero-side .fg-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}
.hero-side .fact{border-bottom:1px dashed var(--line);padding-bottom:7px}
.hero-side .fact .fk{font-size:.63rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.hero-side .fact .fv{font-size:.84rem;font-weight:700;line-height:1.25;overflow-wrap:anywhere}

.cd-body{margin-top:14px}
.body-grid{display:grid;gap:12px;min-width:0}
.span-2{grid-column:1/-1}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);min-width:0}
h3.sec{margin:0 0 9px;font-size:.95rem;display:flex;align-items:center;gap:8px}
h3.sec::before{content:"";width:3px;height:15px;border-radius:3px;background:var(--type)}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;min-width:0}
.section-head .sec{margin-bottom:0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}
.stats-grid>div{border:1px solid var(--line);border-radius:10px;background:#fff;padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.stats-grid strong{font-size:1.2rem;line-height:1}
.stats-grid span{font-size:.72rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
.table-wrap table{width:100%;border-collapse:collapse;font-size:.86rem}
.table-wrap th,.table-wrap td{padding:9px 11px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.table-wrap tr:last-child td{border-bottom:0}
.table-wrap th{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.warning-box{border:1px solid #ffd480;background:#fff8e6;border-radius:12px;padding:10px 12px;margin:10px 0}
.warning-box ul{margin:6px 0 0 18px;padding:0}
.notice-card{display:flex;gap:8px;align-items:flex-start;margin:10px 0;padding:11px 13px;border:1px solid #bfe0cc;
  border-radius:12px;background:#effaf3;color:#1b5f36}
.notice-card strong{font-size:.86rem;line-height:1.25}
.notice-card span{font-size:.82rem;line-height:1.35}
.activity-list{display:grid;gap:8px}
.activity-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;padding:10px 12px;
  border:1px solid var(--line);border-radius:12px;background:#fff}
.activity-row.succeeded{border-color:#bfe0cc;background:#fbfffc}
.activity-row.failed{border-color:#ffc9c9;background:#fff7f7}
.activity-row strong{display:block;font-size:.9rem;line-height:1.25}
.activity-row span{display:block;margin-top:2px;color:var(--muted);font-size:.72rem}
.activity-row p{margin:5px 0 0;color:#9e1e1e;font-size:.78rem}
.activity-row dl{display:grid;grid-template-columns:auto auto;gap:3px 8px;margin:0;font-size:.75rem}
.activity-row dt{color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.activity-row dd{margin:0;font-weight:800;color:var(--ink)}
.legalities{display:flex;gap:6px;flex-wrap:wrap;min-width:0}
.progress-panel{display:flex;flex-direction:column;gap:10px;padding:14px 16px;background:linear-gradient(180deg,#fff,#f8fbff)}
.progress-label{font-size:.82rem;font-weight:700;color:var(--muted)}
.progress-bar{height:12px;border-radius:999px;background:#e6edf9;overflow:hidden}
.progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--type),#56b0ff)}
.collection-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.collection-title{min-width:0}
.collection-title .sec{margin-bottom:2px}
.collection-title p{margin:0;color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.collection-score{display:flex;flex-direction:column;align-items:flex-end;line-height:1;flex:0 0 auto}
.collection-score strong{font-size:1.4rem;letter-spacing:-.04em}
.collection-score span{margin-top:4px;font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.collection-progress{height:8px}
.collection-strip{display:flex;flex-wrap:wrap;gap:8px}
.collection-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.8rem;font-weight:600;color:#24406f}
.collection-chip b{font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.collection-callouts{display:grid;grid-template-columns:1fr;gap:8px;min-width:0}
.collection-mini{display:grid;grid-template-columns:1fr auto;gap:2px 10px;align-items:center;padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:var(--surface)}
.collection-mini-label{font-size:.64rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.collection-mini strong{font-size:.88rem;line-height:1.15;overflow-wrap:anywhere}
.collection-mini-meta{font-size:.74rem;color:#33507e;overflow-wrap:anywhere}
.collection-mini-price{grid-column:2;grid-row:1 / span 3;align-self:center;font-size:.9rem;font-weight:800;letter-spacing:-.02em;text-align:right}
.progress-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.progress-stat{padding:10px 12px;border-radius:12px;background:linear-gradient(180deg,#fff,#f7fbff);border:1px solid var(--line);display:flex;flex-direction:column;gap:4px;min-width:0}
.progress-stat .k{display:block;font-size:1.1rem;font-weight:800;line-height:1.1;overflow-wrap:anywhere}
.progress-stat .v{display:block;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);overflow-wrap:anywhere}
.progress-callouts{display:grid;grid-template-columns:1fr;gap:10px;min-width:0}
.callout{display:flex;flex-direction:column;gap:3px;padding:11px 12px;border-radius:12px;border:1px solid var(--line);
  background:var(--type-soft)}
.callout strong{font-size:.92rem;overflow-wrap:anywhere}
.callout span{font-size:.8rem;color:#33507e;overflow-wrap:anywhere}
.callout-label{font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

.lore-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.lore-head .sec{margin:0}
.lore-summary{margin:0 0 8px;font-size:.95rem;line-height:1.5;color:#223252}
.lore{border-left:3px solid var(--type);background:var(--type-soft);border-radius:0 10px 10px 0;
  padding:8px 12px;margin:8px 0;font-size:.9rem}
.lore-tag{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.lore p{margin:.2em 0 0}
.lore.flavor{font-style:italic;color:var(--muted);border-left-style:dashed}
.lore-details{margin-top:10px}
.lore-details summary{cursor:pointer;font-weight:700;color:var(--blue);list-style:none}
.lore-details summary::-webkit-details-marker{display:none}
.lore-stack{margin-top:8px}
.btn.small{padding:6px 12px;font-size:.82rem}

.copies-wrap{max-width:100%;overflow-x:auto}
.copies{width:100%;border-collapse:collapse;font-size:.86rem}
.copies th,.copies td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.copies th{color:var(--muted);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.03em}
.copies tr:last-child td{border-bottom:0}

/* facts & stats */
.fg-head{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.fg-tag{font-size:.58rem;font-weight:800;letter-spacing:.08em;color:#fff;background:var(--blue);
  padding:2px 7px;border-radius:6px}
.accent-purple .fg-tag{background:#7c5cff}
.fg-head h3{margin:0;font-size:.95rem}
.fg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px 16px}
.fact{display:flex;flex-direction:column;gap:3px}
.fact .fk{display:flex;align-items:center;gap:5px;font-size:.62rem;font-weight:700;
  letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.fact .fv{font-size:.88rem;font-weight:600;overflow-wrap:anywhere}
.dot{width:8px;height:8px;border-radius:50%;background:#d2dbea;flex:0 0 auto}
.dot.on{background:var(--green)}
@media(min-width:560px){
  .fg-grid{grid-template-columns:repeat(3,1fr)}
  .collection-callouts{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* gameplay */
.gameplay-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px;min-width:0}
.action-card{border:1px solid var(--line);border-radius:14px;padding:12px;background:linear-gradient(180deg,#fff,var(--type-soft));min-width:0;max-width:100%;overflow:hidden}
.action-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.action-top h4{margin:0;font-size:1rem;overflow-wrap:anywhere}
.action-tag{font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;background:var(--type);padding:4px 8px;border-radius:999px}
.action-damage{margin-left:auto;font-weight:800;font-size:1.05rem;color:var(--type)}
.action-cost{font-size:.78rem;font-weight:700;color:#33507e;margin-bottom:6px;overflow-wrap:anywhere}
.action-card p{margin:0;font-size:.9rem;line-height:1.45;white-space:normal;word-break:break-word;overflow-wrap:anywhere}
.rule-box{margin-top:12px;padding:12px;border-radius:12px;background:#f7faff;border:1px dashed #bfd3f5;min-width:0;max-width:100%;overflow:hidden}
.rule-box p{margin:0;white-space:normal;word-break:break-word;overflow-wrap:anywhere}
.rule-box p+p{margin-top:6px}

/* evolution line */
.evo{margin:18px 0}
.evo-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.evo-stage{display:flex;flex-direction:column;gap:10px}
.evo-card{display:flex;flex-direction:column;align-items:center;gap:1px;width:108px;padding:8px;
  border-radius:12px;text-align:center}
.evo-card img{width:82px;height:82px;object-fit:contain}
.evo-card.current{background:linear-gradient(180deg,#eaf3ff,#fff);border:2px solid var(--blue);box-shadow:var(--shadow)}
.evo-name{font-weight:700;font-size:.85rem;line-height:1.1}
.evo-ja{font-size:.72rem;color:#33507e}
.evo-arrow{font-size:1.5rem;color:#9fb0c9;font-weight:700}

/* proxy artwork note */
.proxy-note{display:inline-block;margin-top:10px;font-size:.72rem;color:#8a6d1f;
  background:#fff7e0;border:1px solid #ffe7a3;padding:4px 9px;border-radius:8px}
.proxy-note.ok{color:var(--green-d);background:#eaf6ee;border-color:#bfe0c9}
.imgfix{margin-top:8px;font-size:.82rem}
.imgfix summary{cursor:pointer;color:var(--blue);font-weight:600;list-style:none}
.imgfix summary::-webkit-details-marker{display:none}
.imgfix>*{margin-top:7px}
.imgfix .btn.small{display:inline-block}
.imgfix form{display:flex;gap:6px;flex-wrap:wrap}
.imgfix input[type=url]{flex:1;min-width:150px;padding:7px 9px;border:1px solid var(--line);border-radius:8px;font-size:.85rem}
.ai-cands{display:flex;flex-wrap:wrap;gap:8px}
.ai-cand{padding:0;border:2px solid var(--line);background:var(--surface);border-radius:8px;
  cursor:pointer;overflow:hidden;width:78px;display:flex;flex-direction:column}
.ai-cand:hover{border-color:var(--blue)}
.ai-cand img{width:100%;height:100px;object-fit:contain;background:#dfe8f6}
.ai-cand span{font-size:.6rem;color:var(--muted);padding:2px}

/* finishes as mini cards */
.finishes-box{margin:14px 0}
.finishes{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0}
.finish-card{width:132px;display:flex;flex-direction:column;gap:2px;text-align:center}
.fc-img{position:relative;aspect-ratio:5/7;border-radius:10px;overflow:hidden;background:#dfe8f6;
  box-shadow:var(--shadow);border:1px solid var(--line)}
.fc-img img{width:100%;height:100%;object-fit:contain}
.finish-card.missing .fc-img{border-style:dashed}
.finish-card.missing .fc-img img{filter:grayscale(.85) opacity(.45)}
.fc-badge{position:absolute;top:6px;right:6px;font-size:.6rem;font-weight:800;padding:2px 6px;
  border-radius:999px;background:var(--green);color:#fff}
.fc-badge.no{background:#9aa7bd}
.fc-sheen{position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;opacity:.55;
  background:linear-gradient(115deg,transparent 25%,rgba(120,200,255,.8),rgba(255,170,235,.8),rgba(170,255,200,.8),transparent 75%);
  background-size:250% 250%;animation:shimmer 4s linear infinite}
.fin-reverse .fc-sheen{opacity:.4;background:linear-gradient(150deg,transparent,rgba(180,160,255,.7),transparent);background-size:200% 200%}
.finish-card.missing .fc-sheen{opacity:.25}
.fc-label{font-weight:700;font-size:.86rem;margin-top:4px}
.fc-sub{font-size:.74rem;color:var(--muted)} .fc-sub.yes{color:var(--green-d);font-weight:600}
.fc-val{font-weight:700;font-size:.84rem}

/* legacy finish chips (unused) */
.finishes-box .finish{margin:14px 0}
.finishes{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0}
.finish{position:relative;min-width:120px;flex:1 1 120px;max-width:200px;border:1px solid var(--line);
  border-radius:12px;padding:10px 12px;background:var(--surface);display:flex;flex-direction:column;gap:3px;
  box-shadow:var(--shadow);overflow:hidden}
.finish .fl{font-weight:700;font-size:.92rem}
.finish .fo{font-size:.8rem} .finish .fo.yes{color:var(--green-d);font-weight:600}
.finish .fo.no{color:var(--muted)}
.finish .fv{font-weight:700;font-size:.9rem}
.finish.missing{background:#f4f7fc;border-style:dashed}
.finish.owned{border-color:#bfe0c9}
.finish.foil::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:linear-gradient(115deg,transparent 30%,rgba(120,200,255,.5),rgba(255,180,230,.5),rgba(180,255,200,.5),transparent 70%);
  background-size:250% 250%;animation:shimmer 4s linear infinite}
.finish.foil.missing::before{opacity:.22}
@keyframes shimmer{0%{background-position:0% 0%}100%{background-position:100% 100%}}
.finish .fl,.finish .fo,.finish .fv{position:relative;z-index:1}

/* owned-finish dots on grid tiles */
.finrow{display:flex;gap:3px;margin-top:3px}
.findot{font-size:.6rem;font-weight:800;padding:1px 4px;border-radius:5px;background:#e6edf9;color:#3a597f;letter-spacing:.02em}
.findot.f-holo{background:linear-gradient(120deg,#ffd86b,#ff9ad1,#8fd3ff);color:#2a2a2a}
.findot.f-reverse{background:linear-gradient(120deg,#c7b3ff,#9fd3ff);color:#2a2a2a}
.findot.f-1stEdition{background:#1c5fc4;color:#fff}

.related-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.card-tile.current-card{outline:2px solid var(--blue);outline-offset:-2px}
.card-tile.is-hidden{display:none}
.print-filters{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px}
.print-filters .chip{background:#f7faff}
.print-filters .chip.on{background:var(--blue);border-color:var(--blue);color:#fff}

/* search + upload */
.searchbar{display:flex;gap:10px;margin:10px 0 16px}
.searchbar input{flex:1;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:1rem;background:var(--surface)}
.uploader{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:14px 0}
.drop{flex:1;min-width:240px;border:2px dashed #b9cdf0;border-radius:14px;padding:26px;text-align:center;
  background:var(--surface);cursor:pointer;color:var(--muted)}
.drop input{display:none}
.howto{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow)}
.howto li{margin:.3em 0}

/* admin command center */
.admin-command-page{gap:16px}
.admin-head-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.admin-alert{padding:10px 12px;border:1px solid #bfd9ff;border-radius:12px;background:#f4f9ff;color:#274a77;font-weight:700}
.admin-alert.failed,.admin-alert.missing{border-color:#ffc9c9;background:#fff3f3;color:#8d2424}
.settings-command-alert{margin-top:10px;font-size:.78rem}
.version-check{display:grid;gap:10px;margin-bottom:10px;padding:12px;border:1px solid #d7e5fb;border-radius:14px;
  background:#f8fbff}
.version-check-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.version-check-head strong,.version-check-head span{display:block}
.version-check-head strong{font-size:.86rem;line-height:1.2}
.version-check-head span{margin-top:2px;color:var(--muted);font-size:.68rem;line-height:1.25;overflow-wrap:anywhere}
.version-rows{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.version-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid var(--line);
  border-radius:11px;background:#fff}
.version-row span{color:var(--muted);font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.version-row code{font:700 .75rem/1.2 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  color:#274a77;overflow-wrap:anywhere}
.version-check.match{border-color:#b9e6c5;background:#f4fff7}
.version-check.different{border-color:#ffe1aa;background:#fffaf1}
.version-check.missing,.version-check.unreachable{border-color:#ffc9c9;background:#fff6f6}
.local-runner-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;
  border:1px solid #cbe6d4;border-radius:14px;background:#f0fbf4;color:#1e5e38}
.local-runner-banner.remote{border-color:#ffdca0;background:#fff8eb;color:#765112}
.local-runner-banner strong,.local-runner-banner span{display:block}
.local-runner-banner span{font-size:.82rem;line-height:1.35;margin-top:2px}
.admin-guide{padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.78);box-shadow:var(--shadow)}
.settings-command-guide{margin-top:10px;padding:12px;box-shadow:none}
.admin-guide-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.admin-guide-head h2{margin:0;font-size:1.1rem;text-transform:none;letter-spacing:0;color:var(--ink)}
.admin-kicker{font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--blue-d)}
.admin-guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:8px}
.admin-guide-item{padding:10px 11px;border:1px solid #dfe8f6;border-radius:12px;background:#fbfdff}
.admin-guide-item strong{display:block;font-size:.84rem;line-height:1.2}
.admin-guide-item p{margin:4px 0 0;color:var(--muted);font-size:.75rem;line-height:1.35}
.command-section h2{margin:4px 0 10px;font-size:1rem;text-transform:uppercase;letter-spacing:.06em;color:#415a7a}
.settings-command-section{margin-top:14px}
.settings-command-section h2{font-size:.78rem;margin:0 0 8px}
.command-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:10px}
.settings-command-section .command-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.command-card{display:flex;flex-direction:column;gap:10px;padding:12px;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--shadow)}
.command-card.risk-high{border-color:#ffd0d0;background:linear-gradient(180deg,#fff,#fff8f8)}
.command-card.risk-medium{border-color:#ffe1aa;background:linear-gradient(180deg,#fff,#fffaf1)}
.command-card.risk-low{border-color:#cae7d3;background:linear-gradient(180deg,#fff,#f8fff9)}
.command-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.command-title-line{display:flex;gap:9px;align-items:flex-start;min-width:0}
.command-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:9px;
  background:#eef4ff;color:var(--blue-d);font-weight:900;font-size:.82rem;flex:0 0 auto}
.command-card h3{margin:0;font-size:.94rem;line-height:1.18;letter-spacing:0;overflow-wrap:anywhere}
.script-name{display:block;margin-top:2px;color:var(--muted);font-size:.64rem;line-height:1.25;overflow-wrap:anywhere}
.risk-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:.62rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.risk-chip.risk-low{background:#e3f7ea;color:#13713b}
.risk-chip.risk-medium{background:#fff0cc;color:#8a5d09}
.risk-chip.risk-high{background:#ffe1e1;color:#a31e1e}
.command-best{margin:0;color:#28446a;font-size:.82rem;line-height:1.38;font-weight:700}
.command-facts{display:grid;gap:7px;margin:0}
.command-facts div{display:grid;grid-template-columns:72px minmax(0,1fr);gap:9px;padding-top:7px;border-top:1px dashed #dfe8f6}
.command-facts dt{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:#617894}
.command-facts dd{margin:0;color:var(--muted);font-size:.74rem;line-height:1.35;overflow-wrap:anywhere}
.command-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:2px}
.command-actions form{margin:0}
.command-time{color:#405d82;font-size:.68rem;font-weight:800}
.command-run-btn{min-width:64px;padding:8px 12px;font-size:.78rem;border-radius:10px}
.command-run-btn:disabled:hover{background:var(--blue)}
.command-run-btn.ghost:disabled:hover{background:var(--surface)}
@media(max-width:700px){
  .admin-head-actions{justify-content:flex-start}
  .version-rows{grid-template-columns:1fr}
  .version-log-row{grid-template-columns:1fr}
  .activity-log-row summary{display:grid;grid-template-columns:1fr;gap:6px}
  .log-type{justify-content:flex-start;width:max-content}
  .log-detail-grid{grid-template-columns:1fr}
  .command-grid{grid-template-columns:1fr}
  .command-facts div{grid-template-columns:1fr;gap:2px}
  .command-actions{align-items:flex-start;flex-direction:column}
  .command-actions form,.command-run-btn{width:100%}
}

/* admin upload review */
.admin-page{display:flex;flex-direction:column;gap:14px}
.upload-review{gap:8px;font-size:.5rem}
.admin-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}
.upload-review .admin-head{gap:8px}
.upload-review .admin-head h1{margin:0 0 2px;font-size:.95rem;line-height:1.05;letter-spacing:0}
.upload-review .admin-head p{margin:0;font-size:.58rem;line-height:1.25}
.upload-review .admin-head .btn{border-radius:8px;padding:6px 10px;font-size:.58rem}
.review-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:6px}
.review-stat{padding:7px 8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}
.review-stat strong{display:block;font-size:.9rem;line-height:1;letter-spacing:0}
.review-stat span{display:block;margin-top:3px;color:var(--muted);font-size:.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.review-stat.warn{border-color:#ffe0a8;background:#fffaf0}
.review-stat.block{border-color:#ffc9c9;background:#fff3f3}
.review-tabs{display:flex;gap:4px;flex-wrap:wrap;padding:4px;border:1px solid var(--line);border-radius:8px;background:#f6f9ff}
.review-tabs a{padding:4px 7px;border-radius:6px;background:var(--surface);color:#345276;font-size:.54rem;font-weight:800}
.review-tabs a.is-active{background:var(--blue);color:#fff}
.review-section{padding:8px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.88);box-shadow:var(--shadow)}
.review-section[hidden]{display:none !important}
.review-section.is-active{display:block}
.review-section-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;flex-wrap:wrap;margin-bottom:7px}
.review-stage-title{display:flex;gap:7px;align-items:flex-start;min-width:0}
.review-step{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:18px;height:18px;border-radius:50%;
  background:#eaf2ff;color:#2f5f9f;font-size:.54rem;font-weight:900}
.review-section h2{margin:0;font-size:.7rem;line-height:1.1}
.review-section h2 span{color:var(--muted);font-size:.56rem}
.review-section-head p{margin:2px 0 0;color:var(--muted);font-size:.52rem;line-height:1.25}
.review-bulk-actions{display:flex;align-items:center;justify-content:flex-end;gap:4px;flex-wrap:wrap}
.review-bulk-actions span{color:var(--muted);font-size:.5rem;font-weight:700;white-space:nowrap}
.review-bulk-actions .btn.small{border-radius:6px;padding:4px 6px;font-size:.5rem}
.review-list{display:grid;gap:5px}
.upload-review .review-section.is-active .review-list{max-height:58vh;overflow-y:auto;overflow-x:hidden;padding-right:2px}
.review-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px;align-items:center;padding:6px 7px;
  border:1px solid #e5edf8;border-radius:8px;background:#fbfdff}
.review-row strong,.review-row b{display:block;font-size:.62rem;line-height:1.18;overflow-wrap:anywhere}
.review-row span{display:block;color:#506985;font-size:.56rem;line-height:1.18;overflow-wrap:anywhere}
.review-row small,.review-row em{display:block;color:var(--muted);font-size:.52rem;line-height:1.18;font-style:normal;margin-top:1px}
.review-row.two-up{grid-template-columns:auto minmax(0,1fr) minmax(0,1fr) auto}
.review-row.removal-row{cursor:pointer}
.review-row.removal-row input,.review-row.selectable-row input{width:13px;height:13px;grid-column:auto;justify-self:start;accent-color:var(--blue)}
.review-row.selectable-row{cursor:pointer}
.review-row.selectable-row:has(input:not(:checked)){opacity:.62}
.removal-row,.selectable-row{grid-template-columns:auto minmax(0,1fr) auto}
.warning-row{border-color:#ffe0a8;background:#fffaf0}
.warning-row.blocking{border-color:#ffc9c9;background:#fff3f3}
.status-chip{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:2px 5px;border-radius:999px;
  background:#eef4ff;color:#365782;font-size:.46rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.status-pending_review,.status-pending{background:#fff4d8;color:#815e12}
.status-applied,.status-selected{background:#e5f6ec;color:#167244}
.status-cancelled,.status-ignored{background:#eef1f5;color:#68798f}
.status-failed{background:#ffe7e7;color:#9e1e1e}
.confirm-line{display:flex;gap:6px;align-items:flex-start;margin-top:7px;padding:6px 7px;border-radius:8px;
  background:#fff3f3;border:1px solid #ffc9c9;font-size:.55rem;font-weight:700;color:#7d2525}
.confirm-line input{margin-top:1px;width:13px;height:13px;accent-color:var(--red)}
.review-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:2px}
.review-actions .btn,.cancel-form .btn{border-radius:8px;padding:6px 10px;font-size:.58rem}
.cancel-form{margin:0}
.review-stepper{position:sticky;bottom:8px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:8px;padding:8px;border:1px solid #d7e5fb;border-radius:10px;background:rgba(255,255,255,.96);
  box-shadow:0 8px 24px rgba(28,60,120,.14);backdrop-filter:blur(8px)}
.review-stepper-copy{min-width:0}
.review-stepper-copy strong{display:block;font-size:.62rem;line-height:1.2}
.review-stepper-copy span{display:block;margin-top:1px;color:var(--muted);font-size:.5rem;line-height:1.2}
.review-stepper-actions{display:flex;gap:5px;flex:0 0 auto}
.review-stepper .btn.small{border-radius:7px;padding:5px 9px;font-size:.54rem}
.review-log{display:grid;grid-template-columns:86px minmax(0,1fr);gap:4px 8px;margin:0;font-size:.56rem}
.review-log dt{color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.46rem}
.review-log dd{margin:0;overflow-wrap:anywhere}
.review-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:var(--shadow)}
.review-table{width:100%;border-collapse:collapse;font-size:.86rem}
.review-table th,.review-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.review-table tr:last-child td{border-bottom:0}
.review-table th{color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em}
.review-table td strong{display:block;line-height:1.2}
.review-table td span{display:block;color:var(--muted);font-size:.74rem}
.mini-summary{display:flex;gap:5px;flex-wrap:wrap}
.mini-summary span{display:inline-flex;padding:3px 7px;border-radius:999px;background:#eef4ff;color:#345276;font-size:.68rem;font-weight:800}
@media(max-width:700px){
  .upload-review{gap:7px;font-size:.56rem}
  .review-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}
  .review-stat{padding:8px;border-radius:8px}
  .review-tabs{gap:4px}
  .review-tabs a{display:inline-flex;align-items:center;min-height:28px;padding:5px 8px}
  .review-section{padding:7px;border-radius:9px}
  .review-section-head{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:7px}
  .review-bulk-actions{display:grid;grid-template-columns:minmax(0,1fr) auto auto;width:100%;justify-content:start;gap:5px}
  .review-bulk-actions .btn.small{min-height:28px;padding:5px 8px}
  .review-row{grid-template-columns:minmax(0,1fr);padding:7px;gap:6px;border-radius:8px}
  .upload-review .review-section.is-active .review-list{max-height:44vh}
  .review-row.two-up{grid-template-columns:minmax(0,1fr)}
  .removal-row,.selectable-row{grid-template-columns:20px minmax(0,1fr)}
  .review-row.two-up.selectable-row{grid-template-columns:20px minmax(0,1fr)}
  .review-row.removal-row input,.review-row.selectable-row input{width:16px;height:16px;margin-top:2px}
  .review-row.two-up.selectable-row input{grid-row:1/span 3}
  .review-row.two-up.selectable-row div,.review-row.two-up.selectable-row .status-chip{grid-column:2}
  .removal-row .status-chip,.selectable-row .status-chip{grid-column:2;justify-self:start}
  .review-stepper{bottom:6px;align-items:stretch;display:grid;grid-template-columns:1fr;gap:7px;padding:7px}
  .review-stepper-actions{display:grid;grid-template-columns:1fr 1fr}
  .review-stepper .btn.small{min-height:32px}
  .review-log{grid-template-columns:1fr}
}

/* overlay */
.overlay{position:fixed;inset:0;z-index:60;background:rgba(13,30,60,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:12px}
.overlay.show{display:flex}
.overlay-card{background:#0c1830;color:#cfe2ff;border:1px solid #20406f;border-radius:11px;padding:13px;
  width:min(760px,94vw);max-height:86vh;display:flex;flex-direction:column;gap:7px;box-shadow:var(--shadow-lg)}
.overlay .btn,.progress-dock .btn{border-radius:7px;padding:6px 10px;font-size:.55rem}
.overlay .btn.small,.progress-dock .btn.small{padding:4px 7px;font-size:.49rem}
.overlay-head{display:flex;align-items:flex-start;justify-content:space-between;gap:7px}
.overlay-head-copy{display:flex;align-items:center;gap:7px;min-width:0}
.overlay-card h3{color:#fff;margin:0;font-size:.6rem}
.overlay-summary-row{display:flex;align-items:center;justify-content:space-between;gap:7px;color:#8fc8ff;font-size:.51rem}
.overlay-body{display:grid;grid-template-columns:minmax(126px,168px) minmax(0,1fr);gap:8px;min-height:0}
.overlay-jobs{min-height:0}
.overlay-job-list{display:flex;flex-direction:column;gap:5px;max-height:56vh;overflow:auto;padding-right:2px}
.overlay-job-empty{border:1px dashed #254b7d;border-radius:6px;padding:7px;color:#8fc8ff;font-size:.49rem}
.overlay-job{appearance:none;border:1px solid #1f3e68;background:#0a1428;color:#dcebff;border-radius:6px;
  padding:5px 6px;text-align:left;cursor:pointer;display:grid;gap:4px}
.overlay-job:hover,.overlay-job.is-selected{border-color:#56b0ff;background:#102142}
.overlay-job-title{font-weight:700;font-size:.5rem;line-height:1.25;color:#fff;overflow-wrap:anywhere}
.overlay-job-meta{display:flex;align-items:center;justify-content:space-between;gap:5px;color:#8fc8ff;font-size:.44rem}
.overlay-job-status{font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.4rem}
.overlay-job.done .overlay-job-status,
.overlay-job.complete .overlay-job-status{color:#74e3a0}
.overlay-job.error .overlay-job-status{color:#ffb2b2}
.overlay-job.cancelled .overlay-job-status,
.overlay-job.stopped .overlay-job-status{color:#ffd37b}
.overlay-job-track{height:4px;border-radius:999px;background:#16345e;overflow:hidden}
.overlay-job-track span{display:block;height:100%;width:0;background:linear-gradient(90deg,#56b0ff,#9ad0ff)}
.overlay-job.done .overlay-job-track span,
.overlay-job.complete .overlay-job-track span{background:#74e3a0}
.overlay-job.error .overlay-job-track span{background:#ff8c8c}
.overlay-detail{display:flex;flex-direction:column;gap:7px;min-height:0}
.overlay-progress{display:flex;flex-direction:column;gap:4px}
.overlay-progress-bar{height:6px;border-radius:999px;background:#16345e;overflow:hidden;border:1px solid #275288}
.overlay-progress-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#56b0ff,#9ad0ff)}
.overlay-progress-meta{display:flex;justify-content:space-between;gap:7px;font-size:.46rem;color:#8fc8ff}
.overlay-current{margin:0;color:#dcebff;font-size:.53rem;line-height:1.45}
.overlay-log-head{display:flex;align-items:center;justify-content:space-between;gap:7px;color:#8fc8ff;font-size:.46rem;font-weight:700}
.overlay-card pre{background:#081120;border-radius:6px;padding:7px;overflow:auto;flex:1;font-size:.48rem;
  white-space:pre-wrap;color:#8fc8ff;margin:0;max-height:46vh;user-select:text;cursor:text}
.overlay-actions{display:flex;gap:6px;flex-wrap:wrap}
.spinner{width:18px;height:18px;border:2px solid #1d3a66;border-top-color:#56b0ff;border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.progress-dock{position:fixed;right:11px;bottom:11px;z-index:55;width:min(216px,calc(100vw - 24px))}
.progress-dock[hidden]{display:none !important}
.progress-dock-card{background:#0c1830;color:#cfe2ff;border:1px solid #20406f;border-radius:10px;padding:7px 8px;
  display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-lg)}
.progress-dock-top{display:flex;align-items:center;justify-content:space-between;gap:7px}
.progress-dock-top strong{color:#fff;font-size:.55rem;line-height:1.2}
.progress-dock-top span{color:#8fc8ff;font-size:.48rem;font-weight:700;white-space:nowrap}
.progress-dock p{margin:0;color:#dcebff;font-size:.49rem;line-height:1.45}
.progress-dock-stack{display:flex;gap:3px;flex-wrap:wrap}
.progress-dock-pill{font-size:.42rem;color:#8fc8ff;border:1px solid #254b7d;border-radius:999px;padding:1px 4px}
.progress-dock-pill.done{color:#74e3a0;border-color:#2c7a53}
.progress-dock-pill.error{color:#ffb2b2;border-color:#8a3434}
.progress-dock-bar{height:5px;border-radius:999px;background:#16345e;overflow:hidden;border:1px solid #275288}
.progress-dock-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#56b0ff,#9ad0ff)}
.progress-dock-actions{display:flex;gap:5px;flex-wrap:wrap}
.progress-dock-actions .btn{padding:4px 7px}
@media (max-width: 640px){
  .overlay{padding:12px}
  .overlay-card{width:100%;max-height:88vh;padding:11px}
  .overlay-head{flex-direction:column;align-items:stretch}
  .overlay-head-copy{align-items:flex-start}
  .overlay-summary-row{align-items:flex-start;flex-direction:column}
  .overlay-body{grid-template-columns:1fr}
  .overlay-job-list{max-height:24vh}
  .progress-dock{left:12px;right:12px;bottom:12px;width:auto}
  .progress-dock-actions .btn{flex:1 1 auto}
}

/* shopping list */
.shop-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.shop-totals{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.shop-total-card{text-align:right;padding:10px 14px;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--shadow)}
.shop-total-card .big-val{display:block}
.shop-head-compact{padding:8px 0 4px}
.shop-title{min-width:260px;flex:1}
.shop-title h1{font-size:1.35rem;line-height:1.08;margin:0 0 5px;letter-spacing:0}
.shop-title p{margin:0;font-size:.82rem;line-height:1.35}
.shop-summary{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap;
  max-width:650px;color:#405677;font-size:.78rem;font-weight:700}
.shop-summary>span{display:inline-flex;align-items:center;gap:3px;min-height:28px;padding:4px 8px;border:1px solid var(--line);
  border-radius:8px;background:rgba(255,255,255,.74)}
.shop-summary b{font-size:.9rem;color:var(--ink);letter-spacing:0}
.shop-refresh{display:inline-flex;margin:0}
.shop-refresh .btn{padding:6px 9px;border-radius:8px;font-size:.72rem;white-space:nowrap}
.shop-view-tools{display:inline-flex;gap:4px;padding:3px;border:1px solid var(--line);border-radius:9px;background:rgba(255,255,255,.74)}
.shop-all-export{display:inline-flex;gap:4px;padding:3px;border:1px solid var(--line);border-radius:9px;background:rgba(255,255,255,.74)}
.focus-panel{margin:10px 0;padding:8px 10px;border-radius:10px;box-shadow:none;background:rgba(255,255,255,.82)}
.focus-panel summary{cursor:pointer;font-size:.78rem;line-height:1.25;list-style:none;color:#405677}
.focus-panel summary::-webkit-details-marker{display:none}
.focus-form{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.focus-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:999px;
  border:1px solid var(--line);background:#f7faff;cursor:pointer;font-size:.72rem;user-select:none}
.focus-chip.on{background:#e3efff;border-color:#bcd4ff;font-weight:600}
.focus-chip input{accent-color:var(--blue)}
.focus-name{line-height:1.1}
.focus-sub{color:var(--muted);font-size:.62rem;line-height:1.1}
.focus-save{flex-basis:100%;margin-top:6px}
.focus-save .btn{padding:6px 10px;font-size:.72rem;border-radius:8px}
.shop-export-actions{display:flex;gap:6px;flex-wrap:wrap}
.shop-export-actions .btn{padding:6px 9px;border-radius:8px;font-size:.72rem}
.shop-export-payload{display:none}
.shop-group{margin:8px 0;padding:0;overflow:hidden;border-radius:10px;box-shadow:none;background:rgba(255,255,255,.9)}
.shop-group-summary{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:8px;align-items:center;
  padding:8px 10px;cursor:pointer;list-style:none}
.shop-group-summary::-webkit-details-marker{display:none}
.shop-disclosure{width:18px;height:18px;border:1px solid var(--line);border-radius:6px;background:#f7faff;position:relative}
.shop-disclosure::before{content:"";position:absolute;inset:0;margin:auto;width:6px;height:6px;border-right:2px solid #6b7a93;
  border-bottom:2px solid #6b7a93;transform:rotate(-45deg) translate(-1px,1px)}
.shop-group[open] .shop-disclosure::before{transform:rotate(45deg) translate(-1px,-1px)}
.shop-group-title{min-width:0;display:flex;align-items:baseline;gap:6px}
.shop-group-body{padding:0 10px 10px}
.shop-export-actions-compact{gap:4px}
.shop-export-icon,
.copy-btn{appearance:none;border:1px solid var(--line);background:var(--surface);border-radius:7px;
  cursor:pointer;color:var(--muted);flex:0 0 auto}
.shop-export-icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;font-size:.82rem}
.grp-count{font-size:.72rem;font-weight:700;color:#536888;white-space:nowrap}
.inline-title{display:inline-flex}
.shop-set-main{font-size:.88rem;font-weight:800;line-height:1.15;overflow-wrap:anywhere}
.shop-set-sub{font-size:.68rem;color:var(--muted);font-weight:600;line-height:1.15;overflow-wrap:anywhere}
.need-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:6px}
.need-card{display:grid;grid-template-columns:48px minmax(0,1fr);gap:8px;align-items:center;
  border:1px solid var(--line);border-radius:8px;padding:6px;background:#fbfdff;min-width:0}
.need-card:hover{border-color:#cbdaf0;background:#fff}
.need-img{display:block;flex:0 0 auto;width:48px}
.need-img img{width:48px;border-radius:6px;display:block;box-shadow:0 1px 5px rgba(28,60,120,.1)}
.need-meta{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:3px 8px;align-items:center}
.need-title{min-width:0;display:block}
.need-title:hover .need-name{color:var(--blue)}
.need-name{display:block;font-size:.78rem;font-weight:800;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.need-ja{display:block;color:#33507e;font-size:.65rem;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.need-ja.en-sub{color:var(--muted)}
.need-line{grid-column:1/-1;display:flex;align-items:center;gap:4px;min-width:0;flex-wrap:wrap}
.need-number,.need-rarity{font-size:.63rem;font-weight:800;color:#536888;line-height:1.1}
.need-rarity{max-width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.need-line .tag{padding:3px 6px;border-radius:999px;font-size:.62rem;line-height:1.1}
.need-line .tag.price{background:#eaf6ee;border-color:#bfe0c9;color:var(--green-d);font-weight:800}
.need-line .tag.price.researched{background:#eef4ff;border-color:#c8d9f5;color:#28528e}
.need-line .tag.price.rough-ai{background:#fff7e0;border-color:#ffe0a3;color:#7b5a00}
.need-line .tag.no-price{background:#fff7e0;border-color:#ffe0a3;color:#7b5a00}
.ask{grid-column:1/-1;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px;background:#fff;
  border:1px dashed var(--line);border-radius:7px;padding:4px 5px 4px 7px}
.ask-text{font-size:.68rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.copy-btn{width:24px;height:22px;font-size:.72rem}
.shop-export-icon:hover,
.copy-btn:hover{background:var(--bg);color:var(--ink)}

/* trade page */
.trade-panel{margin:16px 0}
.trade-list{display:flex;flex-direction:column;gap:12px}
.trade-item{display:grid;grid-template-columns:74px minmax(0,1fr);gap:12px;align-items:start;
  border:1px solid var(--line);border-radius:14px;padding:10px;background:#fbfdff}
.trade-item-img{display:block;width:74px}
.trade-item-img img{width:74px;border-radius:8px;display:block;box-shadow:var(--shadow)}
.trade-item-main{min-width:0;display:flex;flex-direction:column;gap:8px}
.trade-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}
.trade-copy{min-width:0}
.trade-item-title{display:inline-block}
.trade-item-title:hover .trade-name{color:var(--blue)}
.trade-name{font-weight:700}
.trade-ja{color:#33507e;font-size:.9rem}
.trade-ja.en-sub{color:var(--muted)}
.trade-subline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:3px}
.trade-set{font-size:.92rem;color:#33507e}
.trade-set-ja{font-size:.8rem;color:var(--muted)}
.trade-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.trade-finish{font-weight:700}
.trade-finish.foil{background:#fff5cf;border-color:#f2d56b;color:#7b5a00}
.trade-tag-unmatched{background:#fff0f0;border-color:#ffcaca;color:#a93c3c;font-weight:700}
.trade-metrics{display:flex;gap:8px;flex-wrap:wrap}
.trade-metric{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:999px;
  border:1px solid var(--line);background:#fff;font-size:.82rem}
.trade-metric b{font-size:.72rem;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.trade-item-value{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.trade-price{font-size:1.1rem;font-weight:800;letter-spacing:-.02em}
.trade-empty{margin:16px 0}

/* responsive */
@media(min-width:560px){ .stat-grid{grid-template-columns:repeat(3,1fr)} }
@media(min-width:760px){
  .stat-grid{grid-template-columns:repeat(6,1fr)}
  .grid.cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .set-page .grid.cards{grid-template-columns:repeat(auto-fill,minmax(148px,1fr))}
  .set-hero{padding:16px}
  .set-hero-title{font-size:1.58rem}
  .set-hero-panels{grid-template-columns:1.05fr .95fr}
  .hero{grid-template-columns:214px 1fr;gap:18px;padding:18px;align-items:start}
  .hero-card{justify-self:start}
  .hero-name{font-size:1.9rem}
  .lore-wrap{grid-column:1}
  .need-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}
  .trade-item{grid-template-columns:74px minmax(0,1fr) auto;align-items:center}
  .trade-item-value{align-items:flex-end;text-align:right}
  h1{font-size:2rem}
}
@media(min-width:980px){
  .hero{grid-template-columns:214px minmax(0,1fr) minmax(300px,.95fr);gap:20px}
  .body-grid{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);align-items:start}
  .gameplay-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .progress-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .progress-callouts{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .topbar{padding:10px 12px}
  .topbar-inner{align-items:center;flex-direction:row;flex-wrap:wrap}
  .brand{min-height:42px;min-width:0}
  .brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .menu-toggle{display:inline-flex;margin-left:auto}
  .nav{display:none;width:100%;flex-basis:100%;flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:3px;margin-top:2px;padding:8px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.96);
    box-shadow:var(--shadow)}
  .nav-check:checked ~ .nav{display:flex}
  .nav > *{width:100%}
  .nav a,.nav-button{display:flex;align-items:center;min-height:42px;width:100%;padding:8px 10px;text-align:left}
  .nav-form{width:100%}
  .gear{width:100%;height:42px;justify-content:flex-start;gap:8px;padding:0 10px;transform:none}
  .gear::after{content:"Settings";font-size:.9rem}
  .gear:hover{transform:none}
  .set-hero-top,.set-hero-panels,.set-toolbar{grid-template-columns:1fr}
  .set-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}
  .set-filters{justify-content:flex-start}
  .copies{font-size:.8rem}
  .trade-item{grid-template-columns:1fr}
  .trade-item-img{width:96px}
  .trade-item-img img{width:96px}
  .trade-item-value{padding-top:2px}
  .copies thead{display:none}
  .copies,.copies tbody,.copies tr,.copies td{display:block;width:100%}
  .copies tbody{display:grid;gap:10px}
  .copies tr{padding:8px 10px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#fff,#f8fbff)}
  .copies td{display:grid;grid-template-columns:78px minmax(0,1fr);gap:10px;padding:5px 0;border-bottom:1px dashed var(--line)}
  .copies td:last-child{border-bottom:0}
  .copies td::before{content:attr(data-label);color:var(--muted);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
  .shop-head-compact{gap:10px}
  .shop-summary{justify-content:flex-start}
  .shop-group-summary{grid-template-columns:auto minmax(0,1fr) auto;gap:6px}
  .shop-group-summary .shop-export-actions{grid-column:3;grid-row:1 / span 2;align-self:center}
  .grp-count{grid-column:2;font-size:.68rem;white-space:normal}
  .need-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .wrap,.foot{width:min(1180px,calc(100% - 24px))}
  .uploader.modal-uploader{grid-template-columns:1fr}
  .modal-upload-btn{min-height:44px}
  .set-page{gap:10px}
  .set-hero{padding:12px}
  .set-identity{grid-template-columns:1fr}
  .set-identity-logo{width:100%;min-height:76px}
  .set-kpis,.set-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .set-collection-row{grid-template-columns:1fr}
  .set-collection-row strong{margin-top:2px}
  .set-toolbar{padding:10px}
  .set-progress-track{max-width:none}
  .set-filters .chip{font-size:.74rem}
  .set-page .grid.cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .shop-title{min-width:0}
  .shop-summary>span{min-height:26px}
  .shop-export-actions .btn{flex:1 1 auto}
}
@media(max-width:420px){
  .set-kpis,.set-hero-grid,.set-page .grid.cards{grid-template-columns:1fr}
  .need-card{grid-template-columns:44px minmax(0,1fr)}
  .need-img,.need-img img{width:44px}
}
