/*
Theme Name: Bedorf Systemberatung
Theme URI: https://bedorf-systemberatung.de
Author: Marco Bedorf
Description: Modernes, DSGVO-freundliches Theme für Bedorf Systemberatung.
Version: 1.2
License: GNU General Public License v2 or later
Text Domain: bedorf-systemberatung
*/

:root {
  --color-primary:#0056A3;
  --color-secondary:#00A7A7;
  --color-bg:#f5f7fa;
  --color-text:#222;
  --color-muted:#666;
  --max-width:1100px;
}

*,
*::before,
*::after { box-sizing:border-box; }

body {
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--color-text);
  background:#fff;
  line-height:1.6;
}

a { color:var(--color-primary); text-decoration:none; }
a:hover { text-decoration:underline; }

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

.site-wrapper{min-height:100vh;display:flex;flex-direction:column;}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:#fff;border-bottom:1px solid #e0e4ea;
}
.header-inner{
  max-width:var(--max-width);margin:auto;
  padding:.8rem 1.2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.main-nav ul{
  list-style:none;margin:0;padding:0;
  display:flex;gap:1.2rem;
}
.main-nav a{font-weight:500;color:var(--color-text);}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--color-primary);}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;}

/* Logo darf nicht abgeschnitten werden */
.site-header svg {
  display:block;
}

/* Mobile Nav */
@media(max-width:768px){
  .main-nav ul{
    position:absolute;right:1rem;top:3.1rem;
    flex-direction:column;
    background:#fff;padding:.8rem 1rem;
    border-radius:.8rem;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    display:none;
  }
  .main-nav ul.is-open{display:flex;}
  .nav-toggle{display:block;}
}

/* Sections */
.section{max-width:var(--max-width);margin:auto;padding:2.5rem 1.5rem;}
.section-header{margin-bottom:1.5rem;}
.section-title{font-size:1.4rem;margin:0 0 .5rem;}
.section-subtitle{margin:0;color:var(--color-muted);}

/* Cards */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.5rem;
}
.card{
  background:#fff;border-radius:1rem;
  border:1px solid #e0e4ea;
  padding:1.25rem;
}
.card h3{margin-top:0;font-size:1.05rem;}
.card p{font-size:.9rem;color:var(--color-muted);}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.6rem 1.2rem;border-radius:999px;border:none;
  font-weight:500;cursor:pointer;
}
.btn-primary{background:var(--color-primary);color:#fff;}
.btn-primary:hover{background:#00427b;}
.btn-ghost{background:transparent;border:1px solid #ccc;color:var(--color-text);}

/* Hero */
.hero{
  background:linear-gradient(135deg,rgba(0,86,163,.05),rgba(0,167,167,.05)),#fff;
  border-bottom:1px solid #e0e4ea;
}
.hero-inner{
  max-width:var(--max-width);margin:auto;
  padding:3rem 1.5rem 2.5rem;
  display:grid;gap:2.5rem;
  grid-template-columns:minmax(0,3fr) minmax(0,2.5fr);
  align-items:center;
}
.hero h1{margin:0 0 1rem;font-size:2.1rem;color:#0f172a;}
.hero p{margin:0 0 1rem;color:var(--color-muted);max-width:32rem;}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;}
.badge{
  font-size:.8rem;padding:.25rem .6rem;border-radius:999px;
  border:1px solid rgba(0,86,163,.25);color:var(--color-primary);
  background:rgba(0,86,163,.03);
}
.hero-sidebar{
  background:#fff;border-radius:1.2rem;padding:1.5rem;
  box-shadow:0 18px 35px rgba(15,23,42,.08);
}
.hero-sidebar h2{margin-top:0;font-size:1.05rem;}
.hero-sidebar ul{margin:.5rem 0 0;padding-left:1.1rem;font-size:.9rem;color:var(--color-muted);}

@media(max-width:900px){
  .hero-inner{grid-template-columns:minmax(0,1fr);}
}

/* Kontakt */
.contact-grid{
  display:grid;gap:2rem;
  grid-template-columns:minmax(0,2fr) minmax(0,1.2fr);
}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.contact-form .field{margin-bottom:.9rem;}
.contact-form label{display:block;font-size:.9rem;margin-bottom:.2rem;}
.contact-form input,.contact-form textarea{
  width:100%;padding:.5rem .6rem;border-radius:.6rem;
  border:1px solid #d0d5dd;font:inherit;
}
.contact-form textarea{min-height:120px;resize:vertical;}
.contact-note{font-size:.8rem;color:var(--color-muted);}

/* Footer */
.site-footer{background:#0f172a;color:#e5e7eb;margin-top:auto;}
.footer-inner{
  max-width:var(--max-width);margin:auto;
  padding:1.8rem 1.5rem 1rem;
  display:grid;gap:1.5rem;
  grid-template-columns:minmax(0,2fr) minmax(0,1fr);
  font-size:.9rem;
}
.footer-title{font-weight:600;margin-bottom:.3rem;}
.footer-muted{color:#9ca3af;font-size:.82rem;}
.footer-nav{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem;}
.footer-nav a{color:#e5e7eb;font-size:.86rem;}
.footer-bottom{
  grid-column:1/-1;border-top:1px solid #1f2937;
  margin-top:1rem;padding-top:.6rem;
  display:flex;justify-content:space-between;gap:1rem;
  font-size:.8rem;color:#9ca3af;
}
@media(max-width:700px){
  .footer-inner{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;}
}