/*
Theme Name: GeneratePress Child - MS-KI
Template: generatepress
Version: 1.0.0
*/

/* Parent-Theme CSS laden (Quickstart). Später können wir das per enqueue optimieren. */
@import url("../generatepress/style.css");

:root{
  --mski-hero1:#f97316;
  --mski-hero2:#ef4444;
  --mski-hero3:#7f1d1d;
  --mski-accent:#f97316;
  --mski-accent2:#b91c1c;
  --mski-bg:#fff7ed;
  --mski-card:#ffffff;
  --mski-border:#fde2cf;
  --mski-text:#1f2937;
  --mski-muted:#4b5563;

  --mski-hero-watermark: url('https://ms-ki.de/wp-content/uploads/2025/12/generated-image-2025-12-22.png');
}

.mski-wrap{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--mski-text);
  line-height:1.5;
  background:var(--mski-bg);
}

.mski-container{max-width:1100px;margin:0 auto;padding:28px 18px}

.mski-hero{
  position:relative;
  background: linear-gradient(135deg, var(--mski-hero1) 0%, var(--mski-hero2) 48%, var(--mski-hero3) 100%);
  color:#fff;
  border-radius:18px;
  overflow:hidden;
}

.mski-hero::after{
  content:"";
  position:absolute;
  inset:-10%;
  background-image: var(--mski-hero-watermark);
  background-repeat:no-repeat;
  background-position: 78% 55%;
  background-size: 560px auto;
  opacity:.11;
  pointer-events:none;
  filter: saturate(1.05) contrast(1.05);
}

/* HERO Höhe – Variante A (moderater) */
.mski-hero .mski-container{
  min-height: 78vh;
  display:flex;
  align-items:center;
  padding: 64px 26px;
}

@media (max-width:860px){
  .mski-hero .mski-container{
    min-height: auto;     /* Mobile: nicht erzwungen */
    padding: 44px 18px;
  }
}

.mski-hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  align-items:center;
}

/* Logo im Hero (groß & bündig) */
.mski-brand{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  margin: 0 0 12px 0;
  padding: 0;
}
.mski-brand-logo{
  width: 300px;
  max-width: 100%;
  height: auto;
  display:block;
  margin: 0;
}

/* Hero Foto (Standard-Card) */
.mski-hero-photo{
  justify-self:end;
  width:100%;
  max-width:360px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.22);
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
  background: rgba(255,255,255,.06);
}
.mski-hero-photo img{display:block;width:100%;height:auto}

/* Hero-Foto: Clean (freigestellt, ohne Kasten) */
.mski-hero .mski-hero-photo.ms-ki-hero-photo--clean,
.mski-hero .mski-hero-photo.mski-hero-photo--clean{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
.mski-hero .mski-hero-photo.mski-hero-photo--clean img{
  display:block;
  width:100%;
  height:auto;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.mski-kicker{letter-spacing:.08em;text-transform:uppercase;font-size:12px;opacity:.9;margin:0 0 10px}
.mski-h1{font-size:38px;line-height:1.15;margin:0 0 14px}
.mski-sub{font-size:18px;opacity:.95;max-width:70ch;margin:0 0 22px}

.mski-btnrow{display:flex;gap:12px;flex-wrap:wrap}
.mski-btn{
  display:inline-block;
  padding:12px 16px;
  border-radius:12px;
  text-decoration:none;
  font-weight:800;
  border:none;
  cursor:pointer;
}

/* Buttons: Primary transparent wie Kontakt */
.mski-btn.primary{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
}
.mski-btn.primary:hover{
  background:rgba(255,255,255,.18);
}

.mski-btn.secondary{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
}
.mski-btn.secondary:hover{background:rgba(255,255,255,.18)}

.mski-nav{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.mski-nav a{color:rgba(255,255,255,.9);text-decoration:none;font-size:14px}
.mski-nav a:hover{color:#fff;text-decoration:underline}

.mski-section{padding:18px 0}
.mski-h2{font-size:26px;margin:0 0 10px}
.mski-lead{margin:0 0 18px;color:var(--mski-muted);max-width:85ch}

.mski-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.mski-card{
  grid-column:span 6;
  background:var(--mski-card);
  border:1px solid var(--mski-border);
  border-radius:16px;
  padding:18px;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.mski-card h3{margin:0 0 8px;font-size:18px}
.mski-card p{margin:0 0 12px;color:var(--mski-muted)}
.mski-card a{font-weight:900;text-decoration:none;color:#111}
.mski-card a:hover{text-decoration:underline}

.mski-steps{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.mski-step{
  grid-column:span 4;
  background:rgba(255,255,255,.6);
  border:1px solid var(--mski-border);
  border-radius:16px;
  padding:16px;
}
.mski-step strong{display:block;margin-bottom:6px}

.mski-about{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;align-items:start}
.mski-about .text{grid-column:span 7}
.mski-about .facts{grid-column:span 5;background:#fff;border:1px solid var(--mski-border);border-radius:16px;padding:16px}
.mski-list{margin:10px 0 0;padding-left:18px;color:var(--mski-muted)}
.mski-list li{margin:6px 0}

.mski-contact{background:#111827;color:#fff;border-radius:18px}
.mski-contact .mski-container{padding:34px 22px}
.mski-contact p{opacity:.92;max-width:80ch}
.mski-footnote{font-size:12px;color:#6b7280;margin-top:10px}

.mski-form{margin-top:14px;max-width:720px}
.mski-form .row{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;margin-bottom:12px}
.mski-form .col6{grid-column:span 6}
.mski-form .col12{grid-column:span 12}
.mski-form label{display:block;font-weight:700;margin:0 0 6px}
.mski-form input,.mski-form select,.mski-form textarea{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  color:#fff;
  outline:none;
}
.mski-form textarea{min-height:140px;resize:vertical}
.mski-form input::placeholder,.mski-form textarea::placeholder{color:rgba(255,255,255,.65)}
.mski-form .hint{font-size:12px;color:rgba(255,255,255,.75)}
.mski-form .check{display:flex;gap:10px;align-items:flex-start}
.mski-form .check input{width:auto;margin-top:4px}
.mski-form .error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);padding:10px 12px;border-radius:12px}
.mski-form .success{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.35);padding:10px 12px;border-radius:12px}

/* Onepage: GeneratePress Wrapper neutralisieren */
.page-template-page-mski-onepage .inside-article{
  padding: 0 !important;
  background: transparent !important;
}
.page-template-page-mski-onepage .entry-content{
  margin: 0 !important;
}
.page-template-page-mski-onepage .site-content,
.page-template-page-mski-onepage .content-area,
.page-template-page-mski-onepage .site-main{
  max-width: none !important;
  width: 100% !important;
}

@media (max-width:860px){
  .mski-h1{font-size:30px}
  .mski-card{grid-column:span 12}
  .mski-step{grid-column:span 12}
  .mski-about .text,.mski-about .facts{grid-column:span 12}
  .mski-form .col6{grid-column:span 12}
  .mski-hero-grid{grid-template-columns:1fr}
  .mski-hero-photo{max-width:420px;justify-self:start}
  .mski-hero::after{background-position: 70% 40%; background-size: 520px auto;}
}

/* Onepage: obersten weißen Rand entfernen */
.page-template-page-mski-onepage body{
  margin:0 !important;
}
.page-template-page-mski-onepage .site{
  margin-top:0 !important;
}
.page-template-page-mski-onepage .site-content{
  padding-top:0 !important;
}
.page-template-page-mski-onepage .mski-wrap{
  padding-top:0 !important;
}
.page-template-page-mski-onepage .mski-hero{
  margin-top:0 !important;
}
/* FINAL OVERRIDES (ans Ende der style.css) */

/* Logo im Hero: groß & bündig */
.mski-hero .mski-brand{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  margin: 0 0 12px 0;
  padding: 0;
}
.mski-hero .mski-brand-logo{
  width: 300px;
  max-width: 100%;
  height: auto;
  display:block;
  margin: 0;
}

/* Primary Button transparent wie Kontakt */
.mski-hero .mski-btn.primary{
  background: rgba(255,255,255,.14) !important;
  color:#fff !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  box-shadow:none !important;
  filter:none !important;
}
.mski-hero .mski-btn.primary:hover{
  background: rgba(255,255,255,.18) !important;
}

/* Hero-Foto clean (freigestellt, ohne Kasten) */
.mski-hero .mski-hero-photo.mski-hero-photo--clean{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
.mski-hero .mski-hero-photo.mski-hero-photo--clean img{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}
.mski-hero .mski-brand-logo{
  width: 150px !important;
  max-width: 100% !important;
  height: auto !important;
  display:block;
  margin:0;
  transform: none !important;
}



