/* ============================================================
 * WebStats PRO — Tools & Report Stylesheet (v2.0)
 * ============================================================ */

:root {
	--wsp-primary: #2563eb;
	--wsp-primary-dark: #1d4ed8;
	--wsp-bg: #f8fafc;
	--wsp-card: #ffffff;
	--wsp-border: #e2e8f0;
	--wsp-text: #0f172a;
	--wsp-muted: #64748b;
	--wsp-success: #10b981;
	--wsp-warning: #f59e0b;
	--wsp-danger: #ef4444;
	--wsp-radius: 12px;
	--wsp-shadow: 0 1px 3px rgba(0,0,0,.05), 0 4px 12px rgba(0,0,0,.06);
}

/* ===== Forms ===== */
.wsp-tool {
	background: var(--wsp-card);
	border: 1px solid var(--wsp-border);
	border-radius: var(--wsp-radius);
	padding: 24px;
	margin: 24px 0;
	box-shadow: var(--wsp-shadow);
}
.wsp-form {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.wsp-form input[type="url"],
.wsp-form input[type="text"] {
	flex: 1 1 280px;
	padding: 12px 16px;
	border: 1px solid var(--wsp-border);
	border-radius: 8px;
	font-size: 15px;
	background: #fff;
	color: var(--wsp-text);
}
.wsp-form input:focus {
	outline: none;
	border-color: var(--wsp-primary);
	box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.wsp-form button {
	padding: 12px 24px;
	background: var(--wsp-primary);
	color: #fff;
	border: 0;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s;
}
.wsp-form button:hover { background: var(--wsp-primary-dark); }
.wsp-form button:disabled { opacity: .6; cursor: wait; }

.wsp-result { margin-top: 20px; }
.wsp-result.is-loading { opacity: .6; }
.wsp-loading {
	display: inline-block;
	width: 16px; height: 16px;
	border: 2px solid var(--wsp-border);
	border-top-color: var(--wsp-primary);
	border-radius: 50%;
	animation: wsp-spin .7s linear infinite;
	vertical-align: middle;
	margin-right: 8px;
}
@keyframes wsp-spin { to { transform: rotate(360deg); } }

/* ===== Tools grid ===== */
.wsp-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 16px;
	margin: 24px 0;
}
.wsp-card {
	background: var(--wsp-card);
	border: 1px solid var(--wsp-border);
	border-radius: var(--wsp-radius);
	padding: 20px;
	transition: transform .15s, box-shadow .15s;
}
.wsp-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--wsp-shadow);
}
.wsp-card__icon { font-size: 32px; margin-bottom: 8px; }
.wsp-card__title { margin: 0 0 4px; font-size: 17px; }
.wsp-card__desc { color: var(--wsp-muted); font-size: 13px; margin: 0 0 12px; }
.wsp-card .wsp-form { flex-direction: column; }
.wsp-card .wsp-form input { font-size: 13px; padding: 8px 10px; }
.wsp-card .wsp-form button { padding: 8px 14px; font-size: 13px; }

/* ===== Report ===== */
.wsp-report {
	background: var(--wsp-bg);
	border-radius: var(--wsp-radius);
	padding: 24px;
	margin: 24px 0;
}
.wsp-hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	background: var(--wsp-card);
	padding: 24px;
	border-radius: var(--wsp-radius);
	margin-bottom: 16px;
	flex-wrap: wrap;
}
.wsp-hero__left { display: flex; align-items: center; gap: 16px; }
.wsp-favicon { width: 48px; height: 48px; border-radius: 8px; }
.wsp-hero__domain { margin: 0; font-size: 24px; }
.wsp-hero__url { color: var(--wsp-muted); font-size: 13px; word-break: break-all; }
.wsp-hero__score {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 110px; height: 110px;
	border-radius: 50%;
	color: #fff;
	font-weight: 700;
}
.wsp-hero__num { font-size: 32px; line-height: 1; }
.wsp-hero__grade { font-size: 18px; opacity: .9; }

.wsp-grade-a, .wsp-grade-a-plus, .wsp-grade-aplus { background: var(--wsp-success); }
.wsp-grade-b { background: #22c55e; }
.wsp-grade-c { background: var(--wsp-warning); }
.wsp-grade-d { background: #f97316; }
.wsp-grade-f { background: var(--wsp-danger); }

/* ===== Sub scores ===== */
.wsp-scores {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 12px;
	margin-bottom: 16px;
}
.wsp-score-card {
	background: var(--wsp-card);
	color: #fff;
	padding: 20px;
	border-radius: var(--wsp-radius);
	text-align: center;
}
.wsp-score-card__num { font-size: 32px; font-weight: 700; line-height: 1; }
.wsp-score-card__label { font-size: 13px; margin-top: 4px; opacity: .9; }

/* ===== Sections ===== */
.wsp-section {
	background: var(--wsp-card);
	border-radius: var(--wsp-radius);
	padding: 20px 24px;
	margin-bottom: 12px;
}
.wsp-section__title {
	margin: 0 0 16px;
	font-size: 17px;
	display: flex;
	align-items: center;
	gap: 10px;
	border-bottom: 1px solid var(--wsp-border);
	padding-bottom: 12px;
}
.wsp-section__icon { font-size: 22px; }

/* ===== Tables ===== */
.wsp-kv { width: 100%; border-collapse: collapse; }
.wsp-kv th, .wsp-kv td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--wsp-border); font-size: 14px; }
.wsp-kv th { font-weight: 600; color: var(--wsp-muted); width: 40%; }
.wsp-kv td code { background: #f1f5f9; padding: 2px 6px; border-radius: 4px; font-size: 12px; word-break: break-all; }
.wsp-muted { color: var(--wsp-muted); }

/* ===== Pills ===== */
.wsp-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.wsp-pill {
	display: inline-block;
	padding: 4px 12px;
	background: #eff6ff;
	color: var(--wsp-primary-dark);
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
}

/* ===== Issues / OK ===== */
.wsp-ok { color: var(--wsp-success); margin: 8px 0 0; }
.wsp-issues {
	background: #fef3c7;
	border-left: 4px solid var(--wsp-warning);
	padding: 12px 16px;
	border-radius: 6px;
	margin-top: 12px;
}
.wsp-issues ul { margin: 6px 0 0 18px; padding: 0; }
.wsp-issues li { margin: 2px 0; }

/* ===== Footer ===== */
.wsp-footer { text-align: center; color: var(--wsp-muted); margin-top: 16px; }

/* ===== Single-tool result blocks ===== */
.wsp-result h4 {
	margin: 0 0 10px;
	font-size: 16px;
	color: var(--wsp-primary-dark);
}
.wsp-result table { margin-bottom: 0; }
.wsp-error {
	color: var(--wsp-danger);
	background: #fee2e2;
	border-left: 4px solid var(--wsp-danger);
	padding: 10px 14px;
	border-radius: 6px;
}

/* ===== Mobile ===== */
@media (max-width: 600px) {
	.wsp-hero { flex-direction: column; text-align: center; }
	.wsp-hero__left { flex-direction: column; }
	.wsp-form { flex-direction: column; }
	.wsp-form button { width: 100%; }
	.wsp-kv th { width: 35%; font-size: 13px; }
	.wsp-kv td { font-size: 13px; }
}

/* ============================================================
 * WORTH / TRAFFIC / REVENUE — prominent v1.0-style cards
 * ============================================================ */

.wsp-intro {
	background: var(--wsp-card);
	padding: 18px 22px;
	border-radius: var(--wsp-radius);
	margin-bottom: 16px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--wsp-text);
}
.wsp-intro strong { color: var(--wsp-primary-dark); }
.wsp-intro em     { color: var(--wsp-muted); font-style: normal; }

.wsp-worth-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
	margin-bottom: 16px;
}
.wsp-worth-card {
	background: linear-gradient(135deg, #1e40af 0%, #2563eb 100%);
	color: #fff;
	padding: 22px;
	border-radius: var(--wsp-radius);
	text-align: center;
	box-shadow: var(--wsp-shadow);
}
.wsp-worth-card__label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .08em;
	opacity: .85;
	margin-bottom: 6px;
}
.wsp-worth-card__num {
	font-size: 26px;
	font-weight: 700;
	line-height: 1.2;
	word-break: break-word;
}

.wsp-worth-extra {
	background: var(--wsp-card);
	padding: 14px 20px;
	border-radius: var(--wsp-radius);
	margin-bottom: 16px;
}
.wsp-worth-extra summary {
	cursor: pointer;
	font-weight: 600;
	color: var(--wsp-primary);
}
.wsp-worth-extra[open] summary { margin-bottom: 8px; }

@media (max-width: 600px) {
	.wsp-worth-card__num { font-size: 22px; }
}
