:root { --bg: #f4efe6; --panel: rgba(255, 252, 246, 0.9); --panel-strong: #fffaf0; --ink: #1e2b26; --muted: #57655f; --line: #b8aa93; --line-strong: #3b544a; --accent: #c96d4a; --accent-soft: #f4d8ca; --given: #e2efe8; --selected: #fff0bf; --hint: #d7efe4; --conflict: #ffd8d1; --mistake: #ffebe5; --shadow: 0 18px 45px rgba(53, 43, 26, 0.12); } *, *::before, *::after { box-sizing: border-box; } html, body { margin: 0; min-height: 100%; } body { font-family: "IBM Plex Sans KR", "Noto Sans KR", "Segoe UI", sans-serif; line-height: 1.5; color: var(--ink); background: radial-gradient(circle at top left, rgba(232, 202, 177, 0.55), transparent 28%), linear-gradient(180deg, #f8f3ea 0%, var(--bg) 100%); padding: 24px; } body > * { width: min(100%, 1440px); margin-inline: auto; } button, input { font: inherit; } button { border: 0; border-radius: 14px; cursor: pointer; } h1, h2, p, dl, dd, dt, ol { margin: 0; } ol, ul { padding: 0; } .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; } .site-header, .board-panel, .info-card, .site-footer { background: var(--panel); border: 1px solid rgba(59, 84, 74, 0.1); box-shadow: var(--shadow); } .site-header, .site-footer { border-radius: 28px; } .site-header { display: flex; justify-content: space-between; gap: 24px; align-items: flex-start; padding: 24px; margin-bottom: 24px; } .header-copy { max-width: 700px; } .eyebrow { color: var(--accent); font-size: 0.82rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 10px; } h1 { font-size: clamp(2rem, 4vw, 3.3rem); line-height: 1.05; letter-spacing: -0.04em; } .intro { margin-top: 12px; max-width: 60ch; color: var(--muted); } .top-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; } .top-actions button { padding: 12px 16px; min-height: 48px; background: var(--line-strong); color: #fff; font-weight: 700; transition: transform 0.15s ease, opacity 0.15s ease, background-color 0.15s ease; } .top-actions button:hover, .top-actions button:focus-visible { transform: translateY(-1px); background: #2e443b; outline: 3px solid rgba(201, 109, 74, 0.24); outline-offset: 2px; } .top-actions button:disabled { opacity: 0.5; cursor: not-allowed; transform: none; } .top-actions button[aria-pressed="true"] { background: var(--accent); } .layout { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(300px, 0.8fr); gap: 24px; align-items: start; } .layout > * { min-width: 0; } .board-panel, .info-card { border-radius: 24px; } .board-panel { padding: 22px; } .panel-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 18px; } .panel-head h2, .info-card h2 { font-size: 1.1rem; } .muted, .status, .hint-message, .stats-grid dt, .site-footer { color: var(--muted); } .status-wrap { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; } .badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 999px; background: var(--accent-soft); color: #7a341f; font-size: 0.9rem; font-weight: 700; } .sudoku-shell { background: var(--panel-strong); border-radius: 20px; border: 1px solid rgba(59, 84, 74, 0.12); padding: 16px; } .sudoku-board { display: grid; grid-template-columns: repeat(9, minmax(0, 1fr)); aspect-ratio: 1; width: min(100%, 720px); margin: 0 auto; border: 3px solid var(--line-strong); border-radius: 18px; overflow: hidden; } .cell { width: 100%; min-width: 0; border: 1px solid var(--line); background: #fffdf8; color: var(--ink); text-align: center; font-size: clamp(1rem, 2vw, 1.65rem); font-weight: 600; outline: none; padding: 0; } .cell[readonly] { cursor: default; } .cell.edge-right { border-right: 3px solid var(--line-strong); } .cell.edge-bottom { border-bottom: 3px solid var(--line-strong); } .cell.is-given { background: var(--given); font-weight: 800; } .cell.is-selected { background: var(--selected); } .cell.is-hint { background: var(--hint); box-shadow: inset 0 0 0 2px rgba(59, 84, 74, 0.35); } .cell.is-conflict { background: var(--conflict); color: #8f2417; } .cell.is-mistake { box-shadow: inset 0 0 0 2px rgba(201, 109, 74, 0.8); } .cell:focus-visible { background: var(--selected); box-shadow: inset 0 0 0 2px var(--accent); } .side-panel { display: grid; gap: 16px; } .info-card { padding: 18px; } .hint-message { margin-top: 10px; min-height: 72px; } .stats-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 12px; } .stats-grid div { padding: 14px; border-radius: 16px; background: rgba(244, 239, 230, 0.85); } .stats-grid dt { font-size: 0.84rem; } .stats-grid dd { margin-top: 6px; font-size: 1rem; font-weight: 700; color: var(--ink); } .log-list { list-style: none; margin-top: 12px; display: grid; gap: 10px; } .log-list li { padding: 12px 14px; border-radius: 14px; background: rgba(244, 239, 230, 0.85); color: var(--ink); overflow-wrap: anywhere; } .site-footer { margin-top: 24px; padding: 18px 22px; text-align: center; } @media (max-width: 980px) { .site-header, .panel-head { flex-direction: column; } .status-wrap { align-items: flex-start; } .layout { grid-template-columns: 1fr; } .sudoku-board { width: 100%; } } @media (max-width: 640px) { body { padding: 14px; } .site-header, .board-panel, .info-card, .site-footer { border-radius: 20px; } .site-header, .board-panel, .info-card { padding: 16px; } .top-actions { width: 100%; justify-content: flex-start; } .top-actions button { flex: 1 1 calc(50% - 10px); min-width: 0; } .stats-grid { grid-template-columns: 1fr; } } @media (max-width: 480px) { .top-actions button { flex-basis: 100%; } }