/* ─── CROSSWORD PLAYER ───────────────────────────────────────────────────────
   Styles for the interactive puzzle player and archive pages.
   Inherits: --bg, --bg-2, --text, --text-2, --text-3, --border, --sans, --mono,
             --eagles, --phillies, --flyers, --sixers, --r-sm
 ──────────────────────────────────────────────────────────────────────────── */

/* ── Archive header ──────────────────────────────────────────────────────── */

.crossword-archive-header .archive-desc {
	max-width: 42rem;
}

/* ── Featured puzzle card ─────────────────────────────────────────────────── */

.crossword-featured {
	padding: 2.5rem 0;
	border-bottom: 1px solid var(--border);
}

.featured-crossword-card {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	padding: 2rem;
	background: var(--bg-2);
	border: 1px solid var(--border);
	border-radius: 0;
}

.featured-crossword-card .featured-badge {
	font-family: var(--sans);
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #fff;
	white-space: nowrap;
	flex-shrink: 0;
	padding: 0.25rem 0.55rem;
	background: var(--phillies);
	border-radius: 0;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	margin-bottom: 0.35rem;
}

.featured-crossword-card .featured-info {
	flex: 1;
	min-width: 0;
}

.featured-crossword-card h2 {
	font-size: clamp(1.25rem, 3vw, 1.6rem);
	margin: 0 0 0.25rem;
}

.featured-crossword-card h2 a {
	color: var(--text);
	text-decoration: none;
}

.featured-crossword-card h2 a:hover {
	color: var(--phillies);
}

.crossword-meta-line {
	font-family: var(--mono);
	font-size: 0.78rem;
	color: var(--text-3);
	margin: 0;
}

.crossword-solved-badge-featured {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-family: var(--mono);
	font-size: 0.75rem;
	color: #2a9d2a;
	margin-top: 0.4rem;
}

@media (max-width: 600px) {
	.featured-crossword-card {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* ── Guest banner ─────────────────────────────────────────────────────────── */

.crossword-guest-banner {
	padding: 0.85rem 1.25rem;
	background: color-mix(in srgb, var(--eagles) 12%, transparent);
	border-left: 3px solid var(--eagles);
	border-radius: 0;
	margin-bottom: 2rem;
	font-size: 0.88rem;
}

.crossword-guest-banner a {
	color: var(--eagles);
	font-weight: 600;
}

/* ── Archive grid ─────────────────────────────────────────────────────────── */

.crossword-section-label {
	font-family: var(--mono);
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-3);
	margin: 2.5rem 0 1rem;
}

.crossword-archive-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
	margin-bottom: 3rem;
}

/* ── Crossword archive card ───────────────────────────────────────────────── */

.crossword-card {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 1.25rem;
	background: var(--bg-2);
	border: 1px solid var(--border);
	border-radius: 0;
}

/* Only the CTA button inside the card should react on hover — not the card */
.crossword-card:hover {
	border-color: var(--border);
}
.crossword-card:hover .btn-outline {
	border-color: var(--text);
	color: var(--bg);
}
.crossword-card:hover .btn-outline::before {
	transform: scaleX(1);
}

/* Latest badge inline with card title */
.crossword-latest-badge {
	font-family: var(--sans);
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #fff;
	background: var(--phillies);
	padding: 0.2em 0.5em;
	border-radius: 0;
	display: inline-flex;
	align-items: center;
	line-height: 1;
	vertical-align: middle;
	margin-right: 0.45rem;
	flex-shrink: 0;
}

.crossword-card-info {
	flex: 1;
	min-width: 0;
}

.crossword-card h3 {
	font-size: 0.95rem;
	margin: 0 0 0.2rem;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
}

.crossword-card h3 a {
	color: var(--text);
	text-decoration: none;
}

.crossword-card h3 a:hover {
	color: var(--phillies);
}

.crossword-card-meta {
	font-family: var(--mono);
	font-size: 0.72rem;
	color: var(--text-3);
	margin: 0;
}

.crossword-solved-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-family: var(--mono);
	font-size: 0.72rem;
	color: #2a9d2a;
	margin-bottom: 0.2rem;
}

.btn-sm {
	padding: 0.4rem 0.8rem;
	font-size: 0.78rem;
	white-space: nowrap;
	flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ── PUZZLE PLAYER                                                          ── */
/* ═══════════════════════════════════════════════════════════════════════════ */

.crossword-page-header {
	border-bottom: 1px solid var(--border);
	padding-bottom: 1.5rem;
	margin-bottom: 0;
}

.crossword-page-header h1 {
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	margin: 0.25rem 0 0.5rem;
}

.crossword-puzzle-meta {
	font-family: var(--mono);
	font-size: 0.78rem;
	color: var(--text-3);
	margin: 0;
}

/* ── Player layout ────────────────────────────────────────────────────────── */

.crossword-player {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.5rem;
	align-items: start;
	padding: 2rem 0 4rem;
}

@media (max-width: 820px) {
	.crossword-player {
		grid-template-columns: 1fr;
	}
}

/* ── Board column ─────────────────────────────────────────────────────────── */

.crossword-board {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

/* Current clue bar */
.current-clue-bar {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	padding: 0.6rem 0.85rem;
	background: var(--bg-2);
	border: 1px solid var(--border);
	border-radius: 0;
	min-height: 2.4rem;
}

.current-clue-bar .clue-num {
	font-family: var(--mono);
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--phillies);
	white-space: nowrap;
	flex-shrink: 0;
}

.current-clue-bar .clue-text {
	font-size: 0.88rem;
	color: var(--text);
	line-height: 1.3;
}

/* Timer + controls */
.crossword-controls {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.crossword-controls .crossword-pause-btn {
	margin-right: auto;
}

.crossword-timer {
	font-family: var(--mono);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--text);
	letter-spacing: 0.04em;
	min-width: 4ch;
}

.crossword-timer.paused {
	color: var(--text-3);
}

.btn-hint {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-family: var(--sans);
	font-size: 0.8rem;
	font-weight: 600;
	padding: 0.45rem 0.9rem;
	border: 1px solid var(--border);
	border-radius: 0;
	background: transparent;
	color: var(--text-2);
	cursor: pointer;
	transition: color 200ms, border-color 200ms;
}

.btn-hint:hover {
	color: var(--text);
	border-color: var(--text-2);
}

.btn-hint .hint-count {
	font-size: 0.72rem;
	color: var(--text-3);
}

/* Uniform height for all controls */
.crossword-controls .crossword-pause-btn,
.crossword-controls .hint-type-select,
.crossword-controls .btn-hint {
	height: 2.25rem;
	box-sizing: border-box;
}

/* Hint controls row: dropdown + button */
.hint-controls {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.hint-type-select {
	font-family: var(--mono);
	font-size: 0.75rem;
	padding: 0.4rem 0.6rem;
	border: 1px solid var(--border);
	border-radius: 0;
	background: var(--bg);
	color: var(--text-2);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	transition: border-color 200ms;
}

.hint-type-select:focus {
	outline: none;
	border-color: var(--text-2);
}

/* Wrong letter indicator */
.crossword-cell.wrong input {
	color: #c0392b;
}

/* ── Grid ─────────────────────────────────────────────────────────────────── */

.crossword-grid {
	--cell-size: min(12vw, 72px);
	display: grid;
	/* --cols injected by JS */
	border: 2px solid var(--text);
	/* Use gap + background for uniform 1px internal dividers.
	   This prevents the bottom border from appearing thicker than the sides,
	   and also allows align-self to shrink the grid to its intrinsic width. */
	gap: 1px;
	background: var(--text-3);
	line-height: 0;
	user-select: none;
	width: 100%;
	grid-template-columns: repeat(var(--grid-cols, 5), 1fr) !important;
}

.crossword-cell {
	aspect-ratio: 1;
	position: relative;
	box-sizing: border-box;
	background: var(--bg);
	/* Cell borders are now handled by grid gap — no individual cell borders needed */
}

.crossword-cell.black {
	background: var(--text);
	border-color: var(--text);
}

/* Highlight current word */
.crossword-cell.word-active {
	background: color-mix(in srgb, var(--eagles) 18%, var(--bg));
}

/* Highlight selected cell */
.crossword-cell.cell-selected {
	background: color-mix(in srgb, var(--phillies) 28%, var(--bg));
}

/* Hinted cell */
.crossword-cell.hinted input {
	color: var(--phillies);
}

/* Correct cell (on completion) */
.crossword-cell.correct input {
	color: #2a9d2a;
}

.cell-number {
	position: absolute;
	top: 2px;
	left: 2px;
	font-family: var(--mono);
	font-size: clamp(0.5rem, 2.2vw, 0.8rem);
	line-height: 1;
	color: var(--text-2);
	pointer-events: none;
	z-index: 1;
}

.crossword-cell input {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	padding: 0;
	border: none;
	background: transparent;
	color: var(--text);
	font-family: var(--sans);
	font-size: clamp(1rem, 4.5vw, 1.75rem);
	font-weight: 700;
	text-align: center;
	text-transform: uppercase;
	cursor: pointer;
	caret-color: transparent;
	outline: none;
	-webkit-appearance: none;
}

.crossword-cell input:focus {
	outline: none;
}

/* Mobile: stretch grid to fill container width */
@media (max-width: 820px) {
	.crossword-grid {
		grid-template-columns: repeat(var(--grid-cols, 5), 1fr) !important;
		width: 100%;
	}
	.crossword-cell {
		width: auto;
		height: auto;
		aspect-ratio: 1;
	}
	.crossword-cell input {
		font-size: clamp(1rem, 5.5vw, 1.75rem);
	}
	.cell-number {
		font-size: clamp(0.5rem, 2.5vw, 0.75rem);
	}
}

/* ── Clues panel ──────────────────────────────────────────────────────────── */

.crossword-clues {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	align-items: start;
}

@media (max-width: 560px) {
	.crossword-clues {
		grid-template-columns: 1fr;
	}
}

.clues-panel h3 {
	font-family: var(--mono);
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-3);
	margin: 0 0 0.75rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--border);
}

.clue-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.clue-item {
	display: flex;
	gap: 0.5rem;
	padding: 0.3rem 0.5rem;
	border-radius: 3px;
	cursor: pointer;
	transition: background 150ms;
	font-size: 0.84rem;
	line-height: 1.35;
}

.clue-item:hover {
	background: var(--bg-2);
}

.clue-item.active {
	background: color-mix(in srgb, var(--phillies) 16%, transparent);
}

.clue-item.solved {
	opacity: 0.45;
}

.clue-num {
	font-family: var(--mono);
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--text-3);
	white-space: nowrap;
	flex-shrink: 0;
	min-width: 2.2ch;
	padding-top: 0.1rem;
}

.clue-item.active .clue-num {
	color: var(--phillies);
}

.clue-text-item {
	color: var(--text);
}

/* ── Completion modal ─────────────────────────────────────────────────────── */

.crossword-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.65);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1000;
	padding: 1rem;
	animation: modal-fade-in 350ms ease;
}

@keyframes modal-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.crossword-modal {
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: 0;
	padding: 2.5rem 2rem;
	max-width: 420px;
	width: 100%;
	text-align: center;
	animation: modal-slide-in 400ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes modal-slide-in {
	from { transform: translateY(24px) scale(0.96); opacity: 0; }
	to   { transform: translateY(0) scale(1);       opacity: 1; }
}

.crossword-modal .modal-eyebrow {
	font-family: var(--mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--phillies);
	margin-bottom: 0.5rem;
}

.crossword-modal h2 {
	font-size: clamp(1.75rem, 5vw, 2.25rem);
	margin: 0 0 0.5rem;
}

.crossword-modal .solve-time {
	font-family: var(--mono);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--text-2);
	margin-bottom: 0.25rem;
}

.crossword-modal .hints-note {
	font-family: var(--mono);
	font-size: 0.75rem;
	color: var(--text-3);
	margin-bottom: 2rem;
}

/* Already-solved stats grid */
.modal-stats-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	margin: 1.25rem 0 1.75rem;
	border: 1px solid var(--border);
}

.modal-stat {
	padding: 1rem;
	border-right: 1px solid var(--border);
	text-align: center;
}

.modal-stat:last-child {
	border-right: none;
}

.modal-stat-label {
	display: block;
	font-family: var(--mono);
	font-size: 0.68rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--text-3);
	margin-bottom: 0.35rem;
}

.modal-stat-val {
	display: block;
	font-family: var(--mono);
	font-size: 1rem;
	font-weight: 700;
	color: var(--text);
}

.modal-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	align-items: center;
}

.modal-actions .btn-primary,
.modal-actions .btn-outline {
	width: 100%;
	justify-content: center;
}

.modal-divider {
	width: 100%;
	border: none;
	border-top: 1px solid var(--border);
	margin: 0.5rem 0;
}

.account-prompt-box {
	background: var(--bg-2);
	border: 1px solid var(--border);
	border-radius: 0;
	padding: 1rem;
	width: 100%;
	text-align: left;
}

.account-prompt-box p {
	font-size: 0.82rem;
	color: var(--text-2);
	margin: 0 0 0.6rem;
}

.account-prompt-box .account-links {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.btn-text {
	font-family: var(--sans);
	font-size: 0.82rem;
	color: var(--text-3);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.4rem 0.6rem;
	text-decoration: underline;
	transition: color 200ms;
}

.btn-text:hover {
	color: var(--text);
}

/* ── No-puzzle notice (before .puz is uploaded) ───────────────────────────── */

.crossword-no-puzzle {
	text-align: center;
	padding: 5rem 0;
	color: var(--text-3);
}

.crossword-no-puzzle p {
	font-family: var(--mono);
	font-size: 0.85rem;
}


/* ── Pause button & overlay ────────────────────────────────────────────── */

.crossword-pause-btn {
	background: transparent;
	border: 1px solid var(--border);
	padding: 0.35rem 0.65rem;
	font-family: var(--sans);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--text-2);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	transition: background var(--transition), color var(--transition);
}
.crossword-pause-btn:hover {
	background: var(--text);
	color: var(--bg);
}

.crossword-pause-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.65);
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}
.crossword-pause-modal {
	background: var(--bg);
	padding: 3rem 2.5rem;
	max-width: 400px;
	width: 90%;
	text-align: center;
	border: 1px solid var(--border);
}
.crossword-pause-modal .pause-eyebrow {
	font-family: var(--mono);
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--phillies);
	margin: 0 0 0.75rem;
}
.crossword-pause-modal h2 {
	margin: 0 0 0.5rem;
	font-size: 1.5rem;
}
.crossword-pause-modal .pause-subtext {
	font-family: var(--sans);
	font-size: 0.88rem;
	color: var(--text-2);
	margin: 0 0 1.5rem;
}
.crossword-pause-modal .btn-resume {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.75rem 2rem;
	background: var(--text);
	color: var(--bg);
	border: 2px solid var(--text);
	font-family: var(--sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--transition), color var(--transition);
}
.crossword-pause-modal .btn-resume:hover {
	background: var(--phillies);
	border-color: var(--phillies);
	color: #fff;
}


/* ── Check hint feedback ───────────────────────────────────────────────── */
.crossword-cell.checked-correct {
	background: color-mix(in srgb, #2a9d2a 12%, transparent) !important;
}
.crossword-cell.checked-wrong {
	background: color-mix(in srgb, var(--phillies) 15%, transparent) !important;
}
.crossword-cell.checked-wrong input {
	color: var(--phillies);
}

/* ── Crossword controls — mobile responsive ──────────────────────────────── */
@media (max-width: 480px) {
	.crossword-controls {
		flex-wrap: wrap;
		gap: 0.5rem;
	}
	.hint-controls {
		flex-wrap: wrap;
		gap: 0.35rem;
	}
	.hint-type-select {
		font-size: 0.68rem;
		padding: 0.3rem 0.45rem;
	}
	.btn-hint {
		font-size: 0.72rem;
		padding: 0.35rem 0.65rem;
	}
	.crossword-timer {
		font-size: 1.1rem;
	}
	.crossword-pause-btn {
		font-size: 0.65rem;
		padding: 0.25rem 0.5rem;
	}
	.current-clue-bar .clue-text {
		font-size: 0.8rem;
	}
}

/* ── Crossword page header — mobile ──────────────────────────────────────── */
@media (max-width: 600px) {
	.crossword-page-header {
		padding-bottom: 1rem;
	}
	.crossword-page-header h1 {
		font-size: 1.35rem;
	}
}
