/* =========================================================
   Roland Rugullis – Modern Design System
   ========================================================= */
:root{
	--navy:#16235a;
	--navy-2:#1d2f73;
	--navy-dark:#0f1840;
	--red:#e2001a;
	--red-dark:#bd0016;
	--ink:#161a26;
	--muted:#5d6478;
	--line:#e6e9f2;
	--bg:#ffffff;
	--bg-soft:#f4f6fb;
	--white:#fff;
	--radius:18px;
	--radius-sm:12px;
	--shadow-sm:0 4px 14px rgba(22,35,90,.07);
	--shadow:0 18px 50px rgba(22,35,90,.12);
	--shadow-lg:0 30px 70px rgba(22,35,90,.20);
	--maxw:1180px;
	--header-h:84px;
	--ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body.maler-modern{
	margin:0;
	font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
	color:var(--ink);
	background:var(--bg);
	line-height:1.65;
	-webkit-font-smoothing:antialiased;
	font-size:17px;
	overflow-x:hidden;
}
h1,h2,h3{overflow-wrap:break-word}
img{max-width:100%;height:auto;display:block}
a{color:var(--red);text-decoration:none}
h1,h2,h3{font-family:"Poppins",sans-serif;color:var(--navy);line-height:1.12;margin:0 0 .4em;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5.2vw,3.7rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:700}
h3{font-size:1.22rem;font-weight:600}
p{margin:0 0 1rem}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,8vw,110px) 0}
.section-alt{background:var(--bg-soft)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* Sichtbarer Tastatur-Fokus */
:where(a,button,.btn,.gallery-item,.nav-toggle,input,textarea,select):focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:8px}
.hero a:focus-visible,.cta-band a:focus-visible,.contact-card a:focus-visible,.site-footer a:focus-visible,.lightbox-close:focus-visible{outline-color:#fff}

.eyebrow{font-family:"Poppins",sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:600;color:var(--red);margin:0 0 .7rem}
.section-head{max-width:720px;margin:0 auto clamp(40px,5vw,64px);text-align:center}
.section-sub{color:var(--muted);font-size:1.08rem}
.section-note{text-align:center;color:var(--muted);margin-top:36px;font-weight:500}

/* ---------- Buttons ---------- */
.btn{
	display:inline-flex;align-items:center;justify-content:center;gap:.5em;
	font-family:"Poppins",sans-serif;font-weight:600;font-size:1rem;
	padding:14px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;
	transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
	line-height:1;text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:17px 34px;font-size:1.05rem}
.btn-block{display:flex;width:100%}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(226,0,26,.28)}
.btn-primary:hover{background:var(--red-dark);box-shadow:0 14px 30px rgba(226,0,26,.36)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--navy);background:var(--navy);color:#fff}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:#f0f2fa}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-outline-light:hover{background:#fff;color:var(--navy)}

/* ---------- Hinweis-Balken (Betrieb inaktiv) ---------- */
.notice-bar{background:var(--navy-dark);color:#fff;font-size:.92rem;line-height:1.45}
.notice-bar-inner{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 24px;text-align:center}
.notice-bar svg{flex:0 0 auto;color:#ffcf33}
.notice-bar strong{font-family:"Poppins",sans-serif;font-weight:600;color:#ffcf33}
@media (max-width:560px){
	.notice-bar{font-size:.82rem}
	.notice-bar-inner{align-items:flex-start;text-align:left;gap:8px}
	.notice-bar svg{margin-top:2px}
}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s}
.site-header.is-stuck{box-shadow:0 6px 24px rgba(22,35,90,.08);border-color:var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;min-height:var(--header-h)}
.brand{display:flex;align-items:center;margin-right:auto}
.brand img{height:40px;width:auto}
.main-nav ul{display:flex;gap:30px;list-style:none;margin:0;padding:0}
.main-nav a{font-family:"Poppins",sans-serif;font-weight:500;color:var(--navy);font-size:1rem;position:relative;padding:6px 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--red);transition:width .25s var(--ease)}
.main-nav a:hover,.main-nav a:focus-visible{color:var(--red)}
.main-nav a:hover::after,.main-nav a:focus-visible::after{width:100%}
.header-actions{display:flex;align-items:center;gap:16px}
.header-phone{display:inline-flex;align-items:center;gap:8px;color:var(--navy);font-weight:600;font-family:"Poppins",sans-serif;white-space:nowrap}
.header-phone:hover{color:var(--red)}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);margin:0 auto;transition:transform .3s,opacity .3s}
.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)}

.mobile-nav{display:none;flex-direction:column;gap:8px;padding:18px 24px 28px;background:#fff;border-bottom:1px solid var(--line)}
.mobile-nav[hidden]{display:none}
.mobile-nav.open{display:flex;animation:slideDown .3s var(--ease)}
.mobile-nav ul{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column}
.mobile-nav li a{display:block;padding:14px 4px;font-family:"Poppins",sans-serif;font-weight:500;color:var(--navy);font-size:1.1rem;border-bottom:1px solid var(--line)}
.mobile-phone{display:block;text-align:center;margin-top:12px;font-weight:600;color:var(--navy);font-family:"Poppins",sans-serif}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---------- Status-Hinweis (Betrieb inaktiv) ---------- */
.status-callout{display:flex;gap:13px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--navy);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow-sm)}
.status-callout svg{flex:0 0 auto;color:var(--navy);margin-top:1px}
.status-callout p{margin:0;color:var(--ink);font-size:1rem}
.status-callout strong{font-family:"Poppins",sans-serif;color:var(--navy)}
.status-callout--block{max-width:760px;margin:0 auto clamp(36px,4vw,52px)}
.hero .status-callout{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);border-left-color:#ffcf33;backdrop-filter:blur(4px);max-width:600px;margin:0 0 26px}
.hero .status-callout p{color:#fff}
.hero .status-callout strong,.hero .status-callout svg{color:#ffcf33}

/* ---------- Kontaktblock (neutrale Angaben, zentriert) ---------- */
.contact-block{max-width:560px;margin:0 auto}
.contact-block .contact-list{margin:0}
.contact-block .contact-list a{color:var(--ink)}
.contact-block .contact-list a:hover{color:var(--red)}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);z-index:-2}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(115deg,rgba(15,24,64,.93) 0%,rgba(22,35,90,.82) 45%,rgba(22,35,90,.55) 100%);z-index:-1}
.hero-inner{padding:clamp(90px,13vw,160px) 0 clamp(80px,11vw,140px);max-width:760px}
.hero .eyebrow{color:#ff8a97}
.hero h1{color:#fff}
.hero-lead{font-size:clamp(1.05rem,2vw,1.3rem);color:rgba(255,255,255,.9);max-width:620px;margin-bottom:2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:2.2rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px 22px}
.hero-badges span{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;color:rgba(255,255,255,.92);font-weight:500}
.hero-badges svg{color:#ff5d6c}

/* ---------- Stats ---------- */
.stats{margin-top:-58px;position:relative;z-index:5}
.stats-grid{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden}
.stat{padding:30px 22px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat-num{display:block;font-family:"Poppins",sans-serif;font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--red);line-height:1}
.stat-label{display:block;margin-top:8px;color:var(--muted);font-size:.95rem;font-weight:500}

/* ---------- Cards (Leistungen) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card-icon{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;margin-bottom:20px;transition:background .3s}
.card:hover .card-icon{background:linear-gradient(135deg,var(--red),var(--red-dark))}
.card h3{margin-bottom:.5em}
.card p{color:var(--muted);margin:0;font-size:.98rem}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(36px,5vw,70px);align-items:center}
.about-media{position:relative}
.about-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:4/3}
.about-media-badge{position:absolute;right:-14px;bottom:-14px;background:var(--red);color:#fff;border-radius:16px;padding:16px 20px;box-shadow:var(--shadow);font-family:"Poppins",sans-serif}
.about-media-num{font-weight:700;line-height:1.1;font-size:1.05rem;display:block;text-align:center}
.about-text h2{margin-top:.2em}
.check-list{list-style:none;margin:1.4rem 0;padding:0;display:grid;gap:12px}
.check-list li{position:relative;padding-left:36px;color:var(--ink)}
.check-list li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--red);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");background-size:16px;background-repeat:no-repeat;background-position:center}
.signature{font-family:"Poppins",sans-serif;font-weight:600;color:var(--navy);font-size:1.1rem;margin:.4rem 0 1.4rem}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery-item{position:relative;display:block;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-sm);aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-caption{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 14px;color:#fff;font-family:"Poppins",sans-serif;font-weight:500;font-size:.98rem;background:linear-gradient(transparent,rgba(15,24,64,.82));opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.gallery-item:hover .gallery-caption{opacity:1;transform:none}

/* ---------- Steps ---------- */
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px}
.step-num{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;font-family:"Poppins",sans-serif;font-weight:700;margin-bottom:16px}
.step h3{margin-bottom:.4em}
.step p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--navy-dark),var(--navy-2));color:#fff}
.cta-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:26px;padding:clamp(48px,6vw,72px) 24px}
.cta-inner--center{justify-content:center;text-align:center}
.cta-inner--center>div{max-width:760px}
.cta-inner--center p{margin:0 auto}
.cta-band h2{color:#fff;margin-bottom:.25em}
.cta-band p{color:rgba(255,255,255,.85);margin:0}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,5vw,60px);align-items:start}
.contact-list{list-style:none;margin:1.6rem 0 0;padding:0;display:grid;gap:22px}
.contact-list li{display:flex;gap:16px;align-items:flex-start}
.contact-ico{flex:0 0 auto;width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--bg-soft);color:var(--navy)}
.contact-list strong{font-family:"Poppins",sans-serif;color:var(--navy)}
.contact-list a{color:var(--ink)}
.contact-list a:hover{color:var(--red)}
.contact-card{background:var(--navy);color:#fff;border-radius:var(--radius);padding:36px 32px;box-shadow:var(--shadow)}
.contact-card h3{color:#fff}
.contact-card p{color:rgba(255,255,255,.82)}
.contact-card .btn{margin-bottom:12px}
.contact-card .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.contact-card .btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.contact-hours{font-size:.9rem;margin:14px 0 0;color:rgba(255,255,255,.7)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.78);padding-top:clamp(50px,6vw,72px)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.4fr 1fr;gap:40px;padding-bottom:46px}
.footer-brand img{height:42px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-brand p{font-size:.95rem;max-width:330px}
.site-footer h3{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer-col a{color:rgba(255,255,255,.78)}
.footer-col a:hover{color:#fff}
.site-footer address{font-style:normal;line-height:1.8;font-size:.95rem}
.site-footer address a{color:rgba(255,255,255,.78)}
.site-footer address a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom p{margin:0;padding:22px 0;font-size:.88rem;color:rgba(255,255,255,.6);text-align:center}

/* ---------- To-top + Lightbox ---------- */
.to-top{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;border:0;background:var(--red);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 24px rgba(226,0,26,.32);opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,transform .3s,visibility .3s;z-index:150}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--red-dark)}
.lightbox{position:fixed;inset:0;background:rgba(10,15,38,.92);display:flex;align-items:center;justify-content:center;padding:30px;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:var(--shadow-lg)}
.lightbox-close{position:absolute;top:22px;right:26px;width:48px;height:48px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:1.6rem;cursor:pointer;line-height:1}
.lightbox-close:hover{background:rgba(255,255,255,.28)}

/* ---------- Reveal animation (only when JS is active, so content never hides without JS) ---------- */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
	.cards{grid-template-columns:repeat(2,1fr)}
	.steps{grid-template-columns:repeat(2,1fr)}
	.footer-grid{grid-template-columns:1fr 1fr;gap:32px}
	.main-nav,.header-phone{display:none}
	.nav-toggle{display:flex}
}
@media (max-width:860px){
	.stats-grid{grid-template-columns:repeat(2,1fr)}
	.stat:nth-child(2){border-right:0}
	.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
	.about-grid{grid-template-columns:1fr;gap:48px}
	.about-media{max-width:520px}
	.contact-grid{grid-template-columns:1fr}
	.gallery{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
	body.maler-modern{font-size:16px}
	.hero h1{font-size:clamp(1.85rem,7.5vw,2.4rem)}
	.hero h1 br{display:none}
	.cards{grid-template-columns:1fr}
	.steps{grid-template-columns:1fr}
	.gallery{grid-template-columns:1fr}
	.footer-grid{grid-template-columns:1fr;gap:30px}
	.cta-inner{flex-direction:column;align-items:flex-start}
	.cta-actions{width:100%}
	.cta-actions .btn{flex:1}
	.hero-cta{flex-direction:column;align-items:stretch}
	.hero-cta .btn{width:100%}
}

@media (prefers-reduced-motion:reduce){
	*{scroll-behavior:auto!important}
	.js .reveal{opacity:1!important;transform:none!important;transition:none}
	.hero-bg{transform:none}
}
