/* Safe Tick – floating toggle button */
.safe-tick-button {
	position: absolute;
	top: 0;
	right: 1px;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: none;
	background: rgba(15, 23, 42, 0.85); /* slate-900 ~ */
	color: #94a3b8; /* slate-400 */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.35);
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease, opacity 0.15s ease;
	z-index: 6;
}
.safe-tick-button svg { pointer-events: none; }
.safe-tick-button:hover { color: #e2e8f0; transform: translateY(-2px); }
.safe-tick-button.is-active { background: #dc2626; color: #ffffff; } /* red-600 with white text */
.safe-tick-button.is-loading { opacity: 0.6; pointer-events: none; }

.safe-tick-button-wrap {
	position: absolute;
	top: 12px;
	right: 12px;
	width: auto;
	height: auto;
	z-index: 6;
}

.safe-tick-geo-badge {
	position: absolute;
	top: -6px;
	right: 48px;
	background: #0b162b;
	color: #f8fafc;
	border-radius: 999px;
	padding: 4px 8px;
	font-size: 11px;
	line-height: 1.2;
	box-shadow: 0 6px 15px rgba(0,0,0,0.25);
	white-space: nowrap;
	z-index: 5;
}

/* Admin NSFW rules UI */
.custom-access-styled {
	border: 1px solid #d0d7de;
	border-radius: 8px;
	padding: 12px;
	background: #f6f8fb;
	box-shadow: inset 0 1px 0 #f3f4f6;
	max-width: 760px;
}
.custom-access-styled .nsfw-rule {
	border: 1px solid #dce2e8;
	border-radius: 8px;
	padding: 16px;
	margin-bottom: 12px;
	background: #fff;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 12px 14px;
}
.custom-access-styled .nsfw-rule label {
	font-weight: 600;
	color: #0f172a;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.custom-access-styled .nsfw-rule .full-line {
	grid-column: 1 / -1;
}
.custom-access-styled .nsfw-rule input,
.custom-access-styled .nsfw-rule select {
	width: 100%;
	padding: 6px 8px;
}
.custom-access-styled .nsfw-rule .remove-rule {
	grid-column: 1 / -1;
	justify-self: flex-end;
	margin-top: 4px;
}
#add-nsfw-rule {
	margin-top: 10px;
}

/* NSFW toggle styling (FPSM) */
.fpsm-field-wrap input[name="safe_tick_nsfw"],
.fpsm-field-wrap input[name="_custom_field|safe_tick_nsfw"],
.fpsm-field-wrap input[name="_custom_field|safe_tick_nsfw[]"] {
	accent-color: #2563eb;
	transform: scale(1.1);
}

.fpsm-field-wrap input[name="safe_tick_nsfw"] + label,
.fpsm-field-wrap input[name="_custom_field|safe_tick_nsfw"] + label,
.fpsm-field-wrap input[name="_custom_field|safe_tick_nsfw[]"] + label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 12px;
	background: #eef2ff;
	color: #1e293b;
	font-weight: 600;
	box-shadow: inset 0 0 0 1px #c7d2fe;
}

/* Broader styling to catch FPSM’s wrapper structure */
.fpsm-field-wrap[data-field-key*="safe_tick_nsfw"],
.fpsm-meta-safe_tick_nsfw {
	border: 1px solid #e0e7ff;
	border-radius: 14px;
	padding: 10px 12px;
	background: linear-gradient(135deg, #eef2ff, #e0f2fe);
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.12);
}

.fpsm-field-wrap[data-field-key*="safe_tick_nsfw"] .fpsm-field,
.fpsm-meta-safe_tick_nsfw .fpsm-field {
	display: flex;
	align-items: center;
	gap: 10px;
}

.fpsm-field-wrap[data-field-key*="safe_tick_nsfw"] .fpsm-checkbox label,
.fpsm-meta-safe_tick_nsfw .fpsm-checkbox label {
	font-weight: 700;
	color: #0f172a;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.fpsm-field-wrap[data-field-key*="safe_tick_nsfw"] .fpsm-checkbox input,
.fpsm-meta-safe_tick_nsfw .fpsm-checkbox input {
	accent-color: #2563eb;
	width: 18px;
	height: 18px;
}
/* Utility: ensure parent can host the absolute button if needed */
.wpgb-card {
	position: relative;
}

/* ----------------------------- */
/* Admin facelift (Safe Tick)    */
/* ----------------------------- */
:root {
	--st-bg: #f7f8fb;
	--st-surface: #ffffff;
	--st-border: #d9dce3;
	--st-accent: #2563eb;
	--st-accent-soft: #e8f0ff;
	--st-danger: #d63638;
	--st-text: #1f2937;
	--st-muted: #4b5563;
	--st-radius: 12px;
	--st-gap: 12px;
	--st-shadow: 0 8px 24px rgba(15,23,42,0.08);
	--st-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--st-success-bg: #d1fae5;
	--st-success-text: #065f46;
	--st-danger-bg: #fee2e2;
	--st-danger-text: #991b1b;
	--st-toggle-off: #cbd5e1;
}
@media (prefers-color-scheme: dark) {
	:root {
		--st-bg: #1e293b;
		--st-surface: #0f172a;
		--st-border: #334155;
		--st-text: #f1f5f9;
		--st-muted: #94a3b8;
		--st-accent-soft: #1e3a8a;
		--st-success-bg: #064e3b;
		--st-success-text: #d1fae5;
		--st-danger-bg: #7f1d1d;
		--st-danger-text: #fecaca;
	}
}
.safe-tick-admin { padding: 12px; background: var(--st-bg); font-family: var(--st-font); color: var(--st-text); }
.safe-tick-admin h2, .safe-tick-admin th { color: var(--st-text); }
.safe-tick-admin .description { color: var(--st-muted); }
.safe-tick-admin .nav-tab-wrapper { padding-left: 0; margin-bottom: 12px; }
.safe-tick-admin .nav-tab { border-radius: 10px 10px 0 0; font-weight: 600; }
.safe-tick-admin .nav-tab-active { background: var(--st-surface); border-color: var(--st-border); color: var(--st-text); }

.st-admin-card {
	background: var(--st-surface);
	border: 1px solid var(--st-border);
	border-radius: var(--st-radius);
	box-shadow: var(--st-shadow);
	padding: 14px;
	display: grid;
	gap: var(--st-gap);
	margin-bottom: 14px;
}
.st-admin-card__header { display: flex; align-items: center; gap: 10px; padding-bottom: 12px; border-bottom: 1px solid var(--st-border); margin-bottom: 16px; }
.st-admin-card__icon { width: 20px; height: 20px; opacity: 0.7; }
.st-admin-card__title { font-weight: 700; font-size: 15px; }
.st-admin-card__content { transition: max-height 0.3s ease; overflow: hidden; }
.st-admin-card[data-collapsible] { cursor: pointer; }
.st-admin-card__grid { display: grid; grid-template-columns: 1fr; gap: 12px 16px; }
.st-admin-card label { font-weight: 600; color: var(--st-text); display: flex; flex-direction: column; gap: 6px; }
.st-admin-card input,
.st-admin-card select { padding: 7px 10px; border-radius: 10px; border: 1px solid var(--st-border); background: var(--st-surface); }
.st-status-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: 600; }
.st-status-badge--active { background: var(--st-success-bg); color: var(--st-success-text); }
.st-status-badge--inactive { background: var(--st-danger-bg); color: var(--st-danger-text); }

/* Click feedback for admin buttons */
.safe-tick-admin .st-form .button,
.safe-tick-admin .st-form .button-primary,
.safe-tick-admin .st-form .button-secondary {
	transition: transform 120ms ease, box-shadow 120ms ease, opacity 160ms ease;
	position: relative;
	overflow: hidden;
}
.safe-tick-admin .st-form .button:active,
.safe-tick-admin .st-form .button-primary:active,
.safe-tick-admin .st-form .button-secondary:active {
	transform: translateY(1px) scale(0.99);
	box-shadow: inset 0 1px 2px rgba(0,0,0,0.15);
}
.safe-tick-admin .st-form .button.is-pulsing,
.safe-tick-admin .st-form .button-primary.is-pulsing,
.safe-tick-admin .st-form .button-secondary.is-pulsing {
	animation: st-button-pulse 320ms ease;
}
@keyframes st-button-pulse {
	0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(37,99,235,0.35); }
	70% { transform: scale(0.985); box-shadow: 0 0 0 6px rgba(37,99,235,0); }
	100% { transform: scale(1); box-shadow: none; }
}
.st-alert { border: 1px solid var(--st-border); border-radius: var(--st-radius); padding: 10px 12px; background: #fef9c3; color: #854d0e; }
.st-alert--success { background: #ecfdf3; color: #065f46; }
.st-alert--error { background: #fef2f2; color: #991b1b; }

.safe-tick-admin #safe-tick-nsfw-rules.custom-access-styled { border: 1px dashed var(--st-border); background: var(--st-surface); box-shadow: none; }
.safe-tick-admin #safe-tick-nsfw-rules .nsfw-rule {
	border: 1px solid var(--st-border);
	border-radius: var(--st-radius);
	padding: 14px;
	background: var(--st-accent-soft);
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px 14px;
}
@media (min-width: 601px) { .safe-tick-admin #safe-tick-nsfw-rules .nsfw-rule { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); } }
.safe-tick-admin #safe-tick-nsfw-rules .nsfw-rule .remove-rule { margin-top: 6px; }
.safe-tick-admin #add-nsfw-rule { margin-top: 10px; }

.safe-tick-admin .safe-tick-country-helper .safe-tick-country-helper-inner { border-radius: 10px; border: 1px solid var(--st-border); background: var(--st-surface); }
.safe-tick-admin .safe-tick-country-chip { border-color: var(--st-border); background: var(--st-accent-soft); }
.safe-tick-admin .safe-tick-country-chip.bad { border-color: var(--st-danger); color: #8a1f1f; background: #fbeaea; }
.safe-tick-admin .safe-tick-country-helper input { border: 1px solid var(--st-border); border-radius: 10px; padding: 6px 8px; }

button, input, select { transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease; }
button:hover { transform: translateY(-1px); }
.st-loading { position: relative; pointer-events: none; opacity: 0.6; }
.st-loading::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 20px; height: 20px; border: 2px solid var(--st-border); border-top-color: var(--st-accent); border-radius: 50%; animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes slideIn { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
.st-success-message { animation: slideIn 0.3s ease; background: #ecfdf3; border-left: 4px solid #10b981; padding: 12px 16px; border-radius: 8px; margin-bottom: 16px; }
.st-admin-card input:focus, .st-admin-card select:focus { outline: 2px solid var(--st-accent); outline-offset: 2px; border-color: var(--st-accent); }

.st-empty-state { text-align: center; padding: 48px 24px; color: var(--st-muted); }
.st-empty-state__icon { font-size: 48px; opacity: 0.3; margin-bottom: 16px; }
.st-empty-state__title { font-size: 18px; font-weight: 600; color: var(--st-text); margin-bottom: 8px; }
.st-empty-state__action { margin-top: 16px; }

.st-stats-grid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 24px; }
@media (min-width: 601px) { .st-stats-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); } }
.st-stat-card { background: var(--st-surface); border: 1px solid var(--st-border); border-radius: var(--st-radius); padding: 20px; text-align: center; }
.st-stat-card__value { font-size: 32px; font-weight: 700; color: var(--st-accent); margin-bottom: 8px; }
.st-stat-card__label { font-size: 14px; color: var(--st-muted); text-transform: uppercase; letter-spacing: 0.5px; }

.st-toggle { position: relative; display: inline-block; width: 44px; height: 24px; }
.st-toggle input { opacity: 0; width: 0; height: 0; }
.st-toggle-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--st-toggle-off); transition: 0.3s; border-radius: 24px; }
.st-toggle-slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background-color: white; transition: 0.3s; border-radius: 50%; }
.st-toggle input:checked + .st-toggle-slider { background-color: var(--st-accent); }
.st-toggle input:checked + .st-toggle-slider:before { transform: translateX(20px); }
.st-toggle-row { display: flex; align-items: center; gap: 10px; }
.st-toggle-label { font-weight: 600; color: var(--st-text); }

.st-admin-card select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234b5563' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 10px center;
	padding-right: 32px;
	appearance: none;
}

.st-skip-link { position: absolute; top: -40px; left: 0; background: var(--st-accent); color: white; padding: 8px; z-index: 100; }
.st-skip-link:focus { top: 0; }
.st-admin-card:focus-visible { outline: 2px solid var(--st-accent); outline-offset: 2px; }

.st-help-icon { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 50%; background: var(--st-accent-soft); color: var(--st-accent); font-size: 12px; cursor: help; margin-left: 6px; }
.st-tooltip { position: relative; }
.st-tooltip-content {
	position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
	background: var(--st-text); color: white; padding: 8px 12px; border-radius: 6px;
	font-size: 12px; white-space: nowrap; opacity: 0; pointer-events: none;
	transition: opacity 0.2s; margin-bottom: 8px;
}
.st-tooltip-content::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: var(--st-text);
}
.st-tooltip:hover .st-tooltip-content { opacity: 1; }

@media (min-width: 601px) {
	.safe-tick-admin { padding: 16px; }
	.st-admin-card { padding: 16px 18px; }
	.st-admin-card__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 961px) {
	.st-admin-card__grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
}

/* Select2 container constraints for WordPress admin */
.select2-container--default {
	max-width: 100%;
}

.select2-container--default .select2-selection--multiple {
	min-height: 32px;
	max-height: 120px;
	overflow-y: auto;
	border: 1px solid var(--st-border);
	border-radius: 10px;
	padding: 2px 4px;
	background-color: var(--st-surface);
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
	background-color: var(--st-accent-soft);
	border: 1px solid var(--st-accent);
	border-radius: 6px;
	padding: 2px 8px;
	margin: 2px;
	color: var(--st-accent);
	font-size: 13px;
	line-height: 1.4;
	max-width: calc(100% - 8px);
	word-break: break-word;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
	color: var(--st-accent);
	margin-right: 4px;
	cursor: pointer;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
	color: var(--st-danger);
}

/* Ensure search input is visible */
.select2-container--default .select2-search--inline .select2-search__field {
	color: var(--st-text);
	background: transparent;
	border: none;
	padding: 4px;
	min-width: 150px;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
	color: var(--st-text);
	background-color: var(--st-surface);
	border: 1px solid var(--st-border);
	padding: 6px 8px;
	border-radius: 6px;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
	outline: 2px solid var(--st-accent);
	outline-offset: 2px;
	border-color: var(--st-accent);
}
