/**
 * SEO Audit — Style frontendu
 */

/* =========================================================================
   Zmienne
   ========================================================================= */
:root {
	--seo-primary:    #f29200;
	--seo-primary-dk: #d97e00;
	--seo-success:    #4caf50;
	--seo-warning:    #ff9800;
	--seo-danger:     #e53935;
	--seo-text:       #333;
	--seo-text-light: #666;
	--seo-border:     #e0e0e0;
	--seo-bg:         #f9f9f9;
	--seo-white:      #fff;
	--seo-radius:     6px;
}

/* =========================================================================
   Wrapper
   ========================================================================= */
.seo-audit-wrap {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;
	color: var(--seo-text);
	max-width: 900px;
	margin: 0 auto;
}

/* =========================================================================
   Formularz
   ========================================================================= */
.seo-audit-form-container {
	background: var(--seo-white);
	border: 1px solid var(--seo-border);
	border-radius: var(--seo-radius);
	padding: 32px;
	box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.seo-audit-title {
	margin: 0 0 8px;
	font-size: 1.6rem;
	color: var(--seo-primary);
}

.seo-audit-subtitle {
	margin: 0 0 24px;
	color: var(--seo-text-light);
}

.seo-audit-field {
	margin-bottom: 16px;
}

.seo-audit-field label {
	display: block;
	margin-bottom: 6px;
	font-weight: 600;
	font-size: .9rem;
}

.seo-audit-field label .required {
	color: var(--seo-danger);
	margin-left: 2px;
}

.seo-audit-field input[type="text"],
.seo-audit-field input[type="url"],
.seo-audit-field input[type="email"] {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--seo-border);
	border-radius: var(--seo-radius);
	font-size: .95rem;
	transition: border-color .2s;
	box-sizing: border-box;
}

.seo-audit-field input:focus {
	outline: none;
	border-color: var(--seo-primary);
	box-shadow: 0 0 0 3px rgba(242,146,0,.15);
}

.seo-audit-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

@media (max-width: 600px) {
	.seo-audit-row {
		grid-template-columns: 1fr;
	}
}

.seo-audit-checkbox-field label {
	font-weight: 400;
	display: flex;
	align-items: flex-start;
	gap: 8px;
	cursor: pointer;
}

.seo-audit-checkbox-field input[type="checkbox"] {
	margin-top: 3px;
	flex-shrink: 0;
}

/* =========================================================================
   Przyciski
   ========================================================================= */
.seo-audit-btn {
	display: inline-block;
	padding: 12px 32px;
	background: var(--seo-primary);
	color: var(--seo-white);
	border: none;
	border-radius: var(--seo-radius);
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	transition: background .2s, transform .1s;
}

.seo-audit-btn:hover {
	background: var(--seo-primary-dk);
}

.seo-audit-btn:active {
	transform: scale(.98);
}

.seo-audit-btn:disabled {
	opacity: .6;
	cursor: not-allowed;
}

.seo-audit-btn-secondary {
	display: inline-block;
	padding: 6px 16px;
	background: transparent;
	color: var(--seo-primary);
	border: 1px solid var(--seo-primary);
	border-radius: var(--seo-radius);
	font-size: .85rem;
	cursor: pointer;
	transition: all .2s;
	margin-top: 8px;
}

.seo-audit-btn-secondary:hover {
	background: var(--seo-primary);
	color: var(--seo-white);
}

/* =========================================================================
   Alerty
   ========================================================================= */
.seo-audit-alert {
	padding: 12px 16px;
	border-radius: var(--seo-radius);
	margin-bottom: 16px;
	font-size: .9rem;
}

.seo-audit-alert-error {
	background: #fdecea;
	color: #b71c1c;
	border: 1px solid #ef9a9a;
}

.seo-audit-alert-success {
	background: #e8f5e9;
	color: #1b5e20;
	border: 1px solid #a5d6a7;
	padding: 16px;
	border-radius: var(--seo-radius);
	font-size: 1rem;
	font-weight: 600;
	text-align: center;
}

/* =========================================================================
   Pasek postępu
   ========================================================================= */
.seo-audit-progress-bar-wrap {
	height: 6px;
	background: var(--seo-border);
	border-radius: 3px;
	margin-bottom: 24px;
	overflow: hidden;
}

.seo-audit-progress-bar {
	height: 100%;
	background: var(--seo-primary);
	border-radius: 3px;
	transition: width .4s ease;
}

/* =========================================================================
   Sekcje wyników
   ========================================================================= */
.seo-audit-results {
	margin-top: 24px;
}

.seo-audit-box {
	background: var(--seo-white);
	border: 1px solid var(--seo-border);
	border-radius: var(--seo-radius);
	margin-bottom: 16px;
	overflow: hidden;
	box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.seo-audit-box-title {
	background: var(--seo-primary);
	color: var(--seo-white);
	padding: 12px 20px;
	font-weight: 700;
	font-size: .95rem;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.seo-audit-box-body {
	padding: 16px 20px;
}

.seo-audit-row-data {
	padding: 8px 0;
	border-bottom: 1px solid var(--seo-bg);
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 4px 12px;
}

.seo-audit-row-data:last-child {
	border-bottom: none;
}

.seo-audit-row-meta {
	flex-direction: column;
	align-items: stretch;
}

.seo-audit-label {
	font-weight: 600;
	font-size: .88rem;
	color: var(--seo-text-light);
	min-width: 200px;
}

.seo-audit-sublabel {
	font-weight: 600;
	font-size: .85rem;
	color: var(--seo-text-light);
	margin-right: 6px;
}

.seo-audit-value {
	font-size: .9rem;
	color: var(--seo-text);
}

.seo-audit-meta-detail {
	display: flex;
	align-items: baseline;
	gap: 4px;
	padding: 2px 0;
}

/* =========================================================================
   Status OK / Bad
   ========================================================================= */
.seo-audit-status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	font-size: 12px;
	font-weight: 700;
	margin-right: 6px;
	vertical-align: middle;
}

.seo-audit-ok {
	background: var(--seo-success);
	color: #fff;
}

.seo-audit-bad {
	background: var(--seo-danger);
	color: #fff;
}

/* =========================================================================
   Paski postępu (meta title, ratio itp.)
   ========================================================================= */
.seo-audit-progress-wrap {
	margin: 6px 0 4px;
}

.seo-audit-progress-bar-track {
	display: flex;
	height: 12px;
	border-radius: 4px;
	overflow: hidden;
}

.seo-audit-bar-danger  { background: #e53935; }
.seo-audit-bar-warning { background: #ff9800; }
.seo-audit-bar-success { background: #4caf50; }

.seo-audit-progress-label {
	position: relative;
	height: 20px;
	margin-bottom: 2px;
}

.seo-audit-progress-indicator {
	position: absolute;
	transform: translateX(-50%);
	transition: left .4s ease;
}

.seo-audit-progress-indicator span {
	display: block;
	background: var(--seo-text);
	color: #fff;
	font-size: .75rem;
	padding: 1px 5px;
	border-radius: 3px;
	white-space: nowrap;
}

.seo-audit-progress-legend {
	display: flex;
	justify-content: space-between;
	font-size: .7rem;
	color: var(--seo-text-light);
	margin-top: 2px;
}

/* =========================================================================
   Nagłówki H1-H6
   ========================================================================= */
.seo-audit-headers-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 8px;
	margin-top: 4px;
}

@media (max-width: 500px) {
	.seo-audit-headers-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.seo-audit-header-item {
	background: var(--seo-bg);
	border-radius: var(--seo-radius);
	padding: 6px 8px;
	text-align: center;
}

.seo-audit-header-item .seo-audit-sublabel {
	display: block;
	font-size: .75rem;
}

.seo-audit-header-item .seo-audit-value {
	display: block;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--seo-primary);
}

/* =========================================================================
   Listy linków
   ========================================================================= */
.seo-audit-links-list {
	margin: 4px 0 12px;
}

.seo-audit-links-content {
	max-height: 200px;
	overflow: hidden;
	font-size: .82rem;
	line-height: 1.8;
	word-break: break-all;
	color: var(--seo-text-light);
}

/* =========================================================================
   Animacja ładowania
   ========================================================================= */
.seo-audit-loading {
	display: inline-flex;
	gap: 4px;
	align-items: center;
}

.seo-audit-loading span {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: var(--seo-primary);
	border-radius: 50%;
	animation: seoAuditBounce 1.2s infinite ease-in-out;
}

.seo-audit-loading span:nth-child(1) { animation-delay: 0s;    }
.seo-audit-loading span:nth-child(2) { animation-delay: .2s;   }
.seo-audit-loading span:nth-child(3) { animation-delay: .4s;   }

@keyframes seoAuditBounce {
	0%, 80%, 100% { transform: scale(0);   opacity: .3; }
	40%           { transform: scale(1);   opacity: 1;  }
}

/* =========================================================================
   Komunikat końcowy
   ========================================================================= */
.seo-audit-final-message {
	text-align: center;
	padding: 20px;
	margin-top: 8px;
	border-radius: var(--seo-radius);
	font-size: 1rem;
	font-weight: 600;
}
