/*
Theme Name:   Hello Elementor Child – TC Zell
Theme URI:    https://tczell.ch
Description:  Child-Theme für tczell.ch mit dem TC-Zell-Designsystem.
Author:       codeflux GmbH
Author URI:   https://codeflux.ch
Template:     hello-elementor
Version:      1.0.0
Text Domain:  hello-elementor-child-tczell
License:      GPL-2.0-or-later
*/

/* HINWEIS: In dieser Variante liegt das komplette Designsystem direkt hier
   in der style.css (globales CSS + WooCommerce). Es wird automatisch über
   den Child-Theme-Stylesheet geladen – KEINE separaten Asset-CSS-Dateien
   nötig. Die functions.php lädt daher bewusst keine zusätzlichen CSS-Dateien.
   Bei Änderungen die Version oben hochzählen (Cache-Busting). */

/* =================================================================
   TC ZELL – GLOBALES DESIGNSYSTEM
   Datei: assets/css/tczell-global.css
   Basis: Hello Elementor + Elementor Pro
   Alle Komponenten sind über .tcz-* Klassen ansprechbar und können
   in Elementor im Feld "Erweitert > CSS-Klassen" zugewiesen werden.
   ================================================================= */

/* -----------------------------------------------------------------
   1) DESIGN TOKENS
   ----------------------------------------------------------------- */
:root {
	/* Farben */
	--tcz-navy:        #04284a;
	--tcz-navy-dark:   #001b33;
	--tcz-lime:        #b7d900;
	--tcz-lime-dark:   #9ec000;
	--tcz-green:       #2f7d32;
	--tcz-white:       #ffffff;
	--tcz-light:       #f7f9fb;
	--tcz-border:      #dce3ea;
	--tcz-text:        #08213f;
	--tcz-muted:       #617086;

	/* Radien */
	--tcz-radius-sm:   8px;
	--tcz-radius-md:   16px;
	--tcz-radius-lg:   28px;
	--tcz-radius-pill: 999px;

	/* Schatten */
	--tcz-shadow-card: 0 10px 30px rgba(0, 31, 63, 0.10);
	--tcz-shadow-soft: 0 4px 14px rgba(0, 31, 63, 0.08);
	--tcz-shadow-btn:  0 6px 18px rgba(183, 217, 0, 0.35);

	/* Typografie */
	--tcz-font-head:   "Oswald", "Inter", system-ui, sans-serif;
	--tcz-font-body:   "Inter", "Open Sans", system-ui, sans-serif;

	/* Layout */
	--tcz-container:   1200px;
	--tcz-gap:         24px;
	--tcz-section-y:   80px;

	/* Brush-Assets (austauschbar – eigene PNG/SVG einsetzbar) */
	--tcz-brush-underline: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 22'%3E%3Cpath d='M5 15 C55 4 150 21 215 7' fill='none' stroke='%23b7d900' stroke-width='8' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* -----------------------------------------------------------------
   2) BASIS & TYPOGRAFIE
   ----------------------------------------------------------------- */
body.tcz-theme {
	font-family: var(--tcz-font-body);
	color: var(--tcz-text);
	background: var(--tcz-white);
	-webkit-font-smoothing: antialiased;
}

/* Headings/Texte werden NUR innerhalb der .tcz-Komponenten gestylt – nie auf
   nackten Tags unter .tcz-theme. Sonst überschreibt das CSS die Elementor-
   eigenen Einstellungen (Grösse + Farbe) in Header, Footer und Widgets. */
.tcz-hero h1,
.tcz-heading-brush,
.tcz-join__intro h2 {
	font-family: var(--tcz-font-head);
	line-height: 1.1;
	letter-spacing: 0.01em;
}
.tcz-hero h1        { font-size: clamp(2.4rem, 6vw, 4.4rem); font-weight: 700; }
.tcz-heading-brush  { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 600; color: var(--tcz-navy); }
.tcz-join__intro h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 600; }

.tcz-theme p { line-height: 1.65; }

/* Sektions-Wrapper */
.tcz-section {
	padding-top: var(--tcz-section-y);
	padding-bottom: var(--tcz-section-y);
}
.tcz-section--light { background: var(--tcz-light); }
.tcz-section--navy  { background: var(--tcz-navy); color: var(--tcz-white); }

.tcz-container {
	width: 100%;
	max-width: var(--tcz-container);
	margin-inline: auto;
	padding-inline: 20px;
}

/* Zentrierter Sektionstitel mit Lime-Brush-Unterstrich */
.tcz-section-title {
	text-align: center;
	margin-bottom: 48px;
}
.tcz-heading-brush {
	display: inline-block;
	position: relative;
	padding-bottom: 18px;
}
.tcz-heading-brush::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: clamp(120px, 40%, 220px);
	height: 18px;
	background: var(--tcz-brush-underline) no-repeat center / contain;
}

/* -----------------------------------------------------------------
   3) BUTTONS
   ----------------------------------------------------------------- */
.tcz-button,
.tcz-theme .tcz-button-primary,
.tcz-theme .tcz-button-secondary {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--tcz-font-head);
	font-weight: 600;
	font-size: 1.05rem;
	letter-spacing: 0.02em;
	padding: 15px 30px;
	border-radius: var(--tcz-radius-pill);
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease;
}

.tcz-button-primary {
	background: var(--tcz-lime);
	color: var(--tcz-navy);
	box-shadow: var(--tcz-shadow-btn);
}
.tcz-button-primary:hover,
.tcz-button-primary:focus-visible {
	background: var(--tcz-lime-dark);
	transform: translateY(-2px);
}

.tcz-button-secondary {
	background: transparent;
	color: var(--tcz-white);
	border-color: rgba(255, 255, 255, 0.55);
}
.tcz-button-secondary:hover,
.tcz-button-secondary:focus-visible {
	background: var(--tcz-white);
	color: var(--tcz-navy);
	border-color: var(--tcz-white);
}
/* Sekundär-Variante auf hellem Grund */
.tcz-section--light .tcz-button-secondary,
.tcz-button-secondary--dark {
	color: var(--tcz-navy);
	border-color: var(--tcz-navy);
}
.tcz-section--light .tcz-button-secondary:hover,
.tcz-button-secondary--dark:hover {
	background: var(--tcz-navy);
	color: var(--tcz-white);
}

.tcz-button__icon { font-size: 1.1em; line-height: 1; }

/* Navy-Pill (z. B. "Alle Neuigkeiten ansehen") */
.tcz-button-navy {
	background: var(--tcz-navy);
	color: var(--tcz-white);
}
.tcz-button-navy:hover { background: var(--tcz-navy-dark); }

/* -----------------------------------------------------------------
   4) BRUSH-FLÄCHEN
   Navy-Card mit grob wirkender Kante. Für pixelgenaue Optik kann
   --tcz-brush-mask durch eine eigene Brush-PNG/SVG ersetzt werden.
   ----------------------------------------------------------------- */
.tcz-brush-bg {
	position: relative;
	background: var(--tcz-navy);
	color: var(--tcz-white);
	border-radius: var(--tcz-radius-lg);
	/* leicht unregelmässige Kante als CSS-only-Annäherung */
	clip-path: polygon(
		2% 0%, 98% 1%, 100% 6%, 99% 50%, 100% 94%,
		97% 100%, 4% 99%, 0% 95%, 1% 48%, 0% 5%
	);
	overflow: hidden;
}
/* dezenter Tennisball als Wasserzeichen (optional, swappable) */
.tcz-brush-bg::before {
	content: "";
	position: absolute;
	left: -40px;
	bottom: -40px;
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background:
		radial-gradient(circle at 35% 35%, rgba(183,217,0,.18), rgba(183,217,0,0) 70%);
	pointer-events: none;
}

/* -----------------------------------------------------------------
   5) HEADER (Elementor Pro Theme Builder)
   Farben/Abstände werden in Elementor gesetzt – hier nur Feinschliff:
   Sticky-Shadow, CTA-Pill, Fokuszustände.
   ----------------------------------------------------------------- */
.tcz-header {
	background: var(--tcz-white);
	transition: box-shadow .2s ease;
}
.tcz-header.tcz-is-stuck {
	box-shadow: var(--tcz-shadow-soft);
}
/* CTA-Pill im Header */
.tcz-header .tcz-button-primary { padding: 11px 22px; font-size: 0.98rem; }

/* Nav-Links Hover/Active (falls über CSS-Klasse .tcz-nav am Menü) */
.tcz-nav a { font-family: var(--tcz-font-head); font-weight: 500; color: var(--tcz-navy); }
.tcz-nav a:hover,
.tcz-nav a[aria-current="page"] { color: var(--tcz-lime-dark); }

/* -----------------------------------------------------------------
   6) HERO
   ----------------------------------------------------------------- */
.tcz-hero {
	position: relative;
	color: var(--tcz-white);
	overflow: hidden;
}
/* Navy-Panel links über dem Bild */
.tcz-hero__panel {
	background: var(--tcz-navy);
	padding: clamp(40px, 6vw, 90px);
	position: relative;
	z-index: 2;
}
/* Brush-Übergang zum Bild (rechte Kante des Navy-Panels) */
.tcz-hero__panel::after {
	content: "";
	position: absolute;
	top: 0;
	right: -38px;
	width: 70px;
	height: 100%;
	background: var(--tcz-navy);
	clip-path: polygon(0 0, 60% 0, 35% 12%, 70% 26%, 30% 40%, 75% 55%, 25% 70%, 65% 85%, 40% 100%, 0 100%);
	z-index: 2;
}
.tcz-hero h1 { color: var(--tcz-white); margin-bottom: 0.15em; }
/* zweite Zeile der Headline in Lime */
.tcz-hero h1 .tcz-accent { color: var(--tcz-lime); display: block; }
.tcz-hero__sub {
	font-family: var(--tcz-font-head);
	font-weight: 500;
	font-size: clamp(1.2rem, 2.6vw, 1.8rem);
	color: var(--tcz-white);
	position: relative;
	display: inline-block;
	padding-bottom: 14px;
	margin-bottom: 18px;
}
.tcz-hero__sub::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 70%; height: 14px;
	background: var(--tcz-brush-underline) no-repeat left / contain;
}
.tcz-hero__lead { max-width: 46ch; color: rgba(255,255,255,.92); margin-bottom: 28px; }
.tcz-hero__actions { display: flex; flex-wrap: wrap; gap: 16px; }

/* -----------------------------------------------------------------
   7) VORTEIL-LEISTE (überlappt den Hero)
   ----------------------------------------------------------------- */
.tcz-benefit-bar {
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	box-shadow: var(--tcz-shadow-card);
	padding: 28px clamp(20px, 4vw, 48px);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(16px, 3vw, 40px);
	/* in Elementor: negativer oberer Rand für Überlappung setzen */
}
.tcz-benefit {
	display: flex;
	align-items: center;
	gap: 16px;
}
.tcz-benefit + .tcz-benefit { border-left: 1px solid var(--tcz-border); padding-left: clamp(16px, 3vw, 40px); }
.tcz-benefit__icon {
	flex: 0 0 auto;
	width: 56px; height: 56px;
	border-radius: 50%;
	display: grid; place-items: center;
	background: var(--tcz-navy);
	color: var(--tcz-lime);
	font-size: 1.5rem;
}
.tcz-benefit__title { font-family: var(--tcz-font-head); font-weight: 600; color: var(--tcz-navy); margin: 0; }
.tcz-benefit__text  { margin: 2px 0 0; color: var(--tcz-muted); font-size: 0.95rem; }

/* -----------------------------------------------------------------
   8) KARTEN-RASTER ("Warum TC Zell?")
   ----------------------------------------------------------------- */
.tcz-card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--tcz-gap);
}
.tcz-card {
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	box-shadow: var(--tcz-shadow-card);
	padding: 30px 26px;
	transition: transform .2s ease, box-shadow .2s ease;
}
.tcz-card:hover { transform: translateY(-4px); box-shadow: 0 16px 38px rgba(0,31,63,.14); }
.tcz-card__icon {
	width: 54px; height: 54px;
	display: grid; place-items: center;
	color: var(--tcz-navy);
	margin-bottom: 16px;
	font-size: 1.6rem;
}
.tcz-card__icon svg { width: 32px; height: 32px; }
.tcz-card__title { font-size: 1.15rem; color: var(--tcz-navy); margin-bottom: 8px; }
.tcz-card__text  { color: var(--tcz-muted); font-size: 0.96rem; margin: 0; }

/* -----------------------------------------------------------------
   9) PROBEMITGLIED-FORMULARBEREICH
   ----------------------------------------------------------------- */
.tcz-join {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: clamp(24px, 4vw, 48px);
	align-items: stretch;
}
.tcz-join__intro {
	padding: clamp(32px, 4vw, 56px);
}
.tcz-join__intro h2 { color: var(--tcz-white); }
.tcz-join__intro p  { color: rgba(255,255,255,.9); }

.tcz-join__form {
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-lg);
	box-shadow: var(--tcz-shadow-card);
	padding: clamp(28px, 3.5vw, 44px);
}

/* Elementor Forms im TC-Zell-Stil (Klasse .tcz-form am Form-Widget) */
.tcz-form .elementor-field-group { margin-bottom: 16px; }
.tcz-form .elementor-field-group > .elementor-field,
.tcz-form input[type="text"],
.tcz-form input[type="email"],
.tcz-form input[type="tel"],
.tcz-form select,
.tcz-form textarea {
	width: 100%;
	background: var(--tcz-light);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-sm);
	padding: 14px 16px;
	font-family: var(--tcz-font-body);
	font-size: 1rem;
	color: var(--tcz-text);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.tcz-form input:focus,
.tcz-form select:focus,
.tcz-form textarea:focus {
	outline: none;
	border-color: var(--tcz-lime-dark);
	box-shadow: 0 0 0 3px rgba(183,217,0,.25);
}
.tcz-form ::placeholder { color: var(--tcz-muted); opacity: 1; }
.tcz-form textarea { min-height: 120px; resize: vertical; }

/* Submit-Button (Elementor Forms) */
.tcz-form .elementor-button[type="submit"],
.tcz-form button[type="submit"] {
	width: 100%;
	justify-content: center;
	background: var(--tcz-lime);
	color: var(--tcz-navy);
	font-family: var(--tcz-font-head);
	font-weight: 600;
	font-size: 1.05rem;
	border: none;
	border-radius: var(--tcz-radius-pill);
	padding: 15px 24px;
	box-shadow: var(--tcz-shadow-btn);
	transition: background-color .18s ease, transform .18s ease;
}
.tcz-form .elementor-button[type="submit"]:hover { background: var(--tcz-lime-dark); transform: translateY(-2px); }

/* -----------------------------------------------------------------
   10) NEUIGKEITEN / NEWS-CARDS
   (greift auch im Elementor Posts/Loop-Widget über .tcz-news)
   ----------------------------------------------------------------- */
.tcz-news-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--tcz-gap);
}
.tcz-news-card {
	display: flex;
	flex-direction: column;
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	box-shadow: var(--tcz-shadow-card);
	overflow: hidden;
	transition: transform .2s ease, box-shadow .2s ease;
}
.tcz-news-card:hover { transform: translateY(-4px); box-shadow: 0 16px 38px rgba(0,31,63,.14); }
.tcz-news-card__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.tcz-news-card__media img { width: 100%; height: 100%; object-fit: cover; }
.tcz-news-card__badge {
	position: absolute;
	top: 12px; right: 12px;
	background: var(--tcz-green);
	color: var(--tcz-white);
	font-family: var(--tcz-font-head);
	font-weight: 600;
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 5px 12px;
	border-radius: var(--tcz-radius-pill);
}
.tcz-news-card__badge--event { background: var(--tcz-green); }
.tcz-news-card__body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.tcz-news-card__title { font-size: 1.1rem; color: var(--tcz-navy); margin-bottom: 10px; }
.tcz-news-card__excerpt { color: var(--tcz-muted); font-size: 0.95rem; margin-bottom: 16px; }
.tcz-news-card__more {
	font-family: var(--tcz-font-head);
	font-weight: 600;
	color: var(--tcz-navy);
	text-decoration: none;
	display: inline-flex; align-items: center; gap: 6px;
}
.tcz-news-card__more:hover { color: var(--tcz-lime-dark); }
.tcz-news-card__foot {
	margin-top: auto;
	padding-top: 14px;
	border-top: 1px solid var(--tcz-border);
	display: flex; align-items: center; gap: 8px;
	color: var(--tcz-muted); font-size: 0.85rem;
}

/* -----------------------------------------------------------------
   11) TENNISTRAINING
   ----------------------------------------------------------------- */
.tcz-training { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 56px); align-items: center; }
.tcz-training__media img { width: 100%; border-radius: var(--tcz-radius-md); box-shadow: var(--tcz-shadow-card); }
.tcz-training__contact { display: flex; flex-wrap: wrap; gap: 14px 28px; margin-top: 18px; }
.tcz-training__contact a {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--tcz-font-head); font-weight: 600;
	color: var(--tcz-navy); text-decoration: none;
}
.tcz-training__contact a:hover { color: var(--tcz-lime-dark); }

/* -----------------------------------------------------------------
   12) SPONSOREN-LEISTE (Shortcode [tcz_sponsors])
   ----------------------------------------------------------------- */
.tcz-sponsors { --tcz-sponsor-h: 56px; --tcz-sponsor-speed: 30s; text-align: center; }
.tcz-sponsors__title { font-size: 1.3rem; margin-bottom: 24px; }
.tcz-sponsors__viewport { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.tcz-sponsors__track {
	display: flex; align-items: center; gap: 56px;
	list-style: none; margin: 0; padding: 0; width: max-content;
	animation: tcz-marquee var(--tcz-sponsor-speed) linear infinite;
}
.tcz-sponsors__viewport:hover .tcz-sponsors__track,
.tcz-sponsors__viewport:focus-within .tcz-sponsors__track { animation-play-state: paused; }
.tcz-sponsors__item { flex: 0 0 auto; }
.tcz-sponsors__logo { height: var(--tcz-sponsor-h); width: auto; object-fit: contain; filter: grayscale(1); opacity: .75; transition: filter .2s, opacity .2s; }
.tcz-sponsors__logo:hover { filter: none; opacity: 1; }
@keyframes tcz-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* -----------------------------------------------------------------
   13) FOOTER (Elementor Pro)
   ----------------------------------------------------------------- */
.tcz-footer { background: var(--tcz-navy); color: rgba(255,255,255,.82); }
.tcz-footer a { color: rgba(255,255,255,.82); text-decoration: none; }
.tcz-footer a:hover { color: var(--tcz-lime); }
.tcz-footer__claim { font-family: var(--tcz-font-head); font-weight: 600; color: var(--tcz-white); font-size: 1.4rem; line-height: 1.1; }
.tcz-footer__claim .tcz-accent { color: var(--tcz-lime); }
.tcz-footer__label { font-family: var(--tcz-font-head); color: var(--tcz-white); letter-spacing: .04em; text-transform: uppercase; font-size: .85rem; margin-bottom: 10px; }
.tcz-footer__bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 16px 0; font-size: .82rem; }

/* -----------------------------------------------------------------
   14) NEWS-ARCHIV / SINGLE (Theme-Builder Templates)
   ----------------------------------------------------------------- */
.tcz-post-hero { background: var(--tcz-navy); color: var(--tcz-white); padding: clamp(48px, 7vw, 96px) 0 clamp(40px, 6vw, 72px); }
.tcz-post-hero h1 { color: var(--tcz-white); }
.tcz-post-meta { display: flex; flex-wrap: wrap; gap: 10px 22px; color: rgba(255,255,255,.8); font-size: .9rem; }
.tcz-post-content { max-width: 760px; margin-inline: auto; }
.tcz-post-content img { border-radius: var(--tcz-radius-md); }
.tcz-back-link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--tcz-font-head); font-weight: 600; color: var(--tcz-navy); text-decoration: none; }
.tcz-back-link:hover { color: var(--tcz-lime-dark); }

/* -----------------------------------------------------------------
   15) ACCESSIBILITY
   ----------------------------------------------------------------- */
.tcz-theme a:focus-visible,
.tcz-theme button:focus-visible,
.tcz-theme input:focus-visible,
.tcz-theme select:focus-visible,
.tcz-theme textarea:focus-visible,
.tcz-theme .tcz-button:focus-visible {
	outline: 3px solid var(--tcz-lime-dark);
	outline-offset: 2px;
}
.tcz-skip-link {
	position: absolute; left: -9999px;
	background: var(--tcz-navy); color: #fff;
	padding: 10px 16px; border-radius: var(--tcz-radius-sm); z-index: 1000;
}
.tcz-skip-link:focus { left: 16px; top: 16px; }

@media (prefers-reduced-motion: reduce) {
	.tcz-sponsors__track { animation: none; }
	.tcz-card, .tcz-news-card, .tcz-button { transition: none; }
}

/* -----------------------------------------------------------------
   16) RESPONSIVE BREAKPOINTS
   Desktop  ab 1200px  (Default oben)
   Tablet   768–1199px
   Mobile   bis 767px
   ----------------------------------------------------------------- */
@media (max-width: 1199px) {
	:root { --tcz-section-y: 64px; }
	.tcz-card-grid { grid-template-columns: repeat(2, 1fr); }
	.tcz-news-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 767px) {
	:root { --tcz-section-y: 48px; }

	/* Hero gestapelt */
	.tcz-hero__panel::after { display: none; }

	/* Vorteil-Leiste 1 Spalte */
	.tcz-benefit-bar { grid-template-columns: 1fr; }
	.tcz-benefit + .tcz-benefit { border-left: none; padding-left: 0; border-top: 1px solid var(--tcz-border); padding-top: 16px; }

	/* Raster 1 Spalte */
	.tcz-card-grid,
	.tcz-news-grid,
	.tcz-join,
	.tcz-training { grid-template-columns: 1fr; }

	/* Formular volle Breite */
	.tcz-join__form { padding: 24px; }

	/* Buttons gut antippbar */
	.tcz-button, .tcz-button-primary, .tcz-button-secondary { width: 100%; justify-content: center; }
	.tcz-hero__actions { flex-direction: column; }
}
/* =================================================================
   TC ZELL – WOOCOMMERCE STYLING
   Datei: assets/css/tczell-woocommerce.css
   Wird nur geladen, wenn WooCommerce aktiv ist.
   Greift auf die Tokens aus tczell-global.css zu.
   ================================================================= */

/* -----------------------------------------------------------------
   1) SHOP-ARCHIV / PRODUKT-RASTER
   ----------------------------------------------------------------- */
.tcz-theme.woocommerce ul.products,
.tcz-theme .woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--tcz-gap);
	margin: 0;
	padding: 0;
	list-style: none;
}
.tcz-theme .woocommerce ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	box-shadow: var(--tcz-shadow-card);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .2s ease, box-shadow .2s ease;
}
.tcz-theme .woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 38px rgba(0,31,63,.14);
}
.tcz-theme .woocommerce ul.products li.product a img {
	margin: 0;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}
.tcz-theme .woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--tcz-font-head);
	font-weight: 600;
	font-size: 1.05rem;
	color: var(--tcz-navy);
	padding: 18px 18px 4px;
}
.tcz-theme .woocommerce ul.products li.product .price {
	display: block;
	color: var(--tcz-navy);
	font-weight: 700;
	padding: 0 18px 12px;
}
.tcz-theme .woocommerce ul.products li.product .price del { color: var(--tcz-muted); font-weight: 400; }
.tcz-theme .woocommerce ul.products li.product .price ins { text-decoration: none; }

/* Produktkarten-Button (CTA) */
.tcz-theme .woocommerce ul.products li.product .button {
	margin: auto 18px 18px;
	text-align: center;
}

/* Sale-Badge im CI-Stil */
.tcz-theme .woocommerce span.onsale {
	background: var(--tcz-lime);
	color: var(--tcz-navy);
	font-family: var(--tcz-font-head);
	font-weight: 600;
	border-radius: var(--tcz-radius-pill);
	min-height: auto;
	min-width: auto;
	padding: 5px 12px;
	top: 12px; left: 12px;
	margin: 0;
	line-height: 1.2;
}

/* -----------------------------------------------------------------
   2) BUTTONS (alle Woo-Buttons im TC-Zell-Lime)
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce a.button,
.tcz-theme .woocommerce button.button,
.tcz-theme .woocommerce input.button,
.tcz-theme .woocommerce #respond input#submit,
.tcz-theme .woocommerce a.button.alt,
.tcz-theme .woocommerce button.button.alt {
	background: var(--tcz-lime);
	color: var(--tcz-navy);
	font-family: var(--tcz-font-head);
	font-weight: 600;
	letter-spacing: .02em;
	border: none;
	border-radius: var(--tcz-radius-pill);
	padding: 12px 24px;
	box-shadow: var(--tcz-shadow-btn);
	transition: background-color .18s ease, transform .18s ease;
}
.tcz-theme .woocommerce a.button:hover,
.tcz-theme .woocommerce button.button:hover,
.tcz-theme .woocommerce input.button:hover,
.tcz-theme .woocommerce a.button.alt:hover,
.tcz-theme .woocommerce button.button.alt:hover {
	background: var(--tcz-lime-dark);
	color: var(--tcz-navy);
	transform: translateY(-2px);
}
/* Sekundäre Aktionen (z. B. "Gutschein anwenden") dezenter */
.tcz-theme .woocommerce .button.tcz-secondary,
.tcz-theme .woocommerce .cart .button[name="update_cart"] {
	background: transparent;
	color: var(--tcz-navy);
	border: 2px solid var(--tcz-border);
	box-shadow: none;
}

/* -----------------------------------------------------------------
   3) SINGLE PRODUCT
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce div.product .product_title {
	font-family: var(--tcz-font-head);
	color: var(--tcz-navy);
}
.tcz-theme .woocommerce div.product p.price,
.tcz-theme .woocommerce div.product span.price {
	color: var(--tcz-navy);
	font-weight: 700;
	font-size: 1.6rem;
}
.tcz-theme .woocommerce div.product .woocommerce-product-gallery img { border-radius: var(--tcz-radius-md); }
.tcz-theme .woocommerce .quantity .qty {
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-sm);
	padding: 10px;
}
.tcz-theme .woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: var(--tcz-light);
	border-color: var(--tcz-border);
	border-radius: var(--tcz-radius-sm) var(--tcz-radius-sm) 0 0;
}
.tcz-theme .woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	background: var(--tcz-white);
}

/* -----------------------------------------------------------------
   4) WARENKORB & CHECKOUT (schlicht, vertrauenswürdig)
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce table.shop_table {
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	overflow: hidden;
	border-collapse: separate;
}
.tcz-theme .woocommerce table.shop_table th {
	font-family: var(--tcz-font-head);
	color: var(--tcz-navy);
	background: var(--tcz-light);
}
.tcz-theme .woocommerce-cart .cart-collaterals .cart_totals,
.tcz-theme .woocommerce .cart_totals,
.tcz-theme .woocommerce-checkout #order_review {
	background: var(--tcz-light);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	padding: 24px;
}
.tcz-theme .woocommerce form .form-row input.input-text,
.tcz-theme .woocommerce form .form-row textarea,
.tcz-theme .woocommerce form .form-row select,
.tcz-theme .woocommerce .select2-container .select2-selection {
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-sm);
	padding: 12px 14px;
	min-height: auto;
}
.tcz-theme .woocommerce form .form-row input.input-text:focus,
.tcz-theme .woocommerce form .form-row textarea:focus,
.tcz-theme .woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--tcz-lime-dark);
	box-shadow: 0 0 0 3px rgba(183,217,0,.25);
}
.tcz-theme .woocommerce-checkout #payment {
	background: var(--tcz-light);
	border-radius: var(--tcz-radius-md);
}
.tcz-theme .woocommerce-checkout #payment ul.payment_methods { border-color: var(--tcz-border); }

/* -----------------------------------------------------------------
   5) NOTICES (Hinweise) im TC-Zell-Stil
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce-message,
.tcz-theme .woocommerce-info,
.tcz-theme .woocommerce-error {
	border-top: none;
	border-left: 4px solid var(--tcz-lime);
	border-radius: var(--tcz-radius-sm);
	background: var(--tcz-light);
	color: var(--tcz-text);
	padding: 14px 18px 14px 20px;
}
.tcz-theme .woocommerce-message::before,
.tcz-theme .woocommerce-info::before { color: var(--tcz-green); }
.tcz-theme .woocommerce-error { border-left-color: #d64545; }
.tcz-theme .woocommerce-error::before { color: #d64545; }

/* -----------------------------------------------------------------
   6) MEIN KONTO
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce-account .woocommerce-MyAccount-navigation ul {
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	overflow: hidden;
	list-style: none;
	margin: 0;
	padding: 0;
}
.tcz-theme .woocommerce-account .woocommerce-MyAccount-navigation li { border-bottom: 1px solid var(--tcz-border); }
.tcz-theme .woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 12px 16px; color: var(--tcz-navy); text-decoration: none; }
.tcz-theme .woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--tcz-navy); color: var(--tcz-white); }

/* -----------------------------------------------------------------
   7) PRODUKTKATEGORIEN-KACHELN
   ----------------------------------------------------------------- */
.tcz-theme .woocommerce ul.products li.product-category a img { border-radius: var(--tcz-radius-md); }
.tcz-theme .woocommerce ul.products li.product-category h2.woocommerce-loop-category__title {
	font-family: var(--tcz-font-head);
	color: var(--tcz-navy);
	padding: 14px 0 0;
}

/* -----------------------------------------------------------------
   8) RESPONSIVE
   ----------------------------------------------------------------- */
@media (max-width: 1199px) {
	.tcz-theme .woocommerce ul.products,
	.tcz-theme.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.tcz-theme .woocommerce ul.products,
	.tcz-theme.woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 14px; }
	.tcz-theme .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .95rem; padding: 12px 12px 2px; }
	.tcz-theme .woocommerce ul.products li.product .price { padding: 0 12px 10px; }
	.tcz-theme .woocommerce ul.products li.product .button { margin: auto 12px 12px; }
	/* Warenkorb-Tabelle auf Mobile als Stapel (Woo Standard greift; hier Feinschliff) */
	.tcz-theme .woocommerce table.shop_table_responsive tr td { text-align: right; }
}
/* ===== FOOTER (HTML-Block) – ersetzt die früheren Footer-Regeln ========= */
.tcz-footer            { background: var(--tcz-navy); }
.tcz-footer a          { color: rgba(255,255,255,.85); text-decoration: none; }
.tcz-footer a:hover    { color: var(--tcz-lime); }
.tcz-footer p          { color: rgba(255,255,255,.85); margin: .15em 0; }

.tcz-footer-inner {
	max-width: var(--tcz-container);
	margin-inline: auto;
	padding: 64px 24px;
}
.tcz-footer-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr auto;
	gap: 40px;
	align-items: start;
}
.tcz-footer-logo  { width: 130px; height: auto; display: block; margin-bottom: 16px; }
.tcz-footer__claim {
	font-family: var(--tcz-font-head);
	font-weight: 600; font-size: 1.5rem; line-height: 1.1;
	color: var(--tcz-white); margin: 0;
}
.tcz-footer__claim .tcz-accent { color: var(--tcz-lime); }
.tcz-footer__label {
	font-family: var(--tcz-font-head);
	font-weight: 600; font-size: clamp(1.2rem, 2vw, 1.5rem);
	text-transform: uppercase; letter-spacing: .01em;
	color: var(--tcz-white); line-height: 1.05; margin: 0 0 14px;
}
.tcz-footer-cta { display: flex; justify-content: flex-end; }

.tcz-footer__bottom { background: var(--tcz-navy-dark); }
.tcz-footer__bottom-inner {
	max-width: var(--tcz-container); margin-inline: auto;
	display: flex; justify-content: space-between; align-items: center;
	flex-wrap: wrap; gap: 10px;
	padding: 18px 24px; font-size: .85rem; color: rgba(255,255,255,.6);
}
.tcz-footer__legal a { margin-left: 18px; }

@media (max-width: 900px) {
	.tcz-footer-grid { grid-template-columns: 1fr 1fr; }
	.tcz-footer-cta  { justify-content: flex-start; }
}
@media (max-width: 600px) {
	.tcz-footer-inner { padding: 40px 20px; }
	.tcz-footer-grid  { grid-template-columns: 1fr; gap: 28px; }
	.tcz-footer__bottom-inner { flex-direction: column; align-items: flex-start; }
	.tcz-footer__legal a { margin-left: 0; margin-right: 18px; }
}
/* ===== VORTEILSLEISTE (HTML-Block) ===================================== */
.tcz-benefit-wrap {
	max-width: var(--tcz-container);
	margin: -56px auto 0;          /* zieht die Leiste über den Hero */
	padding: 0 24px;
	position: relative;
	z-index: 3;
}
.tcz-benefit-bar {
	background: var(--tcz-white);
	border: 1px solid var(--tcz-border);
	border-radius: var(--tcz-radius-md);
	box-shadow: var(--tcz-shadow-card);
	padding: 28px clamp(20px, 4vw, 48px);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(16px, 3vw, 40px);
}
.tcz-benefit { display: flex; align-items: center; gap: 16px; }
.tcz-benefit + .tcz-benefit {
	border-left: 1px solid var(--tcz-border);
	padding-left: clamp(16px, 3vw, 40px);
}
.tcz-benefit__icon {
	flex: 0 0 auto;
	width: 56px; height: 56px;
	border-radius: 50%;
	display: grid; place-items: center;
	background: var(--tcz-navy);
	color: var(--tcz-lime);
}
.tcz-benefit__icon svg { width: 26px; height: 26px; }
.tcz-benefit__title { font-family: var(--tcz-font-head); font-weight: 600; color: var(--tcz-navy); margin: 0; font-size: 1.15rem; }
.tcz-benefit__text  { margin: 2px 0 0; color: var(--tcz-muted); font-size: .95rem; }

@media (max-width: 767px) {
	.tcz-benefit-wrap { margin-top: -32px; }
	.tcz-benefit-bar  { grid-template-columns: 1fr; gap: 8px; }
	.tcz-benefit + .tcz-benefit {
		border-left: none; border-top: 1px solid var(--tcz-border);
		padding-left: 0; padding-top: 16px; margin-top: 4px;
	}
}