/* ============================================================
   WP SEO Toolkit — Backlink Profiler
   Alle klassen zijn geprefixed met .blp- om conflicten te voorkomen
   ============================================================ */

:root {
	--blp-font:      -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--blp-radius:    10px;
	--blp-radius-sm: 6px;
	--blp-shadow:    0 2px 12px rgba(0,0,0,0.07);
	--blp-border:    1px solid #e8eaed;

	--blp-green:  #16a34a;
	--blp-green-bg:  #f0fdf4;
	--blp-green-border: #bbf7d0;

	--blp-orange: #d97706;
	--blp-orange-bg: #fffbeb;
	--blp-orange-border: #fde68a;

	--blp-red:    #dc2626;
	--blp-red-bg: #fef2f2;
	--blp-red-border: #fecaca;

	--blp-blue:   #2563eb;
	--blp-blue-bg: #eff6ff;

	--blp-grey:   #6b7280;
	--blp-grey-bg: #f9fafb;
	--blp-grey-border: #e5e7eb;
}

/* ---- Wrap ---- */
.blp-wrap {
	font-family: var(--blp-font);
	max-width: 900px;
	margin: 0 auto;
	color: #111827;
	font-size: 15px;
	line-height: 1.5;
}

/* ---- Search card ---- */
.blp-search-card {
	background: #fff;
	border: var(--blp-border);
	border-radius: var(--blp-radius);
	padding: 28px 32px;
	box-shadow: var(--blp-shadow);
	margin-bottom: 24px;
}

.blp-title {
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 6px;
	color: #111827;
}

.blp-subtitle {
	color: var(--blp-grey);
	margin: 0 0 20px;
	font-size: 14px;
}

.blp-input-row {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.blp-input {
	flex: 1;
	min-width: 220px;
	padding: 11px 14px;
	border: var(--blp-border);
	border-radius: var(--blp-radius-sm);
	font-size: 15px;
	font-family: var(--blp-font);
	transition: border-color .15s;
	outline: none;
}

.blp-input:focus {
	border-color: var(--blp-blue);
	box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}

.blp-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--blp-blue);
	color: #fff;
	border: none;
	border-radius: var(--blp-radius-sm);
	padding: 11px 22px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s, opacity .15s;
	font-family: var(--blp-font);
	white-space: nowrap;
}

.blp-btn:hover:not(:disabled) { background: #1d4ed8; }
.blp-btn:disabled { opacity: .65; cursor: not-allowed; }

.blp-error {
	color: var(--blp-red);
	margin: 10px 0 0;
	font-size: 14px;
}

.blp-cache-note {
	color: var(--blp-grey);
	font-size: 13px;
	margin: 10px 0 0;
}

.blp-link {
	background: none;
	border: none;
	color: var(--blp-blue);
	cursor: pointer;
	font-size: 13px;
	padding: 0;
	text-decoration: underline;
}

/* ---- Spinner ---- */
@keyframes blp-rotate {
	to { transform: rotate(360deg); }
}
.blp-spin svg { animation: blp-rotate .8s linear infinite; }

/* ---- Report ---- */
.blp-report-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
}

.blp-domain-title {
	font-size: 24px;
	font-weight: 700;
	margin: 0 0 4px;
}

.blp-analyzed-at {
	font-size: 13px;
	color: var(--blp-grey);
}

/* ---- Section ---- */
.blp-section {
	background: #fff;
	border: var(--blp-border);
	border-radius: var(--blp-radius);
	padding: 24px 28px;
	margin-bottom: 20px;
	box-shadow: var(--blp-shadow);
}

.blp-section-title {
	font-size: 17px;
	font-weight: 700;
	margin: 0 0 6px;
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.blp-section-sub {
	font-size: 13px;
	font-weight: 400;
	color: var(--blp-grey);
}

.blp-section-intro {
	color: #374151;
	font-size: 14px;
	margin: 0 0 18px;
	line-height: 1.6;
}

/* ---- Health ---- */
.blp-health-section {
	background: linear-gradient(135deg, #f8faff 0%, #fff 100%);
}

.blp-health-row {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 20px;
	align-items: center;
}

.blp-health-score {
	text-align: center;
	width: 90px;
	height: 90px;
	border-radius: 50%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border: 4px solid;
	flex-shrink: 0;
}

.blp-score-green  { border-color: var(--blp-green);  color: var(--blp-green);  background: var(--blp-green-bg); }
.blp-score-orange { border-color: var(--blp-orange); color: var(--blp-orange); background: var(--blp-orange-bg); }
.blp-score-red    { border-color: var(--blp-red);    color: var(--blp-red);    background: var(--blp-red-bg); }

.blp-score-number { font-size: 28px; font-weight: 800; line-height: 1; }
.blp-score-max    { font-size: 12px; opacity: .6; }

.blp-health-status {
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 6px;
}
.blp-status-green  { color: var(--blp-green); }
.blp-status-orange { color: var(--blp-orange); }
.blp-status-red    { color: var(--blp-red); }

.blp-health-desc { color: #374151; font-size: 14px; margin: 0; }

.blp-health-bar-wrap { width: 100%; }

.blp-health-bar {
	height: 10px;
	background: #e5e7eb;
	border-radius: 99px;
	overflow: hidden;
}

.blp-health-fill {
	height: 100%;
	border-radius: 99px;
	transition: width .6s ease;
}
.blp-fill-green  { background: var(--blp-green); }
.blp-fill-orange { background: var(--blp-orange); }
.blp-fill-red    { background: var(--blp-red); }

/* ---- Stat cards ---- */
.blp-cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
	gap: 12px;
}

.blp-card {
	border: var(--blp-border);
	border-radius: var(--blp-radius-sm);
	padding: 16px;
	background: var(--blp-grey-bg);
	border-left: 4px solid transparent;
}

.blp-card-green   { border-left-color: var(--blp-green);  background: var(--blp-green-bg); }
.blp-card-orange  { border-left-color: var(--blp-orange); background: var(--blp-orange-bg); }
.blp-card-red     { border-left-color: var(--blp-red);    background: var(--blp-red-bg); }
.blp-card-neutral { border-left-color: #d1d5db; }

.blp-card-label {
	font-size: 12px;
	color: var(--blp-grey);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 8px;
	display: flex;
	align-items: center;
	gap: 5px;
}

.blp-card-value {
	font-size: 26px;
	font-weight: 800;
	line-height: 1;
	margin-bottom: 4px;
}

.blp-card-sub {
	font-size: 12px;
	color: var(--blp-grey);
}

/* ---- Tooltip icon ---- */
.blp-tooltip-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 16px;
	height: 16px;
	background: #d1d5db;
	color: #374151;
	border-radius: 50%;
	font-size: 10px;
	font-weight: 700;
	cursor: pointer;
	flex-shrink: 0;
	vertical-align: middle;
}

.blp-tooltip-icon:hover { background: var(--blp-blue); color: #fff; }

.blp-tooltip-popup {
	position: absolute;
	z-index: 9999;
	background: #1f2937;
	color: #fff;
	font-size: 13px;
	line-height: 1.5;
	padding: 10px 14px;
	border-radius: var(--blp-radius-sm);
	max-width: 280px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

/* ---- Actions ---- */
.blp-actions {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.blp-action {
	border-radius: var(--blp-radius-sm);
	padding: 16px 18px;
	border: 1px solid;
}

.blp-action-risk    { background: var(--blp-red-bg);    border-color: var(--blp-red-border); }
.blp-action-improve { background: var(--blp-orange-bg); border-color: var(--blp-orange-border); }
.blp-action-opp     { background: var(--blp-green-bg);  border-color: var(--blp-green-border); }

.blp-action-header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}

.blp-action-icon  { font-size: 16px; flex-shrink: 0; }
.blp-action-title { font-size: 15px; }

.blp-action-uitleg {
	margin: 0 0 10px 24px;
	font-size: 14px;
	color: #374151;
	line-height: 1.6;
}

.blp-action-tip {
	margin-left: 24px;
	font-size: 13px;
	background: rgba(255,255,255,0.6);
	border-radius: 4px;
	padding: 8px 12px;
	line-height: 1.5;
}

.blp-action-tip-label {
	font-weight: 700;
}

/* ---- Badge ---- */
.blp-badge {
	font-size: 12px;
	font-weight: 600;
	padding: 2px 10px;
	border-radius: 99px;
	display: inline-block;
}
.blp-badge-green   { background: var(--blp-green-bg);   color: var(--blp-green);  border: 1px solid var(--blp-green-border); }
.blp-badge-orange  { background: var(--blp-orange-bg);  color: var(--blp-orange); border: 1px solid var(--blp-orange-border); }
.blp-badge-red     { background: var(--blp-red-bg);     color: var(--blp-red);    border: 1px solid var(--blp-red-border); }
.blp-badge-neutral { background: var(--blp-grey-bg);    color: var(--blp-grey);   border: 1px solid var(--blp-grey-border); }

/* ---- Anchor layout ---- */
.blp-anchor-layout {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 24px;
	align-items: start;
}

.blp-anchor-chart-wrap {
	width: 220px;
	flex-shrink: 0;
}

/* ---- Tables ---- */
.blp-table-wrap { overflow-x: auto; }

.blp-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.blp-table th {
	text-align: left;
	padding: 9px 12px;
	background: var(--blp-grey-bg);
	border-bottom: 2px solid var(--blp-grey-border);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--blp-grey);
	white-space: nowrap;
}

.blp-table td {
	padding: 9px 12px;
	border-bottom: 1px solid #f3f4f6;
	vertical-align: middle;
}

.blp-table tr:last-child td { border-bottom: none; }
.blp-table tr:hover td { background: var(--blp-grey-bg); }

.blp-anchor-text { font-size: 13px; max-width: 200px; word-break: break-word; }
.blp-anchor-count { white-space: nowrap; font-variant-numeric: tabular-nums; }
.blp-anchor-pct { display: flex; align-items: center; gap: 8px; min-width: 120px; }

.blp-bar-inline {
	flex: 1;
	height: 6px;
	background: #e5e7eb;
	border-radius: 99px;
	overflow: hidden;
}
.blp-bar-fill {
	height: 100%;
	background: var(--blp-blue);
	border-radius: 99px;
}

/* ---- Domain table ---- */
.blp-domain-name a {
	color: #111827;
	text-decoration: none;
	font-weight: 500;
}
.blp-domain-name a:hover { color: var(--blp-blue); text-decoration: underline; }
.blp-domain-seen { color: var(--blp-grey); font-size: 13px; }

.blp-rank-badge {
	display: inline-block;
	font-size: 13px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: var(--blp-radius-sm);
}
.blp-rank-green  { background: var(--blp-green-bg);  color: var(--blp-green); }
.blp-rank-orange { background: var(--blp-orange-bg); color: var(--blp-orange); }
.blp-rank-red    { background: var(--blp-red-bg);    color: var(--blp-red); }

.blp-df-col { white-space: nowrap; }

.blp-pill {
	display: inline-block;
	font-size: 12px;
	padding: 1px 7px;
	border-radius: 99px;
	margin-right: 3px;
}
.blp-pill-green { background: var(--blp-green-bg);  color: var(--blp-green); }
.blp-pill-grey  { background: var(--blp-grey-bg);   color: var(--blp-grey); }

/* ---- Quality bars ---- */
.blp-quality-bars { display: flex; flex-direction: column; gap: 12px; }

.blp-quality-row {
	display: grid;
	grid-template-columns: 180px 1fr 100px;
	align-items: center;
	gap: 12px;
}

.blp-quality-label { font-size: 14px; }

.blp-quality-bar {
	height: 10px;
	background: #e5e7eb;
	border-radius: 99px;
	overflow: hidden;
}

.blp-quality-fill {
	height: 100%;
	border-radius: 99px;
	transition: width .4s ease;
}

.blp-quality-pct { font-size: 13px; color: var(--blp-grey); text-align: right; }

/* ---- Velocity chart ---- */
.blp-velocity-chart-wrap {
	position: relative;
	height: 200px;
}

/* ---- Responsive ---- */
@media ( max-width: 680px ) {
	.blp-search-card  { padding: 20px 18px; }
	.blp-section      { padding: 18px 16px; }
	.blp-health-row   { grid-template-columns: auto 1fr; }
	.blp-health-bar-wrap { grid-column: 1 / -1; }
	.blp-anchor-layout { grid-template-columns: 1fr; }
	.blp-anchor-chart-wrap { width: 100%; max-width: 280px; margin: 0 auto; }
	.blp-quality-row  { grid-template-columns: 1fr; gap: 4px; }
	.blp-quality-pct  { text-align: left; }
	.blp-cards        { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}
