:root{
  --bg:#f7f4ec; --ink:#1d2330; --muted:#5a6172; --line:#c9cdd8;
  --accent:#132d5f; --accent2:#aa3c19; --ok:#1f7a44; --bad:#b3261e;
  --card:#fffdf8; --fs:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink); font-size:var(--fs);
  font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.45; -webkit-text-size-adjust:100%;
}
body.large{--fs:22px}
.wrap{max-width:860px;margin:0 auto;padding:14px 14px 40px}

header{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}
h1{font-size:1.7em;margin:0;color:var(--accent);letter-spacing:.5px}
.spacer{flex:1}
.sub{flex-basis:100%;margin:4px 0 0;color:var(--muted);font-size:.95em}
.iconbtn{
  background:var(--card);border:1.5px solid var(--line);border-radius:9px;
  padding:8px 12px;font-size:.9em;color:var(--ink);cursor:pointer;min-height:40px;
}
.iconbtn:active{transform:translateY(1px)}

.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:6px 0 12px}
.levels{display:flex;gap:6px}
.lvl{
  background:var(--card);border:1.5px solid var(--line);border-radius:9px;
  padding:9px 16px;font-size:1em;cursor:pointer;min-height:44px;color:var(--ink);
}
.lvl.active{background:var(--accent);color:#fff;border-color:var(--accent)}
button.primary{
  background:var(--accent2);color:#fff;border:0;border-radius:9px;
  padding:10px 18px;font-size:1em;cursor:pointer;min-height:44px;margin-left:auto;
}
button.primary:active{transform:translateY(1px)}

.hintbar{
  background:#eef2f9;border:1px solid #d6deec;border-radius:10px;
  padding:10px 14px;color:#33405c;font-size:.92em;margin-bottom:12px;
}
.scenario{font-size:1.15em;margin:4px 0 12px;color:var(--accent2)}

.cols{display:block}
.clues{margin-bottom:18px}
.clues ol{margin:0;padding-left:1.4em;columns:2;column-gap:30px}
.clues li{margin:0 0 9px;line-height:1.4;break-inside:avoid}
.gridwrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

table.assign{border-collapse:collapse;width:100%;background:var(--card)}
table.assign th,table.assign td{border:1px solid var(--line);padding:6px 8px;text-align:left}
table.assign thead th{background:#eef1f7;color:var(--accent);font-size:.9em;white-space:nowrap}
table.assign td.name{font-weight:700;white-space:nowrap}
table.assign select{
  width:100%;min-width:96px;font-size:1em;padding:9px 6px;min-height:44px;
  border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);
}
td.cell.ok select{background:#e6f5ec;border-color:var(--ok)}
td.cell.bad select{background:#fceceb;border-color:var(--bad)}

.status{margin:14px 0;min-height:1.5em;font-weight:700;font-size:1.1em}
.status.win{color:var(--ok)}
.status.miss{color:var(--bad)}

.actions{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 18px}
.actions button{
  background:var(--card);border:1.5px solid var(--line);border-radius:9px;
  padding:10px 18px;font-size:1em;cursor:pointer;min-height:46px;color:var(--ink);
}
#checkBtn{border-color:var(--accent);color:var(--accent);font-weight:700}
.actions button:active{transform:translateY(1px)}

.book{
  display:flex;gap:14px;align-items:center;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:8px 0 18px;
}
.book h3{margin:0 0 4px;color:var(--accent)}
.book p{margin:0;color:var(--muted);font-size:.92em}
.grid-ico{font-size:1.6em;line-height:1;display:flex;gap:2px}
.grid-ico .gx{color:var(--accent)}
.grid-ico .go{color:var(--accent2)}

.crosslinks{text-align:center;color:var(--muted);margin:6px 0 18px;font-size:.95em}
.crosslinks a{color:var(--accent);text-decoration:none}
.crosslinks a:hover{text-decoration:underline}

footer{text-align:center;color:var(--muted);font-size:.85em;border-top:1px solid var(--line);padding-top:14px}
footer .links a{color:var(--accent);text-decoration:none;margin:0 4px}
footer .privacy{margin-top:6px}

@media (max-width:560px){
  .clues ol{columns:1}
  h1{font-size:1.45em}
  button.primary{margin-left:0}
  table.assign select{min-width:74px}
}

@media print{
  .toolbar,.actions,.book,.crosslinks,footer,#largeBtn,#langBtn,.hintbar{display:none}
  body{background:#fff}
  td.cell.ok select,td.cell.bad select{background:#fff}
}
