/**
 * RTM Font Preview — Elementor preview (rows + grid layouts).
 * Foundry-style listing: one editable type-tester per product.
 */

.rtmfs-preview {
	--rtmfs-accent: #111;
	width: 100%;
}

/* ── v1.5.0: auto full-width inside any Elementor container (flex or grid),
   so the user never has to set Advanced → Width → 100% manually. ───────── */
.elementor-widget-rtm_font_preview,
.elementor-widget-rtm_archive_fonts {
	width: 100%;
	max-width: 100%;
}
.elementor-widget-rtm_font_preview > .elementor-widget-container,
.elementor-widget-rtm_archive_fonts > .elementor-widget-container {
	width: 100%;
}

/* ── v1.5.0: Rows (list) becomes a flex column so the Card Gap control works. */
.rtmfs-preview--rows {
	display: flex;
	flex-direction: column;
}

.rtmfs-empty {
	padding: 24px;
	border: 1px dashed #c9c9c9;
	color: #777;
	font-size: 14px;
	text-align: center;
	border-radius: 6px;
}

/* ── Row (default = list) ─────────────────────────────────────────────── */
.rtmfs-row {
	padding: 32px 0;
	border-bottom: 1px solid #e6e6e6;
}
.rtmfs-preview--rows .rtmfs-row:last-child {
	border-bottom: 0;
}

/* ── Grid (cards) ─────────────────────────────────────────────────────── */
.rtmfs-preview--grid {
	--rtmfs-cols: 3;
	display: grid;
	grid-template-columns: repeat(var(--rtmfs-cols), minmax(0, 1fr));
	gap: 24px;
}
.rtmfs-preview--grid .rtmfs-row {
	padding: 24px;
	border: 1px solid #e6e6e6;
	border-radius: 10px;
	background: #fff;
	display: flex;
	flex-direction: column;
}
.rtmfs-preview--grid .rtmfs-sampler {
	flex: 1 1 auto;
	min-height: 0;
}
/* Sensible fallback if no responsive value is generated yet. */
@media ( max-width: 767px ) {
	.rtmfs-preview--grid { --rtmfs-cols: 1; }
}

.rtmfs-row__head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 8px 16px;
	margin-bottom: 14px;
}

.rtmfs-row__name {
	font-size: 15px;
	font-weight: 600;
	letter-spacing: .01em;
}
.rtmfs-row__name a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color .15s ease;
}
.rtmfs-row__name a:hover {
	border-bottom-color: currentColor;
}

.rtmfs-row__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 8px;
}
.rtmfs-meta-item {
	font-size: 11px;
	line-height: 1;
	padding: 5px 9px;
	border: 1px solid #e0e0e0;
	border-radius: 999px;
	color: #555;
	white-space: nowrap;
}

/* ── Editable sampler ─────────────────────────────────────────────────── */
.rtmfs-sampler {
	/* v1.5.1: bind the product @font-face via CSS (not only JS) so the real
	   font also renders inside the Elementor editor / preview, matching the
	   live frontend. The unique family is set on .rtmfs-row as --rtmfs-family. */
	font-family: var(--rtmfs-family, system-ui), system-ui, sans-serif;
	display: block;
	width: 100%;
	margin: 0 0 16px;
	padding: 4px 0;
	line-height: 1.05;
	font-weight: 400;
	color: #111;
	outline: none;
	cursor: text;
	overflow-wrap: break-word;
	word-break: break-word;
	-webkit-font-smoothing: antialiased;
}
/* Focus styling is controlled through Elementor (var below); the hardcoded
   underline shadow was removed. An accessible default ring is kept so the
   editable preview always exposes a visible focus state. */
/* v1.8.0: no box-shadow on the editable type-tester when focused. */
.rtmfs-sampler:focus,
.rtmfs-sampler:focus-visible {
	box-shadow: none;
}
.rtmfs-sampler:empty::before {
	content: attr(data-placeholder);
	opacity: .35;
}

/* ── Controls ─────────────────────────────────────────────────────────── */
.rtmfs-controls {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px 22px;
	margin-top: 6px;
}

.rtmfs-ctrl {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 12px;
	color: #666;
}
.rtmfs-ctrl__lbl {
	text-transform: uppercase;
	letter-spacing: .06em;
	font-size: 10px;
	color: #999;
}
.rtmfs-ctrl__val {
	min-width: 38px;
	font-variant-numeric: tabular-nums;
	color: #111;
}

.rtmfs-ctrl input[type="range"] {
	-webkit-appearance: none;
	appearance: none;
	width: 130px;
	height: 2px;
	background: #ddd;
	border-radius: 2px;
	outline: none;
	cursor: pointer;
}
.rtmfs-ctrl input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--rtmfs-accent);
	cursor: pointer;
	border: 0;
}
.rtmfs-ctrl input[type="range"]::-moz-range-thumb {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--rtmfs-accent);
	cursor: pointer;
	border: 0;
}

/* Italic + alignment buttons */
.rtmfs-italic,
.rtmfs-align-btn {
	font-size: 12px;
	line-height: 1;
	padding: 7px 11px;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 5px;
	color: #555;
	cursor: pointer;
	transition: all .12s ease;
}
.rtmfs-italic:hover,
.rtmfs-align-btn:hover {
	border-color: #999;
	color: #111;
}
.rtmfs-italic.is-active,
.rtmfs-align-btn.is-active {
	background: var(--rtmfs-accent);
	border-color: var(--rtmfs-accent);
	color: #fff;
}

.rtmfs-align {
	display: inline-flex;
	gap: 4px;
}
.rtmfs-align-btn {
	width: 30px;
	padding: 7px 0;
	text-align: center;
}

.rtmfs-row__desc {
	margin: 16px 0 0;
	max-width: 60ch;
	font-size: 14px;
	line-height: 1.55;
	color: #666;
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media ( max-width: 600px ) {
	.rtmfs-controls {
		gap: 12px 16px;
	}
	.rtmfs-ctrl input[type="range"] {
		width: 96px;
	}
}

/* ── v1.3.0: tester wrapper + control position ─────────────────────────── */
.rtmfs-tester {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.rtmfs-tester--top    { flex-direction: column-reverse; }
.rtmfs-tester--bottom { flex-direction: column; }
.rtmfs-tester--left,
.rtmfs-tester--right  { align-items: flex-start; }
.rtmfs-tester--left   { flex-direction: row-reverse; }
.rtmfs-tester--right  { flex-direction: row; }
.rtmfs-tester--left  .rtmfs-controls,
.rtmfs-tester--right .rtmfs-controls {
	flex-direction: column;
	align-items: flex-start;
	min-width: 160px;
}

/* Transform dropdown matches the lightweight control aesthetic */
.rtmfs-tt {
	font-size: 12px;
	padding: 5px 8px;
	border: 1px solid #ddd;
	border-radius: 5px;
	background: #fff;
	color: #333;
	cursor: pointer;
}

/* ── v1.3.0: CTA button ────────────────────────────────────────────────── */
.rtmfs-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 16px;
	padding: 12px 22px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	color: #fff;
	background: var(--rtmfs-accent);
	border: 1px solid transparent;
	border-radius: 8px;
	text-decoration: none;
	cursor: pointer;
	transition: background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
	align-self: flex-start;
}
.rtmfs-cta:hover { opacity: .94; }
.rtmfs-cta__icon {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}
.rtmfs-cta__icon svg { width: 1em; height: 1em; fill: currentColor; }

/* ── v1.4.0+: range styling vars, active toggle, align icons ───────────── */
.rtmfs-ctrl input[type="range"] {
	height: var(--rtmfs-track-h, 2px);
	background: var(--rtmfs-track, #ddd);
}
/* v1.5.0: independent thumb color / border color / border width / radius. */
.rtmfs-ctrl input[type="range"]::-webkit-slider-thumb {
	background: var(--rtmfs-thumb, var(--rtmfs-accent));
	border: var(--rtmfs-thumb-bw, 0) solid var(--rtmfs-thumb-brd, transparent);
	border-radius: var(--rtmfs-thumb-r, 50%);
}
.rtmfs-ctrl input[type="range"]::-moz-range-thumb {
	background: var(--rtmfs-thumb, var(--rtmfs-accent));
	border: var(--rtmfs-thumb-bw, 0) solid var(--rtmfs-thumb-brd, transparent);
	border-radius: var(--rtmfs-thumb-r, 50%);
}

.rtmfs-italic.is-active,
.rtmfs-align-btn.is-active {
	background: var(--rtmfs-active, var(--rtmfs-accent));
	border-color: var(--rtmfs-active, var(--rtmfs-accent));
	color: #fff;
}

/* Alignment icon buttons (replaces the L/C/R text buttons) */
.rtmfs-align-btn {
	width: 32px;
	height: 32px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.rtmfs-align-btn svg { width: 15px; height: 15px; display: block; }

/* ── v1.4.0: single-row layout ─────────────────────────────────────────── */
.rtmfs-preview--single .rtmfs-row__head {
	align-items: center;
}
.rtmfs-preview--single .rtmfs-row__head .rtmfs-controls {
	margin-top: 0;
	border-top: 0;
	padding-top: 0;
}
@media ( max-width: 767px ) {
	.rtmfs-preview--single .rtmfs-row__head {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* ── v1.5.0: combined Dark / Light toggle button ───────────────────── */
.rtmfs-theme-btn {
	width: 32px;
	height: 32px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 5px;
	color: #555;
	cursor: pointer;
	transition: all .12s ease;
}
.rtmfs-theme-btn:hover { border-color: #999; color: #111; }
.rtmfs-theme-btn svg { width: 15px; height: 15px; display: block; }

/* v1.5.1 NO-SHIFT: theme toggle changes ONLY colours. No padding / border /
   margin is added in either mode, so Light and Dark keep identical spacing
   and the font preview never moves or reflows. */
.rtmfs-tester {
	transition: background-color .15s ease, color .15s ease;
}
.rtmfs-row--dark .rtmfs-tester {
	background: #111;
	border-radius: var(--rtmfs-dark-r, 3px);
}
.rtmfs-row--dark .rtmfs-sampler { color: #fff; }
.rtmfs-row--dark .rtmfs-ctrl,
.rtmfs-row--dark .rtmfs-ctrl__val { color: #e6e6e6; }
.rtmfs-row--dark .rtmfs-ctrl__lbl { color: #9b9b9b; }
.rtmfs-row--dark .rtmfs-theme-btn,
.rtmfs-row--dark .rtmfs-italic,
.rtmfs-row--dark .rtmfs-align-btn,
.rtmfs-row--dark .rtmfs-tt {
	background: #1d1d1d;
	border-color: #333;
	color: #ddd;
}

/* ── v1.5.0: improved tablet + mobile control layout ───────────────────────
   The per-row controls n


/* ── v1.5.2: balanced full-width per-row controls (non single-row) ──────────
   When the controls sit below the preview, let them use the full width with
   the range sliders growing to fill — no dead space, consistent rhythm, and
   touch-friendly on tablet / mobile (matching the Archive toolbar feel). */
.rtmfs-tester .rtmfs-controls { width: 100%; }
.rtmfs-tester .rtmfs-controls .rtmfs-ctrl--range { flex: 1 1 200px; }
.rtmfs-tester .rtmfs-controls .rtmfs-ctrl--range input[type="range"] {
	flex: 1 1 auto;
	width: auto;
	min-width: 0;
}

/* ── v1.5.3: balanced per-row controls across breakpoints ──────────────── */
.rtmfs-tester .rtmfs-controls { gap: 14px 20px; }
@media ( max-width: 1024px ) {
	.rtmfs-tester .rtmfs-controls { justify-content: space-between; }
}
@media ( max-width: 600px ) {
	.rtmfs-tester .rtmfs-controls .rtmfs-ctrl--range { flex: 1 1 100%; }
	.rtmfs-tester .rtmfs-controls .rtmfs-align { flex: 1 1 100%; display: flex; justify-content: space-between; }
	.rtmfs-tester .rtmfs-controls .rtmfs-align .rtmfs-align-btn { flex: 1 1 auto; }
}


/* ── v1.7.0: consistent 8px radius design language ───────────────────────
   Plain class selectors (low specificity) so any Elementor per-widget
   border-radius the user sets still overrides these defaults. */
.rtmfs-preview--grid .rtmfs-row,
.rtmfs-align-btn,
.rtmfs-italic,
.rtmfs-tt,
.rtmfs-theme-btn,
.rtmfs-g-otf,
.rtmfs-g-theme,
.rtmfs-g-align .rtmfs-align-btn,
.rtmfs-row__hover-btn,
.rtmfs-cta {
	border-radius: 8px;
}


/* ── v1.8.0: Control Bar responsiveness (mirrors the Archive control bar) ── */
.rtmfs-controls { flex-wrap: wrap; }
.rtmfs-tester--top .rtmfs-controls,
.rtmfs-tester--bottom .rtmfs-controls { width: 100%; }
.rtmfs-controls .rtmfs-ctrl--range { flex: 1 1 180px; min-width: 140px; }
.rtmfs-controls .rtmfs-ctrl--range input[type="range"] { flex: 1 1 auto; width: auto; min-width: 0; }
@media ( max-width: 1024px ) {
	.rtmfs-controls .rtmfs-ctrl--range { flex: 1 1 220px; }
}
@media ( max-width: 600px ) {
	.rtmfs-controls .rtmfs-ctrl--range { flex: 1 1 100%; }
	.rtmfs-controls .rtmfs-align { flex: 1 1 100%; display: flex; justify-content: space-between; }
	.rtmfs-controls .rtmfs-align-btn { flex: 1 1 auto; min-height: 42px; }
	.rtmfs-controls .rtmfs-theme-btn,
	.rtmfs-controls .rtmfs-italic,
	.rtmfs-controls .rtmfs-tt { min-height: 42px; }
}

/* ── v1.8.1: per-row OpenType toggle button ─────────────────────────────── */
.rtmfs-otf {
	font-size: 12px;
	line-height: 1;
	padding: 9px 12px;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 8px;
	color: #555;
	cursor: pointer;
	transition: all .12s ease;
}
.rtmfs-otf:hover { border-color: #999; color: #111; }
.rtmfs-otf.is-active { background: #111; border-color: #111; color: #fff; }

/* ── v1.8.1: Card Hover system for Font Preview (parity with Archive) ── */
.rtmfs-preview--grid { grid-auto-rows: 1fr; }
.rtmfs-preview--grid .rtmfs-row { height: 100%; }
.rtmfs-row--hover { transition: background-color .25s ease; }
.rtmfs-row__hover {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px 16px;
	margin-top: auto;
	padding-top: 14px;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity .25s ease, transform .25s ease;
	pointer-events: none;
}
.rtmfs-row--hover:hover .rtmfs-row__hover,
.rtmfs-row--hover:focus-within .rtmfs-row__hover {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.rtmfs-row__price { font-size: 14px; font-weight: 600; color: #111; }
.rtmfs-row__price .amount { color: inherit; }
.rtmfs-row__hover-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1;
	color: #fff;
	background: #111;
	border: 1px solid transparent;
	border-radius: 8px;
	text-decoration: none;
	cursor: pointer;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.rtmfs-row__hover-btn:hover { background: #333; }
@media ( hover: none ) {
	.rtmfs-row__hover { opacity: 1; transform: none; pointer-events: auto; }
}


/* ── v1.8.2: Control Bar always sits above the editable type-tester so its
   buttons stay clickable even when Line Height = 0 makes the sampler text
   overflow over the toolbar. Applies to Font Preview & Product Font Preview. */
.rtmfs-row__head { position: relative; z-index: 3; }
.rtmfs-controls { position: relative; z-index: 3; }
.rtmfs-tester { position: relative; }
.rtmfs-sampler { position: relative; z-index: 1; }
