:root{
  --bg:#091528;
  --bg2:#0e213c;
  --panel:#173253cc;
  --panel-solid:#173253;
  --panel-2:#223f63;
  --line:rgba(255,255,255,.08);
  --text:#f7f6f1;
  --muted:#d4dced;
  --gold:#ebc84e;
  --gold-strong:#f0cf58;
  --shadow:0 18px 40px rgba(0,0,0,.18);
  --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Roboto",system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 70% 15%, rgba(255,255,255,.06), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0) 18%),
    linear-gradient(180deg, #10284a 0%, #0c1d35 40%, #081426 100%);
}
a{text-decoration:none;color:inherit}
.wrap{width:min(1180px, calc(100% - 56px)); margin:0 auto}
.section-line{border-top:1px solid var(--line)}
.topbar{
  position:sticky; top:0; z-index:30;
  background:rgba(9,21,40,.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  min-height:86px;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-icon,.footer-mark{
  width:30px;height:30px;border-radius:50%;
  display:grid;place-items:center;
  color:var(--gold); font-size:20px; line-height:1;
}
.brand-text{display:flex; flex-direction:column}
.brand-title{font-size:1.06rem; font-weight:800; letter-spacing:.02em}
.brand-sub{font-size:.92rem; color:var(--gold); font-weight:700}
.mainnav{display:flex; gap:36px; font-weight:700}
.mainnav a{color:#eef3ff}
.nav-actions{display:flex; gap:12px}
.pill{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:110px; height:46px; padding:0 18px; border-radius:14px;
  font-weight:700; border:1px solid rgba(255,255,255,.14);
}
.pill-dark{background:transparent}
.pill-gold{background:var(--gold); color:#302300; border-color:transparent}

.hero{
  padding:54px 0 56px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0) 28%),
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.04), transparent 30%);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.25fr .72fr;
  gap:34px;
  align-items:center;
}
.hero-copy h1{
  font-size:clamp(2.6rem, 5vw, 4.4rem);
  line-height:1.02;
  margin:0 0 24px;
  max-width:11ch;
  font-weight:800;
}
.hero-copy h1 span,
.intro h2 span,
.contact-copy h2 span{color:var(--gold)}
.hero-copy p{
  font-size:1.08rem;
  line-height:1.55;
  color:var(--muted);
  max-width:710px;
  margin:0 0 20px;
}
.hero-buttons{display:flex; gap:16px; padding-top:10px}
.cta{
  min-height:54px; padding:0 24px; border-radius:14px;
  display:inline-flex; align-items:center; justify-content:center;
  font-weight:700; border:1px solid rgba(255,255,255,.14);
}
.cta-gold{background:var(--gold-strong); color:#342700; border-color:transparent}
.cta-outline{background:rgba(16,33,59,.55)}

.contact-panel,
.feature-card,
.service-card,
.contact-form{
  background:linear-gradient(180deg, rgba(33,61,95,.76), rgba(21,45,74,.78));
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  box-shadow:var(--shadow);
}
.contact-panel{padding:34px 28px}
.contact-panel h3{
  margin:0 0 12px;
  font-size:1.6rem;
  font-weight:800;
}
.contact-panel p{margin:0 0 24px; color:var(--muted); line-height:1.55}
.mini-contact{
  display:flex; gap:14px; align-items:flex-start;
  padding:13px 0;
}
.mini-icon{
  width:42px;height:42px;border-radius:12px;
  display:grid;place-items:center;
  background:rgba(240,207,88,.12);
  color:var(--gold);
  flex:0 0 42px;
}
.mini-contact span{
  display:block; font-size:.92rem; color:#d7e0f3;
}
.mini-contact strong{
  display:block; padding-top:2px; font-size:1rem;
}

.features{padding:28px 0 42px}
.feature-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
}
.feature-card{
  min-height:142px; padding:28px 22px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
}
.feature-icon{font-size:1.7rem; color:var(--gold); margin-bottom:14px}
.feature-card strong{font-size:1.18rem; margin-bottom:4px}
.feature-card span{color:var(--muted)}

.section-center{padding:36px 0 12px}
.narrow{max-width:900px; text-align:center}
.intro h2{
  font-size:clamp(2rem, 3.5vw, 3.4rem);
  line-height:1.08;
  margin:0 0 18px;
  font-weight:800;
}
.intro p{
  color:var(--muted);
  font-size:1.1rem;
  line-height:1.6;
  margin:0 auto;
}

.services{padding:34px 0 58px}
.services-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
}
.service-card{padding:26px 24px 28px; min-height:430px}
.service-icon{font-size:1.7rem; color:var(--gold); margin-bottom:16px}
.service-card h3{
  margin:0 0 14px; font-size:1.95rem; font-weight:800;
}
.service-card p{
  margin:0 0 18px; color:var(--muted); line-height:1.55;
}
.service-card ul{margin:0; padding-left:20px}
.service-card li{
  margin:10px 0; color:var(--text);
}
.service-card li::marker{color:var(--gold)}

.about{padding:42px 0 60px}
.section-head{
  text-align:center;
  font-size:clamp(2rem, 3.2vw, 3.2rem);
  color:var(--gold);
  margin:0 0 30px;
  font-weight:800;
}
.about-grid{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:34px;
  align-items:start;
}
.about-images{display:flex; flex-direction:column; gap:16px}
.image-placeholder,
.photo-card{
  border-radius:18px;
  border:1px solid rgba(235,200,78,.45);
  background:rgba(182,196,220,.06);
  min-height:190px;
  display:grid; place-items:center;
  color:#cdd8e9;
  font-weight:500;
  overflow:hidden;
}
.photo-1,.photo-2,.photo-3{
  min-height:160px;
  border-color:rgba(255,255,255,.09);
  background:linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.05));
}
.about-copy p{
  margin:0 0 22px;
  font-size:1.04rem;
  line-height:1.62;
  color:#f0f4fb;
}

.contact{padding:44px 0 44px}
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:start;
}
.contact-copy h2{
  margin:0 0 18px; font-size:clamp(2rem, 3.5vw, 3.2rem); line-height:1.06; font-weight:800;
}
.contact-copy p{
  margin:0 0 28px; color:var(--muted); font-size:1.08rem; line-height:1.58;
}
.contact-list{display:flex; flex-direction:column; gap:14px; font-size:1.05rem}
.contact-list strong{line-height:1.4}
.contact-list a,.contact-list span{color:#eff3fb}
.contact-form{
  padding:30px;
  display:grid;
  gap:14px;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:none;
  outline:none;
  color:var(--text);
  background:linear-gradient(180deg, rgba(120,151,193,.36), rgba(94,123,161,.26));
  border-radius:12px;
  min-height:54px;
  padding:0 16px;
  font:inherit;
}
.contact-form textarea{
  min-height:140px;
  padding-top:16px;
  resize:vertical;
}
.contact-form select{appearance:auto}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:#eef3fb}
.contact-form button{
  min-height:56px;
  border:none;
  border-radius:12px;
  background:var(--gold-strong);
  color:#382a00;
  font:inherit;
  font-weight:700;
  cursor:pointer;
  margin-top:8px;
}

.footer{
  border-top:1px solid var(--line);
  padding:26px 0 34px;
}
.footer-row{
  display:flex; justify-content:space-between; gap:20px; align-items:center; flex-wrap:wrap;
}
.footer-left,.footer-right{display:flex; gap:18px; align-items:center; color:#eef3fb}
.footer-right a{color:#eef3fb}

@media (max-width:1100px){
  .hero-grid,.about-grid,.contact-grid,.feature-grid,.services-grid{
    grid-template-columns:1fr 1fr;
  }
  .services-grid{grid-template-columns:1fr 1fr}
  .feature-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .wrap{width:min(100% - 28px, 1180px)}
  .nav{min-height:auto; padding:14px 0; flex-direction:column; align-items:flex-start}
  .mainnav,.nav-actions{width:100%; flex-wrap:wrap}
  .hero-grid,.about-grid,.contact-grid,.services-grid,.feature-grid{
    grid-template-columns:1fr;
  }
  .hero{padding-top:28px}
  .hero-copy h1{max-width:none}
  .contact-panel,.contact-form,.service-card,.feature-card{border-radius:16px}
}


.brand-logo{
  width:42px;
  height:42px;
  object-fit:contain;
  display:block;
}
.footer-logo{
  width:28px;
  height:28px;
  object-fit:contain;
  display:block;
}
.about-images .photo-card{
  margin:0;
  min-height:180px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.09);
}
.about-images .photo-large{
  min-height:240px;
}
.about-images .photo-card img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.about-images .photo-large img{
  object-position:center 20%;
}
@media (max-width:760px){
  .brand-logo{width:36px;height:36px}
  .footer-logo{width:24px;height:24px}
}


.legal-page{
  padding: 52px 0 70px;
}
.legal-wrap{
  max-width: 860px;
}
.legal-wrap h1{
  font-size: clamp(2rem, 4vw, 3rem);
  margin: 0 0 22px;
}
.legal-wrap h2{
  font-size: 1.35rem;
  margin: 34px 0 12px;
  color: var(--gold);
}
.legal-wrap p,
.legal-wrap li{
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--text);
}
.back-link{
  display: inline-block;
  margin-top: 20px;
  color: var(--gold);
  font-weight: 700;
}

.hp-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}

.status-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px;
}
.status-card{
  width:min(680px, 100%);
  text-align:center;
  padding:42px 28px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(33,61,95,.82), rgba(21,45,74,.86));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
}
.status-logo{
  width:72px;
  height:72px;
  object-fit:contain;
  display:block;
  margin:0 auto 20px;
}
.status-card h1{
  margin:0 0 14px;
  font-size:clamp(2rem, 4vw, 3rem);
}
.status-card p{
  margin:0 0 26px;
  color:var(--muted);
  font-size:1.05rem;
  line-height:1.6;
}
.status-links{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}









/* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil */

/* ---------- Hover‑Effekte für Links ----------
   (gilt für Hero‑Links, Nav‑Links und Footer‑Links) */
a:hover,
a:focus {
    color: var(--gold);          /* goldene Akzentfarbe */
    text-decoration: underline;
    transition: color .25s ease, text-decoration .25s ease;
}

/* ---------- Hover‑Effekte für die CTA‑Buttons (.pill) ----------
   (z. B. „Anfrage senden“, „Mehr erfahren“) */
.pill:hover,
.pill:focus {
    transform: translateY(-3px);
    box-shadow: 0 8px 18px rgba(0,0,0,.16);
    background: var(--gold);
    color: #302300;             /* dunkles Text‑Kontrast */
    border-color: transparent;
    transition: all .25s ease;
}

/* ---------- Hover‑Effekte für die Dienstleistungs‑Cards ----------
   (Karten in den Service‑Sektionen) */
.card, .service-card {          /* falls unterschiedliche Klassen existieren */
    transition: transform .25s ease, box-shadow .25s ease;
}
.card:hover, .service-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0,0,0,.20);
    border-color: var(--gold);
}

/* ---------- Hover‑Overlay für Bilder (z. B. hero‑Image) ----------
   Falls ein transparentes weißes Overlay genutzt wird */
.hero .overlay,
.card .overlay {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.05);
    opacity: 0;
    transition: opacity .25s ease;
}
.hero:hover .overlay,
.card:hover .overlay {
    opacity: 1;
}

/* ---------- Footer‑Links ----------
   (kleine zusätzliche Hover‑Akzentuierung) */
footer a:hover,
footer a:focus {
    color: var(--gold);
    text-decoration: underline;
}


/* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil *//* Basis‑Link‑Stil */

/*--- Hover für generische CTA‑Buttons ---*/
.cta:hover,
.cta:focus {
    transform: translateY(-3px);
    box-shadow: 0 8px 18px rgba(0,0,0,.16);
    background: var(--gold-strong);          /* bei cta-gold bleibt gold */
    color: #342700;                          /* Textfarbe für gold‑Button */
    border-color: transparent;
    transition: all .25s ease;
}

/* Spezifischer Hover für den Outline‑Button “Kontakt” */
.cta-outline:hover,
.cta-outline:focus {
    background: var(--gold-strong);          /* Farbe ändern, z. B. gold */
    color: #342700;                          /* Textfarbe */
    box-shadow: 0 8px 18px rgba(0,0,0,.16);
    transform: translateY(-3px);
    transition: all .25s ease;
}

/* -------- Hover‑Effekt für die Mini‑Contact‑Container -------- */
.mini-contact {
    transition: background-color .25s ease, border-radius .25s ease;
}

.mini-contact:hover {
    background: rgba(255, 255, 255, 0.12);   /* weiß, 12 % Deckkraft */
    border-radius: 16px;                     /* abgerundete Ecken */
	padding-left:20px;
}