/*
Theme Name: Firma Dirk Heising – Custom
Theme URI: https://firma-dirk-heising.lead.bummeltech.com/
Author: ECC / Claude
Description: Individuelles, hochwertiges Theme für die Firma Dirk Heising – Installateur Meisterbetrieb für Bäder, Heizungen, Sanitär & Klima. Premium-Look (Liquid Glass, Schwarz + Gold) mit 3D-Effekten, eigenem Slider (CPT) und voller wp-admin-Pflegbarkeit.
Version: 1.0.3
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: fdh
*/

/* =========================================================================
   0. Design Tokens (ui-ux-pro-max: Premium Black + Gold, Liquid Glass)
   ====================================================================== */
:root{
	--color-primary:#1C1917;
	--color-on-primary:#FFFFFF;
	--color-secondary:#44403C;
	--color-accent:#A16207;          /* Gold */
	--color-accent-bright:#CA8A04;
	--color-on-accent:#FFFFFF;
	--color-background:#FAFAF9;
	--color-foreground:#0C0A09;
	--color-card:#FFFFFF;
	--color-muted:#E8ECF0;
	--color-muted-fg:#64748B;
	--color-border:#D6D3D1;
	--color-ring:#1C1917;

	--grad-gold:linear-gradient(135deg,#CA8A04 0%,#A16207 55%,#7C4A02 100%);
	--grad-dark:linear-gradient(160deg,#1C1917 0%,#292524 60%,#0C0A09 100%);

	--glass-bg:rgba(255,255,255,.14);
	--glass-border:rgba(255,255,255,.22);
	--glass-blur:16px;

	--shadow-sm:0 1px 2px rgba(12,10,9,.06),0 2px 6px rgba(12,10,9,.06);
	--shadow-md:0 10px 30px -12px rgba(12,10,9,.25);
	--shadow-lg:0 30px 60px -20px rgba(12,10,9,.35);
	--shadow-gold:0 16px 40px -12px rgba(161,98,7,.45);

	--radius-sm:10px;
	--radius:18px;
	--radius-lg:28px;
	--radius-xl:36px;

	--container:1200px;
	--gap:clamp(1rem,3vw,2rem);
	--section-py:clamp(4rem,8vw,7.5rem);

	--ease:cubic-bezier(.22,.61,.36,1);
	--dur:280ms;

	--font-sans:"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* =========================================================================
   1. Reset / Base
   ====================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
	margin:0;
	font-family:var(--font-sans);
	font-size:clamp(1rem,.55vw + .9rem,1.125rem);
	line-height:1.7;
	color:var(--color-foreground);
	background:var(--color-background);
	-webkit-font-smoothing:antialiased;
	overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-accent);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--color-accent-bright)}
h1,h2,h3,h4{font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--color-primary);margin:0 0 .5em}
h1{font-size:clamp(2.3rem,5.2vw,4.2rem);font-weight:800}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.25rem,1.8vw,1.6rem)}
p{margin:0 0 1.1rem}
ul{margin:0 0 1.1rem;padding-left:1.2rem}
:focus-visible{outline:3px solid var(--color-accent-bright);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;z-index:9999;background:#fff;padding:.6rem 1rem;border-radius:8px;box-shadow:var(--shadow-md)}

/* Layout helpers */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-wide{width:min(100% - 2.4rem,1440px);margin-inline:auto}
.section{padding-block:var(--section-py)}
.section--dark{background:var(--grad-dark);color:#E7E5E4}
.section--dark h2,.section--dark h3{color:#fff}
.section--muted{background:linear-gradient(180deg,#fff 0%,var(--color-background) 100%)}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--grad-gold);display:inline-block;border-radius:2px}
.section-head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head.center{margin-inline:auto;text-align:center}
.lead{font-size:1.12rem;color:var(--color-muted-fg)}
.section--dark .lead{color:#A8A29E}

/* Icons */
.fdh-ico{width:1.4em;height:1.4em;flex:none}

/* Buttons */
.btn{
	display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;
	font-weight:700;font-size:1rem;line-height:1;border:0;border-radius:999px;
	padding:1.05rem 1.9rem;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease);
	will-change:transform;text-align:center;
}
.btn .fdh-ico{width:1.15em;height:1.15em}
.btn--primary{background:var(--grad-gold);color:#fff;box-shadow:var(--shadow-gold)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 22px 48px -12px rgba(161,98,7,.6);color:#fff}
.btn--ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-3px);color:#fff}
.btn--dark{background:var(--color-primary);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-3px);color:#fff}
.btn--outline{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-border)}
.btn--outline:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-3px)}

/* =========================================================================
   2. Header / Navbar (sticky, großzügig, Burger < 900px)
   ====================================================================== */
.site-header{position:sticky;top:0;z-index:1000;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),backdrop-filter var(--dur)}
.site-header__inner{
	display:flex;align-items:center;justify-content:space-between;gap:2rem;
	min-height:84px;padding-block:.6rem;
}
.site-header.scrolled,.no-hero .site-header{
	background:rgba(250,250,249,.82);
	backdrop-filter:blur(var(--glass-blur)) saturate(160%);
	-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);
	box-shadow:0 1px 0 var(--color-border),var(--shadow-sm);
}
/* Über dem Hero: transparent mit hellem Text */
.has-hero .site-header:not(.scrolled){background:transparent}
.has-hero .site-header:not(.scrolled) .nav-menu>li>a,
.has-hero .site-header:not(.scrolled) .brand__name{color:#fff}
.has-hero .site-header:not(.scrolled) .brand__tag{color:rgba(255,255,255,.75)}
.has-hero .site-header:not(.scrolled) .nav-toggle span{background:#fff}
.has-hero .site-header:not(.scrolled) .header-cta{color:#fff;border-color:rgba(255,255,255,.55)}

.brand{display:flex;align-items:center;gap:.85rem;flex:none}
.brand__logo img{max-height:54px;width:auto}
.brand__mark{
	width:46px;height:46px;border-radius:13px;background:var(--grad-gold);
	display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.2rem;
	box-shadow:var(--shadow-gold);flex:none;
}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__name{font-weight:800;font-size:1.18rem;letter-spacing:-.02em;color:var(--color-primary)}
.brand__tag{font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--color-muted-fg);text-transform:uppercase}

.primary-nav{display:flex;align-items:center;gap:2rem;margin-left:auto}
.nav-menu{display:flex;align-items:center;gap:.4rem;list-style:none;margin:0;padding:0}
.nav-menu li{position:relative}
.nav-menu>li>a{
	display:block;padding:.7rem 1.05rem;border-radius:999px;font-weight:600;font-size:.98rem;
	color:var(--color-primary);transition:color var(--dur),background var(--dur);white-space:nowrap;
}
.nav-menu>li>a:hover,.nav-menu>li.current-menu-item>a{color:var(--color-accent);background:rgba(161,98,7,.08)}
.has-hero .site-header:not(.scrolled) .nav-menu>li>a:hover{background:rgba(255,255,255,.14);color:#fff}

/* Dropdown (Sub-Menüs) */
.nav-menu .sub-menu{
	position:absolute;top:calc(100% + 10px);left:0;min-width:240px;list-style:none;margin:0;padding:.5rem;
	background:rgba(255,255,255,.96);backdrop-filter:blur(var(--glass-blur));
	border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);
	opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--dur) var(--ease);z-index:50;
}
.nav-menu li:hover>.sub-menu,.nav-menu li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu .sub-menu a{display:block;padding:.6rem .9rem;border-radius:10px;color:var(--color-primary);font-weight:600;font-size:.95rem}
.nav-menu .sub-menu a:hover{background:var(--color-muted);color:var(--color-accent)}

.header-cta{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;padding:.7rem 1.2rem;border-radius:999px;border:1.5px solid var(--color-accent);color:var(--color-accent);transition:all var(--dur) var(--ease);white-space:nowrap}
.header-cta:hover{background:var(--grad-gold);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:var(--shadow-gold)}

/* Burger */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:0;background:transparent;cursor:pointer;padding:0;border-radius:12px}
.nav-toggle span{display:block;width:24px;height:2.4px;border-radius:3px;background:var(--color-primary);transition:transform var(--dur) var(--ease),opacity var(--dur)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

@media (max-width:900px){
	.nav-toggle{display:flex}
	.primary-nav{
		position:fixed;inset:0 0 0 auto;width:min(86vw,360px);
		flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
		padding:6rem 1.6rem 2rem;margin:0;
		background:rgba(28,25,23,.97);backdrop-filter:blur(20px);
		transform:translateX(105%);transition:transform .4s var(--ease);
		box-shadow:var(--shadow-lg);overflow-y:auto;
	}
	.primary-nav.open{transform:translateX(0)}
	.nav-menu{flex-direction:column;align-items:stretch;gap:.2rem;width:100%}
	.nav-menu>li>a{color:#fff !important;font-size:1.1rem;padding:.95rem 1rem}
	.nav-menu>li>a:hover{background:rgba(255,255,255,.1)}
	.nav-menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:0;box-shadow:none;padding:.1rem 0 .4rem 1rem}
	.nav-menu .sub-menu a{color:rgba(255,255,255,.8)}
	.nav-menu .sub-menu a:hover{background:rgba(255,255,255,.08);color:#fff}
	.header-cta{margin-top:1.2rem;justify-content:center;color:#fff !important;border-color:rgba(255,255,255,.5) !important}
	.nav-backdrop{position:fixed;inset:0;background:rgba(12,10,9,.5);opacity:0;visibility:hidden;transition:opacity var(--dur);z-index:999}
	.nav-backdrop.show{opacity:1;visibility:visible}
}

/* =========================================================================
   3. Hero (3D, parallax, glass)
   ====================================================================== */
.hero{position:relative;min-height:clamp(620px,92vh,960px);display:flex;align-items:center;color:#fff;isolation:isolate;overflow:hidden;margin-top:-84px;padding-top:84px}
.hero__bg{position:absolute;inset:0;z-index:-3;background-size:cover;background-position:center;transform:scale(1.08);will-change:transform}
.hero__overlay{position:absolute;inset:0;z-index:-2;background:linear-gradient(115deg,rgba(12,10,9,.92) 0%,rgba(28,25,23,.72) 45%,rgba(28,25,23,.35) 100%)}
.hero__glow{position:absolute;z-index:-1;width:60vmax;height:60vmax;border-radius:50%;filter:blur(90px);opacity:.5;pointer-events:none}
.hero__glow--gold{background:radial-gradient(circle,rgba(202,138,4,.5),transparent 62%);top:-18vmax;right:-12vmax;animation:floatGlow 14s var(--ease) infinite alternate}
.hero__glow--blue{background:radial-gradient(circle,rgba(56,93,140,.4),transparent 62%);bottom:-22vmax;left:-12vmax;animation:floatGlow 18s var(--ease) infinite alternate-reverse}
@keyframes floatGlow{to{transform:translate3d(40px,30px,0) scale(1.12)}}

.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center;width:100%;padding-block:clamp(3rem,7vw,5rem)}
.hero__badge{display:inline-flex;align-items:center;gap:.55rem;padding:.5rem 1rem;border-radius:999px;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(10px);font-size:.82rem;font-weight:700;letter-spacing:.04em;margin-bottom:1.6rem}
.hero__badge .fdh-ico{width:1.05em;height:1.05em;color:var(--color-accent-bright)}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero h1 .hl{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__sub{font-size:1.18rem;color:rgba(255,255,255,.88);max-width:54ch;margin-bottom:2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.2rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.4rem 2rem}
.hero__trust .ti{display:flex;align-items:center;gap:.55rem;font-size:.92rem;font-weight:600;color:rgba(255,255,255,.9)}
.hero__trust .fdh-ico{color:var(--color-accent-bright);width:1.3em;height:1.3em}

/* Hero floating glass card (3D) */
.hero__card{
	position:relative;perspective:1200px;
}
.hero__card-inner{
	background:var(--glass-bg);border:1px solid var(--glass-border);
	backdrop-filter:blur(var(--glass-blur)) saturate(150%);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);
	border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-lg);
	transform-style:preserve-3d;transition:transform .35s var(--ease);
}
.hero__card-inner h3{color:#fff;font-size:1.15rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:.5rem}
.hero__card-inner h3 .fdh-ico{color:var(--color-accent-bright)}
.hero__stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;transform:translateZ(40px)}
.hero__stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:1.1rem}
.hero__stat .num{font-size:1.9rem;font-weight:800;color:#fff;line-height:1}
.hero__stat .lbl{font-size:.82rem;color:rgba(255,255,255,.75);margin-top:.35rem;display:block}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.hero__scroll .mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.5);border-radius:14px;position:relative}
.hero__scroll .mouse::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:7px;background:rgba(255,255,255,.8);border-radius:2px;animation:scrollDot 1.6s infinite}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

@media (max-width:880px){
	.hero__inner{grid-template-columns:1fr;gap:2.4rem}
	.hero__card{max-width:480px}
	.hero{min-height:auto;padding-block:7rem 4rem}
}

/* =========================================================================
   4. USP / Trust bar
   ====================================================================== */
.usps{position:relative;margin-top:-3.5rem;z-index:5}
.usps__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.usp{
	background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);
	padding:1.6rem 1.4rem;box-shadow:var(--shadow-md);text-align:center;
	transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.usp:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.usp__ico{width:52px;height:52px;margin:0 auto .9rem;border-radius:14px;display:grid;place-items:center;background:rgba(161,98,7,.1);color:var(--color-accent)}
.usp__ico .fdh-ico{width:26px;height:26px}
.usp h3{font-size:1.05rem;margin-bottom:.3rem}
.usp p{font-size:.9rem;color:var(--color-muted-fg);margin:0}
@media (max-width:880px){.usps__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.usps__grid{grid-template-columns:1fr}}

/* =========================================================================
   5. Services (3D tilt cards)
   ====================================================================== */
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,1.8rem)}
.service-card{
	position:relative;perspective:1000px;
}
.service-card__inner{
	background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);
	overflow:hidden;box-shadow:var(--shadow-md);height:100%;display:flex;flex-direction:column;
	transform-style:preserve-3d;transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.service-card:hover .service-card__inner{box-shadow:var(--shadow-lg)}
.service-card__media{position:relative;aspect-ratio:16/10;overflow:hidden}
.service-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.service-card:hover .service-card__media img{transform:scale(1.08)}
.service-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(12,10,9,.45))}
.service-card__badge{position:absolute;top:1rem;left:1rem;z-index:2;width:48px;height:48px;border-radius:13px;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(10px);display:grid;place-items:center;color:#fff;transform:translateZ(40px)}
.service-card__badge .fdh-ico{width:24px;height:24px}
.service-card__body{padding:1.5rem 1.5rem 1.7rem;display:flex;flex-direction:column;flex:1}
.service-card__body h3{margin-bottom:.5rem}
.service-card__body p{color:var(--color-muted-fg);font-size:.96rem;flex:1}
.service-card__link{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--color-accent);margin-top:.6rem}
.service-card__link .fdh-ico{width:1.1em;height:1.1em;transition:transform var(--dur) var(--ease)}
.service-card:hover .service-card__link .fdh-ico{transform:translateX(5px)}
@media (max-width:980px){.services__grid{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.services__grid{grid-template-columns:1fr}}

/* =========================================================================
   6. Slider (CPT slide) – scroll-snap + auto-advance
   ====================================================================== */
.slider{position:relative}
.slider__track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:0;scrollbar-width:none;border-radius:var(--radius-lg)}
.slider__track::-webkit-scrollbar{display:none}
.slide{position:relative;flex:0 0 100%;scroll-snap-align:center;min-height:clamp(380px,56vh,560px);display:flex;align-items:flex-end;overflow:hidden}
.slide__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 6s var(--ease)}
.slide.is-active .slide__bg{transform:scale(1.08)}
.slide__overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(12,10,9,.85) 0%,rgba(12,10,9,.25) 55%,transparent 100%)}
.slide__content{position:relative;z-index:2;padding:clamp(1.6rem,4vw,3rem);max-width:680px;color:#fff}
.slide__content .eyebrow{color:var(--color-accent-bright)}
.slide__content h3{color:#fff;font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:.6rem}
.slide__content p{color:rgba(255,255,255,.9);margin:0}
.slider__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:50px;height:50px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.18);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.35);color:#fff;display:grid;place-items:center;transition:background var(--dur),transform var(--dur)}
.slider__nav:hover{background:var(--grad-gold);transform:translateY(-50%) scale(1.06)}
.slider__nav .fdh-ico{width:22px;height:22px}
.slider__nav--prev{left:1rem}.slider__nav--prev .fdh-ico{transform:rotate(180deg)}
.slider__nav--next{right:1rem}
.slider__dots{display:flex;justify-content:center;gap:.55rem;margin-top:1.4rem}
.slider__dots button{width:10px;height:10px;border-radius:50%;border:0;cursor:pointer;background:var(--color-border);padding:0;transition:all var(--dur) var(--ease)}
.slider__dots button.active{background:var(--grad-gold);width:30px;border-radius:6px}
@media (max-width:620px){.slider__nav{display:none}}

/* =========================================================================
   7. About (split, parallax image)
   ====================================================================== */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about__media{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.about__media img{width:100%;height:100%;object-fit:cover}
.about__badge{position:absolute;bottom:1.4rem;left:1.4rem;right:1.4rem;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius);padding:1.1rem 1.3rem;color:#fff;display:flex;align-items:center;gap:.9rem}
.about__badge .fdh-ico{width:34px;height:34px;color:var(--color-accent-bright);flex:none}
.about__badge strong{display:block;font-size:1.05rem}
.about__badge span{font-size:.85rem;color:rgba(255,255,255,.8)}
.about__list{list-style:none;padding:0;margin:1.4rem 0 2rem;display:grid;gap:.8rem}
.about__list li{display:flex;align-items:flex-start;gap:.7rem;font-weight:600}
.about__list .fdh-ico{color:var(--color-accent);width:1.4em;height:1.4em;flex:none;margin-top:.1rem}
@media (max-width:880px){.about__grid{grid-template-columns:1fr}.about__media{order:-1}}

/* =========================================================================
   8. Process / Ablauf
   ====================================================================== */
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.step{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.8rem 1.4rem;transition:transform var(--dur) var(--ease),background var(--dur)}
.step:hover{transform:translateY(-6px);background:rgba(255,255,255,.07)}
.step__num{counter-increment:step;font-size:2.6rem;font-weight:800;line-height:1;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.6rem}
.step__num::before{content:"0" counter(step)}
.step h3{color:#fff;font-size:1.15rem;margin-bottom:.4rem}
.step p{color:#A8A29E;font-size:.92rem;margin:0}
@media (max-width:980px){.process__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.process__grid{grid-template-columns:1fr}}

/* =========================================================================
   9. CTA band
   ====================================================================== */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:clamp(2.6rem,6vw,4.5rem);background:var(--grad-gold);color:#fff;box-shadow:var(--shadow-gold)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,rgba(255,255,255,.35),transparent 50%);pointer-events:none}
.cta-band__inner{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.8rem}
.cta-band h2{color:#fff;max-width:20ch;margin:0}
.cta-band p{color:rgba(255,255,255,.92);margin:.5rem 0 0;max-width:46ch}
.cta-band .btn--dark{background:#fff;color:var(--color-primary)}
.cta-band .btn--dark:hover{background:var(--color-primary);color:#fff}

/* =========================================================================
   10. Contact
   ====================================================================== */
.contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,4vw,3.4rem);align-items:start}
.contact__cards{display:grid;gap:1rem}
.contact-card{display:flex;align-items:flex-start;gap:1rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.3rem 1.4rem;box-shadow:var(--shadow-sm);transition:transform var(--dur) var(--ease),box-shadow var(--dur)}
.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.contact-card__ico{width:48px;height:48px;border-radius:13px;background:rgba(161,98,7,.1);color:var(--color-accent);display:grid;place-items:center;flex:none}
.contact-card__ico .fdh-ico{width:24px;height:24px}
.contact-card strong{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-fg);margin-bottom:.2rem}
.contact-card a,.contact-card span{font-size:1.1rem;font-weight:700;color:var(--color-primary)}
.contact-card a:hover{color:var(--color-accent)}
.contact__form{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-md)}
/* Kontaktformular-Plugin Styling */
.contact__form input[type=text],.contact__form input[type=email],.contact__form input[type=tel],.contact__form textarea,.contact__form select{
	width:100%;padding:.9rem 1.1rem;border:1.5px solid var(--color-border);border-radius:12px;font-family:inherit;font-size:1rem;background:#fff;color:var(--color-foreground);margin-bottom:1rem;transition:border-color var(--dur),box-shadow var(--dur)
}
.contact__form input:focus,.contact__form textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(161,98,7,.15)}
.contact__form textarea{min-height:130px;resize:vertical}
.contact__form button,.contact__form input[type=submit]{
	background:var(--grad-gold);color:#fff;border:0;border-radius:999px;padding:1rem 2rem;font-weight:700;font-size:1rem;cursor:pointer;transition:transform var(--dur),box-shadow var(--dur);box-shadow:var(--shadow-gold)
}
.contact__form button:hover,.contact__form input[type=submit]:hover{transform:translateY(-3px)}
.contact__form label{font-weight:600;font-size:.95rem;display:block;margin-bottom:.3rem}
@media (max-width:880px){.contact__grid{grid-template-columns:1fr}}

/* =========================================================================
   11. Page content (Unterseiten)
   ====================================================================== */
.page-hero{position:relative;padding:clamp(7rem,14vw,10rem) 0 clamp(3rem,6vw,5rem);color:#fff;text-align:center;overflow:hidden;isolation:isolate;margin-top:-84px}
.page-hero__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(160deg,rgba(12,10,9,.9),rgba(28,25,23,.75))}
.page-hero h1{color:#fff;margin-bottom:.6rem}
.page-hero p{color:rgba(255,255,255,.85);max-width:60ch;margin-inline:auto}
.breadcrumbs{font-size:.85rem;color:rgba(255,255,255,.65);margin-bottom:1rem}
.breadcrumbs a{color:rgba(255,255,255,.85)}
.entry-content{max-width:760px;margin-inline:auto}
.entry-content h2{margin-top:2.2rem}
.entry-content h3{margin-top:1.6rem}
.entry-content img{border-radius:var(--radius);box-shadow:var(--shadow-md);margin-block:1.4rem}
.entry-content ul li{margin-bottom:.5rem}
.entry-content blockquote{border-left:4px solid var(--color-accent);background:var(--color-muted);padding:1rem 1.4rem;border-radius:0 12px 12px 0;margin:1.4rem 0;font-style:italic}
.content-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.2rem;margin:1.8rem 0;list-style:none;padding:0}
.content-cards li{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow-sm);display:flex;gap:.8rem;align-items:flex-start;margin:0}
.content-cards .fdh-ico{color:var(--color-accent);flex:none;width:1.6em;height:1.6em}

/* =========================================================================
   12. Footer
   ====================================================================== */
.site-footer{background:var(--grad-dark);color:#A8A29E;padding-top:clamp(3rem,6vw,4.5rem)}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.4rem;padding-bottom:2.6rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand .brand__name{color:#fff}
.footer__about{margin:1rem 0;font-size:.94rem;max-width:34ch}
.footer h4{color:#fff;font-size:1rem;margin-bottom:1.1rem;letter-spacing:.02em}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer a{color:#A8A29E}
.footer a:hover{color:var(--color-accent-bright)}
.footer__contact li{display:flex;align-items:flex-start;gap:.6rem;font-size:.94rem}
.footer__contact .fdh-ico{color:var(--color-accent-bright);width:1.2em;height:1.2em;flex:none;margin-top:.15rem}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-block:1.5rem;font-size:.85rem}
.footer__bottom nav{display:flex;flex-wrap:wrap;gap:1.2rem}
@media (max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer__grid{grid-template-columns:1fr}}

/* =========================================================================
   13. Scroll-Reveal Animations
   ====================================================================== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}

/* =========================================================================
   14. A11y / Motion
   ====================================================================== */
@media (prefers-reduced-motion:reduce){
	*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
	.hero__bg{transform:none}
	.reveal{opacity:1;transform:none}
}
