/*
Theme Name: KIUntermain
Theme URI: https://kiuntermain.de
Author: Kelira
Author URI: https://kelira.de
Description: Regionalportal für Künstliche Intelligenz, Digitalisierung und moderne Webseiten am Bayerischen Untermain. Schwester-Theme von Kelira – Dunkelblau-Design mit Türkis/Cyan-Akzent. Ein Projekt der Agentur Kelira.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: kiuntermain
*/

/* =========================================================
   Fonts (Satoshi, selbst gehostet)
   ========================================================= */
@font-face {
	font-family: "Satoshi";
	src: url("assets/fonts/Satoshi-Light.woff2") format("woff2"),
		url("assets/fonts/Satoshi-Light.woff") format("woff");
	font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
	font-family: "Satoshi";
	src: url("assets/fonts/Satoshi-Regular.woff2") format("woff2"),
		url("assets/fonts/Satoshi-Regular.woff") format("woff");
	font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
	font-family: "Satoshi";
	src: url("assets/fonts/Satoshi-Medium.woff2") format("woff2"),
		url("assets/fonts/Satoshi-Medium.woff") format("woff");
	font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
	font-family: "Satoshi";
	src: url("assets/fonts/Satoshi-Bold.woff2") format("woff2"),
		url("assets/fonts/Satoshi-Bold.woff") format("woff");
	font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
	font-family: "Satoshi";
	src: url("assets/fonts/Satoshi-Black.woff2") format("woff2"),
		url("assets/fonts/Satoshi-Black.woff") format("woff");
	font-weight: 900; font-style: normal; font-display: swap;
}

/* =========================================================
   Design-Tokens – Dunkelblau / Weiß / Türkis-Cyan
   ========================================================= */
:root {
	--color-bg: #0a1226;
	--color-bg-elev: #0e1730;
	--color-bg-card: #121d3a;
	--color-border: #233252;
	--color-accent: #22d3ee;        /* Türkis/Cyan */
	--color-accent-dim: #0ea5c4;
	--color-accent-2: #3b82f6;      /* Blau für Verläufe */
	--color-text: #f3f6fb;
	--color-text-muted: #aebdd6;
	--color-text-faint: #7f8eac;

	--font-sans: "Satoshi", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--maxw: 1200px;
	--radius: 14px;
	--radius-lg: 22px;
	--space: clamp(4rem, 9vw, 8rem);

	--ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* =========================================================
   Reset / Base
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: 17px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

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

a { color: inherit; text-decoration: none; transition: color 0.2s var(--ease); }

h1, h2, h3, h4 {
	margin: 0 0 0.5em;
	line-height: 1.1;
	font-weight: 900;
	letter-spacing: -0.02em;
}

p { margin: 0 0 1em; }

::selection { background: var(--color-accent); color: #06121f; }

:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
	border-radius: 4px;
}

/* =========================================================
   Layout helpers
   ========================================================= */
.container {
	width: 100%;
	max-width: var(--maxw);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.section { padding-block: var(--space); position: relative; }
.section--alt { background: var(--color-bg-elev); }

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: 1rem;
}
.eyebrow::before { content: ""; width: 28px; height: 2px; background: var(--color-accent); }

.section-head { max-width: 680px; margin-bottom: 3.5rem; }
.section-head h2 { font-size: clamp(2rem, 4.5vw, 3.25rem); }
.section-head p { color: var(--color-text-muted); font-size: 1.1rem; }

/* =========================================================
   Buttons
   ========================================================= */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.95rem 1.6rem;
	border-radius: 999px;
	font-weight: 700;
	font-size: 0.98rem;
	line-height: 1;
	cursor: pointer;
	border: 1px solid transparent;
	transition: transform 0.2s var(--ease), background 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
	will-change: transform;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--color-accent); color: #06121f; box-shadow: 0 8px 24px rgba(34, 211, 238, 0.18); }
.btn--primary:hover { background: #5fe2f5; box-shadow: 0 12px 30px rgba(34, 211, 238, 0.28); }
.btn--ghost { background: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn--ghost:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* =========================================================
   Header / Navigation
   ========================================================= */
.site-header {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 100;
	transition: background 0.3s var(--ease), border-color 0.3s var(--ease), backdrop-filter 0.3s var(--ease);
	border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
	background: rgba(10, 18, 38, 0.82);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom-color: var(--color-border);
}
body.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar .site-header { top: 46px; } }
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	height: 84px;
	transition: height 0.3s var(--ease);
}
.site-header.is-scrolled .site-header__inner { height: 68px; }
.site-header.is-scrolled .brand__mark { width: 36px; height: 36px; }
.brand__mark { width: 42px; height: 42px; }
.site-brand { display: inline-flex; align-items: center; }
.brand { display: inline-flex; align-items: center; gap: 0.7rem; }
.brand__mark {
	flex: 0 0 auto;
	border-radius: 11px;
	transition: transform 0.3s var(--ease), width 0.3s var(--ease), height 0.3s var(--ease);
}
.site-brand:hover .brand__mark { transform: rotate(-6deg) scale(1.05); }
.brand__name { font-weight: 900; font-size: 1.5rem; letter-spacing: -0.03em; line-height: 1; }
.brand__name span { color: var(--color-accent); }

.footer__brand .brand__name { font-size: 1.45rem; }
.footer__brand .brand__mark { width: 38px; height: 38px; }

.main-nav { display: flex; align-items: center; gap: 1.7rem; }
.main-nav ul { display: flex; align-items: center; gap: 1.6rem; list-style: none; margin: 0; padding: 0; flex-wrap: nowrap; }
.main-nav li { flex: 0 0 auto; }
.main-nav .btn { padding: 0.62rem 1.35rem; font-size: 0.95rem; }
.main-nav a { font-weight: 500; font-size: 0.97rem; color: var(--color-text-muted); position: relative; white-space: nowrap; }
.main-nav a:hover { color: var(--color-text); }
.main-nav .current-menu-item a { color: var(--color-text); }
/* Dezenter, animierter Cyan-Unterstrich (nur Desktop, nicht auf Buttons) */
@media (min-width: 769px) {
	.main-nav a:not(.btn)::after {
		content: "";
		position: absolute;
		left: 0; right: 0; bottom: -7px;
		height: 2px; border-radius: 2px;
		background: var(--color-accent);
		transform: scaleX(0);
		transform-origin: left;
		transition: transform 0.25s var(--ease);
	}
	.main-nav a:not(.btn):hover::after,
	.main-nav .current-menu-item > a:not(.btn)::after { transform: scaleX(1); }
}
.main-nav a.btn--primary, .main-nav a.btn--primary:hover { color: #06121f; }
.main-nav a.btn--ghost { color: var(--color-text); }
.main-nav a.btn--ghost:hover { color: var(--color-accent); }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; width: 44px; height: 44px; padding: 10px; }
.nav-toggle span { display: block; height: 2px; background: var(--color-text); margin: 5px 0; transition: transform 0.3s var(--ease), opacity 0.3s var(--ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =========================================================
   Hero
   ========================================================= */
.hero {
	position: relative;
	padding-top: clamp(9rem, 16vh, 12rem);
	padding-bottom: var(--space);
	overflow: hidden;
}
.hero::before {
	content: "";
	position: absolute;
	top: -25%;
	left: 60%;
	transform: translateX(-50%);
	width: 80vw;
	height: 80vw;
	max-width: 1000px;
	max-height: 1000px;
	background: radial-gradient(circle, rgba(34, 211, 238, 0.16), rgba(59, 130, 246, 0.08) 40%, transparent 65%);
	pointer-events: none;
	z-index: 0;
}
.hero__grid {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(var(--color-border) 1px, transparent 1px),
		linear-gradient(90deg, var(--color-border) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(circle at 60% 30%, #000 0%, transparent 70%);
	opacity: 0.22;
	z-index: 0;
}
.hero .container { position: relative; z-index: 1; }
.hero__layout {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
.hero h1 { font-size: clamp(2.4rem, 6vw, 4.6rem); max-width: 17ch; }
.hero h1 em { color: var(--color-accent); font-style: normal; }
.hero__lead {
	max-width: 54ch;
	font-size: clamp(1.05rem, 2vw, 1.28rem);
	color: var(--color-text-muted);
	margin-bottom: 2.25rem;
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.hero__stats {
	display: flex;
	flex-wrap: wrap;
	gap: clamp(1.5rem, 5vw, 3rem);
	margin-top: 3rem;
	padding-top: 2.25rem;
	border-top: 1px solid var(--color-border);
}
.hero__stat { position: relative; padding-left: 1.1rem; }
.hero__stat::before {
	content: "";
	position: absolute;
	left: 0; top: 0.35rem; bottom: 0.35rem;
	width: 3px; border-radius: 2px;
	background: var(--color-accent);
}
.hero__stat strong { display: block; font-size: clamp(1.6rem, 4vw, 2.3rem); font-weight: 900; line-height: 1.05; margin-bottom: 0.35rem; }
.hero__stat span { color: var(--color-text-muted); font-size: 0.95rem; }

/* Hero KI-Illustration */
.hero__visual { display: flex; justify-content: center; }
.ai-illu {
	width: 100%;
	max-width: 480px;
	background: rgba(18, 29, 58, 0.78);
	backdrop-filter: blur(8px);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: 0 30px 70px rgba(0, 0, 0, 0.5);
	overflow: hidden;
	animation: ai-float 6s ease-in-out infinite;
}
@keyframes ai-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.ai-illu__bar {
	display: flex; align-items: center; gap: 0.6rem;
	padding: 0.9rem 1.25rem;
	border-bottom: 1px solid var(--color-border);
	font-size: 0.9rem;
	background: rgba(255, 255, 255, 0.02);
}
.ai-illu__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); animation: nn-pulse 2s infinite; }
.ai-illu__title { font-weight: 700; }
.ai-illu__pct { margin-left: auto; color: var(--color-accent); font-weight: 700; }
.ai-illu__viz { padding: 1.5rem 1.25rem 0.75rem; }
.ai-illu__viz svg { width: 100%; height: auto; display: block; }
.nn-active circle { animation: nn-blink 1.8s ease-in-out infinite; }
.nn-active circle:nth-child(2) { animation-delay: 0.4s; }
.nn-active circle:nth-child(3) { animation-delay: 0.8s; }
@keyframes nn-blink { 0%, 100% { opacity: 0.35; } 50% { opacity: 1; } }
@keyframes nn-pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }
.nn-flow path { animation: nn-dash 1.4s linear infinite; }
@keyframes nn-dash { to { stroke-dashoffset: -16; } }
.ai-illu__foot {
	display: flex; align-items: center; gap: 0.75rem;
	padding: 0.5rem 1.25rem 1.25rem;
	font-size: 0.82rem; color: var(--color-text-faint);
}
.ai-illu__track { flex: 1; height: 6px; border-radius: 3px; background: var(--color-bg-elev); overflow: hidden; }
.ai-illu__fill { display: block; height: 100%; width: 96%; border-radius: 3px; background: linear-gradient(90deg, var(--color-accent-2), var(--color-accent)); animation: ai-fill 2.4s ease-out both; }
@keyframes ai-fill { from { width: 0; } to { width: 96%; } }
@media (prefers-reduced-motion: reduce) {
	.ai-illu, .ai-illu__dot, .nn-active circle, .nn-flow path, .ai-illu__fill { animation: none; }
}

/* =========================================================
   Cards (Features, Artikel, Vorteile)
   ========================================================= */
.cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1.25rem;
}
.cards--4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.card {
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
	transition: transform 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
	position: relative;
	overflow: hidden;
}
.card:hover { transform: translateY(-6px); border-color: var(--color-accent); box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35); }
.card__icon {
	width: 52px; height: 52px;
	display: grid; place-items: center;
	border-radius: 14px;
	background: rgba(34, 211, 238, 0.12);
	color: var(--color-accent);
	margin-bottom: 1.5rem;
}
.card__icon svg { width: 26px; height: 26px; }
.card h3 { font-size: 1.3rem; }
.card p { color: var(--color-text-muted); margin-bottom: 0; }
.card ul { margin: 1rem 0 0; padding: 0; list-style: none; }
.card li { color: var(--color-text-muted); font-size: 0.95rem; padding-left: 1.4rem; position: relative; margin-bottom: 0.4rem; }
.card li::before { content: "→"; position: absolute; left: 0; color: var(--color-accent); }
.card__link {
	display: inline-flex; align-items: center; gap: 0.5rem;
	margin-top: 1.5rem; font-weight: 700; font-size: 0.95rem;
	color: var(--color-accent);
}
.card__link svg { transition: transform 0.25s var(--ease); }
.card:hover .card__link svg, .card__link:hover svg { transform: translateX(4px); }

/* Artikel-Karte mit Meta */
.card--post .card__cat {
	display: inline-block;
	font-size: 0.72rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: 0.75rem;
}
.card--post h3 { font-size: 1.2rem; margin-bottom: 0.6rem; }
.card--post h3 a:hover { color: var(--color-accent); }
.card--post .card__meta { color: var(--color-text-faint); font-size: 0.85rem; margin-top: 1rem; margin-bottom: 0; }

/* =========================================================
   Vorteile (Warum KIUntermain)
   ========================================================= */
.benefits { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.25rem; }
.benefit {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
	background: var(--color-bg-card);
	transition: transform 0.3s var(--ease), border-color 0.3s var(--ease);
}
.benefit:hover { transform: translateY(-4px); border-color: var(--color-accent); }
.benefit__icon {
	width: 48px; height: 48px; display: grid; place-items: center;
	border-radius: 12px; background: rgba(34, 211, 238, 0.12); color: var(--color-accent);
	margin-bottom: 1.25rem;
}
.benefit__icon svg { width: 24px; height: 24px; }
.benefit h3 { font-size: 1.2rem; }
.benefit p { color: var(--color-text-muted); font-size: 0.96rem; margin-bottom: 0; }

/* =========================================================
   Prozess / Steps (Webseitencheck-Ablauf etc.)
   ========================================================= */
.process { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.25rem; counter-reset: step; }
.process__step { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 2rem; position: relative; background: var(--color-bg-card); }
.process__step::before {
	counter-increment: step;
	content: "0" counter(step);
	font-size: 2.6rem; font-weight: 900; color: var(--color-accent);
	opacity: 0.3; line-height: 1; display: block; margin-bottom: 1rem;
}
.process__step h3 { font-size: 1.2rem; }
.process__step p { color: var(--color-text-muted); font-size: 0.96rem; margin-bottom: 0; }

/* =========================================================
   CTA-Band
   ========================================================= */
.cta-band {
	position: relative;
	overflow: hidden;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	background:
		radial-gradient(120% 140% at 80% 0%, rgba(34, 211, 238, 0.14), transparent 55%),
		radial-gradient(120% 140% at 0% 100%, rgba(59, 130, 246, 0.14), transparent 55%),
		var(--color-bg-elev);
}
.cta-band__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 6vw, 4rem); align-items: start; }
.cta-band__info h2 { font-size: clamp(2rem, 4.5vw, 3rem); }
.cta-band__info p { color: var(--color-text-muted); font-size: 1.08rem; }
.cta-band__list { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: 0.75rem; }
.cta-band__list li { display: flex; gap: 0.75rem; align-items: flex-start; color: var(--color-text-muted); }

/* =========================================================
   Einzugsgebiet / Region (lokales SEO)
   ========================================================= */
.region .section-head { margin-inline: auto; text-align: center; }
.region .eyebrow { justify-content: center; }
.region__chips { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; }
.region__chip {
	border: 1px solid var(--color-border);
	background: var(--color-bg-card);
	border-radius: 999px;
	padding: 0.5rem 1.1rem;
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--color-text-muted);
	transition: border-color 0.2s var(--ease), color 0.2s var(--ease);
}
.region__chip:hover { border-color: var(--color-accent); color: var(--color-text); }

/* =========================================================
   Forms
   ========================================================= */
.form { display: grid; gap: 1rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-card {
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: clamp(1.5rem, 4vw, 2.5rem);
}
.field label { display: block; font-size: 0.85rem; font-weight: 500; color: var(--color-text-muted); margin-bottom: 0.4rem; }
.field input, .field textarea, .field select {
	width: 100%;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 12px;
	color: var(--color-text);
	font: inherit;
	padding: 0.85rem 1rem;
	transition: border-color 0.2s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--color-accent); }
.field textarea { min-height: 130px; resize: vertical; }
.form .btn { justify-content: center; }
.form-note { font-size: 0.85rem; color: var(--color-text-faint); }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.field-check { display: flex; gap: 0.6rem; align-items: flex-start; font-size: 0.88rem; color: var(--color-text-muted); line-height: 1.5; cursor: pointer; }
.field-check input { margin-top: 0.2rem; flex: 0 0 auto; accent-color: var(--color-accent); width: 17px; height: 17px; }
.field-check a { color: var(--color-accent); text-decoration: underline; }
.form-feedback { border-radius: 12px; padding: 0.9rem 1.1rem; margin-bottom: 1rem; font-size: 0.95rem; }
.form-feedback--ok { background: rgba(34, 211, 238, 0.12); border: 1px solid rgba(34, 211, 238, 0.4); color: var(--color-text); }
.form-feedback--err { background: rgba(255, 118, 118, 0.1); border: 1px solid rgba(255, 118, 118, 0.4); color: #ffb4b4; }

/* =========================================================
   Contact info column
   ========================================================= */
.contact__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 6vw, 4rem); align-items: start; }
.contact__info h2 { font-size: clamp(2rem, 4.5vw, 3rem); }
.contact__info p { color: var(--color-text-muted); }
.contact__list { list-style: none; padding: 0; margin: 2rem 0 0; display: grid; gap: 1.25rem; }
.contact__list li { display: flex; gap: 1rem; align-items: center; }
.contact__list .ico { width: 44px; height: 44px; flex: 0 0 auto; border-radius: 12px; background: rgba(34, 211, 238, 0.12); color: var(--color-accent); display: grid; place-items: center; }
.contact__list small { display: block; color: var(--color-text-faint); }

/* =========================================================
   Firmenverzeichnis
   ========================================================= */
.dir-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: flex-end;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	margin-bottom: 2.5rem;
}
.dir-filters .field { flex: 1 1 180px; margin: 0; }
.dir-filters .btn { flex: 0 0 auto; }
.dir-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }
.firma-card {
	display: flex; flex-direction: column;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 1.75rem;
	transition: transform 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
	position: relative;
}
.firma-card:hover { transform: translateY(-5px); border-color: var(--color-accent); box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35); }
.firma-card.is-premium { border-color: rgba(34, 211, 238, 0.55); background: linear-gradient(180deg, rgba(34, 211, 238, 0.05), var(--color-bg-card)); }
.firma-card__badge {
	position: absolute; top: 1rem; right: 1rem;
	font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
	color: #06121f; background: var(--color-accent);
	padding: 0.2rem 0.6rem; border-radius: 999px;
}
.firma-card__head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.firma-card__logo { width: 56px; height: 56px; flex: 0 0 auto; border-radius: 12px; object-fit: contain; background: #fff; padding: 6px; }
.firma-card__logo--ph { display: grid; place-items: center; background: var(--color-bg-elev); color: var(--color-accent); font-weight: 900; font-size: 1.4rem; border: 1px solid var(--color-border); }
.firma-card h3 { font-size: 1.2rem; margin: 0 0 0.15rem; }
.firma-card__loc { color: var(--color-text-faint); font-size: 0.85rem; }
.firma-card p { color: var(--color-text-muted); font-size: 0.95rem; flex: 1; }
.firma-card__tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin: 0.5rem 0 1rem; }
.firma-card__tag { font-size: 0.75rem; color: var(--color-text-muted); border: 1px solid var(--color-border); border-radius: 999px; padding: 0.2rem 0.7rem; }
.firma-card__foot { display: flex; gap: 1.25rem; margin-top: auto; padding-top: 0.5rem; }
.firma-card__foot a { font-size: 0.9rem; font-weight: 700; color: var(--color-accent); display: inline-flex; align-items: center; gap: 0.35rem; }
.dir-empty { text-align: center; color: var(--color-text-muted); padding: 3rem 1rem; }

/* Single Firma */
.firma-single__head { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; }
.firma-single__logo { width: 80px; height: 80px; border-radius: 16px; object-fit: contain; background: #fff; padding: 8px; }
.firma-meta { list-style: none; padding: 0; margin: 1.5rem 0; display: grid; gap: 0.85rem; }
.firma-meta li { display: flex; gap: 0.75rem; align-items: center; color: var(--color-text-muted); }
.firma-meta .ico { width: 40px; height: 40px; flex: 0 0 auto; border-radius: 10px; background: rgba(34, 211, 238, 0.12); color: var(--color-accent); display: grid; place-items: center; }
.firma-meta a { color: var(--color-accent); }

/* =========================================================
   Generic page content
   ========================================================= */
.page-hero { padding-top: clamp(8rem, 14vh, 11rem); padding-bottom: 2rem; }
.breadcrumbs { font-size: 0.85rem; color: var(--color-text-faint); margin-bottom: 1rem; }
.breadcrumbs a { color: var(--color-text-muted); }
.breadcrumbs a:hover { color: var(--color-accent); }
.page-content { padding-bottom: var(--space); }
.page-content .container { max-width: 820px; }
.page-content.contact__grid, .page-content .contact__grid { max-width: var(--maxw); }
.entry-content a { color: var(--color-accent); text-decoration: underline; }
.entry-content > p.lead, .contact__info .lead { font-size: 1.2rem; color: var(--color-text); margin-bottom: 2rem; }
.entry-content h2 { font-size: clamp(1.5rem, 3vw, 2rem); margin-top: 2.5rem; }
.entry-content h3 { font-size: 1.25rem; margin-top: 1.75rem; }
.entry-content p { color: var(--color-text-muted); }
.entry-content ul { margin: 1rem 0 1.5rem; padding-left: 0; list-style: none; }
.entry-content ul li { position: relative; padding-left: 1.6rem; margin-bottom: 0.6rem; color: var(--color-text-muted); }
.entry-content ul li::before { content: "→"; position: absolute; left: 0; color: var(--color-accent); font-weight: 700; }
.entry-content strong { color: var(--color-text); }
.entry-content img { border-radius: var(--radius); margin: 1.5rem 0; }
.post-meta { color: var(--color-text-faint); font-size: 0.9rem; }

/* Article list (blog) */
.archive-toolbar { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-bottom: 2.5rem; }
.cat-chip {
	font-size: 0.85rem; font-weight: 600;
	color: var(--color-text-muted);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	padding: 0.45rem 1.1rem;
	transition: all 0.2s var(--ease);
}
.cat-chip:hover, .cat-chip.is-active { color: #06121f; background: var(--color-accent); border-color: var(--color-accent); }

.pagination { margin-top: 3rem; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.pagination .page-numbers { display: inline-grid; place-items: center; min-width: 42px; height: 42px; padding: 0 0.5rem; border: 1px solid var(--color-border); border-radius: 10px; color: var(--color-text-muted); font-weight: 600; }
.pagination .page-numbers.current { background: var(--color-accent); color: #06121f; border-color: var(--color-accent); }
.pagination a.page-numbers:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* FAQ */
.faq { display: grid; gap: 0.75rem; margin-top: 1.5rem; }
.faq__item { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.25rem 1.5rem; }
.faq__item h3 { margin: 0 0 0.4rem; font-size: 1.1rem; }
.faq__item p { margin: 0; color: var(--color-text-muted); }

/* =========================================================
   Cookie consent banner
   ========================================================= */
.ki-consent {
	position: fixed; z-index: 200; left: 50%; bottom: 1.25rem; transform: translateX(-50%);
	width: min(680px, calc(100% - 2rem));
	background: var(--color-bg-card); border: 1px solid var(--color-border);
	border-radius: var(--radius-lg); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); padding: 1.5rem;
}
.ki-consent[hidden] { display: none; }
.ki-consent__inner { display: flex; gap: 1.5rem; align-items: center; flex-wrap: wrap; }
.ki-consent__text { flex: 1 1 300px; }
.ki-consent__text strong { display: block; margin-bottom: 0.35rem; font-size: 1.05rem; }
.ki-consent__text p { margin: 0; font-size: 0.92rem; color: var(--color-text-muted); }
.ki-consent__text a { color: var(--color-accent); text-decoration: underline; }
.ki-consent__actions { display: flex; gap: 0.75rem; flex: 0 0 auto; }
.ki-consent__actions .btn { padding: 0.65rem 1.3rem; }
@media (max-width: 560px) {
	.ki-consent__actions { width: 100%; }
	.ki-consent__actions .btn { flex: 1; justify-content: center; }
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer { border-top: 1px solid var(--color-border); background: var(--color-bg-elev); padding-block: 4rem 2rem; }
.footer__grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 2rem; margin-bottom: 3rem; }
.footer__brand { font-weight: 900; font-size: 1.3rem; margin-bottom: 1rem; }
.site-footer p { color: var(--color-text-muted); font-size: 0.95rem; max-width: 34ch; }
.footer__col h4 { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-text-faint); font-weight: 700; }
.footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.6rem; }
.footer__col a { color: var(--color-text-muted); font-size: 0.95rem; }
.footer__col a:hover { color: var(--color-accent); }
.footer__agency { margin-top: 1.25rem; font-size: 0.85rem; color: var(--color-text-faint); }
.footer__agency a { color: var(--color-accent); }
.footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; padding-top: 2rem; border-top: 1px solid var(--color-border); color: var(--color-text-faint); font-size: 0.9rem; }

/* =========================================================
   404 + search
   ========================================================= */
.error404 .container { text-align: left; }
.error404__code { color: var(--color-accent); font-size: clamp(3.5rem, 12vw, 7rem); line-height: 1; }
.error404__links { display: flex; flex-wrap: wrap; gap: 0.6rem 1.5rem; margin-top: 2.5rem; padding-top: 1.75rem; border-top: 1px solid var(--color-border); }
.error404__links a { color: var(--color-text-muted); font-weight: 500; }
.error404__links a:hover { color: var(--color-accent); }
.search-form { display: flex; gap: 0.6rem; }
.search-form label { flex: 1; }
.search-field { width: 100%; background: var(--color-bg-elev); border: 1px solid var(--color-border); border-radius: 999px; color: var(--color-text); font: inherit; padding: 0.8rem 1.25rem; }
.search-field:focus { outline: none; border-color: var(--color-accent); }
.search-submit { background: var(--color-accent); color: #06121f; border: 0; border-radius: 999px; font-weight: 700; padding: 0.8rem 1.5rem; cursor: pointer; }

/* =========================================================
   Reveal on scroll
   ========================================================= */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 980px) {
	.hero__layout { grid-template-columns: 1fr; }
	.hero__visual { order: -1; margin-bottom: 1.5rem; }
	.ai-illu { max-width: 420px; }
}
@media (max-width: 900px) {
	.contact__grid, .cta-band__grid { grid-template-columns: 1fr; }
	.footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
	.nav-toggle { display: block; }
	body.admin-bar .main-nav { top: calc(68px + 46px); }
	.main-nav {
		position: fixed; inset: 68px 0 auto 0;
		flex-direction: column; align-items: stretch; gap: 0;
		background: var(--color-bg-elev); border-bottom: 1px solid var(--color-border);
		padding: 1rem 1.5rem 1.5rem;
		transform: translateY(-120%); transition: transform 0.35s var(--ease); z-index: 99;
	}
	.main-nav.is-open { transform: translateY(0); }
	.main-nav ul { flex-direction: column; gap: 0; width: 100%; }
	.main-nav li { border-bottom: 1px solid var(--color-border); }
	.main-nav a { display: block; padding: 1rem 0; font-size: 1.1rem; }
	.main-nav .btn { margin-top: 1rem; justify-content: center; }
}
@media (max-width: 560px) {
	.form-row { grid-template-columns: 1fr; }
	.footer__grid { grid-template-columns: 1fr; }
	.dir-filters .field { flex-basis: 100%; }
}
