/**
 * SEO Insights — Tools CSS
 *
 * Styles for the 6 SEO tool modules. Uses the theme's existing design
 * tokens (--color-primary, --color-bg-card, etc. from style.css) so
 * tools feel native rather than bolted-on, whether they appear on a
 * dedicated tool page, the homepage grid, or embedded in an article.
 *
 * @package SEOInsights
 */

/* ── Shimmer skeleton ──────────────────────────────────────────── */
.shimmer {
	background: linear-gradient( 90deg, var(--color-border) 25%, var(--color-bg-alt) 50%, var(--color-border) 75% );
	background-size: 600px 100%;
	animation: si-shimmer 1.8s ease-in-out infinite;
	border-radius: 6px;
}
@keyframes si-shimmer {
	0%   { background-position: -600px 0; }
	100% { background-position:  600px 0; }
}

/* ── Tool module wrapper ───────────────────────────────────────── */
.si-tool-module {
	display: flex;
	flex-direction: column;
	gap: var(--space-5, 1.25rem);
}

.si-tool-controls,
.si-tool-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3, 0.75rem);
}
@media (max-width: 640px) {
	.si-tool-controls,
	.si-tool-grid-2 { grid-template-columns: 1fr; }
}

.si-tool-col { display: flex; flex-direction: column; gap: var(--space-3, 0.75rem); }
.si-tool-field { display: flex; flex-direction: column; }

.si-tool-actions {
	display: flex;
	align-items: center;
	gap: var(--space-3, 0.75rem);
	flex-wrap: wrap;
}

.si-tool-output-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 6px;
	gap: 8px;
	flex-wrap: wrap;
}
.si-tool-output-actions { display: flex; gap: 6px; }

.si-tool-meta  { font-size: 12px; color: var(--color-text-subtle); }
.si-tool-warning { font-size: 11px; color: #d97706; }
.si-tool-empty {
	text-align: center; padding: 20px;
	color: var(--color-text-subtle); font-size: 13px;
}

.si-toggle-row { display: flex; flex-wrap: wrap; gap: 16px; padding: 12px; background: var(--color-bg-alt); border-radius: 10px; border: 1px solid var(--color-border); }

.si-skeleton-block { display: flex; flex-direction: column; gap: 8px; }

/* ── Form controls ─────────────────────────────────────────────── */
.si-label { font-size: 12px; font-weight: 600; color: var(--color-text-muted); margin-bottom: 5px; display: block; letter-spacing: .02em; }

.si-input, .si-select, .si-textarea {
	width: 100%; padding: 10px 14px;
	border: 1.5px solid var(--color-border);
	border-radius: 10px; font-size: 14px; font-family: inherit;
	color: var(--color-text); background: var(--color-bg-alt);
	outline: none; transition: border-color .2s, box-shadow .2s;
}
.si-input:focus, .si-select:focus, .si-textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px var(--color-primary-glow);
	background: var(--color-bg-card);
}
.si-textarea { resize: vertical; min-height: 100px; line-height: 1.6; }
.si-mono-output { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 13px; background: var(--color-bg-alt); color: var(--color-text-muted); }

/* ── Buttons ───────────────────────────────────────────────────── */
.btn-primary {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 10px 20px; border: none; border-radius: 10px;
	background: var(--color-primary); color: #fff;
	font-size: 13px; font-weight: 600; font-family: inherit;
	cursor: pointer; transition: background .18s, transform .15s;
	white-space: nowrap;
}
.btn-primary:hover { background: var(--si-indigo-light); transform: translateY(-1px); }

.btn-ghost {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px; border: 1.5px solid var(--color-border); border-radius: 8px;
	background: var(--color-bg-card); color: var(--color-text-muted);
	font-size: 12px; font-weight: 600; font-family: inherit;
	cursor: pointer; transition: all .18s;
}
.btn-ghost:hover { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-glow); }

.btn-copy {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 7px 13px; border: 1.5px solid var(--color-border); border-radius: 8px;
	background: var(--color-bg-card); color: var(--color-text-muted);
	font-size: 12px; font-weight: 600; font-family: var(--font-mono, monospace);
	cursor: pointer; transition: all .18s; white-space: nowrap;
}
.btn-copy:hover  { border-color: var(--color-primary); color: var(--color-primary); }
.btn-copy.copied { background: #f0fdf4; border-color: #22c55e; color: #16a34a; }

/* ── Code blocks ───────────────────────────────────────────────── */
.code-block {
	background: var(--si-ink, #0f172a); color: #e2e8f0;
	border-radius: 12px; padding: 16px;
	font-family: var(--font-mono, 'JetBrains Mono', monospace);
	font-size: 12.5px; line-height: 1.7;
	overflow-x: auto; white-space: pre;
	max-height: 280px; overflow-y: auto;
}

/* ── Result table ──────────────────────────────────────────────── */
.result-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.result-table th {
	text-align: left; padding: 9px 12px;
	background: var(--color-bg-alt); color: var(--color-text-muted);
	font-weight: 600; font-size: 11px;
	text-transform: uppercase; letter-spacing: .05em;
}
.result-table th:first-child { border-radius: 8px 0 0 8px; }
.result-table th:last-child  { border-radius: 0 8px 8px 0; }
.result-table td { padding: 8px 12px; border-bottom: 1px solid var(--color-border); color: var(--color-text); }
.result-table tr:last-child td { border-bottom: none; }
.result-table tr:hover td { background: var(--color-bg-alt); }

.si-tool-result-box { max-height: 320px; overflow-y: auto; border-radius: 12px; border: 1px solid var(--color-border); }

/* ── Badges ────────────────────────────────────────────────────── */
.badge { display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.badge-indigo { background: var(--color-primary-glow); color: var(--color-primary); }
.badge-green  { background: #f0fdf4; color: #16a34a; }
.badge-amber  { background: #fffbeb; color: #d97706; }
.badge-red    { background: #fef2f2; color: #dc2626; }

/* ── SERP preview ──────────────────────────────────────────────── */
.si-serp-card { background: #fff; border: 1px solid #e8eaed; border-radius: 10px; padding: 14px; }
.si-serp-card-label { font-size: 10px; font-weight: 700; color: #94a3b8; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 8px; }
.serp-url   { color: #006621; font-size: 13px; margin-bottom: 2px; }
.serp-title { color: #1a0dab; font-size: 18px; font-weight: 400; cursor: pointer; line-height: 1.3; }
.serp-title:hover { text-decoration: underline; }
.serp-desc  { color: #545454; font-size: 14px; line-height: 1.55; margin-top: 4px; }

/* ── Progress bar ──────────────────────────────────────────────── */
.char-bar { height: 4px; border-radius: 99px; background: var(--color-border); overflow: hidden; margin-top: 5px; }
.char-bar-fill { height: 100%; border-radius: 99px; transition: width .25s, background .25s; }

/* ── Toggle switch ─────────────────────────────────────────────── */
.toggle-wrap { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--color-text); }
.toggle { position: relative; width: 36px; height: 20px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-track { position: absolute; inset: 0; background: #cbd5e1; border-radius: 99px; transition: background .2s; cursor: pointer; }
.toggle input:checked + .toggle-track { background: var(--color-primary); }
.toggle-thumb { position: absolute; top: 3px; left: 3px; width: 14px; height: 14px; background: #fff; border-radius: 50%; transition: transform .2s; pointer-events: none; }
.toggle input:checked ~ .toggle-thumb { transform: translateX(16px); }

/* ── Errors ────────────────────────────────────────────────────── */
.err-line {
	font-family: var(--font-mono, monospace); font-size: 12px; color: #dc2626;
	background: #fef2f2; border-left: 3px solid #dc2626;
	padding: 6px 10px; border-radius: 0 6px 6px 0; margin-bottom: 4px;
}

/* ── Share bar (traffic / virality driver) ────────────────────────
   Appears beneath every tool module. Encourages social sharing,
   which is one of the cheapest top-of-funnel traffic channels for
   free utility tools — every share embeds a canonical backlink. */
.si-tool-share-bar {
	display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
	padding-top: 16px; margin-top: 4px;
	border-top: 1px dashed var(--color-border);
}
.si-tool-share-label { font-size: 12px; color: var(--color-text-subtle); font-weight: 500; }
.si-share-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 30px; height: 30px; border-radius: 8px;
	background: var(--color-bg-alt); color: var(--color-text-muted);
	border: 1px solid var(--color-border); cursor: pointer;
	transition: all .18s;
}
.si-share-btn:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.si-share-btn.copied { background: #22c55e; color: #fff; border-color: #22c55e; }
.si-tool-canonical-url {
	font-size: 11px; font-family: var(--font-mono, monospace); color: var(--color-text-subtle);
	margin-left: auto; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 220px;
}

/* ── Tool icon used on cards / single pages ───────────────────────*/
.tool-icon-lg {
	width: 56px; height: 56px; border-radius: 14px;
	display: flex; align-items: center; justify-content: center;
	font-size: 28px; flex-shrink: 0;
	background: var(--color-primary-glow);
}

/* ── Tools archive grid ────────────────────────────────────────── */
.si-tools-archive-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--space-6, 1.5rem);
}

/* ── Embedded-in-article tool wrapper (compact) ───────────────────*/
.si-embedded-tool-wrapper {
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl, 16px);
	padding: 24px;
	box-shadow: var(--shadow-sm);
}
.si-embedded-tool-wrapper::before {
	content: '🛠 Try it yourself';
	display: inline-block;
	font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
	color: var(--color-primary); background: var(--color-primary-glow);
	padding: 4px 10px; border-radius: 999px; margin-bottom: 16px;
}

/* ── Scrollbar within code/result blocks ──────────────────────────*/
.code-block::-webkit-scrollbar, .si-tool-result-box::-webkit-scrollbar { width: 6px; }
.code-block::-webkit-scrollbar-thumb, .si-tool-result-box::-webkit-scrollbar-thumb { background: #475569; border-radius: 99px; }
