/**
 * AI Discovery Files — Crawler Analytics Stylesheet
 *
 * Premium analytics dashboard for AI crawler tracking.
 * Uses ONLY --aidf-* variables from the parent admin.css.
 *
 * @package AIDF
 * @since   1.3.0
 */

/* ==========================================================
   1. Layout
   ========================================================== */

.aidf-crawlers-wrap {
	display: flex;
	flex-direction: column;
	gap: var(--aidf-sp-6);
}

#aidf-crawlers-dashboard {
	display: flex;
	flex-direction: column;
	gap: var(--aidf-sp-6);
}

.aidf-crawlers-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--aidf-sp-4);
	padding: var(--aidf-sp-4) var(--aidf-sp-6);
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
}

/* ==========================================================
   2. Summary Cards
   ========================================================== */

.aidf-stat-cards {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--aidf-sp-4);
}

.aidf-stat-card {
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	padding: var(--aidf-sp-5) var(--aidf-sp-6);
	box-shadow: var(--aidf-shadow-sm);
	transition: box-shadow var(--aidf-transition);
}

.aidf-stat-card:hover {
	box-shadow: var(--aidf-shadow);
}

.aidf-stat-card__value {
	font-size: var(--aidf-text-2xl);
	font-weight: 700;
	color: var(--aidf-text);
	line-height: 1.2;
	margin-bottom: var(--aidf-sp-1);
}

.aidf-stat-card__label {
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
	line-height: 1.4;
}

.aidf-stat-card--warning {
	background: var(--aidf-amber-bg);
	border-color: var(--aidf-amber-border);
}

.aidf-stat-card--warning .aidf-stat-card__value {
	color: var(--aidf-amber);
}

/* ==========================================================
   3. Period Selector
   ========================================================== */

.aidf-period-selector {
	display: flex;
	gap: var(--aidf-sp-1);
	background: var(--aidf-bg);
	border-radius: var(--aidf-radius);
	padding: 2px;
}

.aidf-period-selector__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--aidf-sp-1) var(--aidf-sp-3);
	font-family: var(--aidf-font);
	font-size: var(--aidf-text-xs);
	font-weight: 500;
	color: var(--aidf-text-secondary);
	background: transparent;
	border: none;
	border-radius: var(--aidf-radius-sm);
	cursor: pointer;
	transition: all var(--aidf-transition);
	white-space: nowrap;
	line-height: 1.5;
}

.aidf-period-selector__btn:hover {
	color: var(--aidf-text);
	background: var(--aidf-white);
}

.aidf-period-selector__btn--active {
	background: var(--aidf-orange);
	color: var(--aidf-text-inverse);
	box-shadow: var(--aidf-shadow-sm);
}

.aidf-period-selector__btn--active:hover {
	background: var(--aidf-orange-hover);
	color: var(--aidf-text-inverse);
}

/* ==========================================================
   4. Chart.js Canvas
   ========================================================== */

.aidf-chart-canvas-wrap {
	position: relative;
	height: 250px;
	width: 100%;
	padding: var(--aidf-sp-4) var(--aidf-sp-6) var(--aidf-sp-6);
}

.aidf-chart-canvas-wrap--detail {
	height: 180px;
	padding: 0;
}

.aidf-chart-empty {
	text-align: center;
	padding: var(--aidf-sp-8) var(--aidf-sp-4);
	color: var(--aidf-text-tertiary);
	font-size: var(--aidf-text-sm);
	margin: 0;
}

/* ==========================================================
   5. Tables
   ========================================================== */

.aidf-crawlers-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	overflow: hidden;
	box-shadow: var(--aidf-shadow-sm);
}

.aidf-crawlers-table th {
	text-align: left;
	padding: var(--aidf-sp-3) var(--aidf-sp-4);
	font-size: var(--aidf-text-xs);
	font-weight: 600;
	color: var(--aidf-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-bottom: 1px solid var(--aidf-border);
	background: var(--aidf-bg);
}

.aidf-crawlers-table td {
	padding: var(--aidf-sp-3) var(--aidf-sp-4);
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text);
	border-bottom: 1px solid var(--aidf-border-light);
	vertical-align: middle;
}

.aidf-crawlers-table tbody tr:last-child td {
	border-bottom: none;
}

.aidf-crawlers-table tbody tr:nth-child(even) {
	background: var(--aidf-gray-bg);
}

.aidf-crawlers-table__row--clickable {
	cursor: pointer;
	transition: background var(--aidf-transition);
}

.aidf-crawlers-table__row--clickable:hover {
	background: var(--aidf-orange-light) !important;
}

.aidf-status-badge {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--aidf-sp-2);
	font-size: var(--aidf-text-xs);
	font-weight: 600;
	border-radius: 10px;
	line-height: 1.5;
	white-space: nowrap;
}

.aidf-status-badge--green {
	background: var(--aidf-green-bg);
	color: var(--aidf-green);
	border: 1px solid var(--aidf-green-border);
}

.aidf-status-badge--red {
	background: var(--aidf-red-bg);
	color: var(--aidf-red);
	border: 1px solid var(--aidf-red-border);
}

.aidf-status-badge--gray {
	background: var(--aidf-gray-bg);
	color: var(--aidf-gray);
	border: 1px solid var(--aidf-gray-border);
}

/* ==========================================================
   6. Discovery File Access
   ========================================================== */

.aidf-file-access {
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	padding: var(--aidf-sp-5) var(--aidf-sp-6);
	box-shadow: var(--aidf-shadow-sm);
}

.aidf-file-access__row {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-4);
	padding: var(--aidf-sp-3) 0;
	border-bottom: 1px solid var(--aidf-border-light);
}

.aidf-file-access__row:last-child {
	border-bottom: none;
}

.aidf-file-access__name {
	font-family: var(--aidf-font-mono);
	font-size: var(--aidf-text-sm);
	font-weight: 500;
	color: var(--aidf-text);
	width: 140px;
	flex-shrink: 0;
}

.aidf-file-access__bar-track {
	flex: 1;
	height: 8px;
	background: var(--aidf-bg);
	border-radius: var(--aidf-radius-sm);
	overflow: hidden;
}

.aidf-file-access__bar-fill {
	height: 100%;
	background: var(--aidf-orange);
	border-radius: var(--aidf-radius-sm);
	transition: width var(--aidf-transition-slow);
	min-width: 2px;
}

.aidf-file-access__bar-fill--zero {
	background: var(--aidf-border);
	width: 2px;
}

.aidf-file-access__count {
	font-size: var(--aidf-text-sm);
	font-weight: 600;
	color: var(--aidf-text);
	min-width: 40px;
	text-align: right;
	flex-shrink: 0;
}

.aidf-bot-pill {
	display: inline-flex;
	align-items: center;
	padding: 1px var(--aidf-sp-2);
	font-size: var(--aidf-text-xs);
	font-weight: 500;
	border-radius: 10px;
	background: var(--aidf-orange-light);
	color: var(--aidf-orange-hover);
	white-space: nowrap;
	line-height: 1.5;
}

/* ==========================================================
   7. Insights
   ========================================================== */

.aidf-insights {
	display: flex;
	flex-direction: column;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-4) var(--aidf-sp-6);
}

.aidf-insight-alert {
	display: flex;
	align-items: flex-start;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-4) var(--aidf-sp-5);
	border-radius: var(--aidf-radius-md);
	font-size: var(--aidf-text-sm);
	line-height: 1.5;
}

.aidf-insight-alert .dashicons {
	flex-shrink: 0;
	font-size: 18px;
	width: 18px;
	height: 18px;
	margin-top: 1px;
}

.aidf-insight-alert__body {
	flex: 1;
}

.aidf-insight-alert__action {
	flex-shrink: 0;
	font-size: var(--aidf-text-sm);
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
}

.aidf-insight-alert--error {
	background: var(--aidf-red-bg);
	border: 1px solid var(--aidf-red-border);
	color: #991b1b;
}

.aidf-insight-alert--error .dashicons {
	color: var(--aidf-red);
}

.aidf-insight-alert--error .aidf-insight-alert__action {
	color: var(--aidf-red);
}

.aidf-insight-alert--warning {
	background: var(--aidf-amber-bg);
	border: 1px solid var(--aidf-amber-border);
	color: #92400e;
}

.aidf-insight-alert--warning .dashicons {
	color: var(--aidf-amber);
}

.aidf-insight-alert--warning .aidf-insight-alert__action {
	color: var(--aidf-amber);
}

.aidf-insight-alert--info {
	background: var(--aidf-blue-bg);
	border: 1px solid var(--aidf-blue-border);
	color: #1e40af;
}

.aidf-insight-alert--info .dashicons {
	color: var(--aidf-blue);
}

.aidf-insight-alert--info .aidf-insight-alert__action {
	color: var(--aidf-blue);
}

/* ==========================================================
   8. Bot Detail
   ========================================================== */

.aidf-bot-detail {
	display: none;
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
	overflow: hidden;
}

.aidf-bot-detail--visible {
	display: block;
}

.aidf-bot-detail__header {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-4);
	padding: var(--aidf-sp-5) var(--aidf-sp-6);
	border-bottom: 1px solid var(--aidf-border-light);
}

.aidf-bot-detail__name {
	font-size: var(--aidf-text-xl);
	font-weight: 700;
	color: var(--aidf-text);
}

.aidf-bot-detail__back {
	display: inline-flex;
	align-items: center;
	gap: var(--aidf-sp-1);
	font-size: var(--aidf-text-sm);
	font-weight: 500;
	color: var(--aidf-text-secondary);
	text-decoration: none;
	cursor: pointer;
	transition: color var(--aidf-transition);
	margin-right: auto;
}

.aidf-bot-detail__back:hover {
	color: var(--aidf-orange);
}

.aidf-bot-detail__back .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
}

/* ==========================================================
   9. Log Viewer
   ========================================================== */

.aidf-log-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-4) var(--aidf-sp-6);
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
}

.aidf-log-filters .aidf-select {
	max-width: 200px;
}

.aidf-log-table__status--blocked {
	background: var(--aidf-red-bg) !important;
}

/* ==========================================================
   10. Settings — Collapsible Section
   ========================================================== */

.aidf-crawlers-settings {
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
	overflow: hidden;
}

.aidf-crawlers-settings__header {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-4) var(--aidf-sp-6);
	cursor: pointer;
	user-select: none;
	background: var(--aidf-bg);
	border-bottom: 1px solid transparent;
	transition: background var(--aidf-transition), border-color var(--aidf-transition);
	list-style: none;
}

/* Remove default details marker in all browsers */
.aidf-crawlers-settings__header::-webkit-details-marker,
.aidf-crawlers-settings__header::marker {
	display: none;
	content: '';
}

.aidf-crawlers-settings__header:hover {
	background: var(--aidf-border-light);
}

.aidf-crawlers-settings[open] > .aidf-crawlers-settings__header {
	border-bottom-color: var(--aidf-border);
}

.aidf-crawlers-settings__icon {
	font-size: 18px;
	width: 18px;
	height: 18px;
	color: var(--aidf-text-secondary);
	flex-shrink: 0;
}

.aidf-crawlers-settings__title {
	font-size: var(--aidf-text-base);
	font-weight: 600;
	color: var(--aidf-text);
	flex: 1;
}

.aidf-crawlers-settings__chevron {
	font-size: 18px;
	width: 18px;
	height: 18px;
	color: var(--aidf-text-tertiary);
	transition: transform var(--aidf-transition);
	flex-shrink: 0;
}

.aidf-crawlers-settings[open] > .aidf-crawlers-settings__header .aidf-crawlers-settings__chevron {
	transform: rotate(180deg);
}

.aidf-crawlers-settings__body {
	padding: var(--aidf-sp-6);
	display: flex;
	flex-direction: column;
	gap: var(--aidf-sp-6);
}

/* ==========================================================
   11. Settings — Rows
   ========================================================== */

.aidf-setting-row {
	display: flex;
	align-items: flex-start;
	gap: var(--aidf-sp-8);
	padding-bottom: var(--aidf-sp-6);
	border-bottom: 1px solid var(--aidf-border-light);
}

.aidf-setting-row:last-of-type {
	border-bottom: none;
	padding-bottom: 0;
}

.aidf-setting-row__label {
	flex: 1;
	min-width: 0;
}

.aidf-setting-row__label > label {
	display: block;
	font-size: var(--aidf-text-base);
	font-weight: 600;
	color: var(--aidf-text);
	margin-bottom: var(--aidf-sp-1);
}

.aidf-setting-row__help {
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-tertiary);
	line-height: 1.5;
	margin: 0;
}

.aidf-setting-row__control {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}

.aidf-setting-row__control .aidf-select {
	max-width: 180px;
	width: auto;
}

.aidf-setting-row--full {
	flex-direction: column;
	gap: var(--aidf-sp-4);
}

.aidf-setting-row--full .aidf-setting-row__label {
	width: 100%;
}

/* ==========================================================
   12. Settings — Actions Row
   ========================================================== */

.aidf-setting-actions {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-3);
	padding-top: var(--aidf-sp-4);
	border-top: 1px solid var(--aidf-border-light);
}

/* ==========================================================
   13. Toggle Switch (BEM variant for crawlers)
   ========================================================== */

.aidf-switch__slider {
	position: absolute;
	cursor: pointer;
	inset: 0;
	background-color: var(--aidf-border);
	border-radius: 24px;
	transition: background-color var(--aidf-transition);
}

.aidf-switch__slider::before {
	content: '';
	position: absolute;
	height: 18px;
	width: 18px;
	left: 3px;
	bottom: 3px;
	background-color: var(--aidf-white);
	border-radius: 50%;
	transition: transform var(--aidf-transition);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

.aidf-switch input:checked + .aidf-switch__slider {
	background-color: var(--aidf-orange);
}

.aidf-switch input:checked + .aidf-switch__slider::before {
	transform: translateX(20px);
}

.aidf-switch input:focus + .aidf-switch__slider {
	box-shadow: 0 0 0 3px var(--aidf-orange-glow);
}

/* ==========================================================
   14. Buttons — Additional Variants
   ========================================================== */

.aidf-btn--outline {
	background: var(--aidf-white);
	color: var(--aidf-text-secondary);
	border-color: var(--aidf-border);
}

.aidf-btn--outline:hover {
	background: var(--aidf-bg);
	color: var(--aidf-text);
	border-color: var(--aidf-text-tertiary);
}

.aidf-btn--outline:focus {
	outline: none;
	box-shadow: 0 0 0 3px var(--aidf-orange-glow);
}

.aidf-link-btn {
	display: inline;
	padding: 0;
	margin: 0;
	border: none;
	background: none;
	font-family: var(--aidf-font);
	font-size: var(--aidf-text-xs);
	font-weight: 600;
	color: var(--aidf-text-tertiary);
	cursor: pointer;
	text-decoration: none;
	transition: color var(--aidf-transition);
}

.aidf-link-btn:hover {
	color: var(--aidf-orange);
}

/* ==========================================================
   15. Bot Selector
   ========================================================== */

.aidf-bot-selector {
	width: 100%;
}

.aidf-bot-presets {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-2);
	margin-bottom: var(--aidf-sp-4);
}

/* --- Category --- */

.aidf-bot-category {
	border: 1px solid var(--aidf-border-light);
	border-radius: var(--aidf-radius);
	margin-bottom: var(--aidf-sp-3);
	overflow: hidden;
	background: var(--aidf-white);
}

.aidf-bot-category:last-child {
	margin-bottom: 0;
}

.aidf-bot-category__header {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-3) var(--aidf-sp-4);
	cursor: pointer;
	user-select: none;
	background: var(--aidf-gray-bg);
	transition: background var(--aidf-transition);
	list-style: none;
}

.aidf-bot-category__header::-webkit-details-marker,
.aidf-bot-category__header::marker {
	display: none;
	content: '';
}

.aidf-bot-category__header:hover {
	background: var(--aidf-border-light);
}

.aidf-bot-category__name {
	font-size: var(--aidf-text-sm);
	font-weight: 600;
	color: var(--aidf-text);
	flex: 1;
}

.aidf-bot-category__count {
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	white-space: nowrap;
}

.aidf-bot-category__actions {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-2);
	margin-left: var(--aidf-sp-2);
}

.aidf-bot-category__actions .aidf-link-btn {
	padding: var(--aidf-sp-1) var(--aidf-sp-2);
	border-radius: var(--aidf-radius-sm);
}

.aidf-bot-category__actions .aidf-link-btn:hover {
	background: var(--aidf-white);
}

/* --- Category body: grid of bot items --- */

.aidf-bot-category__body {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--aidf-border-light);
}

/* --- Individual bot item --- */

.aidf-bot-item {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-2);
	padding: var(--aidf-sp-2) var(--aidf-sp-4);
	cursor: pointer;
	transition: background var(--aidf-transition);
	border-bottom: 1px solid var(--aidf-border-light);
	border-right: 1px solid var(--aidf-border-light);
	margin: 0;
}

/* Remove right border on every 3rd item (last column) */
.aidf-bot-item:nth-child(3n) {
	border-right: none;
}

/* Remove bottom border on last row */
.aidf-bot-item:nth-last-child(-n+3) {
	border-bottom: none;
}

.aidf-bot-item:hover {
	background: var(--aidf-orange-light);
}

.aidf-bot-item input[type="checkbox"] {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	margin: 0;
	cursor: pointer;
	accent-color: var(--aidf-orange);
}

.aidf-bot-item__check {
	display: none;
}

.aidf-bot-item__name {
	font-size: var(--aidf-text-sm);
	font-weight: 500;
	color: var(--aidf-text);
	white-space: nowrap;
}

.aidf-bot-item__meta {
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	white-space: nowrap;
	margin-left: auto;
}

/* ==========================================================
   16. Notices (crawler-specific adjustments)
   ========================================================== */

.aidf-crawlers-settings__body > .aidf-notice {
	margin-bottom: 0;
}

/* ==========================================================
   17. Empty State
   ========================================================== */

.aidf-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--aidf-sp-12) var(--aidf-sp-8);
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
}

.aidf-empty-state .dashicons {
	font-size: 48px;
	width: 48px;
	height: 48px;
	color: var(--aidf-text-tertiary);
	margin-bottom: var(--aidf-sp-4);
}

.aidf-empty-state__heading {
	font-size: var(--aidf-text-lg);
	font-weight: 700;
	color: var(--aidf-text);
	margin: 0 0 var(--aidf-sp-2);
}

.aidf-empty-state__description {
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
	max-width: 420px;
	line-height: 1.6;
	margin: 0 0 var(--aidf-sp-6);
}

/* ==========================================================
   18. Dashboard Panels
   ========================================================== */

.aidf-dashboard-panel {
	background: var(--aidf-panel);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-md);
	box-shadow: var(--aidf-shadow-sm);
	overflow: hidden;
}

.aidf-dashboard-panel__header {
	display: flex;
	align-items: baseline;
	gap: var(--aidf-sp-3);
	padding: var(--aidf-sp-4) var(--aidf-sp-6);
	border-bottom: 1px solid var(--aidf-border-light);
}

.aidf-dashboard-panel__title {
	font-size: var(--aidf-text-base);
	font-weight: 700;
	color: var(--aidf-text);
	margin: 0;
}

.aidf-dashboard-panel__help {
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	margin: 0;
	line-height: 1.5;
}

/* ==========================================================
   19. Header Title
   ========================================================== */

.aidf-crawlers-header__title {
	font-size: var(--aidf-text-base);
	font-weight: 700;
	color: var(--aidf-text);
	margin: 0;
}

/* ==========================================================
   20. Loading State
   ========================================================== */

.aidf-dashboard--loading {
	opacity: 0.5;
	pointer-events: none;
	transition: opacity var(--aidf-transition);
}

/* ==========================================================
   21. Muted Cards (zero state)
   ========================================================== */

.aidf-stat-card--muted {
	opacity: 0.45;
}

.aidf-stat-card--muted .aidf-stat-card__value {
	color: var(--aidf-text-tertiary);
}

/* ==========================================================
   22. (Reserved — previously CSS bar chart enhancements)
   ========================================================== */

/* ==========================================================
   23. Chart Legend
   ========================================================== */

.aidf-chart-legend {
	display: flex;
	flex-wrap: wrap;
	gap: var(--aidf-sp-3);
	margin-left: auto;
}

.aidf-chart-legend__item {
	display: inline-flex;
	align-items: center;
	gap: var(--aidf-sp-1);
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-secondary);
	white-space: nowrap;
}

.aidf-chart-legend__dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* ==========================================================
   24. Bot Operator Sub-Label
   ========================================================== */

.aidf-bot-operator {
	display: block;
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	font-weight: 400;
	line-height: 1.4;
}

/* ==========================================================
   25. Mono Small (top page paths)
   ========================================================== */

code.aidf-mono-sm {
	font-family: var(--aidf-font-mono);
	font-size: var(--aidf-text-xs);
	background: var(--aidf-gray-bg);
	padding: 1px var(--aidf-sp-1);
	border-radius: var(--aidf-radius-sm);
	color: var(--aidf-text-secondary);
}

/* ==========================================================
   26. File Access Bots Container
   ========================================================== */

.aidf-file-access__bots {
	display: flex;
	flex-wrap: wrap;
	gap: var(--aidf-sp-1);
	flex-shrink: 0;
	max-width: 220px;
}

.aidf-text-muted {
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	font-style: italic;
}

.aidf-file-access__row--muted {
	opacity: 0.5;
}

/* ==========================================================
   27. Table Empty State
   ========================================================== */

.aidf-table-empty {
	text-align: center;
	padding: var(--aidf-sp-8) var(--aidf-sp-4) !important;
	color: var(--aidf-text-tertiary);
	font-size: var(--aidf-text-sm);
}

/* ==========================================================
   28. File Access inside Panel
   ========================================================== */

.aidf-dashboard-panel > .aidf-file-access,
.aidf-dashboard-panel > .aidf-crawlers-table {
	border: none;
	box-shadow: none;
	border-radius: 0;
}

/* ==========================================================
   29. Screen Reader Only
   ========================================================== */

.aidf-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ==========================================================
   30. Responsive — Below 1200px
   ========================================================== */

@media (max-width: 1200px) {
	.aidf-stat-cards {
		grid-template-columns: repeat(2, 1fr);
	}

	.aidf-bot-category__body {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Fix border removal for 2-column layout */
	.aidf-bot-item:nth-child(3n) {
		border-right: 1px solid var(--aidf-border-light);
	}

	.aidf-bot-item:nth-child(2n) {
		border-right: none;
	}

	.aidf-bot-item:nth-last-child(-n+3) {
		border-bottom: 1px solid var(--aidf-border-light);
	}

	.aidf-bot-item:nth-last-child(-n+2) {
		border-bottom: none;
	}
}

/* ==========================================================
   31. Responsive — Below 768px
   ========================================================== */

@media (max-width: 768px) {
	.aidf-stat-cards {
		grid-template-columns: 1fr;
	}

	.aidf-crawlers-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--aidf-sp-3);
	}

	.aidf-period-selector {
		width: 100%;
	}

	.aidf-period-selector__btn {
		flex: 1;
		justify-content: center;
	}

	.aidf-bot-category__body {
		grid-template-columns: 1fr;
	}

	/* Fix border removal for 1-column layout */
	.aidf-bot-item:nth-child(2n),
	.aidf-bot-item:nth-child(3n) {
		border-right: none;
	}

	.aidf-bot-item:nth-last-child(-n+2),
	.aidf-bot-item:nth-last-child(-n+3) {
		border-bottom: 1px solid var(--aidf-border-light);
	}

	.aidf-bot-item:last-child {
		border-bottom: none;
	}

	.aidf-bot-item__meta {
		display: none;
	}

	.aidf-setting-row {
		flex-direction: column;
		gap: var(--aidf-sp-3);
	}

	.aidf-setting-row__control .aidf-select {
		max-width: 100%;
		width: 100%;
	}

	.aidf-setting-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.aidf-setting-actions .aidf-btn {
		justify-content: center;
	}

	.aidf-log-filters {
		flex-direction: column;
		align-items: stretch;
	}

	.aidf-log-filters .aidf-select {
		max-width: 100%;
	}

	.aidf-file-access__row {
		flex-wrap: wrap;
		gap: var(--aidf-sp-2);
	}

	.aidf-file-access__name {
		width: auto;
	}

	.aidf-file-access__bar-track {
		flex-basis: 100%;
		order: 3;
	}

	.aidf-file-access__bots {
		flex-basis: 100%;
		max-width: none;
	}

	.aidf-crawlers-settings__body {
		padding: var(--aidf-sp-4);
	}

	.aidf-bot-presets {
		flex-wrap: wrap;
	}

	.aidf-dashboard-panel__header {
		flex-direction: column;
		gap: var(--aidf-sp-1);
		padding: var(--aidf-sp-3) var(--aidf-sp-4);
	}

	.aidf-chart-legend {
		margin-left: 0;
	}

	/* Make breakdown table horizontally scrollable */
	.aidf-dashboard-panel > .aidf-crawlers-table {
		display: block;
		overflow-x: auto;
	}
}

/* ==========================================================
   11. Bot Detail — Extended Components
   ========================================================== */

/* Wrapper panels inside the bot detail container */
.aidf-bot-detail__panel {
	margin: 0 var(--aidf-sp-6) var(--aidf-sp-4);
	border-radius: var(--aidf-radius-md);
	overflow: hidden;
}

/* Back link sits above the header panel */
.aidf-bot-detail > .aidf-bot-detail__back {
	display: inline-flex;
	margin: var(--aidf-sp-4) var(--aidf-sp-6) 0;
}

/* Header (name, operator, badge) */
.aidf-bot-detail__operator {
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
}

.aidf-bot-detail__badge {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--aidf-sp-2);
	border-radius: var(--aidf-radius-sm);
	font-size: var(--aidf-text-xs);
	font-weight: 600;
	background: var(--aidf-blue-bg);
	color: var(--aidf-blue);
	border: 1px solid var(--aidf-blue-border);
	text-transform: capitalize;
}

/* Meta row: first / last seen */
.aidf-bot-detail__meta {
	display: flex;
	gap: var(--aidf-sp-6);
	padding: var(--aidf-sp-3) var(--aidf-sp-6) var(--aidf-sp-4);
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
}

.aidf-detail-meta__label {
	font-weight: 600;
	color: var(--aidf-text);
}

/* Loading state inside detail panels */
.aidf-detail-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--aidf-sp-8);
	color: var(--aidf-text-tertiary);
}

/* Trend chart — now rendered via Chart.js canvas (see .aidf-chart-canvas-wrap--detail) */

/* Status code horizontal stacked bar */
.aidf-status-bar {
	display: flex;
	height: 28px;
	border-radius: var(--aidf-radius-sm);
	overflow: hidden;
	margin-bottom: var(--aidf-sp-3);
}

.aidf-status-bar__segment {
	height: 100%;
	transition: opacity 0.15s;
}

.aidf-status-bar__segment:hover {
	opacity: 0.8;
}

.aidf-status-bar__segment--ok {
	background: var(--aidf-green);
}

.aidf-status-bar__segment--blocked {
	background: var(--aidf-red);
}

.aidf-status-bar__segment--other {
	background: var(--aidf-gray);
}

.aidf-status-bar__legend {
	display: flex;
	flex-wrap: wrap;
	gap: var(--aidf-sp-4);
	font-size: var(--aidf-text-sm);
}

.aidf-status-bar__legend-item {
	display: inline-flex;
	align-items: center;
	gap: var(--aidf-sp-2);
}

.aidf-status-bar__dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

.aidf-status-bar__dot--ok      { background: var(--aidf-green); }
.aidf-status-bar__dot--blocked { background: var(--aidf-red); }
.aidf-status-bar__dot--other   { background: var(--aidf-gray); }

/* Shared detail table (pages visited + log) */
.aidf-detail-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--aidf-text-sm);
}

.aidf-detail-table th {
	text-align: left;
	font-weight: 600;
	color: var(--aidf-text-secondary);
	padding: var(--aidf-sp-2) var(--aidf-sp-3);
	border-bottom: 1px solid var(--aidf-border);
	font-size: var(--aidf-text-xs);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.aidf-detail-table td {
	padding: var(--aidf-sp-2) var(--aidf-sp-3);
	border-bottom: 1px solid var(--aidf-border-light);
	color: var(--aidf-text);
	vertical-align: middle;
}

.aidf-detail-table tbody tr:last-child td {
	border-bottom: none;
}

.aidf-detail-table tbody tr:hover td {
	background: var(--aidf-bg);
}

.aidf-detail-table__note {
	font-size: var(--aidf-text-xs);
	color: var(--aidf-text-tertiary);
	margin-top: var(--aidf-sp-3);
}

/* Discovery file checklist */
.aidf-file-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--aidf-sp-2);
}

.aidf-file-checklist__item {
	display: flex;
	align-items: center;
	gap: var(--aidf-sp-2);
	padding: var(--aidf-sp-2) var(--aidf-sp-3);
	border-radius: var(--aidf-radius-sm);
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
	background: var(--aidf-bg);
}

.aidf-file-checklist__item--accessed {
	background: var(--aidf-green-bg);
	color: var(--aidf-text);
}

.aidf-file-checklist__icon {
	font-size: 16px;
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.aidf-file-checklist__item--accessed .aidf-file-checklist__icon {
	color: var(--aidf-green);
}

.aidf-file-checklist__item:not(.aidf-file-checklist__item--accessed) .aidf-file-checklist__icon {
	color: var(--aidf-gray);
}

/* "View Full Log" link appended to breakdown panel footer */
.aidf-breakdown-footer {
	padding: var(--aidf-sp-3) var(--aidf-sp-6) var(--aidf-sp-4);
	border-top: 1px solid var(--aidf-border-light);
	display: flex;
	justify-content: flex-end;
}

.aidf-breakdown-footer .aidf-btn .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
	margin-right: var(--aidf-sp-1);
}

/* ==========================================================
   12. Log Viewer — Extended Components
   ========================================================== */

/* Log viewer container */
.aidf-log-viewer {
	display: none;
	flex-direction: column;
	gap: var(--aidf-sp-4);
}

.aidf-log-viewer > .aidf-bot-detail__back {
	display: inline-flex;
}

/* Filter row date inputs */
.aidf-log-filter__date {
	height: 34px;
	padding: var(--aidf-sp-1) var(--aidf-sp-2);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-sm);
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text);
	background: var(--aidf-white);
	transition: border-color var(--aidf-transition);
}

.aidf-log-filter__date:focus {
	outline: none;
	border-color: var(--aidf-orange);
	box-shadow: 0 0 0 3px var(--aidf-orange-glow);
}

/* URL path filter input */
.aidf-log-filter__path {
	height: 34px;
	padding: var(--aidf-sp-1) var(--aidf-sp-2);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-sm);
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text);
	background: var(--aidf-white);
	min-width: 180px;
	font-family: var(--aidf-font-mono);
	transition: border-color var(--aidf-transition);
}

.aidf-log-filter__path:focus {
	outline: none;
	border-color: var(--aidf-orange);
	box-shadow: 0 0 0 3px var(--aidf-orange-glow);
}

/* Panel header for log viewer (header has export button, needs flex layout) */
.aidf-log-viewer .aidf-panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.aidf-log-viewer .aidf-panel-header .aidf-btn .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
	margin-right: 4px;
}

/* Results summary text */
.aidf-log-summary {
	font-size: var(--aidf-text-sm);
	color: var(--aidf-text-secondary);
	margin: 0 0 var(--aidf-sp-3);
}

/* Log table — status code badges */
.aidf-log-status {
	display: inline-block;
	padding: 2px 6px;
	border-radius: var(--aidf-radius-sm);
	font-size: var(--aidf-text-xs);
	font-weight: 700;
	font-family: var(--aidf-font-mono);
}

.aidf-log-status--ok {
	background: var(--aidf-green-bg);
	color: var(--aidf-green);
	border: 1px solid var(--aidf-green-border);
}

.aidf-log-status--blocked {
	background: var(--aidf-red-bg);
	color: var(--aidf-red);
	border: 1px solid var(--aidf-red-border);
}

/* Log table blocked-row highlight */
.aidf-log-table .aidf-log-table__status--blocked td {
	background: var(--aidf-red-bg);
}

/* Pagination controls */
.aidf-log-pagination {
	margin-top: var(--aidf-sp-4);
}

.aidf-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: var(--aidf-sp-1);
}

.aidf-pagination__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 34px;
	height: 34px;
	padding: 0 var(--aidf-sp-2);
	border: 1px solid var(--aidf-border);
	border-radius: var(--aidf-radius-sm);
	background: var(--aidf-white);
	color: var(--aidf-text);
	font-size: var(--aidf-text-sm);
	cursor: pointer;
	transition: background var(--aidf-transition), border-color var(--aidf-transition), color var(--aidf-transition);
}

.aidf-pagination__btn:hover:not([disabled]):not(.aidf-pagination__btn--active) {
	background: var(--aidf-bg);
	border-color: var(--aidf-orange);
	color: var(--aidf-orange);
}

.aidf-pagination__btn--active {
	background: var(--aidf-orange);
	border-color: var(--aidf-orange);
	color: var(--aidf-white);
	font-weight: 700;
	cursor: default;
}

.aidf-pagination__btn[disabled] {
	opacity: 0.4;
	cursor: not-allowed;
}

.aidf-pagination__ellipsis {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 34px;
	padding: 0 var(--aidf-sp-1);
	color: var(--aidf-text-tertiary);
	font-size: var(--aidf-text-sm);
}

/* ==========================================================
   13. Responsive — Bot Detail & Log Viewer
   ========================================================== */

@media (max-width: 782px) {
	.aidf-bot-detail__meta {
		flex-direction: column;
		gap: var(--aidf-sp-2);
	}

	.aidf-bot-detail__panel {
		margin-left: var(--aidf-sp-3);
		margin-right: var(--aidf-sp-3);
	}

	.aidf-file-checklist {
		grid-template-columns: 1fr;
	}

	.aidf-detail-table {
		display: block;
		overflow-x: auto;
	}

	.aidf-status-bar__legend {
		flex-direction: column;
		gap: var(--aidf-sp-2);
	}

	.aidf-log-viewer .aidf-panel-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--aidf-sp-2);
	}

	.aidf-pagination {
		gap: 2px;
	}

	.aidf-pagination__btn {
		min-width: 30px;
		height: 30px;
		font-size: 12px;
	}
}
