/**
 * GREKO Elektro Modern – main.css
 * Ergänzende Styles für WordPress-Inhaltsbereiche
 */

/* ============================================================
   WORDPRESS CORE
   ============================================================ */
.wp-caption {
	max-width: 100%;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-sm);
}
.wp-caption img { display: block; width: 100%; }
.wp-caption-text {
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
	text-align: center;
	padding: var(--space-xs) 0 0;
}

.alignleft  { float: left;  margin: 0 var(--space-xl) var(--space-lg) 0; }
.alignright { float: right; margin: 0 0 var(--space-lg) var(--space-xl); }
.aligncenter { display: block; margin: 0 auto var(--space-lg); }
.alignfull   { width: 100vw; margin-left: calc(50% - 50vw); }

/* ============================================================
   PAGE CONTENT (für normale Seiten/Beiträge)
   ============================================================ */
.page-content h2,
.entry-content h2 { font-size: var(--fs-3xl); margin: var(--space-2xl) 0 var(--space-md); }
.page-content h3,
.entry-content h3 { font-size: var(--fs-2xl); margin: var(--space-xl) 0 var(--space-sm); }
.page-content h4,
.entry-content h4 { font-size: var(--fs-xl);  margin: var(--space-lg) 0 var(--space-sm); }

.page-content ul,
.entry-content ul { list-style: disc; padding-left: var(--space-xl); margin-bottom: var(--space-md); }
.page-content ol,
.entry-content ol { list-style: decimal; padding-left: var(--space-xl); margin-bottom: var(--space-md); }
.page-content li,
.entry-content li { margin-bottom: var(--space-xs); }

.page-content a,
.entry-content a { color: var(--color-primary); text-decoration: underline; }
.page-content a:hover,
.entry-content a:hover { color: var(--color-primary-dark); }

.page-content blockquote,
.entry-content blockquote {
	border-left: 4px solid var(--color-primary);
	padding: var(--space-md) var(--space-lg);
	margin: var(--space-xl) 0;
	background: rgba(245,168,0,0.05);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	color: var(--color-text-muted);
	font-style: italic;
}

.page-content table,
.entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--space-xl);
}
.page-content th,
.entry-content th {
	background: var(--color-dark);
	color: #fff;
	padding: var(--space-sm) var(--space-md);
	text-align: left;
	font-size: var(--fs-sm);
}
.page-content td,
.entry-content td {
	padding: var(--space-sm) var(--space-md);
	border-bottom: 1px solid var(--color-border);
	font-size: var(--fs-sm);
}
.page-content tr:nth-child(even) td,
.entry-content tr:nth-child(even) td {
	background: var(--color-bg);
}

/* ============================================================
   WIDGET-BEREICH
   ============================================================ */
.widget { margin-bottom: var(--space-2xl); }
.widget-title {
	font-size: var(--fs-base);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-dark);
	margin-bottom: var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 2px solid var(--color-primary);
}
.widget ul { display: flex; flex-direction: column; gap: var(--space-xs); }
.widget ul a { color: var(--color-text); font-size: var(--fs-sm); }
.widget ul a:hover { color: var(--color-primary); }

/* ============================================================
   PAGINATION
   ============================================================ */
.nav-links, .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	margin-top: var(--space-2xl);
	flex-wrap: wrap;
}
.page-numbers a,
.page-numbers span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-md);
	font-size: var(--fs-sm);
	font-weight: 600;
	border: 1px solid var(--color-border);
	color: var(--color-text);
	transition: all var(--transition-fast);
}
.page-numbers a:hover { background: var(--color-primary); color: var(--color-dark); border-color: var(--color-primary); }
.page-numbers .current { background: var(--color-primary); color: var(--color-dark); border-color: var(--color-primary); }

/* ============================================================
   SEARCH FORM
   ============================================================ */
.search-form {
	display: flex;
	gap: var(--space-sm);
}
.search-field {
	flex: 1;
	padding: 0.6rem var(--space-md);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-full);
	font-size: var(--fs-sm);
	transition: border-color var(--transition-fast);
}
.search-field:focus { border-color: var(--color-primary); outline: none; }
.search-submit {
	background: var(--color-primary);
	color: var(--color-dark);
	border: none;
	padding: 0.6rem 1.25rem;
	border-radius: var(--radius-full);
	font-weight: 700;
	cursor: pointer;
	font-size: var(--fs-sm);
	transition: background var(--transition-fast);
}
.search-submit:hover { background: var(--color-primary-dark); }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
:focus-visible {
	outline: 3px solid var(--color-primary);
	outline-offset: 3px;
	border-radius: var(--radius-sm);
}
.screen-reader-text {
	position: absolute;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	width: 1px; height: 1px;
	overflow: hidden;
	white-space: nowrap;
}

/* ============================================================
   PRODUKTE – Archiv-Seite
   ============================================================ */
.taxonomy-filter {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	margin-bottom: var(--space-2xl);
	justify-content: center;
}
.taxonomy-filter a {
	padding: 0.4rem 1.1rem;
	border-radius: var(--radius-full);
	font-size: var(--fs-sm);
	font-weight: 600;
	border: 2px solid var(--color-border);
	color: var(--color-text-muted);
	transition: all var(--transition-fast);
}
.taxonomy-filter a:hover,
.taxonomy-filter a.active {
	background: var(--color-primary);
	color: var(--color-dark);
	border-color: var(--color-primary);
}

/* ============================================================
   LOADING STATE
   ============================================================ */
@keyframes spin { to { transform: rotate(360deg); } }
.loading-spinner {
	width: 24px; height: 24px;
	border: 3px solid rgba(245,168,0,0.3);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 0.7s linear infinite;
	display: inline-block;
	vertical-align: middle;
}
