/*
 Theme Name: Blocksy Child
 Template: blocksy
*/

/* =========================================================
   Designsystem agostini.works
   Variablen global auf :root – auf allen Seiten verfügbar.
   ========================================================= */

:root {
	--na-petrol:       #063E3F;
	--na-gelb:         #FFFF00;
	--na-lavendel:     #9EA3F5;
	--na-weiss:        #f0f1fd;
	--na-content-max:  1200px;
	--na-header-offset: 0px;
	--na-font-display: 'Chaney', sans-serif;
	--na-font-body:    'Archia', sans-serif;
}

/* =========================================================
   Startseite agostini.works – Template "Home"
   Aufbau:
   1. Grundreset
   2. Basis-Regeln = MOBILE Ansicht (gelten immer)
   3. @media (min-width: 768px) = DESKTOP-Überschreibungen
   Wichtig: Desktop-Anpassungen gehören IMMER in den
   @media-Block unten, nie in die Basis-Regeln.
   ========================================================= */

.na-home {
	font-family: var(--na-font-body);
	color: var(--na-petrol);
	background: var(--na-weiss);
}

/* Grundreset innerhalb des Templates */
.na-home section {
	margin: 0;
}

.na-home img {
	display: block;
	max-width: 100%;
}

/* ---------------------------------------------------------
   Sektion 1 – Hero (Basis = Mobile)
   Slideshow oben, Text darunter.
   --------------------------------------------------------- */

.na-hero {
	display: flex;              /* zwingend – Spaltenlayout + Slideshow-Höhe hängen daran */
	flex-direction: column;
	background: var(--na-petrol);
}

.na-hero__text {
	order: 2; /* Mobile: Text unter der Slideshow */
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 3rem 1.5rem 4rem;
}

.na-hero__tagline {
	margin: 0 0 1.75rem;
	font-family: var(--na-font-display);
	font-weight: normal; /* Chaney bringt ihr Gewicht selbst mit */
	text-transform: uppercase;
	color: var(--na-lavendel);
	font-size: clamp(1.6rem, 4.5vw, 2.7rem);
	line-height: 1.15;
}

.na-hero__copy p {
	margin: 0 0 1.25rem;
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	line-height: 1.6;
	color: var(--na-lavendel);
}

.na-hero__copy p:last-child {
	margin-bottom: 0;
}

/* Slideshow */

.na-hero__slideshow {
	order: 1; /* Mobile: Slideshow oben */
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 3; /* Mobile-Höhe; Desktop überschreibt das */
}

.na-hero__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 1s ease-in-out; /* sanfter Fade */
}

.na-hero__slide.is-active {
	opacity: 1;
	z-index: 1;
}

.na-hero__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover; /* füllt die Spalte vollständig */
}

/* Dezente Dots unten, keine weiteren Controls */

.na-hero__dots {
	position: absolute;
	bottom: 1rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 0.5rem;
	z-index: 2;
}

.na-hero__dot {
	width: 9px;
	height: 9px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: rgba(240, 241, 253, 0.55); /* Weiß, halbtransparent */
	cursor: pointer;
	transition: background 0.3s ease;
}

.na-hero__dot.is-active,
.na-hero__dot:hover {
	background: var(--na-weiss);
}

.na-hero__dot:focus-visible {
	outline: 2px solid var(--na-petrol);
	outline-offset: 2px;
}

/* ---------------------------------------------------------
   Sektion 2 – Drei Bereichs-Cards (Basis = Mobile)
   --------------------------------------------------------- */

.na-areas {
	background: var(--na-weiss);
	padding: 4rem 1.5rem;
}

.na-areas__inner {
	max-width: var(--na-content-max);
	margin: 0 auto;
}

.na-areas__heading {
	margin: 0 0 0.75rem;
	font-family: var(--na-font-display);
	font-weight: 400;
	color: var(--na-petrol);
	font-size: clamp(1.5rem, 3vw, 2rem);
}

.na-areas__intro {
	margin: 0 0 2.5rem;
	font-size: 1.0625rem;
	line-height: 1.6;
}

.na-areas__grid {
	display: grid;
	/* minmax(0, 1fr) statt 1fr: erlaubt der Spalte, schmaler zu
	   werden als ihr breitester Inhalt – verhindert den Überlauf
	   durch lange Wörter wie "Organisationsberatung" */
	grid-template-columns: minmax(0, 1fr);
	gap: 1.5rem;
}

/* Card – komplett verlinkt */

.na-card {
	display: block;
	min-width: 0; /* Teil des Überlauf-Schutzes */
	background: var(--na-petrol);
	padding: 1.5rem;
	text-decoration: none;
	transition: filter 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

.na-card:hover,
.na-card:focus-visible {
	filter: brightness(1.20); 
	box-shadow: 0 10px 30px rgba(6, 62, 63, 0.18);
	transform: translateY(-3px);
}

.na-card:focus-visible {
	outline: 3px solid var(--na-lavendel);
	outline-offset: 3px;
}

.na-card__title {
	margin: 0 0 1.25rem;
	font-family: var(--na-font-display);
	font-weight: 400;
	color: var(--na-lavendel);
	font-size: clamp(1.05rem, 4.5vw, 1.375rem); /* schrumpft auf schmalen Screens */
	overflow-wrap: break-word;
	hyphens: auto; /* Sicherheitsnetz: trennt statt abzuschneiden */
}

.na-card__media img {
	width: 100%;
	aspect-ratio: 16 / 9; /* Mobile: rechteckiger Ausschnitt */
	object-fit: cover;
}

/* ---------------------------------------------------------
   Sektion 3 – Komplizin-Anker
   --------------------------------------------------------- */

.na-anchor {
	background: var(--na-petrol);
	padding: 5.5rem 1.5rem;
}

.na-anchor__inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.na-anchor p {
	margin: 0;
	color: var(--na-weiss);
	font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
	line-height: 1.7;
}

.na-anchor p + p {
      margin-top: 1.25rem;
  }

/* ---------------------------------------------------------
   Desktop ab 768px – alle Desktop-Anpassungen NUR hier
   --------------------------------------------------------- */

@media (min-width: 768px) {

	.na-hero {
		flex-direction: row;
		/* Volle Viewport-Höhe abzüglich Header-Offset (oben einstellbar). */
		min-height: min(calc(100svh - var(--na-header-offset)), 760px);
		/* Rechter Puffer für die Slideshow – gleiche Formel wie links beim Text */
		padding-right: max(clamp(2rem, 5vw, 5rem), calc((100vw - var(--na-content-max)) / 2));
	}

	.na-hero__text {
		order: 1;
		flex: 0 0 60%;
		/* padding-left richtet die Textkante an der zentrierten
		   Content-Breite aus (Leerzeichen um das Minus sind Pflicht!) */
		padding-top: 0rem;
		padding-right: clamp(2rem, 5vw, 5rem);
		padding-bottom: 4rem;
		padding-left: max(clamp(2rem, 5vw, 5rem), calc((100vw - var(--na-content-max)) / 2));
      	justify-content: flex-start;
	}

	.na-hero__slideshow {
		order: 2;
		flex: 0 0 40%;
		aspect-ratio: auto; /* Höhe kommt aus dem Hero selbst */
	}

	.na-areas {
		padding: 5.5rem 2rem;
	}

	.na-areas__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr)); /* drei gleichbreite Cards */
		gap: 2rem;
	}

	.na-card__media img {
		aspect-ratio: 1 / 1; /* Desktop: quadratisch */
	}
}

/* ---------------------------------------------------------
   Reduced Motion: keine Fades, kein Hover-Lift.
   Der Auto-Wechsel wird zusätzlich im JS deaktiviert.
   --------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {

	.na-hero__slide,
	.na-card {
		transition: none;
	}

	.na-card:hover,
	.na-card:focus-visible {
		transform: none;
	}
}

/* =========================================================
   Content-Seiten (About, Angebot, Beratung, …)
   Scope: .entry-content – kommt auf der Home nicht vor,
   weil page-home.php kein Standard-Blocksy-Layout nutzt.
   ========================================================= */

/* Einheitliche Schriftgröße für alle Content-Absätze */
.entry-content p {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	line-height: 1.65;
}

/* Links: Lavendel, unterstrichen */
.entry-content a {
	color: var(--na-lavendel);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: color 0.15s ease, background-color 0.15s ease;
}

/* Hover/Fokus: Petrol auf Gelb – barrierefreier Kontrast */
.entry-content a:hover,
.entry-content a:focus-visible {
	color: var(--na-petrol);
	background-color: var(--na-gelb);
	text-decoration: none;
	outline: none;
}

/* =========================================================
   /angebot – Bereichsblöcke
   Drei farbige Sektionen (Petrol / Lavendel / Gelb).
   Jeder Block ist ein Gutenberg-Gruppenblock mit
   Ausrichtung „Volle Breite" (alignfull) und einer
   der drei Klassen: na-block--petrol / --lavendel / --gelb
   ========================================================= */

/* Basis – gilt für alle drei Blöcke */
.na-block--petrol,
.na-block--lavendel,
.na-block--gelb {
	padding: 1.5rem;
}

.na-block--petrol .wp-block-heading,
.na-block--lavendel .wp-block-heading,
.na-block--gelb .wp-block-heading {
	font-family: var(--na-font-display);
	font-weight: 400;
	text-transform: uppercase;
	font-size: clamp(1.5rem, 3.5vw, 2.25rem);
	line-height: 1.1;
	margin-bottom: 1.5rem;
}

/* Bild: volle Breite des Containers, 16:9-Ausschnitt.
   !important nötig, weil Gutenberg bei manuell skalierten Bildern
   (is-resized) Inline-Styles mit festen Pixelwerten setzt.          */
.na-block--petrol .wp-block-image,
.na-block--lavendel .wp-block-image,
.na-block--gelb .wp-block-image {
	width: 100% !important;
	max-width: 100% !important;
	margin-bottom: 1.75rem;
}

.na-block--petrol .wp-block-image img,
.na-block--lavendel .wp-block-image img,
.na-block--gelb .wp-block-image img {
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	display: block;
}

/* Absätze und Links innerhalb der Blöcke */
.na-block--petrol p,
.na-block--lavendel p,
.na-block--gelb p {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	line-height: 1.65;
	margin-bottom: 1.25rem;
	/* kein max-width: 68ch – Block-Padding übernimmt die Zeilenlängenkontrolle */
}

.na-block--petrol p:last-child,
.na-block--lavendel p:last-child,
.na-block--gelb p:last-child {
	margin-bottom: 0;
}

/* — Petrol-Block: Lavendel-Text —————————————————————————— */
.na-block--petrol {
	background: var(--na-petrol);
	color: var(--na-lavendel);
}

.na-block--petrol .wp-block-heading {
	color: var(--na-lavendel);
}

/* Link-Override: auf Petrol-Hintergrund kein Hover-Gelb-Hintergrund nötig */
.na-block--petrol a {
	color: var(--na-lavendel);
	text-decoration-color: var(--na-lavendel);
}

.na-block--petrol a:hover,
.na-block--petrol a:focus-visible {
	color: var(--na-gelb);
	background-color: transparent;
	text-decoration-color: var(--na-gelb);
}

/* — Lavendel-Block: Petrol-Text ——————————————————————————— */
.na-block--lavendel {
	background: var(--na-lavendel);
	color: var(--na-petrol);
}

.na-block--lavendel .wp-block-heading {
	color: var(--na-petrol);
}

.na-block--lavendel a {
	color: var(--na-petrol);
	text-decoration-color: var(--na-petrol);
}

.na-block--lavendel a:hover,
.na-block--lavendel a:focus-visible {
	color: var(--na-petrol);
	background-color: var(--na-gelb);
}

/* — Gelb-Block: Petrol-Text ———————————————————————————————— */
.na-block--gelb {
	background: var(--na-gelb);
	color: var(--na-petrol);
}

.na-block--gelb .wp-block-heading {
	color: var(--na-petrol);
}

.na-block--gelb a {
	color: var(--na-petrol);
	text-decoration-color: var(--na-petrol);
}

.na-block--gelb a:hover,
.na-block--gelb a:focus-visible {
	color: var(--na-petrol);
	background-color: rgba(6, 62, 63, 0.1); /* Petrol-Hauch auf Gelb */
}

/* Desktop: innere Content-Breite zentrieren ——————————————— */
@media (min-width: 768px) {
	.na-block--petrol,
	.na-block--lavendel,
	.na-block--gelb {
		padding: 2rem;
	}

	.na-block--petrol > *,
	.na-block--lavendel > *,
	.na-block--gelb > * {
		max-width: var(--na-content-max);
		margin-left: auto;
		margin-right: auto;
	}
  /* CTA-Link (Bereichsseiten) */
.na-cta a {
  font-weight: 700;
  color: var(--na-petrol);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.na-cta a:hover {
  background-color: var(--na-gelb);
  color: var(--na-petrol);
}
  
  /* Tabellen-Spaltenbreiten und Label-Styling */
.entry-content table td:first-child {
  width: 33%;
  font-family: 'Archia', sans-serif;
  font-weight: 700;
}

  .wp-block-table,
.wp-block-table table {
  width: 66% !important;
}
  
  /* Klickbare Bereichsblöcke /angebot */
.na-block--petrol,
.na-block--lavendel,
.na-block--gelb {
  position: relative;
}

.na-block-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}
  
  .na-block-link:hover {
  background-color: transparent !important;
}
  
}