/* TipityPuzzle */
:root {
  --bg: #080808;
  --surface: #111;
  --surface2: #1a1a1a;
  --border: rgba(255,255,255,.08);
  --red: #DC2626;
  --red2: #EF4444;
  --text: #f1f1f1;
  --muted: #888;
  --cell: 34px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; background: var(--bg); color: var(--text); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }
body { display: flex; flex-direction: column; }

/* ── Header ── */
.header { background: #0d0d0d; border-bottom: 1px solid var(--border); padding: 14px 20px; display: flex; align-items: center; gap: 12px; }
.header-logo { font-size: 20px; font-weight: 900; color: var(--text); letter-spacing: -.5px; }
.header-logo span { color: var(--red); }
.header-sub { font-size: 12px; color: var(--muted); }

/* ── Views ── */
.view { display: none; flex: 1; }
.view.active { display: flex; flex-direction: column; }

/* ── Home ── */
#view-home { align-items: center; justify-content: center; padding: 24px 16px 100px; gap: 24px; }
.home-hero { text-align: center; max-width: 600px; }
.home-hero h1 { font-size: clamp(26px, 5vw, 42px); font-weight: 900; line-height: 1.1; margin-bottom: 10px; }
.home-hero h1 span { color: var(--red); }
.home-hero p { color: var(--muted); font-size: 15px; line-height: 1.6; }
.home-card { background: var(--surface); border: 1px solid var(--border); border-radius: 20px; padding: 28px; width: 100%; max-width: 520px; display: flex; flex-direction: column; gap: 20px; }
.form-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: 6px; }
.topic-input { width: 100%; background: var(--surface2); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px; color: var(--text); font-size: 16px; outline: none; transition: border-color .15s; }
.topic-input:focus { border-color: var(--red); }
.topic-input::placeholder { color: var(--muted); }
.toggle-group { display: flex; gap: 8px; }
.toggle-btn { flex: 1; padding: 10px; background: var(--surface2); border: 1px solid var(--border); border-radius: 10px; color: var(--muted); font-size: 13px; font-weight: 700; cursor: pointer; transition: all .15s; }
.toggle-btn.active { background: var(--red); border-color: var(--red); color: #fff; }
.diff-group { display: flex; gap: 6px; }
.diff-btn { flex: 1; padding: 8px 4px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; color: var(--muted); font-size: 12px; font-weight: 700; cursor: pointer; transition: all .15s; }
.diff-btn.active { background: rgba(220,38,38,.15); border-color: var(--red); color: var(--red2); }
.generate-btn { width: 100%; padding: 16px; background: var(--red); border: none; border-radius: 12px; color: #fff; font-size: 16px; font-weight: 800; cursor: pointer; letter-spacing: .02em; transition: opacity .15s; }
.generate-btn:disabled { opacity: .5; cursor: not-allowed; }
.generate-btn:not(:disabled):hover { opacity: .9; }

/* ── Puzzle views shared ── */
.puzzle-header { padding: 12px 16px; background: #0d0d0d; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.puzzle-title { font-size: 15px; font-weight: 800; flex: 1; }
.puzzle-title span { color: var(--red); }
.btn-sm { padding: 7px 14px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 12px; font-weight: 700; cursor: pointer; transition: all .15s; }
.btn-sm:hover { border-color: var(--red); color: var(--red2); }
.btn-sm.red { background: var(--red); border-color: var(--red); color: #fff; }

/* ── Word Search ── */
#view-wordsearch { padding: 0 0 80px; }
.ws-layout { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 16px; }
.ws-grid {
  display: grid;
  grid-template-columns: repeat(var(--ws-size), var(--cell));
  grid-template-rows: repeat(var(--ws-size), var(--cell));
  gap: 2px;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
}
.ws-cell {
  width: var(--cell); height: var(--cell);
  display: flex; align-items: center; justify-content: center;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 5px; font-size: 13px; font-weight: 800;
  cursor: pointer; transition: background .08s;
}
.ws-cell.ws-selected { background: rgba(220,38,38,.35); border-color: var(--red); }
.ws-cell.ws-found { background: rgba(220,38,38,.15); border-color: rgba(220,38,38,.4); color: var(--red2); }
.ws-word-list { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 600px; }
.ws-word { font-size: 13px; font-weight: 800; padding: 5px 10px; background: var(--surface); border: 1px solid var(--border); border-radius: 6px; letter-spacing: .05em; }
.ws-word.ws-word-found { background: rgba(220,38,38,.1); border-color: rgba(220,38,38,.3); color: var(--muted); text-decoration: line-through; }
.ws-progress-bar-wrap { width: 100%; max-width: 500px; height: 4px; background: var(--surface2); border-radius: 2px; }
.ws-progress-bar { height: 4px; background: var(--red); border-radius: 2px; transition: width .3s; width: 0%; }
.ws-progress-text { font-size: 12px; color: var(--muted); }

/* ── Crossword ── */
#view-crossword { overflow-y: auto; padding-bottom: 80px; }
.cw-layout { display: flex; flex-direction: column; gap: 16px; padding: 16px; }
@media (min-width: 800px) {
  .cw-layout { flex-direction: row; align-items: flex-start; }
  .cw-grid-wrap { flex: 0 0 auto; }
  .cw-clues-wrap { flex: 1; min-width: 0; }
}
.cw-grid {
  display: grid;
  grid-template-columns: repeat(var(--cw-cols), var(--cell));
  gap: 2px;
  touch-action: manipulation;
}
.cw-cell { width: var(--cell); height: var(--cell); position: relative; border-radius: 3px; }
.cw-black { background: #222; }
.cw-white { background: var(--surface); border: 1px solid var(--border); cursor: pointer; }
.cw-white.cw-highlight { background: rgba(220,38,38,.12); border-color: rgba(220,38,38,.3); }
.cw-white.cw-active { background: rgba(220,38,38,.35); border-color: var(--red); }
.cw-white.cw-correct .cw-letter { color: #22c55e; }
.cw-white.cw-wrong .cw-letter { color: var(--red2); }
.cw-white.cw-revealed .cw-letter { color: #facc15; }
.cw-num { position: absolute; top: 2px; left: 3px; font-size: 7px; font-weight: 900; color: var(--muted); line-height: 1; }
.cw-letter { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 800; }
.cw-clues-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 500px) { .cw-clues-wrap { grid-template-columns: 1fr; } }
.cw-clue-section h3 { font-size: 13px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; color: var(--red2); margin-bottom: 8px; }
.cw-across, .cw-down { list-style: none; display: flex; flex-direction: column; gap: 4px; max-height: 340px; overflow-y: auto; }
.cw-clue { font-size: 12px; padding: 6px 8px; border-radius: 6px; cursor: pointer; transition: background .12s; }
.cw-clue:hover { background: var(--surface2); }
.cw-clue.cw-clue-active { background: rgba(220,38,38,.12); color: var(--text); }
.cw-clue-num { font-weight: 800; color: var(--red2); margin-right: 4px; }
.cw-actions { display: flex; gap: 8px; flex-wrap: wrap; padding: 0 16px; }

/* ── Toast ── (ad bar and install banner are inline-styled to match platform template) */

/* ── Toast ── */
#toast { position: fixed; bottom: 70px; left: 50%; transform: translateX(-50%) translateY(20px); background: #222; color: var(--text); padding: 10px 18px; border-radius: 10px; font-size: 13px; font-weight: 600; opacity: 0; transition: opacity .2s, transform .2s; pointer-events: none; z-index: 9999; white-space: nowrap; }
#toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── Home Stats Chip ── */
.home-stats-chip {
  margin-top: 4px; padding: 10px 14px; background: #0e0e0e; border: 1px solid #1e1e1e;
  border-radius: 10px; display: flex; flex-wrap: wrap; gap: 6px 14px; align-items: center;
  font-size: .78rem; min-height: 36px; cursor: pointer; transition: border-color .15s;
}
.home-stats-chip:hover { border-color: #333; }
.home-stats-chip:empty { display: none; }
.hsc-level { font-weight: 800; color: var(--text); }
.hsc-count { color: var(--muted); }
.hsc-near { color: var(--red2); font-weight: 700; }
.hsc-badges-link { margin-left: auto; color: #444; font-size: .72rem; }

/* ── Share Puzzle Overlay ── */
#share-puzzle-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.85);
  z-index: 9200; align-items: center; justify-content: center; padding: 16px;
}
#share-puzzle-overlay.show { display: flex; }
#share-puzzle-box {
  background: #111; border: 1px solid #2a2a2a; border-radius: 16px;
  padding: 24px 20px; max-width: 340px; width: 100%; text-align: center;
}
#spo-title { font-size: 1rem; font-weight: 900; color: #fff; margin-bottom: 14px; }
#spo-url-row { display: flex; gap: 8px; margin-bottom: 12px; }
#spo-url { flex: 1; background: #0a0a0a; border: 1px solid #2a2a2a; border-radius: 7px; padding: 8px 10px; color: #666; font-size: .72rem; min-width: 0; }
#spo-copy-url { background: #DC2626; color: #fff; border: none; border-radius: 7px; padding: 8px 14px; font-size: .8rem; font-weight: 700; cursor: pointer; white-space: nowrap; }
#spo-btns { display: flex; flex-direction: column; gap: 8px; }

/* ── Achievement Modal ── */
#achieve-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.9);
  z-index: 9500; align-items: center; justify-content: center; padding: 16px;
}
#achieve-overlay.show { display: flex; }
#achieve-box {
  background: #0a0a0a; border: 2px solid #DC2626;
  box-shadow: 0 0 40px rgba(220,38,38,.3), 0 0 80px rgba(220,38,38,.1);
  border-radius: 20px; padding: 32px 28px 24px; text-align: center;
  max-width: 360px; width: 100%;
  animation: achievePop .45s cubic-bezier(.175,.885,.32,1.275) both;
}
@keyframes achievePop {
  from { transform: scale(.6) translateY(40px); opacity: 0; }
  to   { transform: scale(1) translateY(0);      opacity: 1; }
}
#achieve-header {
  font-size: .68rem; font-weight: 900; letter-spacing: .2em; text-transform: uppercase;
  color: #DC2626; margin-bottom: 20px;
  animation: headerGlow 1.5s ease-in-out infinite alternate;
}
@keyframes headerGlow {
  from { text-shadow: 0 0 6px rgba(220,38,38,.4); }
  to   { text-shadow: 0 0 18px rgba(220,38,38,.9); }
}
#achieve-emoji {
  font-size: 5rem; line-height: 1; margin-bottom: 14px;
  animation: emojiBounce .6s cubic-bezier(.175,.885,.32,1.275) .2s both;
}
@keyframes emojiBounce {
  from { transform: scale(0) rotate(-20deg); }
  to   { transform: scale(1) rotate(0deg); }
}
#achieve-name { font-size: 1.6rem; font-weight: 900; color: #fff; margin-bottom: 6px; }
#achieve-desc { font-size: .85rem; color: #666; margin-bottom: 28px; }
#achieve-share-btn {
  display: block; width: 100%; padding: 14px; margin-bottom: 10px;
  background: #DC2626; color: #fff; border: none; border-radius: 10px;
  font-size: 1rem; font-weight: 800; cursor: pointer; letter-spacing: .02em;
  transition: background .15s;
}
#achieve-share-btn:hover { background: #b91c1c; }
#achieve-continue-btn {
  background: none; border: none; color: #444; font-size: .82rem;
  cursor: pointer; text-decoration: underline; padding: 6px;
}

/* ── Share Options ── */
#share-options-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.85);
  z-index: 9600; align-items: center; justify-content: center; padding: 16px;
}
#share-options-overlay.show { display: flex; }
#share-options-box {
  background: #111; border: 1px solid #2a2a2a; border-radius: 16px;
  padding: 24px 20px; max-width: 320px; width: 100%; text-align: center;
}
#so-title { font-size: 1rem; font-weight: 900; color: #fff; margin-bottom: 16px; }
#so-btns { display: flex; flex-direction: column; gap: 8px; margin-bottom: 8px; }
.so-btn {
  display: block; width: 100%; padding: 12px; border-radius: 8px; font-size: .9rem;
  font-weight: 700; text-decoration: none; border: none; cursor: pointer; text-align: center;
}
.so-fb-btn { background: #1877f2; color: #fff; }
.so-tw-btn { background: #000; color: #fff; border: 1px solid #333; }
.so-wa-btn { background: #25d366; color: #fff; }
.so-copy-btn { background: #1a1a1a; color: #ccc; border: 1px solid #333; margin-bottom: 8px; }
.so-dl-btn  { background: #1a1a1a; color: #ccc; border: 1px solid #333; }

/* ── Win Modal ── */
#win-overlay, #stats-overlay {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.8);
  z-index: 8000; align-items: center; justify-content: center; padding: 16px;
}
#win-overlay.show, #stats-overlay.show { display: flex; }
#win-box {
  background: #111; border: 1px solid #2a2a2a; border-radius: 16px;
  padding: 28px 24px 20px; text-align: center; max-width: 360px; width: 100%;
  max-height: 90vh; overflow-y: auto;
}
#win-emoji { font-size: 2.6rem; margin-bottom: 8px; }
#win-title { font-size: 1.35rem; font-weight: 900; color: var(--text); margin-bottom: 4px; }
#win-sub { font-size: .82rem; color: var(--muted); margin-bottom: 14px; }
.win-level-badge { font-size: .9rem; font-weight: 700; color: var(--text); margin-bottom: 12px; padding: 6px 14px; background: #1a1a1a; border-radius: 20px; display: inline-block; }
.win-level-up { font-size: .9rem; font-weight: 800; color: #facc15; margin-bottom: 12px; padding: 8px 14px; background: rgba(250,204,21,.1); border: 1px solid rgba(250,204,21,.3); border-radius: 10px; }
.win-badge-unlock { background: linear-gradient(135deg,#1a0a0a,#2a0f0f); border: 1px solid var(--red); border-radius: 12px; padding: 14px; margin-bottom: 12px; }
.wbu-label { display: block; font-size: .65rem; font-weight: 900; letter-spacing: .12em; color: var(--red2); text-transform: uppercase; margin-bottom: 4px; }
.wbu-emoji { display: block; font-size: 2rem; margin-bottom: 4px; }
.win-badge-unlock strong { display: block; font-size: 1rem; color: var(--text); margin-bottom: 2px; }
.win-badge-unlock span { font-size: .78rem; color: var(--muted); }
.win-goal-bar { font-size: .8rem; color: var(--muted); margin-bottom: 16px; padding: 8px 12px; background: #141414; border-radius: 8px; border: 1px solid #222; }
.win-goal-bar span { color: var(--text); }
#win-actions { display: flex; flex-direction: column; gap: 10px; }

/* ── Stats / Badges Page ── */
#stats-box {
  background: #111; border: 1px solid #2a2a2a; border-radius: 16px;
  max-width: 420px; width: 100%; max-height: 90vh; overflow-y: auto;
}
#stats-header { display: flex; justify-content: space-between; align-items: center; padding: 18px 20px 14px; border-bottom: 1px solid #1e1e1e; }
#stats-title { font-size: 1.1rem; font-weight: 900; color: var(--text); }
#stats-close { background: none; border: none; color: var(--muted); font-size: 1.1rem; cursor: pointer; padding: 4px 8px; }
#stats-body { padding: 18px 20px 24px; }
.stats-level-row { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.stats-level-badge { font-size: 2.4rem; }
.stats-level-name { font-size: 1.1rem; font-weight: 900; color: var(--text); }
.stats-count { font-size: .82rem; color: var(--muted); margin-top: 2px; }
.stats-progress-wrap { margin-bottom: 20px; }
.stats-progress-bar { height: 6px; background: var(--red); border-radius: 3px; transition: width .4s; margin-bottom: 6px; }
.stats-progress-label { font-size: .75rem; color: var(--muted); }
.stats-maxed { font-size: .85rem; color: #facc15; font-weight: 700; margin-bottom: 20px; }
.stats-badges-title { font-size: .7rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.stats-badges-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.stats-badge-card { background: #0e0e0e; border: 1px solid #1e1e1e; border-radius: 10px; padding: 14px 12px; text-align: center; opacity: .45; }
.stats-badge-card.earned { opacity: 1; border-color: #2a2a2a; }
.sbc-emoji { font-size: 1.6rem; margin-bottom: 5px; }
.sbc-name { font-size: .78rem; font-weight: 800; color: var(--text); margin-bottom: 3px; }
.sbc-desc { font-size: .7rem; color: var(--muted); line-height: 1.4; }

/* ── Print header / answer page (screen: hidden) ── */
#print-header { display: none; }
#print-answer-page { display: none; }
.ws-wordlist-label { display: none; }

/* ── Crossword per-clue reveal ── */
.cw-clue-ans-btn {
  display: inline-block; margin-left: 6px; font-size: 9px; font-weight: 700;
  padding: 1px 5px; background: transparent; border: 1px solid var(--border);
  border-radius: 3px; color: var(--muted); cursor: pointer; vertical-align: middle;
  transition: border-color .12s, color .12s; line-height: 1.4;
}
.cw-clue-ans-btn:hover { border-color: var(--red); color: var(--red2); }
.cw-ans-tip {
  display: inline-block; margin-left: 5px; font-size: 10px; font-weight: 900;
  color: var(--red2); letter-spacing: .06em; vertical-align: middle;
}

/* ── Print ── */
@media print {
  @page { size: letter portrait; margin: 1.4cm; }

  /* hide all screen chrome */
  .header, .puzzle-header, #toast, #ad-bar, #install-banner, footer,
  #win-overlay, #stats-overlay, #achieve-overlay, #share-options-overlay, #share-puzzle-overlay,
  .ws-progress-bar-wrap, .ws-progress-text { display: none !important; }

  body { background: #fff !important; color: #000 !important; }

  /* show print-only header */
  #print-header {
    display: flex !important; justify-content: space-between; align-items: center;
    border-bottom: 2px solid #000; padding-bottom: 10px; margin-bottom: 18px;
  }
  #print-header strong { font-size: 19px; letter-spacing: -.3px; color: #000; }
  #print-header .ph-red { color: #DC2626; }
  #print-header .ph-sub { font-size: 13px; color: #333; border-left: 1px solid #bbb; padding-left: 12px; margin-left: 4px; }
  #print-header .ph-date { font-size: 10.5px; color: #666; }

  /* views */
  .view { display: none !important; }
  .view.active { display: block !important; }

  /* ── Word Search ── */
  #view-wordsearch.active { padding: 0 !important; }
  .ws-layout { gap: 14px !important; padding: 0 !important; align-items: flex-start !important; }
  :root { --cell: 26px; }
  .ws-grid { gap: 1px !important; }
  .ws-cell {
    width: var(--cell) !important; height: var(--cell) !important;
    background: #fff !important; border: 1px solid #c8c8c8 !important;
    color: #000 !important; font-size: 10.5px !important; border-radius: 2px !important;
  }
  .ws-cell.ws-selected { background: #fff !important; border-color: #c8c8c8 !important; }
  .ws-cell.ws-found   { background: #fff !important; border-color: #c8c8c8 !important; color: #000 !important; }
  body.print-answer .ws-cell.ws-found { background: #dedede !important; font-weight: 900 !important; }

  /* word list — show in print */
  .ws-wordlist-label {
    display: block !important; font-size: 9.5px !important; font-weight: 900 !important;
    text-transform: uppercase !important; letter-spacing: .1em !important;
    color: #555 !important; margin-bottom: 6px !important;
  }
  .ws-word-list {
    display: grid !important; grid-template-columns: repeat(4, auto) !important;
    gap: 3px 24px !important; justify-content: start !important;
    max-width: none !important; padding-top: 12px !important;
    border-top: 1px solid #ddd !important;
  }
  .ws-word {
    font-size: 10px !important; font-weight: 700 !important; padding: 1px 0 !important;
    background: none !important; border: none !important; border-radius: 0 !important;
    color: #000 !important; text-decoration: none !important; letter-spacing: .06em !important;
  }
  .ws-word.ws-word-found { text-decoration: none !important; color: #000 !important; }
  body.print-answer .ws-word.ws-word-found { color: #999 !important; text-decoration: line-through !important; }

  /* ── Crossword ── */
  #view-crossword.active { padding: 0 !important; overflow: visible !important; }
  .cw-layout { flex-direction: row !important; padding: 0 !important; gap: 20px !important; align-items: flex-start !important; }
  .cw-grid { gap: 1px !important; }
  .cw-cell { border-radius: 0 !important; }
  .cw-white { background: #fff !important; border: 1px solid #999 !important; cursor: default !important; }
  .cw-black { background: #000 !important; }
  .cw-letter { color: #000 !important; font-size: 12px !important; }
  .cw-num { color: #333 !important; font-size: 6.5px !important; }
  .cw-white.cw-highlight,
  .cw-white.cw-active { background: #fff !important; border-color: #999 !important; }
  .cw-white.cw-correct .cw-letter,
  .cw-white.cw-wrong .cw-letter,
  .cw-white.cw-revealed .cw-letter { color: #000 !important; }
  .cw-clues-wrap {
    display: grid !important; grid-template-columns: 1fr 1fr !important;
    gap: 10px !important; max-height: none !important; overflow: visible !important;
  }
  .cw-across, .cw-down { max-height: none !important; overflow: visible !important; gap: 1px !important; }
  .cw-clue { font-size: 10px !important; padding: 1px 2px !important; line-height: 1.4 !important; }
  .cw-clue.cw-clue-active { background: none !important; }
  .cw-clue-section h3 { font-size: 11px !important; color: #000 !important; margin-bottom: 5px !important; border-bottom: 1px solid #ddd; padding-bottom: 3px; }
  .cw-clue-num { color: #000 !important; }

  /* hide digital-only interactive bits */
  .cw-clue-ans-btn, .cw-ans-tip { display: none !important; }

  /* ── Answer key page (page 2) ── */
  body.print-answer #print-answer-page {
    display: block !important;
    page-break-before: always;
    break-before: page;
    padding-top: 4px;
  }
  .print-answer-title {
    font-size: 13px; font-weight: 900; text-transform: uppercase;
    letter-spacing: .1em; color: #000; margin-bottom: 14px;
    border-bottom: 2px solid #000; padding-bottom: 8px;
  }
  /* word search answer key: highlighted grid clone */
  /* unfound letters are light gray, found letters are bold black — works without background printing */
  #print-answer-page .ws-cell { background: #fff !important; border-color: #e0e0e0 !important; color: #c0c0c0 !important; font-weight: 400 !important; }
  #print-answer-page .ws-cell.ws-found { background: #e8e8e8 !important; -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; color: #000 !important; font-weight: 900 !important; border-color: #999 !important; }
  #print-answer-page .ws-word-list { display: grid !important; grid-template-columns: repeat(4, auto) !important; gap: 3px 24px !important; justify-content: start !important; max-width: none !important; padding-top: 12px !important; border-top: 1px solid #ddd !important; }
  #print-answer-page .ws-word,
  #print-answer-page .ws-word.ws-word-found { font-size: 10px !important; font-weight: 700 !important; padding: 1px 0 !important; background: none !important; border: none !important; border-radius: 0 !important; color: #999 !important; text-decoration: line-through !important; letter-spacing: .06em !important; }
  /* crossword answer list */
  .print-ans-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .print-ans-head { font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; color: #000; margin-bottom: 6px; border-bottom: 1px solid #ddd; padding-bottom: 3px; }
  .print-ans-item { font-size: 10px; margin-bottom: 3px; line-height: 1.4; color: #000; }
  .print-ans-num { font-weight: 700; }
  .print-ans-word { font-weight: 900; letter-spacing: .04em; }
}

@media (max-width: 400px) {
  :root { --cell: 28px; }
  .ws-cell { font-size: 11px; }
}
