/* ==========================================================================
   Sophicly · Crossword (v3.10.11)
   Light/dark via shared --sc-* tokens. Fixed mini-crossword retrieval grid.
   ========================================================================== */

.scxw-widget {
    font-family: 'Proxima Soft', system-ui, -apple-system, sans-serif;
    max-width: 760px;
    margin: 24px auto;
    -webkit-font-smoothing: antialiased;
}

.scxw-card {
    background: var(--sc-surface);
    border: 1px solid var(--sc-border);
    border-radius: 16px;
    padding: 24px;
    color: var(--sc-text);
}

.scxw-eyebrow {
    font-size: 11px; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase;
    color: var(--sc-accent);
    margin-bottom: 8px;
}
.scxw-title { font-size: 19px; font-weight: 700; line-height: 1.25; margin: 0 0 6px; }
.scxw-intro { font-size: 14px; color: var(--sc-text-muted); margin: 0 0 18px; }

.scxw-layout { display: flex; flex-wrap: wrap; gap: 24px; align-items: flex-start; }

/* ── Grid ── */
.scxw-gridhost { flex: 1 1 320px; }
.scxw-grid {
    display: grid;
    grid-template-columns: repeat(var(--scxw-cols), 1fr);
    gap: 2px;
    width: min(100%, 460px);
}
.scxw-cell {
    position: relative;
    aspect-ratio: 1 / 1;
}
.scxw-cell--block { background: transparent; }

.scxw-num {
    position: absolute; top: 1px; left: 2px;
    font-size: 9px; font-weight: 700; line-height: 1;
    color: var(--sc-text-muted);
    pointer-events: none; z-index: 2;
}

.scxw-input {
    width: 100%; height: 100%;
    border: 1.5px solid var(--sc-border);
    border-radius: 4px;
    background: var(--sc-surface-2);
    color: var(--sc-text);
    text-align: center;
    text-transform: uppercase;
    font-size: clamp(13px, 3.4vw, 19px); font-weight: 700;
    padding: 0; margin: 0;
    caret-color: var(--sc-accent);
    transition: background 0.12s ease, border-color 0.12s ease;
}
.scxw-input:focus { outline: none; }
.scxw-input.is-active { background: color-mix(in srgb, var(--sc-accent) 12%, var(--sc-surface-2)); }
.scxw-input.is-current { border-color: var(--sc-accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--sc-accent) 35%, transparent); }
.scxw-input.is-correct { border-color: #1CD991; background: color-mix(in srgb, #1CD991 16%, var(--sc-surface-2)); }
.scxw-input.is-wrong   { border-color: #ff5470; background: color-mix(in srgb, #ff5470 14%, var(--sc-surface-2)); }

/* ── Clues ── */
.scxw-clues { display: flex; flex-direction: column; gap: 16px; flex: 1 1 240px; min-width: 220px; }
.scxw-clue-head {
    font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--sc-accent); margin-bottom: 6px;
}
.scxw-clue {
    display: flex; gap: 8px; padding: 6px 8px; border-radius: 8px; cursor: pointer;
    font-size: 13.5px; line-height: 1.35; color: var(--sc-text);
    transition: background 0.12s ease;
}
.scxw-clue:hover { background: var(--sc-surface-2); }
.scxw-clue.is-active { background: color-mix(in srgb, var(--sc-accent) 12%, var(--sc-surface-2)); }
.scxw-clue-n { font-weight: 700; color: var(--sc-text-muted); flex: 0 0 auto; }
.scxw-clue-t { flex: 1 1 auto; }

/* ── Actions + score ── */
.scxw-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 20px; }
.scxw-btn {
    appearance: none; cursor: pointer;
    font-family: inherit; font-size: 14px; font-weight: 600;
    padding: 9px 18px; border-radius: 10px;
    border: 1.5px solid var(--sc-border);
    background: var(--sc-surface-2); color: var(--sc-text);
    transition: transform 0.1s ease, opacity 0.12s ease;
}
.scxw-btn:hover { transform: translateY(-1px); }
.scxw-btn:disabled { opacity: 0.55; cursor: default; transform: none; }
.scxw-btn-primary { background: var(--sc-accent); border-color: var(--sc-accent); color: #fff; }

.scxw-scorebar { font-size: 14px; font-weight: 600; color: var(--sc-text); margin-top: 14px; min-height: 1.2em; opacity: 0; transition: opacity 0.15s ease; }
.scxw-scorebar.is-on { opacity: 1; }

@media (max-width: 560px) {
    .scxw-card { padding: 18px 14px; }
    .scxw-layout { gap: 18px; }
    .scxw-grid { width: 100%; }
}
