/*
Theme Name:   Andys Tennisschule
Theme URI:    https://andys-tennisschule.com
Description:  Eigenständiges Custom-Theme für Andys Tennisschule. Platzgrün, Optikgelb, Courtlinien-Signatur. Integriert das Plugin "Andys Camps".
Author:       Andys Tennisschule
Version:      1.0.0
Requires PHP: 7.4
Text Domain:  andys-theme
*/

/* ==========================================================================
   Tokens
   ========================================================================== */
:root {
	--court: #16302b;        /* Platzgrün, dunkel */
	--court-deep: #0e211d;   /* Schattenstufe */
	--optic: #d8f031;        /* Tennisball-Optikgelb */
	--clay: #c4593a;         /* Sandplatz – für Camp-Badges */
	--paper: #fafaf7;        /* Hintergrund */
	--ink: #14201c;          /* Text */
	--line: #dfe3dc;         /* Hairlines */

	--font-display: "Archivo", system-ui, sans-serif;
	--font-body: "Archivo", system-ui, sans-serif;
	--font-mono: "IBM Plex Mono", ui-monospace, monospace;

	--maxw: 1120px;
	--radius: 6px;
}

/* ==========================================================================
   Basis
   ========================================================================== */
* { box-sizing: border-box; }

body {
	margin: 0;
	background: var(--paper);
	color: var(--ink);
	font-family: var(--font-body);
	font-size: 1.0625rem;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; }

.wrap {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0 1.25rem;
}

/* Headlines mit „Grundlinie“ – die Signatur des Themes */
h1, h2, h3 {
	font-family: var(--font-display);
	font-weight: 800;
	letter-spacing: -0.015em;
	line-height: 1.12;
	text-wrap: balance;
}

h2.baseline {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	text-transform: uppercase;
	display: inline-block;
	padding-bottom: 0.35rem;
	border-bottom: 6px solid var(--optic);
	margin: 0 0 1.5rem;
}

.eyebrow {
	font-family: var(--font-mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--clay);
	margin: 0 0 0.5rem;
}

/* Buttons */
.btn {
	display: inline-block;
	font-family: var(--font-display);
	font-weight: 700;
	text-decoration: none;
	padding: 0.8em 1.8em;
	border-radius: var(--radius);
	background: var(--optic);
	color: var(--court-deep);
	border: 2px solid var(--optic);
	transition: transform 0.12s ease;
}

.btn:hover, .btn:focus-visible { transform: translateY(-2px); }

.btn--ghost {
	background: transparent;
	color: var(--optic);
}

:focus-visible { outline: 3px solid var(--optic); outline-offset: 2px; }

/* ==========================================================================
   Header
   ========================================================================== */
.site-header {
	background: var(--court);
	color: #fff;
	position: sticky;
	top: 0;
	z-index: 50;
	border-bottom: 3px solid var(--optic);
}

.site-header .wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	min-height: 68px;
}

.site-brand {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 1.15rem;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	text-decoration: none;
	color: #fff;
}

.site-brand em {
	font-style: normal;
	color: var(--optic);
}

.site-nav ul {
	list-style: none;
	display: flex;
	gap: 1.5rem;
	margin: 0;
	padding: 0;
}

.site-nav a {
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95rem;
	color: #fff;
	padding: 0.4em 0;
	border-bottom: 3px solid transparent;
}

.site-nav a:hover,
.site-nav .current-menu-item > a {
	border-bottom-color: var(--optic);
}

.nav-toggle { display: none; }

@media (max-width: 760px) {
	.nav-toggle {
		display: inline-flex;
		background: none;
		border: 2px solid var(--optic);
		border-radius: var(--radius);
		color: var(--optic);
		font: inherit;
		font-weight: 700;
		padding: 0.35em 0.8em;
		cursor: pointer;
	}
	.site-nav { display: none; width: 100%; }
	.site-nav.is-open { display: block; padding-bottom: 1rem; }
	.site-nav ul { flex-direction: column; gap: 0.25rem; }
	.site-header .wrap { flex-wrap: wrap; }
}

/* ==========================================================================
   Hero – Courtlinien als Bühne
   ========================================================================== */
.hero {
	background:
		/* Courtlinien: Mittellinie + Aufschlaglinien, dezent */
		linear-gradient(90deg, transparent calc(50% - 1px), rgba(255,255,255,0.14) calc(50% - 1px), rgba(255,255,255,0.14) calc(50% + 1px), transparent calc(50% + 1px)),
		linear-gradient(0deg, transparent 118px, rgba(255,255,255,0.14) 118px, rgba(255,255,255,0.14) 120px, transparent 120px),
		var(--court);
	color: #fff;
	padding: clamp(4rem, 10vw, 7.5rem) 0 clamp(3.5rem, 8vw, 6rem);
	position: relative;
	overflow: hidden;
}

.hero::after { /* Grundlinie unten */
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 10px;
	background: var(--optic);
}

.hero h1 {
	font-size: clamp(2.4rem, 7vw, 4.5rem);
	text-transform: uppercase;
	margin: 0 0 0.75rem;
	max-width: 14ch;
}

.hero h1 em {
	font-style: normal;
	color: var(--optic);
}

.hero p {
	font-size: clamp(1.05rem, 2vw, 1.3rem);
	max-width: 44ch;
	margin: 0 0 2rem;
	color: rgba(255,255,255,0.85);
}

.hero .btn + .btn { margin-left: 0.75rem; }

/* ==========================================================================
   Sektionen
   ========================================================================== */
.section { padding: clamp(3rem, 7vw, 5.5rem) 0; }
.section--alt { background: #f1f3ee; }

/* Angebote */
.offers {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
	gap: 1.25rem;
	margin-top: 1rem;
}

.offer {
	background: #fff;
	border: 1px solid var(--line);
	border-top: 5px solid var(--court);
	border-radius: var(--radius);
	padding: 1.4rem 1.4rem 1.5rem;
}

.offer h3 { margin: 0 0 0.5rem; font-size: 1.15rem; text-transform: uppercase; }
.offer p { margin: 0; font-size: 0.97rem; color: #3c4a44; }

/* Camps – Anzeigetafel-Optik */
.camps { display: grid; gap: 1rem; margin-top: 1rem; }

.camp-card {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem 1.5rem;
	background: var(--court);
	color: #fff;
	border-radius: var(--radius);
	padding: 1.25rem 1.5rem;
	text-decoration: none;
	border-left: 8px solid var(--clay);
}

.camp-card:hover { background: var(--court-deep); }

.camp-card .camp-date {
	font-family: var(--font-mono);
	font-size: 0.95rem;
	color: var(--optic);
	min-width: 15ch;
}

.camp-card .camp-title {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 1.2rem;
	flex: 1;
}

.camp-card .camp-meta {
	font-family: var(--font-mono);
	font-size: 0.85rem;
	color: rgba(255,255,255,0.8);
}

.camp-card .camp-cta {
	font-weight: 700;
	color: var(--optic);
	white-space: nowrap;
}

/* Kontakt */
.contact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.5rem;
	margin-top: 1rem;
}

.contact-grid .label {
	font-family: var(--font-mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--clay);
	margin-bottom: 0.25rem;
}

/* ==========================================================================
   Inhalt / Blog / Seiten
   ========================================================================== */
.entry { padding: clamp(2.5rem, 6vw, 4rem) 0; }
.entry-content { max-width: 72ch; }
.entry h1 { font-size: clamp(2rem, 5vw, 3rem); }

.camp-facts {
	font-family: var(--font-mono);
	background: #fff;
	border: 1px solid var(--line);
	border-left: 8px solid var(--optic);
	border-radius: var(--radius);
	padding: 1rem 1.25rem;
	margin: 1.5rem 0;
	display: grid;
	gap: 0.35rem;
	max-width: 480px;
	font-size: 0.95rem;
}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer {
	background: var(--court-deep);
	color: rgba(255,255,255,0.75);
	padding: 2.5rem 0;
	margin-top: 3rem;
	border-top: 6px solid var(--optic);
	font-size: 0.92rem;
}

.site-footer .wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1rem;
}

.site-footer a { color: #fff; }

/* ==========================================================================
   Preise – Anzeigetafel-Optik
   ========================================================================== */
.price-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.25rem;
	margin: 1.5rem 0;
}

.price-card {
	background: #fff;
	border: 1px solid var(--line);
	border-top: 5px solid var(--court);
	border-radius: var(--radius);
	padding: 1.4rem;
}

.price-card h2 {
	margin: 0 0 0.15rem;
	font-size: 1.2rem;
	text-transform: uppercase;
}

.price-card__note {
	font-family: var(--font-mono);
	font-size: 0.8rem;
	color: var(--clay);
	margin: 0 0 1rem;
}

.price-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.97rem;
}

.price-table td {
	padding: 0.55em 0;
	border-bottom: 1px dashed var(--line);
}

.price-table tr:last-child td { border-bottom: 0; }

.price-table td.price {
	text-align: right;
	font-family: var(--font-mono);
	font-weight: 600;
	white-space: nowrap;
}

.price-footnote {
	font-size: 0.9rem;
	color: #4c5a53;
	max-width: 60ch;
}

/* ==========================================================================
   Galerie
   ========================================================================== */
.gallery-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 0.75rem;
	margin-top: 1.5rem;
}

.gallery-item {
	display: block;
	border-radius: var(--radius);
	overflow: hidden;
	border-bottom: 4px solid var(--optic);
}

.gallery-item img {
	width: 100%;
	height: 220px;
	object-fit: cover;
	transition: transform 0.2s ease;
}

.gallery-item:hover img,
.gallery-item:focus-visible img {
	transform: scale(1.03);
}

.entry-content--gallery .wp-block-gallery { margin-top: 1.5rem; }

/* Formulare im Fliesstext linksbündig statt zentriert */
.ac-form--left { margin: 0; }

/* ==========================================================================
   Reduced motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
	* { transition: none !important; }
}
