/* print.css — clean worksheet output for browser Print-to-PDF. */

.worksheet {
  max-width: 820px; margin: 0 auto; padding: 28px 32px;
  font-family: 'Inter', -apple-system, 'Segoe UI', sans-serif;
  color: #111;
}
.worksheet header { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 2px solid #111; padding-bottom: 10px; margin-bottom: 22px; }
.worksheet h1 { margin: 0; font-size: 22px; }
.worksheet .meta { font-size: 12px; color: #555; }
.worksheet .name-line { display: flex; gap: 30px; margin: 10px 0 16px; font-size: 14px; }
.worksheet .name-line span { border-bottom: 1px solid #999; min-width: 180px; display: inline-block; height: 1.4em; }
.worksheet .directions { font-size: 14px; margin: 0 0 18px; color: #333; }

/* Trace grid */
.trace-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; }
.trace-cell {
  border: 2px solid #111; border-radius: 12px;
  aspect-ratio: 1/1; display: grid; place-items: center;
  font-size: 110px; font-weight: 900; color: rgba(0,0,0,0.18);
  font-family: 'Inter', sans-serif;
}

/* Dot-count worksheet */
.dot-rows { display: grid; grid-template-columns: 1fr; gap: 12px; }
.dot-row {
  display: grid; grid-template-columns: 1fr 120px; gap: 16px;
  border-bottom: 1px dashed #999; padding-bottom: 10px;
}
.dot-row .dots { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.dot-row .dot { width: 22px; height: 22px; border-radius: 50%; background: #111; }
.dot-row .answer { border-bottom: 1.5px solid #111; display: inline-block; min-width: 70px; }
.dot-row .label { font-size: 14px; color: #555; }

/* Match worksheet */
.match-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.match-col { display: flex; flex-direction: column; gap: 16px; }
.match-item { display: flex; align-items: center; gap: 10px; font-size: 22px; font-weight: 700; padding: 10px 14px; border: 2px solid #111; border-radius: 10px; }

/* Fill-in worksheet */
.fill-rows { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 40px; }
.fill-row { display: flex; align-items: baseline; gap: 10px; font-size: 15px; }
.fill-row strong { min-width: 36px; display: inline-block; font-weight: 800; }
.fill-row .blank { flex: 1; border-bottom: 1.5px solid #111; height: 1.4em; }

.worksheet footer { margin-top: 28px; font-size: 11px; color: #777; text-align: center; }

/* Hide on-screen chrome during print */
@media print {
  body { background: #fff !important; }
  .print-hide, .topbar, .footer, .guide-strip, .crumbs, .celebrate { display: none !important; }
  .worksheet { padding: 20px; }
  .trace-cell { font-size: 90px; }
}

/* On-screen preview shell */
.worksheet-shell {
  background: #f6f7f9; padding: 24px 0;
}
.worksheet-shell .worksheet {
  background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.worksheet-actions {
  max-width: 820px; margin: 0 auto 16px; text-align: right; padding: 0 32px;
}
.worksheet-actions a, .worksheet-actions button {
  font: inherit; font-size: 14px; padding: 8px 14px;
  border-radius: 999px; border: 0; cursor: pointer;
  background: #111; color: #fff; text-decoration: none;
  display: inline-block; margin-left: 8px;
}
.worksheet-actions a.secondary { background: #eee; color: #111; }
